Skip to content

Commit

Permalink
Add note about uninstalling debians before installing MoveIt2 from so…
Browse files Browse the repository at this point in the history
…urce (#763)

* Add note about uninstalling debians first

* Remove deprecated link
  • Loading branch information
AndyZe authored Nov 23, 2022
1 parent b47467a commit 5bdfabb
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 1 deletion.
2 changes: 1 addition & 1 deletion _posts/2020-06-09-moveit2-robotic-application.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ The Motion Planning Framework for ROS known as [MoveIt](/) has been successfully

My ROS2 setup involved building the MoveIt2 repository from source as described in github and then overlaying that colcon workspace on top of my existing CRS application workspace. I also built and ran the simple demo which worked right out of the gate and was very helpful in helping me understand how to integrate MoveIt2 into my own application.

The C++ integration was very straight forward and only needed the use of two new classes, MoveItCpp and PlanningComponent. In this architecture, MoveItCpp is used to load the robot model, configure the planning pipeline from ROS2 parameters and initialize defaults; then there's the PlanningComponent class which is associated to a planning group and is used to setup the motion plan request and call the low level planner. Furthermore, the PlanningComponent class has a similar interface to the familiar <a href="http://docs.ros.org/melodic/api/moveit_ros_planning_interface/html/classmoveit_1_1planning__interface_1_1MoveGroupInterface.html" target="_blanl">MoveGroupInterface</a> class from MoveIt; however one of the big changes here is that the methods in the PlanningComponent class aren't just wrappers to various services and actions provided by the [move_group](/documentation/concepts/) node but they instead make direct function calls to the various motion planning capabilities. I think this is a welcomed changed since this architecture will allow creating MoveIt2 planning configuration on the fly that can adapt to varying planning situations that may arise in an application.
The C++ integration was very straight forward and only needed the use of two new classes, MoveItCpp and PlanningComponent. In this architecture, MoveItCpp is used to load the robot model, configure the planning pipeline from ROS2 parameters and initialize defaults; then there's the PlanningComponent class which is associated to a planning group and is used to setup the motion plan request and call the low level planner. Furthermore, the PlanningComponent class has a similar interface to the familiar MoveGroupInterface class from MoveIt; however one of the big changes here is that the methods in the PlanningComponent class aren't just wrappers to various services and actions provided by the [move_group](/documentation/concepts/) node but they instead make direct function calls to the various motion planning capabilities. I think this is a welcomed changed since this architecture will allow creating MoveIt2 planning configuration on the fly that can adapt to varying planning situations that may arise in an application.

On the other hand, the launch/yaml integration wasn't as clean as many ROS2 concepts are still relatively new to me. In order to properly configure MoveIt2, it is necessary to load a <a href="http://wiki.ros.org/urdf" target="_blank">URDF</a> file as well as a number of parameters residing in several yaml files into your MoveIt2 application. Fortunately, most of the yaml files generated by the <a href="https://ros-planning.github.io/moveit_tutorials/doc/setup_assistant/setup_assistant_tutorial.html" target="_blank">MoveIt Setup Assistant</a> from the original MoveIt can be used with just minor modifications and so I ran the Setup Assistant in ROS1 and generated the needed config files. Furthermore, the ability to assemble ROS2 launch files in python really came in handy here as it allowed me to instantiate a python dictionary from a YAML file and pass its elements as parameters for my ROS2 application. Beyond learning about MoveIt2, going through this exercise showed me how to reuse the same yaml file for initializing parameters in different applications which I thought was a feature that was no longer available in ROS2.

Expand Down
6 changes: 6 additions & 0 deletions install-moveit2/source/index.markdown
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,12 @@ Source installation requires various <a href="https://docs.ros.org/en/foxy/Insta
pytest-rerunfailures \
pytest

### Uninstall Any Pre-existing MoveIt Debians

In ROS2, debians conflict with packages built from source. So, remove any existing MoveIt debians:

sudo apt remove ros-$ROS_DISTRO-moveit*

### Create Workspace and Source

Create a colcon workspace:
Expand Down

0 comments on commit 5bdfabb

Please sign in to comment.