Skip to main content
Version: 5

Creating an Objective

Tutorial Level: Beginner

This tutorial will walk you through how to use the Objective Builder to create a basic pick and place application. A tutorial workspace is provided with the completed objectives as well as a minimal configuration that can be used for this tutorial. To create the objectives used in this tutorial, you will need to clone the MoveIt Pro training workspace and configure your workspace using moveit_pro configure. For the completed solution use the tutorial_solution configuration, or follow along using the tutorial_new configuration.

Launch MoveIt Pro

We assume you have already installed MoveIt Pro and configured it to use the tutorial workspace. Launch the application using:

moveit_pro run
tip

You can select or change the MoveIt Pro configuration package using moveit_pro run -c tutorial_new

1. Create New Objective

In the "Objective Builder" screen click the "+ Objective" button to create a new Objective.

Create Objective

Enter the following information and click the "Create" button.

  • Name: Move to Pick
  • Description: Move to the Pick position

Objective Beginning

The Objective has been created and can now be edited or executed. By default, a simple behavior tree that will always succeed is generated.

2. Modify the Objective

While editing an Objective in the Objective Builder, the full list of Behaviors available for inclusion is provided in the left panel. Additional information about each Behavior is available by hovering the cursor over the name.

The first Behavior needed is Create Stamped Pose, which allows us to place a geometry_msgs/PoseStamped ROS 2 message on the blackboard. It can be found under the Miscellaneous heading or using the search bar on the left panel. Drag the Behavior on to the editor canvas and release it. Move it above the Always Success Behavior, near the Sequence control node, and a dotted line indicating a connection between the two is shown. When the cursor is released the behavior will be connected with a solid line. You can manually remove connections by selecting it and pressing delete, as well as connect existing Behaviors by dragging from one to the other.

Connections

The next step of this objective is to move to the given pose. We will use a Subtree (a behavior tree within a behavior tree) to minimize repeated information. From the Subtrees section, drag Move to Pose on to the canvas and attach it to the Sequence node. You can now remove the Always Succeess behavior from the objective. Press the Auto layout button to align your behaviors.

Auto Layout

Ensure that the Create Stamped Pose behavior is above the Move to Pose Subtree. A behavior tree executes from top to bottom, so we must ensure the goal pose is created and placed on the blackboard for the Move to Pose Subtree before it runs.

tip

The blackboard is a behavior tree concept. It is a location to store runtime data in the form of a key/value pair. Create Stamped Pose has an out port that places a pose on the blackboard using the key stamped_pose. Move to Pose has an in port that reads the key stamped_pose off the blackboard. A value wrapped in braces like {stamped_pose} points to an object or variable, otherwise the value's type is determined by the contents (string, int, bool, etc.)

Finally we can specify the Pick location using an orientation quaternion and position vector defined in the reference frame of our choosing. In this example we will choose a location 0.5m beside the robot with the gripper oriented down. Using semicolons to separate values we will define the quaternion as 1;0;0;0 and the position vector using 0.5;0;0.1.

Pose

3. Run the Objective

From the Objective Builder, select Move to Pick and click the Run button in the top right. You will be transitioned to the Objectives tab where you can see a visualization of the robot state along with the behavior tree. The currently running behavior (and its parent nodes) are highlighted during execution.

Plan

4. Create a Pick and Place Objective

Now that we have created a Move to Pick Objective we can use it within a larger Pick and Place Objective. Navigate back to the Objective Builder tab to create a new Objective, and name it "Pick and Place".

From the Subtrees section add the Move to Pick and Move to Waypoint Subtrees as shown:

Pick and Place

In the example workspace a Pick waypoint has already been saved. Select it from the dropdown menu of the Move to Waypoint Subtree.

Waypoint Select

When you run this Objective it will complete a single pick and place action. Next we will modify the objective to continue running until a failure occurs.

Delete the connection between the Pick and Place and Sequence nodes. From the Behavior pane on the left, add the Decorator node called Keep Running Until Failure and add it to your behavior tree so it looks like the one below.

Decorator

tip

Behaviors (blue) and subtrees (yellow) are robot skills. Control nodes (red) dictate which behaviors and subtrees to execute and when to do so. Decorators (purple) are used to modify the execution of your behavior tree.

Your pick and place behavior will now repeat until there is a failure or the objective is stopped. Using the Open Gripper and Close Gripper subtrees, can you make the pick and place behavior more realistic?

5. Next Steps

Now that you have your robot performing a pick and place action, lets make our behavior tree more robust. In the next tutorial, Adding Failure Recovery to your Behavior Tree, we will introduce fallbacks with human-in-the-loop failure recovery.