state machine library for ROS
Developed By OUXT Polaris
How to use
Example
launch example state machine
1 roslaunch rostate_machine example.launch
if you succeed to launch, the message was appeared in the terminal
1 [ INFO] [1556286488.574721992]: from : /example_event_client_node, succeed to transition, current state : emergency, event_name : motor_disconnected
2 [ INFO] [1556286488.674441095]: from : /example_event_client_node, failed to transition, current state : emergency, event_name : stop_motor
If you want to check whole state machine, you shold execute commands below
1 roscd rostate_machine/data
2 dot -T pdf example_state_machine.dot -o example_state_machine.pdf
3 evince example_state_machine.pdf
You can see pdf like below.
Example State Machine
rostate_machine node and event_client communticate with state and event topic
Example State Machine Node
State Topic (rostate_machine/State)
3 string[] possible_transitions
4 string[] possible_transition_states
Event Topic (rostate_machine/Event)
2 string trigger_event_name
Tutorial
Make XML file in order to define state machine
2 <init_state name="remote_operated"/>
3 <state_machine_name name="example_state_machine"/>
5 <callback tag="become_autonomos" when="on_entry" states="autonomous"/>
6 <callback tag="stop_motor" when="on_exit" states="autonomous,remote_operated"/>
7 <callback tag="check_motor" when="always" states="autonomous,remote_operated"/>
9 <transition from = "remote_operated" to="autonomous" name="system_bringup"/>
10 <transition from = "remote_operated" to="emergency" name="motor_disconnected"/>
11 <transition from = "autonomous" to="remote_operated" name="manual_override"/>
12 <transition from = "autonomous" to="emergency" name="motor_disconnected"/>
transition element defines how to change states in the state machine. rostate_machine node subscribe event topic and chenge state when the event name was matched with name attribute in the transition element in the XML.
callback element defines which callback function was called. callback functions are managed with tag by using event_client. states attribute in callback element defines the states in which calls callback. states was defined by "," splited string.
when attribute defines when the callback function was called. now, rostate_machine supports "always","on_exit","on_entry" values. if you set when="always", callback function was called when the current_state topic was recieved and the current_state was matched with states value. if you set when="on_exit" or when="on_entry", callback function was called when the current_state topic was recieved and the state was changed. when="on_exit", the tagged callback functions was called when the state was changed from the setted states. when="on_entry", the tagged callback functions was called when the state was changed to the setted states.
Register Callback function to the EventClient class
add EventClient class to your ROS node and register callback by using EventClient::registerCallback function.
1 void EventClient::registerCallback(std::function<boost::optional<rostate_machine::Event>(void)> func,std::string tag)
Make Launch files for your state machine
You can see how to make launch file for your statemachin in rostate_machine/launch/example.lannch
3 <param name="example_state_machine_node/description" textfile="$(find rostate_machine)/data/example_state_machine.xml"/>
5 <node pkg="rostate_machine" type="rostate_machine_node" name="example_state_machine_node" output="screen" respawn="true">
6 <param name="dot_filepath" value="$(find rostate_machine)/data/example_state_machine.dot"/>
9 <node pkg="rostate_machine" type="example_event_client_node" name="example_event_client_node" output="log" respawn="false" respawn_delay="0">
You have to pass xml_filepath,dot_filepath,state_machine_name args to the included launch file. (rostate_machine.launch) You have to also set rosparam named (namespace)/target_state_machine_namespace. Event client get state_machine_description from (value of (namespace)/target_state_machine_namespace )/xml_filepath