Note: This tutorial assumes that you have completed the previous tutorials: System Configuration.
(!) Please ask about problems and questions regarding this tutorial on answers.ros.org. Don't forget to include in your question the link to this page, the versions of your OS & ROS, and also add appropriate tags.

Creating a New Behavior

Description: Explains how to set up a new behavior using the FlexBE UI.

Tutorial Level: BEGINNER

Next Tutorial: Using the Statemachine Editor

In this tutorial, and in the next one, we will create a very simple demo behavior to demonstrate the steps required for behavior creation.

Launch the FlexBE App and start with giving your new behavior a name, describe it, and enter your own name as author. You can launch the FlexBE App by using roslaunch

$  roslaunch flexbe_app flexbe_ocs.launch

http://philserver.bplaced.net/fbe/img/tutorials/fbetut11.png

We would like our new behavior to print a "Hello World!" message when executing it. In the Private Configuration section of the dashboard, constant values of the behaviors can be defined. This serves as a single point of change for any value required by the behavior. So let's define a new string named hello for our message.

http://philserver.bplaced.net/fbe/img/tutorials/fbetut12.png

Add the new string by clicking the Add button. We will use it later.

Also, we want our behavior to wait some time before printing the message. However, the time to wait should not be constant. Instead, we want the operator to select a value when he starts execution of the behavior. For this purpose, Behavior Parameters are available. Select Numeric as type of the new parameter and name it waiting_time.

http://philserver.bplaced.net/fbe/img/tutorials/fbetut13.png

Add the parameter and edit its properties by clicking on the pencil icon.

http://philserver.bplaced.net/fbe/img/tutorials/fbetut14.png

You can now enter reasonable values for the waiting time as shown below. Unit is seconds, because we will use this value later to pass it to a state which waits for the given amount of seconds.

http://philserver.bplaced.net/fbe/img/tutorials/fbetut15.png

To leave the property view of the parameter and have the list of all parameters displayed again, click on the arrow icon at the top of this box.

We started creating our new behavior by defining some values (one constant, one variable) and can now proceed to define the state machine of the behavior. Your Behavior Dashboard should now look like shown below. Click Statemachine Editor at the top to switch to the editor and continue with the next tutorial.

http://philserver.bplaced.net/fbe/img/tutorials/fbetut16.png

That's it! Proceed to the next tutorial and learn about using the Statemachine Editor.

Wiki: flexbe/Tutorials/Creating a New Behavior (last edited 2018-12-01 13:02:22 by PhilippSchillinger)