Creating a Flow
MOV.AI Flow™ is intended for ROS developers to develop robot-ready runtime executables that operate complex robot behaviors.
In MOV.AI Flow, a flow is a visual representation of the behavior to be executed by a robot that is displayed as a diagram of Nodes connected by lines. Click here for more information about what a flow is.
Before the defining robot behaviors, make sure that you have set up your robot, it's drivers and its world.
To create a robot behavior flow –
-
Launch MOV.AI Flow, as described in Launching MOV.AI Flow™ or click the Home
button to return to the MOV.AI Flow home page.
-
Click the Create New Document
button in the top left corner, as shown above. The following menu displays –
data:image/s3,"s3://crabby-images/b01ee/b01eed0bb7bfb60ac0627e9eb3b681006e8db92e" alt="image376.jpg 193"
- Select the Flow option. The following displays –
data:image/s3,"s3://crabby-images/559a5/559a5a54cc7e0ecd48af2cbc4b0ca66b4e04984b" alt="image377.jpg 619"
- Click the anywhere in the flow diagram, as shown above. The following displays –
data:image/s3,"s3://crabby-images/bad15/bad1509ce6ca10447596e0772c8fe8127c3ecfc8" alt="image379.jpg 275"
-
Enter the name of the flow and click CREATE to save this flow with the new name. In our example, we will call it my_control.
-
To instantiate a node into a template, expand the pane on the right by clicking
, as shown below –
data:image/s3,"s3://crabby-images/d245c/d245ccfdecc8e09204a1c6f9348076756c2374cf" alt="image381.jpg 560"
The following displays –
data:image/s3,"s3://crabby-images/9350b/9350bce1833782a409161d28e4b20ea0f3a68dbd" alt="image382.jpg 554"
-
Expand the Flows branch in the right pane.
-
In the Search field above it, type any part of the name of the subflow that defines your robot drivers.
In this example, we will type the word my to find the my_robot_drivers subflow that we created, as described in Robot Drivers.
data:image/s3,"s3://crabby-images/63304/6330400a5ed338c845d4883204ddaf03f880ae3d" alt="image384.jpg 581"
- Drag-and-drop the my_robot_drivers subflow from the left pane into the flow. A popup appears into which you must enter the name of this node instance.
data:image/s3,"s3://crabby-images/ea253/ea253fceed5a87534fd0d01e58cdd8190f77fe40" alt="image386.jpg 284"
-
In our example, we will leave the same name. Click the ADD button.
-
Drag and draw a link from the start node to the input port (dot) on the left side of the my_robot_drivers subflow node.
data:image/s3,"s3://crabby-images/114f3/114f368aec072beecee6acbd679f473c2aa68b33" alt="image388.jpg 565"
If you hover over this port, the information is displayed about the type of message that this port can send/receive. This enables you to determine to which input port (dot) on the left side of the my_robot_drivers subflow to draw the connection.
data:image/s3,"s3://crabby-images/2c515/2c5152b0056b8027cfb2a51ac269d4920053f8a8" alt="image390.jpg 284"
The left side of each node has a dot for each input port and the right side of each node has a dot for each output port.
The dots on the left of the my robot drivers node represent the input ports that we defined, such as for the diffdrive control node and so on.
The dots on the right side of the subflow node represent the output (publishing) ports that we defined, such as the camera, diffdrive optometry and so on.
The Nodes list in the right pane enables you to access all the nodes provided in the ROS community, as well as those added by MOV.AI and those that you have defined yourself in MOV.AI.
Note – You may refer to MOV.AI GD Nodes description (Coming Soon) for a description of all the nodes provided by MOV.AI. You may refer to Build and Configure Your Own Node Templates and Node Instances for a description of how to create your own nodes.
- To add a node that sends a command to the diffdriver –
- Search for the node named cmd_vel_pub.
- Drag it into the flow, as shown below –
data:image/s3,"s3://crabby-images/c8306/c8306de3e4253ec9ffdd144917fe9c522305adc8" alt="image392.jpg 454"
- Assign it a name or leave the name as is (as we did here).
- Drag and draw a connection from the output port of the my robot drivers node to the input port of cmd 1 in order to receive the output after the 5 seconds waited by the wait node.
data:image/s3,"s3://crabby-images/99715/997157bb0e5528b9c6b3340927b5d753373d5106" alt="image394.jpg 577"
In order to know which port (dot) to connect to which port (dot) on each node, you can hover over the port on the node to see the type of messages that it can send or receive. For example, as follows –
- You can hover over the output port on the my_robot_drivers subflow to see the type of messages that it can send, as shown below –
data:image/s3,"s3://crabby-images/f8566/f85661f1a1c982b69e4be4b7f76aa3a2fb030f3b" alt="image396.jpg 201"
- You can then hover over the input port of the cmd vel pub node to see the type of messages that it can receive, as shown below –
data:image/s3,"s3://crabby-images/857b9/857b95fea3b1b6d66676521b0afcc25ef4b71c84" alt="image398.jpg 196"
- The cmd 1 node has an output port named1 cmd_msgs_publisher that appears in the right Parameters pane in the Ports → Outputs section (as shown below), which publishes the message received from the diffdriver.
data:image/s3,"s3://crabby-images/29782/297829e4ee4342933b5fa4e92e37e4692338bb7b" alt="image400.jpg 143"
You can also see it by hovering over the relevant output port (dot), as shown below –
data:image/s3,"s3://crabby-images/06190/061904b9a61c24b193f239ed5b5cc3a20a634339" alt="image402.jpg 594"
- Drag and draw a connection from the output port of cmd vel pub to the input port of the my robot drivers node, as shown below –
data:image/s3,"s3://crabby-images/4f257/4f2579135fc28c0fad1edb7999a11ca6dfa0796c" alt="image404.jpg 187"
Connecting Nodes
Color-coded dots help you connect nodes according to the message type.
The dots that represent the ports of a node are color-coded to help you understand which ports can be connected. The white colored dots indicate ports that can be connected. For example, the cmd1 node has one white output port.
data:image/s3,"s3://crabby-images/abff7/abff77797a1207578719539c5855b23dadfc689f" alt="7.png 453"
When you click on the white output port of the cmd 1 node it turns green to indicate that it is selected, as shown below –
data:image/s3,"s3://crabby-images/8b03a/8b03ad033df01c1d50cf23a71831b04c0c47a862" alt="8.png 455"
Start dragging and drawing a line from it towards the my robot drivers node. While you do so, it turns gray, as shown below.
Only one of the input ports of the my robot drivers nodes remains white indicating that this is the only one to which you can connect.
data:image/s3,"s3://crabby-images/bd2dc/bd2dc9917466e0adc4cd9e2bc2bcaaae980c93ad" alt="9.png 481"
When you draw the end of the line so that it is hovering over the input port of the my robot drivers node, it turns green to indicate that this is a port to which it can connect, as shown below –
data:image/s3,"s3://crabby-images/5c8b4/5c8b4559cc93d4f166d30adc951de2112b82fd1a" alt="10.png 437"
Watch this to see what we did above –
data:image/s3,"s3://crabby-images/fb4a2/fb4a2f810eb96a138605a867f147bf0d540180fb" alt="6-3.mp4 up to 57 seconds.gif 640"
Here's a small taste. Click below to see the full video.
Watch the next steps!
data:image/s3,"s3://crabby-images/97efd/97efd0b537ea7b8a5589d99bd63c7eba5776b851" alt=""
- Click the cmd vel pub node to configure its parameters in the right pane. Expand the Parameters section. The following displays –
data:image/s3,"s3://crabby-images/7011b/7011b1a4cc47f4013acd21b3b973890a4ef29d82" alt="image420.jpg 576"
- Use the Edit
button to modify its parameters in order to specify the velocity of movement in each direction in meters per second – linear_x, linear_y and so on. This means that when the flow starts and it transitions to the cmd vel publish node, the robot will start moving at the velocity specified here. For example, the following shows how to modify the speed of the robot travels per meter in the X direction by editing the value in the linear_X parameter –
data:image/s3,"s3://crabby-images/b198e/b198e1bc556b5be23729c5e7192952dca006acd4" alt="image423.jpg 348"
You can modify all these parameters in the same manner. For example, editing the angular parameter enables you to change the speed at which the robot turns.
-
In the same manner as above, you can add another output port from the cmd vel publish node, which can be drawn from the dot that represents the camera port.
-
Redisplay the Tugbot world in Gazebo. If it’s not already open, then perform the following. Alternatively, you can launch the new world that you created in Gazebo using the same procedure as below.
- Open the MOV.AI Simulator Launcher, by clicking the following icon –
The following displays –
data:image/s3,"s3://crabby-images/45863/45863d500d278f0d2c1dc834d5fbcc6e3bb232bf" alt="image425.jpg 488"
- In the Fuel World Scene dropdown menu, select fuel.ignitionrobotics.org/movai/worlds/tugbot_depot, as shown above.
- Start the simulation by clicking the START SIMULATOR button. The following displays –
data:image/s3,"s3://crabby-images/50aab/50aab63cc386585ab4ed1c24dcd233da029e3847" alt="image427.jpg 545"
Playing the Flow
Click on the Play button to make everything play. Green dots should start flashing on the nodes in the flow and after a while the robot will start to move.
data:image/s3,"s3://crabby-images/1dc49/1dc494c2f437f6f6410eb7cdb6a8b8b837d93808" alt="image430.jpg 562"
Watch this to see what we did above –
data:image/s3,"s3://crabby-images/1f8c0/1f8c074e745cb959f70a9437f1724eeed5253e7f" alt="6-3.mp4 from 57 seconds – 2.18.gif 640"
Here's a small taste. Click below to see the full video.
Watch the next steps!
data:image/s3,"s3://crabby-images/97efd/97efd0b537ea7b8a5589d99bd63c7eba5776b851" alt=""
Updated over 2 years ago