diff --git a/.catkin_tools/profiles/default/devel_collisions.txt b/.catkin_tools/profiles/default/devel_collisions.txt index 768d822ef136346617894866387b8a256d061b1c..3e752148aba4b3b88043479bc58f5b06e41d2201 100644 --- a/.catkin_tools/profiles/default/devel_collisions.txt +++ b/.catkin_tools/profiles/default/devel_collisions.txt @@ -1,4 +1,4 @@ /home/matteo/ws_panda/devel/./cmake.lock 42 -/home/matteo/reachability/devel/./cmake.lock 7718 +/home/matteo/reachability/devel/./cmake.lock 7884 /home/matteo/reachability/devel/lib/libmoveit_grasps.so 66 /home/matteo/reachability/devel/lib/libmoveit_grasps_filter.so 66 diff --git a/.catkin_tools/profiles/default/packages/ceti_bot/devel_manifest.txt b/.catkin_tools/profiles/default/packages/ceti_bot/devel_manifest.txt new file mode 100644 index 0000000000000000000000000000000000000000..68d5b594d1472398c59d755796af159db62a7650 --- /dev/null +++ b/.catkin_tools/profiles/default/packages/ceti_bot/devel_manifest.txt @@ -0,0 +1,5 @@ +ceti_bot +/home/matteo/reachability/devel/.private/ceti_bot/cmake.lock /home/matteo/reachability/devel/./cmake.lock +/home/matteo/reachability/devel/.private/ceti_bot/share/ceti_bot/cmake/ceti_botConfig-version.cmake /home/matteo/reachability/devel/share/ceti_bot/cmake/ceti_botConfig-version.cmake +/home/matteo/reachability/devel/.private/ceti_bot/share/ceti_bot/cmake/ceti_botConfig.cmake /home/matteo/reachability/devel/share/ceti_bot/cmake/ceti_botConfig.cmake +/home/matteo/reachability/devel/.private/ceti_bot/lib/pkgconfig/ceti_bot.pc /home/matteo/reachability/devel/lib/pkgconfig/ceti_bot.pc diff --git a/.catkin_tools/profiles/default/packages/ceti_bot/package.xml b/.catkin_tools/profiles/default/packages/ceti_bot/package.xml new file mode 100644 index 0000000000000000000000000000000000000000..3075d2573d8c3a01ce693eb6cf39a6a3b0a84ca4 --- /dev/null +++ b/.catkin_tools/profiles/default/packages/ceti_bot/package.xml @@ -0,0 +1,41 @@ +<package> + + <name>ceti_bot</name> + <version>0.3.0</version> + <description> + An automatically generated package with all the configuration and launch files for using the panda with the MoveIt Motion Planning Framework + </description> + <author email="matteo.anedda@mailbox.tu-dresden.de">matteo anedda</author> + <maintainer email="matteo.anedda@mailbox.tu-dresden.de">matteo anedda</maintainer> + + <license>BSD</license> + + <url type="website">http://moveit.ros.org/</url> + <url type="bugtracker">https://github.com/ros-planning/moveit/issues</url> + <url type="repository">https://github.com/ros-planning/moveit</url> + + <buildtool_depend>catkin</buildtool_depend> + + <run_depend>moveit_ros_move_group</run_depend> + <run_depend>moveit_fake_controller_manager</run_depend> + <run_depend>moveit_kinematics</run_depend> + <run_depend>moveit_planners_ompl</run_depend> + <run_depend>moveit_ros_visualization</run_depend> + <run_depend>moveit_setup_assistant</run_depend> + <run_depend>moveit_simple_controller_manager</run_depend> + <run_depend>joint_state_publisher</run_depend> + <run_depend>joint_state_publisher_gui</run_depend> + <run_depend>robot_state_publisher</run_depend> + <run_depend>rviz</run_depend> + <run_depend>tf2_ros</run_depend> + <run_depend>xacro</run_depend> + <!-- The next 2 packages are required for the gazebo simulation. + We don't include them by default to prevent installing gazebo and all its dependencies. --> + <!-- <run_depend>joint_trajectory_controller</run_depend> --> + <!-- <run_depend>gazebo_ros_control</run_depend> --> + <!-- This package is referenced in the warehouse launch files, but does not build out of the box at the moment. Commented the dependency until this works. --> + <!-- <run_depend>warehouse_ros_mongo</run_depend> --> + <run_depend>franka_description</run_depend> + + +</package> diff --git a/.catkin_tools/profiles/default/packages/ceti_double/devel_manifest.txt b/.catkin_tools/profiles/default/packages/ceti_double/devel_manifest.txt new file mode 100644 index 0000000000000000000000000000000000000000..9bd1ecbeb489836a4e70be5349c69a90948af968 --- /dev/null +++ b/.catkin_tools/profiles/default/packages/ceti_double/devel_manifest.txt @@ -0,0 +1,5 @@ +ceti_double +/home/matteo/reachability/devel/.private/ceti_double/cmake.lock /home/matteo/reachability/devel/./cmake.lock +/home/matteo/reachability/devel/.private/ceti_double/share/ceti_double/cmake/ceti_doubleConfig.cmake /home/matteo/reachability/devel/share/ceti_double/cmake/ceti_doubleConfig.cmake +/home/matteo/reachability/devel/.private/ceti_double/share/ceti_double/cmake/ceti_doubleConfig-version.cmake /home/matteo/reachability/devel/share/ceti_double/cmake/ceti_doubleConfig-version.cmake +/home/matteo/reachability/devel/.private/ceti_double/lib/pkgconfig/ceti_double.pc /home/matteo/reachability/devel/lib/pkgconfig/ceti_double.pc diff --git a/.catkin_tools/profiles/default/packages/ceti_double/package.xml b/.catkin_tools/profiles/default/packages/ceti_double/package.xml new file mode 100644 index 0000000000000000000000000000000000000000..9dfe30656ae3c41939d86ff0bd7d3ac1ca5537db --- /dev/null +++ b/.catkin_tools/profiles/default/packages/ceti_double/package.xml @@ -0,0 +1,41 @@ +<package> + + <name>ceti_double</name> + <version>0.3.0</version> + <description> + An automatically generated package with all the configuration and launch files for using the panda with the MoveIt Motion Planning Framework + </description> + <author email="matteo.anedda@mailbox.tu-dresden.de">matteo anedda</author> + <maintainer email="matteo.anedda@mailbox.tu-dresden.de">matteo anedda</maintainer> + + <license>BSD</license> + + <url type="website">http://moveit.ros.org/</url> + <url type="bugtracker">https://github.com/ros-planning/moveit/issues</url> + <url type="repository">https://github.com/ros-planning/moveit</url> + + <buildtool_depend>catkin</buildtool_depend> + + <run_depend>moveit_ros_move_group</run_depend> + <run_depend>moveit_fake_controller_manager</run_depend> + <run_depend>moveit_kinematics</run_depend> + <run_depend>moveit_planners_ompl</run_depend> + <run_depend>moveit_ros_visualization</run_depend> + <run_depend>moveit_setup_assistant</run_depend> + <run_depend>moveit_simple_controller_manager</run_depend> + <run_depend>joint_state_publisher</run_depend> + <run_depend>joint_state_publisher_gui</run_depend> + <run_depend>robot_state_publisher</run_depend> + <run_depend>rviz</run_depend> + <run_depend>tf2_ros</run_depend> + <run_depend>xacro</run_depend> + <!-- The next 2 packages are required for the gazebo simulation. + We don't include them by default to prevent installing gazebo and all its dependencies. --> + <!-- <run_depend>joint_trajectory_controller</run_depend> --> + <!-- <run_depend>gazebo_ros_control</run_depend> --> + <!-- This package is referenced in the warehouse launch files, but does not build out of the box at the moment. Commented the dependency until this works. --> + <!-- <run_depend>warehouse_ros_mongo</run_depend> --> + <run_depend>franka_description</run_depend> + + +</package> diff --git a/.catkin_tools/profiles/default/packages/panda_moveit_config1/devel_manifest.txt b/.catkin_tools/profiles/default/packages/panda_moveit_config1/devel_manifest.txt new file mode 100644 index 0000000000000000000000000000000000000000..4e64c0de5a3415621dbf171587a5cf102a9cc18b --- /dev/null +++ b/.catkin_tools/profiles/default/packages/panda_moveit_config1/devel_manifest.txt @@ -0,0 +1,5 @@ +panda_moveit_config1 +/home/matteo/reachability/devel/.private/panda_moveit_config1/cmake.lock /home/matteo/reachability/devel/./cmake.lock +/home/matteo/reachability/devel/.private/panda_moveit_config1/share/panda_moveit_config1/cmake/panda_moveit_config1Config.cmake /home/matteo/reachability/devel/share/panda_moveit_config1/cmake/panda_moveit_config1Config.cmake +/home/matteo/reachability/devel/.private/panda_moveit_config1/share/panda_moveit_config1/cmake/panda_moveit_config1Config-version.cmake /home/matteo/reachability/devel/share/panda_moveit_config1/cmake/panda_moveit_config1Config-version.cmake +/home/matteo/reachability/devel/.private/panda_moveit_config1/lib/pkgconfig/panda_moveit_config1.pc /home/matteo/reachability/devel/lib/pkgconfig/panda_moveit_config1.pc diff --git a/.catkin_tools/profiles/default/packages/panda_moveit_config1/package.xml b/.catkin_tools/profiles/default/packages/panda_moveit_config1/package.xml new file mode 100644 index 0000000000000000000000000000000000000000..cf8871dfa2b8b2940a86a956700cd9005e446f27 --- /dev/null +++ b/.catkin_tools/profiles/default/packages/panda_moveit_config1/package.xml @@ -0,0 +1,41 @@ +<package> + + <name>panda_moveit_config1</name> + <version>0.3.0</version> + <description> + An automatically generated package with all the configuration and launch files for using the panda with the MoveIt Motion Planning Framework + </description> + <author email="mike@picknik.ai">Mike Lautman</author> + <maintainer email="mike@picknik.ai">Mike Lautman</maintainer> + + <license>BSD</license> + + <url type="website">http://moveit.ros.org/</url> + <url type="bugtracker">https://github.com/ros-planning/moveit/issues</url> + <url type="repository">https://github.com/ros-planning/moveit</url> + + <buildtool_depend>catkin</buildtool_depend> + + <run_depend>moveit_ros_move_group</run_depend> + <run_depend>moveit_fake_controller_manager</run_depend> + <run_depend>moveit_kinematics</run_depend> + <run_depend>moveit_planners_ompl</run_depend> + <run_depend>moveit_ros_visualization</run_depend> + <run_depend>moveit_setup_assistant</run_depend> + <run_depend>moveit_simple_controller_manager</run_depend> + <run_depend>joint_state_publisher</run_depend> + <run_depend>joint_state_publisher_gui</run_depend> + <run_depend>robot_state_publisher</run_depend> + <run_depend>rviz</run_depend> + <run_depend>tf2_ros</run_depend> + <run_depend>xacro</run_depend> + <!-- The next 2 packages are required for the gazebo simulation. + We don't include them by default to prevent installing gazebo and all its dependencies. --> + <!-- <run_depend>joint_trajectory_controller</run_depend> --> + <!-- <run_depend>gazebo_ros_control</run_depend> --> + <!-- This package is referenced in the warehouse launch files, but does not build out of the box at the moment. Commented the dependency until this works. --> + <!-- <run_depend>warehouse_ros_mongo</run_depend> --> + <run_depend>franka_description</run_depend> + + +</package> diff --git a/.catkin_tools/profiles/default/packages/panda_moveit_config_/devel_manifest.txt b/.catkin_tools/profiles/default/packages/panda_moveit_config_/devel_manifest.txt new file mode 100644 index 0000000000000000000000000000000000000000..2dfd7023feab2c7b7dd7e706cf30be0d3cbd5c28 --- /dev/null +++ b/.catkin_tools/profiles/default/packages/panda_moveit_config_/devel_manifest.txt @@ -0,0 +1,5 @@ +panda_moveit_config_ +/home/matteo/reachability/devel/.private/panda_moveit_config_/cmake.lock /home/matteo/reachability/devel/./cmake.lock +/home/matteo/reachability/devel/.private/panda_moveit_config_/share/panda_moveit_config_/cmake/panda_moveit_config_Config.cmake /home/matteo/reachability/devel/share/panda_moveit_config_/cmake/panda_moveit_config_Config.cmake +/home/matteo/reachability/devel/.private/panda_moveit_config_/share/panda_moveit_config_/cmake/panda_moveit_config_Config-version.cmake /home/matteo/reachability/devel/share/panda_moveit_config_/cmake/panda_moveit_config_Config-version.cmake +/home/matteo/reachability/devel/.private/panda_moveit_config_/lib/pkgconfig/panda_moveit_config_.pc /home/matteo/reachability/devel/lib/pkgconfig/panda_moveit_config_.pc diff --git a/.catkin_tools/profiles/default/packages/panda_moveit_config_/package.xml b/.catkin_tools/profiles/default/packages/panda_moveit_config_/package.xml new file mode 100644 index 0000000000000000000000000000000000000000..1761e4d741ce55b7aa5a9aaf67adc2872f4bc906 --- /dev/null +++ b/.catkin_tools/profiles/default/packages/panda_moveit_config_/package.xml @@ -0,0 +1,41 @@ +<package> + + <name>panda_moveit_config_</name> + <version>0.3.0</version> + <description> + An automatically generated package with all the configuration and launch files for using the panda with the MoveIt Motion Planning Framework + </description> + <author email="mike@picknik.ai">Mike Lautman</author> + <maintainer email="mike@picknik.ai">Mike Lautman</maintainer> + + <license>BSD</license> + + <url type="website">http://moveit.ros.org/</url> + <url type="bugtracker">https://github.com/ros-planning/moveit/issues</url> + <url type="repository">https://github.com/ros-planning/moveit</url> + + <buildtool_depend>catkin</buildtool_depend> + + <run_depend>moveit_ros_move_group</run_depend> + <run_depend>moveit_fake_controller_manager</run_depend> + <run_depend>moveit_kinematics</run_depend> + <run_depend>moveit_planners_ompl</run_depend> + <run_depend>moveit_ros_visualization</run_depend> + <run_depend>moveit_setup_assistant</run_depend> + <run_depend>moveit_simple_controller_manager</run_depend> + <run_depend>joint_state_publisher</run_depend> + <run_depend>joint_state_publisher_gui</run_depend> + <run_depend>robot_state_publisher</run_depend> + <run_depend>rviz</run_depend> + <run_depend>tf2_ros</run_depend> + <run_depend>xacro</run_depend> + <!-- The next 2 packages are required for the gazebo simulation. + We don't include them by default to prevent installing gazebo and all its dependencies. --> + <!-- <run_depend>joint_trajectory_controller</run_depend> --> + <!-- <run_depend>gazebo_ros_control</run_depend> --> + <!-- This package is referenced in the warehouse launch files, but does not build out of the box at the moment. Commented the dependency until this works. --> + <!-- <run_depend>warehouse_ros_mongo</run_depend> --> + <run_depend>franka_description</run_depend> + + +</package> diff --git a/src/ceti_double/.setup_assistant b/src/ceti_double/.setup_assistant new file mode 100644 index 0000000000000000000000000000000000000000..86127ef95ebf3de6758fa93694b71f131cc1164e --- /dev/null +++ b/src/ceti_double/.setup_assistant @@ -0,0 +1,11 @@ +moveit_setup_assistant_config: + URDF: + package: franka_description + relative_path: robots/ceti_double.urdf.xacro + xacro_args: "" + SRDF: + relative_path: config/panda.srdf + CONFIG: + author_name: matteo anedda + author_email: matteo.anedda@mailbox.tu-dresden.de + generated_timestamp: 1662152488 \ No newline at end of file diff --git a/src/ceti_double/CMakeLists.txt b/src/ceti_double/CMakeLists.txt new file mode 100644 index 0000000000000000000000000000000000000000..59a53b6ab3d5d23724c2727e09048016521be68f --- /dev/null +++ b/src/ceti_double/CMakeLists.txt @@ -0,0 +1,10 @@ +cmake_minimum_required(VERSION 3.1.3) +project(ceti_double) + +find_package(catkin REQUIRED) + +catkin_package() + +install(DIRECTORY launch DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION} + PATTERN "setup_assistant.launch" EXCLUDE) +install(DIRECTORY config DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION}) diff --git a/src/ceti_double/config/cartesian_limits.yaml b/src/ceti_double/config/cartesian_limits.yaml new file mode 100644 index 0000000000000000000000000000000000000000..7df72f693b3dfc63bdd0715b9fad7cdac3edcebe --- /dev/null +++ b/src/ceti_double/config/cartesian_limits.yaml @@ -0,0 +1,5 @@ +cartesian_limits: + max_trans_vel: 1 + max_trans_acc: 2.25 + max_trans_dec: -5 + max_rot_vel: 1.57 diff --git a/src/ceti_double/config/chomp_planning.yaml b/src/ceti_double/config/chomp_planning.yaml new file mode 100644 index 0000000000000000000000000000000000000000..eb9c91225b1db9db1f5b5f7e1d8ff51191a311e8 --- /dev/null +++ b/src/ceti_double/config/chomp_planning.yaml @@ -0,0 +1,18 @@ +planning_time_limit: 10.0 +max_iterations: 200 +max_iterations_after_collision_free: 5 +smoothness_cost_weight: 0.1 +obstacle_cost_weight: 1.0 +learning_rate: 0.01 +smoothness_cost_velocity: 0.0 +smoothness_cost_acceleration: 1.0 +smoothness_cost_jerk: 0.0 +ridge_factor: 0.0 +use_pseudo_inverse: false +pseudo_inverse_ridge_factor: 1e-4 +joint_update_limit: 0.1 +collision_clearance: 0.2 +collision_threshold: 0.07 +use_stochastic_descent: true +enable_failure_recovery: false +max_recovery_attempts: 5 diff --git a/src/ceti_double/config/fake_controllers.yaml b/src/ceti_double/config/fake_controllers.yaml new file mode 100644 index 0000000000000000000000000000000000000000..9ec7514bc038d8e3b285301e886fd970cd2a091d --- /dev/null +++ b/src/ceti_double/config/fake_controllers.yaml @@ -0,0 +1,36 @@ +controller_list: + - name: fake_panda_arm1_controller + type: $(arg fake_execution_type) + joints: + - panda_1_joint1 + - panda_1_joint2 + - panda_1_joint3 + - panda_1_joint4 + - panda_1_joint5 + - panda_1_joint6 + - panda_1_joint7 + - name: fake_hand_1_controller + type: $(arg fake_execution_type) + joints: + - panda_1_finger_joint1 + - panda_1_finger_joint2 + - name: fake_panda_arm2_controller + type: $(arg fake_execution_type) + joints: + - panda_2_joint1 + - panda_2_joint2 + - panda_2_joint3 + - panda_2_joint4 + - panda_2_joint5 + - panda_2_joint6 + - panda_2_joint7 + - name: fake_hand_2_controller + type: $(arg fake_execution_type) + joints: + - panda_2_finger_joint1 + - panda_2_finger_joint2 +initial: # Define initial robot poses per group + - group: panda_arm1 + pose: home1 + - group: panda_arm2 + pose: home2 \ No newline at end of file diff --git a/src/ceti_double/config/gazebo_controllers.yaml b/src/ceti_double/config/gazebo_controllers.yaml new file mode 100644 index 0000000000000000000000000000000000000000..e4d2eb00c7e2ef8add07787a513c2cd1c567d627 --- /dev/null +++ b/src/ceti_double/config/gazebo_controllers.yaml @@ -0,0 +1,4 @@ +# Publish joint_states +joint_state_controller: + type: joint_state_controller/JointStateController + publish_rate: 50 diff --git a/src/ceti_double/config/joint_limits.yaml b/src/ceti_double/config/joint_limits.yaml new file mode 100644 index 0000000000000000000000000000000000000000..35b0bf26ce0d1e1e41e9806cc3bf62fa797f6f05 --- /dev/null +++ b/src/ceti_double/config/joint_limits.yaml @@ -0,0 +1,100 @@ +# joint_limits.yaml allows the dynamics properties specified in the URDF to be overwritten or augmented as needed + +# For beginners, we downscale velocity and acceleration limits. +# You can always specify higher scaling factors (<= 1.0) in your motion requests. # Increase the values below to 1.0 to always move at maximum speed. +default_velocity_scaling_factor: 0.1 +default_acceleration_scaling_factor: 0.1 + +# Specific joint properties can be changed with the keys [max_position, min_position, max_velocity, max_acceleration] +# Joint limits can be turned off with [has_velocity_limits, has_acceleration_limits] +joint_limits: + panda_1_finger_joint1: + has_velocity_limits: true + max_velocity: 0.2 + has_acceleration_limits: false + max_acceleration: 0 + panda_1_finger_joint2: + has_velocity_limits: true + max_velocity: 0.2 + has_acceleration_limits: false + max_acceleration: 0 + panda_1_joint1: + has_velocity_limits: true + max_velocity: 2.175 + has_acceleration_limits: false + max_acceleration: 0 + panda_1_joint2: + has_velocity_limits: true + max_velocity: 2.175 + has_acceleration_limits: false + max_acceleration: 0 + panda_1_joint3: + has_velocity_limits: true + max_velocity: 2.175 + has_acceleration_limits: false + max_acceleration: 0 + panda_1_joint4: + has_velocity_limits: true + max_velocity: 2.175 + has_acceleration_limits: false + max_acceleration: 0 + panda_1_joint5: + has_velocity_limits: true + max_velocity: 2.61 + has_acceleration_limits: false + max_acceleration: 0 + panda_1_joint6: + has_velocity_limits: true + max_velocity: 2.61 + has_acceleration_limits: false + max_acceleration: 0 + panda_1_joint7: + has_velocity_limits: true + max_velocity: 2.61 + has_acceleration_limits: false + max_acceleration: 0 + panda_2_finger_joint1: + has_velocity_limits: true + max_velocity: 0.2 + has_acceleration_limits: false + max_acceleration: 0 + panda_2_finger_joint2: + has_velocity_limits: true + max_velocity: 0.2 + has_acceleration_limits: false + max_acceleration: 0 + panda_2_joint1: + has_velocity_limits: true + max_velocity: 2.175 + has_acceleration_limits: false + max_acceleration: 0 + panda_2_joint2: + has_velocity_limits: true + max_velocity: 2.175 + has_acceleration_limits: false + max_acceleration: 0 + panda_2_joint3: + has_velocity_limits: true + max_velocity: 2.175 + has_acceleration_limits: false + max_acceleration: 0 + panda_2_joint4: + has_velocity_limits: true + max_velocity: 2.175 + has_acceleration_limits: false + max_acceleration: 0 + panda_2_joint5: + has_velocity_limits: true + max_velocity: 2.61 + has_acceleration_limits: false + max_acceleration: 0 + panda_2_joint6: + has_velocity_limits: true + max_velocity: 2.61 + has_acceleration_limits: false + max_acceleration: 0 + panda_2_joint7: + has_velocity_limits: true + max_velocity: 2.61 + has_acceleration_limits: false + max_acceleration: 0 \ No newline at end of file diff --git a/src/ceti_double/config/kinematics.yaml b/src/ceti_double/config/kinematics.yaml new file mode 100644 index 0000000000000000000000000000000000000000..9e26dfeeb6e641a33dae4961196235bdb965b21b --- /dev/null +++ b/src/ceti_double/config/kinematics.yaml @@ -0,0 +1 @@ +{} \ No newline at end of file diff --git a/src/ceti_double/config/ompl_planning.yaml b/src/ceti_double/config/ompl_planning.yaml new file mode 100644 index 0000000000000000000000000000000000000000..0e7e823f52849fb692db55ceb4daea845d94ffb0 --- /dev/null +++ b/src/ceti_double/config/ompl_planning.yaml @@ -0,0 +1,233 @@ +planner_configs: + AnytimePathShortening: + type: geometric::AnytimePathShortening + shortcut: true # Attempt to shortcut all new solution paths + hybridize: true # Compute hybrid solution trajectories + max_hybrid_paths: 24 # Number of hybrid paths generated per iteration + num_planners: 4 # The number of default planners to use for planning + planners: "" # A comma-separated list of planner types (e.g., "PRM,EST,RRTConnect"Optionally, planner parameters can be passed to change the default:"PRM[max_nearest_neighbors=5],EST[goal_bias=.5],RRT[range=10. goal_bias=.1]" + SBL: + type: geometric::SBL + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + EST: + type: geometric::EST + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0 setup() + goal_bias: 0.05 # When close to goal select goal, with this probability. default: 0.05 + LBKPIECE: + type: geometric::LBKPIECE + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + border_fraction: 0.9 # Fraction of time focused on boarder default: 0.9 + min_valid_path_fraction: 0.5 # Accept partially valid moves above fraction. default: 0.5 + BKPIECE: + type: geometric::BKPIECE + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + border_fraction: 0.9 # Fraction of time focused on boarder default: 0.9 + failed_expansion_score_factor: 0.5 # When extending motion fails, scale score by factor. default: 0.5 + min_valid_path_fraction: 0.5 # Accept partially valid moves above fraction. default: 0.5 + KPIECE: + type: geometric::KPIECE + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + goal_bias: 0.05 # When close to goal select goal, with this probability. default: 0.05 + border_fraction: 0.9 # Fraction of time focused on boarder default: 0.9 (0.0,1.] + failed_expansion_score_factor: 0.5 # When extending motion fails, scale score by factor. default: 0.5 + min_valid_path_fraction: 0.5 # Accept partially valid moves above fraction. default: 0.5 + RRT: + type: geometric::RRT + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + goal_bias: 0.05 # When close to goal select goal, with this probability? default: 0.05 + RRTConnect: + type: geometric::RRTConnect + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + RRTstar: + type: geometric::RRTstar + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + goal_bias: 0.05 # When close to goal select goal, with this probability? default: 0.05 + delay_collision_checking: 1 # Stop collision checking as soon as C-free parent found. default 1 + TRRT: + type: geometric::TRRT + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + goal_bias: 0.05 # When close to goal select goal, with this probability? default: 0.05 + max_states_failed: 10 # when to start increasing temp. default: 10 + temp_change_factor: 2.0 # how much to increase or decrease temp. default: 2.0 + min_temperature: 10e-10 # lower limit of temp change. default: 10e-10 + init_temperature: 10e-6 # initial temperature. default: 10e-6 + frountier_threshold: 0.0 # dist new state to nearest neighbor to disqualify as frontier. default: 0.0 set in setup() + frountierNodeRatio: 0.1 # 1/10, or 1 nonfrontier for every 10 frontier. default: 0.1 + k_constant: 0.0 # value used to normalize expresssion. default: 0.0 set in setup() + PRM: + type: geometric::PRM + max_nearest_neighbors: 10 # use k nearest neighbors. default: 10 + PRMstar: + type: geometric::PRMstar + FMT: + type: geometric::FMT + num_samples: 1000 # number of states that the planner should sample. default: 1000 + radius_multiplier: 1.1 # multiplier used for the nearest neighbors search radius. default: 1.1 + nearest_k: 1 # use Knearest strategy. default: 1 + cache_cc: 1 # use collision checking cache. default: 1 + heuristics: 0 # activate cost to go heuristics. default: 0 + extended_fmt: 1 # activate the extended FMT*: adding new samples if planner does not finish successfully. default: 1 + BFMT: + type: geometric::BFMT + num_samples: 1000 # number of states that the planner should sample. default: 1000 + radius_multiplier: 1.0 # multiplier used for the nearest neighbors search radius. default: 1.0 + nearest_k: 1 # use the Knearest strategy. default: 1 + balanced: 0 # exploration strategy: balanced true expands one tree every iteration. False will select the tree with lowest maximum cost to go. default: 1 + optimality: 1 # termination strategy: optimality true finishes when the best possible path is found. Otherwise, the algorithm will finish when the first feasible path is found. default: 1 + heuristics: 1 # activates cost to go heuristics. default: 1 + cache_cc: 1 # use the collision checking cache. default: 1 + extended_fmt: 1 # Activates the extended FMT*: adding new samples if planner does not finish successfully. default: 1 + PDST: + type: geometric::PDST + STRIDE: + type: geometric::STRIDE + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + goal_bias: 0.05 # When close to goal select goal, with this probability. default: 0.05 + use_projected_distance: 0 # whether nearest neighbors are computed based on distances in a projection of the state rather distances in the state space itself. default: 0 + degree: 16 # desired degree of a node in the Geometric Near-neightbor Access Tree (GNAT). default: 16 + max_degree: 18 # max degree of a node in the GNAT. default: 12 + min_degree: 12 # min degree of a node in the GNAT. default: 12 + max_pts_per_leaf: 6 # max points per leaf in the GNAT. default: 6 + estimated_dimension: 0.0 # estimated dimension of the free space. default: 0.0 + min_valid_path_fraction: 0.2 # Accept partially valid moves above fraction. default: 0.2 + BiTRRT: + type: geometric::BiTRRT + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + temp_change_factor: 0.1 # how much to increase or decrease temp. default: 0.1 + init_temperature: 100 # initial temperature. default: 100 + frountier_threshold: 0.0 # dist new state to nearest neighbor to disqualify as frontier. default: 0.0 set in setup() + frountier_node_ratio: 0.1 # 1/10, or 1 nonfrontier for every 10 frontier. default: 0.1 + cost_threshold: 1e300 # the cost threshold. Any motion cost that is not better will not be expanded. default: inf + LBTRRT: + type: geometric::LBTRRT + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + goal_bias: 0.05 # When close to goal select goal, with this probability. default: 0.05 + epsilon: 0.4 # optimality approximation factor. default: 0.4 + BiEST: + type: geometric::BiEST + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + ProjEST: + type: geometric::ProjEST + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + goal_bias: 0.05 # When close to goal select goal, with this probability. default: 0.05 + LazyPRM: + type: geometric::LazyPRM + range: 0.0 # Max motion added to tree. ==> maxDistance_ default: 0.0, if 0.0, set on setup() + LazyPRMstar: + type: geometric::LazyPRMstar + SPARS: + type: geometric::SPARS + stretch_factor: 3.0 # roadmap spanner stretch factor. multiplicative upper bound on path quality. It does not make sense to make this parameter more than 3. default: 3.0 + sparse_delta_fraction: 0.25 # delta fraction for connection distance. This value represents the visibility range of sparse samples. default: 0.25 + dense_delta_fraction: 0.001 # delta fraction for interface detection. default: 0.001 + max_failures: 1000 # maximum consecutive failure limit. default: 1000 + SPARStwo: + type: geometric::SPARStwo + stretch_factor: 3.0 # roadmap spanner stretch factor. multiplicative upper bound on path quality. It does not make sense to make this parameter more than 3. default: 3.0 + sparse_delta_fraction: 0.25 # delta fraction for connection distance. This value represents the visibility range of sparse samples. default: 0.25 + dense_delta_fraction: 0.001 # delta fraction for interface detection. default: 0.001 + max_failures: 5000 # maximum consecutive failure limit. default: 5000 +panda_arm1: + planner_configs: + - AnytimePathShortening + - SBL + - EST + - LBKPIECE + - BKPIECE + - KPIECE + - RRT + - RRTConnect + - RRTstar + - TRRT + - PRM + - PRMstar + - FMT + - BFMT + - PDST + - STRIDE + - BiTRRT + - LBTRRT + - BiEST + - ProjEST + - LazyPRM + - LazyPRMstar + - SPARS + - SPARStwo +hand_1: + planner_configs: + - AnytimePathShortening + - SBL + - EST + - LBKPIECE + - BKPIECE + - KPIECE + - RRT + - RRTConnect + - RRTstar + - TRRT + - PRM + - PRMstar + - FMT + - BFMT + - PDST + - STRIDE + - BiTRRT + - LBTRRT + - BiEST + - ProjEST + - LazyPRM + - LazyPRMstar + - SPARS + - SPARStwo +panda_arm2: + planner_configs: + - AnytimePathShortening + - SBL + - EST + - LBKPIECE + - BKPIECE + - KPIECE + - RRT + - RRTConnect + - RRTstar + - TRRT + - PRM + - PRMstar + - FMT + - BFMT + - PDST + - STRIDE + - BiTRRT + - LBTRRT + - BiEST + - ProjEST + - LazyPRM + - LazyPRMstar + - SPARS + - SPARStwo +hand_2: + planner_configs: + - AnytimePathShortening + - SBL + - EST + - LBKPIECE + - BKPIECE + - KPIECE + - RRT + - RRTConnect + - RRTstar + - TRRT + - PRM + - PRMstar + - FMT + - BFMT + - PDST + - STRIDE + - BiTRRT + - LBTRRT + - BiEST + - ProjEST + - LazyPRM + - LazyPRMstar + - SPARS + - SPARStwo diff --git a/src/ceti_double/config/panda.srdf b/src/ceti_double/config/panda.srdf new file mode 100644 index 0000000000000000000000000000000000000000..360074c6423824fe171e6a0819fd139bd13bdfc9 --- /dev/null +++ b/src/ceti_double/config/panda.srdf @@ -0,0 +1,277 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!--This does not replace URDF, and is not an extension of URDF. + This is a format for representing semantic information about the robot structure. + A URDF file must exist for this robot as well, where the joints and the links that are referenced are defined +--> +<robot name="panda"> + <!--GROUPS: Representation of a set of joints and links. This can be useful for specifying DOF to plan for, defining arms, end effectors, etc--> + <!--LINKS: When a link is specified, the parent joint of that link (if it exists) is automatically included--> + <!--JOINTS: When a joint is specified, the child link of that joint (which will always exist) is automatically included--> + <!--CHAINS: When a chain is specified, all the links along the chain (including endpoints) are included in the group. Additionally, all the joints that are parents to included links are also included. This means that joints along the chain and the parent joint of the base link are included in the group--> + <!--SUBGROUPS: Groups can also be formed by referencing to already defined group names--> + <group name="panda_arm1"> + <chain base_link="base_1" tip_link="panda_1_link8"/> + </group> + <group name="hand_1"> + <link name="panda_1_hand"/> + <link name="panda_1_leftfinger"/> + <link name="panda_1_rightfinger"/> + </group> + <group name="panda_arm2"> + <chain base_link="base_2" tip_link="panda_2_link8"/> + </group> + <group name="hand_2"> + <link name="panda_2_hand"/> + <link name="panda_2_leftfinger"/> + <link name="panda_2_rightfinger"/> + </group> + <!--GROUP STATES: Purpose: Define a named state for a particular group, in terms of joint values. This is useful to define states like 'folded arms'--> + <group_state name="home1" group="panda_arm1"> + <joint name="panda_1_joint1" value="0"/> + <joint name="panda_1_joint2" value="0"/> + <joint name="panda_1_joint3" value="0"/> + <joint name="panda_1_joint4" value="-1.5708"/> + <joint name="panda_1_joint5" value="0"/> + <joint name="panda_1_joint6" value="0"/> + <joint name="panda_1_joint7" value="0"/> + </group_state> + <group_state name="home2" group="panda_arm2"> + <joint name="panda_2_joint1" value="0"/> + <joint name="panda_2_joint2" value="0"/> + <joint name="panda_2_joint3" value="0"/> + <joint name="panda_2_joint4" value="-1.5708"/> + <joint name="panda_2_joint5" value="0"/> + <joint name="panda_2_joint6" value="0"/> + <joint name="panda_2_joint7" value="0"/> + </group_state> + <!--END EFFECTOR: Purpose: Represent information about an end effector.--> + <end_effector name="hand1" parent_link="panda_1_link8" group="hand_1"/> + <end_effector name="hand2" parent_link="panda_2_link8" group="hand_2"/> + <!--VIRTUAL JOINT: Purpose: this element defines a virtual joint between a robot link and an external frame of reference (considered fixed with respect to the robot)--> + <virtual_joint name="virtual_joint" type="fixed" parent_frame="world" child_link="world"/> + <!--DISABLE COLLISIONS: By default it is assumed that any link of the robot could potentially come into collision with any other link in the robot. This tag disables collision checking between a specified pair of links. --> + <disable_collisions link1="base_1" link2="base_2" reason="Adjacent"/> + <disable_collisions link1="base_1" link2="panda_1_link0" reason="Adjacent"/> + <disable_collisions link1="base_1" link2="panda_1_link1" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_1_link2" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_1_link3" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_1_link4" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_2_hand" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_2_leftfinger" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_2_link0" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="base_1" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_1_hand" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_1_leftfinger" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_1_link0" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_1_link1" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_1_link2" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_1_link3" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_1_link4" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_1_link5" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_1_link6" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_1_link7" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_1_rightfinger" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_2_link0" reason="Adjacent"/> + <disable_collisions link1="base_2" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="base_2" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_1_leftfinger" reason="Adjacent"/> + <disable_collisions link1="panda_1_hand" link2="panda_1_link3" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_1_link4" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_1_link5" reason="Default"/> + <disable_collisions link1="panda_1_hand" link2="panda_1_link6" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_1_link7" reason="Adjacent"/> + <disable_collisions link1="panda_1_hand" link2="panda_1_rightfinger" reason="Adjacent"/> + <disable_collisions link1="panda_1_hand" link2="panda_2_hand" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_2_leftfinger" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_2_link0" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_1_hand" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_1_link3" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_1_link4" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_1_link6" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_1_link7" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_1_rightfinger" reason="Default"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_2_hand" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_2_leftfinger" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_2_link0" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_1_leftfinger" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_1_link1" reason="Adjacent"/> + <disable_collisions link1="panda_1_link0" link2="panda_1_link2" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_1_link3" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_1_link4" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_2_hand" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_2_leftfinger" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_2_link0" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_1_link0" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_1_link2" reason="Adjacent"/> + <disable_collisions link1="panda_1_link1" link2="panda_1_link3" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_1_link4" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_2_hand" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_2_leftfinger" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_2_link0" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_1_link1" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_link2" link2="panda_1_link3" reason="Adjacent"/> + <disable_collisions link1="panda_1_link2" link2="panda_1_link4" reason="Never"/> + <disable_collisions link1="panda_1_link2" link2="panda_2_hand" reason="Never"/> + <disable_collisions link1="panda_1_link2" link2="panda_2_leftfinger" reason="Never"/> + <disable_collisions link1="panda_1_link2" link2="panda_2_link0" reason="Never"/> + <disable_collisions link1="panda_1_link2" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="panda_1_link2" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="panda_1_link2" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_1_link2" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_1_link2" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="panda_1_link2" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_1_link2" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_1_link2" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_1_link4" reason="Adjacent"/> + <disable_collisions link1="panda_1_link3" link2="panda_1_link5" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_1_link6" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_1_link7" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_1_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_2_hand" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_2_leftfinger" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_2_link0" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_1_link3" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_1_link5" reason="Adjacent"/> + <disable_collisions link1="panda_1_link4" link2="panda_1_link6" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_1_link7" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_1_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_2_hand" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_2_leftfinger" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_2_link0" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_1_link4" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_link5" link2="panda_1_link6" reason="Adjacent"/> + <disable_collisions link1="panda_1_link5" link2="panda_1_link7" reason="Default"/> + <disable_collisions link1="panda_1_link5" link2="panda_2_hand" reason="Never"/> + <disable_collisions link1="panda_1_link5" link2="panda_2_leftfinger" reason="Never"/> + <disable_collisions link1="panda_1_link5" link2="panda_2_link0" reason="Never"/> + <disable_collisions link1="panda_1_link5" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="panda_1_link5" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="panda_1_link5" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_1_link5" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_1_link5" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="panda_1_link5" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_1_link5" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_1_link5" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_link6" link2="panda_1_link7" reason="Adjacent"/> + <disable_collisions link1="panda_1_link6" link2="panda_1_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_link6" link2="panda_2_hand" reason="Never"/> + <disable_collisions link1="panda_1_link6" link2="panda_2_leftfinger" reason="Never"/> + <disable_collisions link1="panda_1_link6" link2="panda_2_link0" reason="Never"/> + <disable_collisions link1="panda_1_link6" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="panda_1_link6" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="panda_1_link6" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_1_link6" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_1_link6" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="panda_1_link6" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_1_link6" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_1_link6" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_link7" link2="panda_1_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_link7" link2="panda_2_hand" reason="Never"/> + <disable_collisions link1="panda_1_link7" link2="panda_2_leftfinger" reason="Never"/> + <disable_collisions link1="panda_1_link7" link2="panda_2_link0" reason="Never"/> + <disable_collisions link1="panda_1_link7" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="panda_1_link7" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="panda_1_link7" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_1_link7" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_1_link7" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="panda_1_link7" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_1_link7" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_1_link7" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_1_rightfinger" link2="panda_2_hand" reason="Never"/> + <disable_collisions link1="panda_1_rightfinger" link2="panda_2_leftfinger" reason="Never"/> + <disable_collisions link1="panda_1_rightfinger" link2="panda_2_link0" reason="Never"/> + <disable_collisions link1="panda_1_rightfinger" link2="panda_2_link1" reason="Never"/> + <disable_collisions link1="panda_1_rightfinger" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="panda_1_rightfinger" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_1_rightfinger" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_1_rightfinger" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="panda_1_rightfinger" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_1_rightfinger" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_1_rightfinger" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_2_hand" link2="panda_2_leftfinger" reason="Adjacent"/> + <disable_collisions link1="panda_2_hand" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_2_hand" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_2_hand" link2="panda_2_link5" reason="Default"/> + <disable_collisions link1="panda_2_hand" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_2_hand" link2="panda_2_link7" reason="Adjacent"/> + <disable_collisions link1="panda_2_hand" link2="panda_2_rightfinger" reason="Adjacent"/> + <disable_collisions link1="panda_2_leftfinger" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_2_leftfinger" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_2_leftfinger" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_2_leftfinger" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_2_leftfinger" link2="panda_2_rightfinger" reason="Default"/> + <disable_collisions link1="panda_2_link0" link2="panda_2_link1" reason="Adjacent"/> + <disable_collisions link1="panda_2_link0" link2="panda_2_link2" reason="Never"/> + <disable_collisions link1="panda_2_link0" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_2_link0" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_2_link1" link2="panda_2_link2" reason="Adjacent"/> + <disable_collisions link1="panda_2_link1" link2="panda_2_link3" reason="Never"/> + <disable_collisions link1="panda_2_link1" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_2_link2" link2="panda_2_link3" reason="Adjacent"/> + <disable_collisions link1="panda_2_link2" link2="panda_2_link4" reason="Never"/> + <disable_collisions link1="panda_2_link3" link2="panda_2_link4" reason="Adjacent"/> + <disable_collisions link1="panda_2_link3" link2="panda_2_link5" reason="Never"/> + <disable_collisions link1="panda_2_link3" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_2_link3" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_2_link3" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_2_link4" link2="panda_2_link5" reason="Adjacent"/> + <disable_collisions link1="panda_2_link4" link2="panda_2_link6" reason="Never"/> + <disable_collisions link1="panda_2_link4" link2="panda_2_link7" reason="Never"/> + <disable_collisions link1="panda_2_link4" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_2_link5" link2="panda_2_link6" reason="Adjacent"/> + <disable_collisions link1="panda_2_link5" link2="panda_2_link7" reason="Default"/> + <disable_collisions link1="panda_2_link6" link2="panda_2_link7" reason="Adjacent"/> + <disable_collisions link1="panda_2_link6" link2="panda_2_rightfinger" reason="Never"/> + <disable_collisions link1="panda_2_link7" link2="panda_2_rightfinger" reason="Never"/> +</robot> diff --git a/src/ceti_double/config/ros_controllers.yaml b/src/ceti_double/config/ros_controllers.yaml new file mode 100644 index 0000000000000000000000000000000000000000..2300582b42fd9dbaf75500ad6f5313c3ba36c6fc --- /dev/null +++ b/src/ceti_double/config/ros_controllers.yaml @@ -0,0 +1,124 @@ +panda_arm1_controller: + type: effort_controllers/JointTrajectoryController + joints: + - panda_1_joint1 + - panda_1_joint2 + - panda_1_joint3 + - panda_1_joint4 + - panda_1_joint5 + - panda_1_joint6 + - panda_1_joint7 + gains: + panda_1_joint1: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_1_joint2: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_1_joint3: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_1_joint4: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_1_joint5: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_1_joint6: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_1_joint7: + p: 100 + d: 1 + i: 1 + i_clamp: 1 +hand_1_controller: + type: effort_controllers/JointTrajectoryController + joints: + - panda_1_finger_joint1 + - panda_1_finger_joint2 + gains: + panda_1_finger_joint1: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_1_finger_joint2: + p: 100 + d: 1 + i: 1 + i_clamp: 1 +panda_arm2_controller: + type: effort_controllers/JointTrajectoryController + joints: + - panda_2_joint1 + - panda_2_joint2 + - panda_2_joint3 + - panda_2_joint4 + - panda_2_joint5 + - panda_2_joint6 + - panda_2_joint7 + gains: + panda_2_joint1: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_2_joint2: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_2_joint3: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_2_joint4: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_2_joint5: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_2_joint6: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_2_joint7: + p: 100 + d: 1 + i: 1 + i_clamp: 1 +hand_2_controller: + type: effort_controllers/JointTrajectoryController + joints: + - panda_2_finger_joint1 + - panda_2_finger_joint2 + gains: + panda_2_finger_joint1: + p: 100 + d: 1 + i: 1 + i_clamp: 1 + panda_2_finger_joint2: + p: 100 + d: 1 + i: 1 + i_clamp: 1 \ No newline at end of file diff --git a/src/ceti_double/config/sensors_3d.yaml b/src/ceti_double/config/sensors_3d.yaml new file mode 100644 index 0000000000000000000000000000000000000000..51010a36779bb9deb49c87d378e0f5af4f4a0e54 --- /dev/null +++ b/src/ceti_double/config/sensors_3d.yaml @@ -0,0 +1,2 @@ +sensors: + [] \ No newline at end of file diff --git a/src/ceti_double/config/simple_moveit_controllers.yaml b/src/ceti_double/config/simple_moveit_controllers.yaml new file mode 100644 index 0000000000000000000000000000000000000000..9d1e7ffa29de25f64d3b35f06c3cf4570a66c05e --- /dev/null +++ b/src/ceti_double/config/simple_moveit_controllers.yaml @@ -0,0 +1,39 @@ +controller_list: + - name: panda_arm1_controller + action_ns: follow_joint_trajectory + type: FollowJointTrajectory + default: True + joints: + - panda_1_joint1 + - panda_1_joint2 + - panda_1_joint3 + - panda_1_joint4 + - panda_1_joint5 + - panda_1_joint6 + - panda_1_joint7 + - name: hand_1_controller + action_ns: follow_joint_trajectory + type: FollowJointTrajectory + default: True + joints: + - panda_1_finger_joint1 + - panda_1_finger_joint2 + - name: panda_arm2_controller + action_ns: follow_joint_trajectory + type: FollowJointTrajectory + default: True + joints: + - panda_2_joint1 + - panda_2_joint2 + - panda_2_joint3 + - panda_2_joint4 + - panda_2_joint5 + - panda_2_joint6 + - panda_2_joint7 + - name: hand_2_controller + action_ns: follow_joint_trajectory + type: FollowJointTrajectory + default: True + joints: + - panda_2_finger_joint1 + - panda_2_finger_joint2 \ No newline at end of file diff --git a/src/ceti_double/config/stomp_planning.yaml b/src/ceti_double/config/stomp_planning.yaml new file mode 100644 index 0000000000000000000000000000000000000000..3bf9dcb061ce1b10f5ebd55b55c2707fb959f3e2 --- /dev/null +++ b/src/ceti_double/config/stomp_planning.yaml @@ -0,0 +1,156 @@ +stomp/panda_arm1: + group_name: panda_arm1 + optimization: + num_timesteps: 60 + num_iterations: 40 + num_iterations_after_valid: 0 + num_rollouts: 30 + max_rollouts: 30 + initialization_method: 1 # [1 : LINEAR_INTERPOLATION, 2 : CUBIC_POLYNOMIAL, 3 : MININUM_CONTROL_COST] + control_cost_weight: 0.0 + task: + noise_generator: + - class: stomp_moveit/NormalDistributionSampling + stddev: [0.05, 0.05, 0.05, 0.05, 0.05, 0.05, 0.05] + cost_functions: + - class: stomp_moveit/CollisionCheck + collision_penalty: 1.0 + cost_weight: 1.0 + kernel_window_percentage: 0.2 + longest_valid_joint_move: 0.05 + noisy_filters: + - class: stomp_moveit/JointLimits + lock_start: True + lock_goal: True + - class: stomp_moveit/MultiTrajectoryVisualization + line_width: 0.02 + rgb: [255, 255, 0] + marker_array_topic: stomp_trajectories + marker_namespace: noisy + update_filters: + - class: stomp_moveit/PolynomialSmoother + poly_order: 6 + - class: stomp_moveit/TrajectoryVisualization + line_width: 0.05 + rgb: [0, 191, 255] + error_rgb: [255, 0, 0] + publish_intermediate: True + marker_topic: stomp_trajectory + marker_namespace: optimized +stomp/hand_1: + group_name: hand_1 + optimization: + num_timesteps: 60 + num_iterations: 40 + num_iterations_after_valid: 0 + num_rollouts: 30 + max_rollouts: 30 + initialization_method: 1 # [1 : LINEAR_INTERPOLATION, 2 : CUBIC_POLYNOMIAL, 3 : MININUM_CONTROL_COST] + control_cost_weight: 0.0 + task: + noise_generator: + - class: stomp_moveit/NormalDistributionSampling + stddev: [0.05, 0.05] + cost_functions: + - class: stomp_moveit/CollisionCheck + collision_penalty: 1.0 + cost_weight: 1.0 + kernel_window_percentage: 0.2 + longest_valid_joint_move: 0.05 + noisy_filters: + - class: stomp_moveit/JointLimits + lock_start: True + lock_goal: True + - class: stomp_moveit/MultiTrajectoryVisualization + line_width: 0.02 + rgb: [255, 255, 0] + marker_array_topic: stomp_trajectories + marker_namespace: noisy + update_filters: + - class: stomp_moveit/PolynomialSmoother + poly_order: 6 + - class: stomp_moveit/TrajectoryVisualization + line_width: 0.05 + rgb: [0, 191, 255] + error_rgb: [255, 0, 0] + publish_intermediate: True + marker_topic: stomp_trajectory + marker_namespace: optimized +stomp/panda_arm2: + group_name: panda_arm2 + optimization: + num_timesteps: 60 + num_iterations: 40 + num_iterations_after_valid: 0 + num_rollouts: 30 + max_rollouts: 30 + initialization_method: 1 # [1 : LINEAR_INTERPOLATION, 2 : CUBIC_POLYNOMIAL, 3 : MININUM_CONTROL_COST] + control_cost_weight: 0.0 + task: + noise_generator: + - class: stomp_moveit/NormalDistributionSampling + stddev: [0.05, 0.05, 0.05, 0.05, 0.05, 0.05, 0.05] + cost_functions: + - class: stomp_moveit/CollisionCheck + collision_penalty: 1.0 + cost_weight: 1.0 + kernel_window_percentage: 0.2 + longest_valid_joint_move: 0.05 + noisy_filters: + - class: stomp_moveit/JointLimits + lock_start: True + lock_goal: True + - class: stomp_moveit/MultiTrajectoryVisualization + line_width: 0.02 + rgb: [255, 255, 0] + marker_array_topic: stomp_trajectories + marker_namespace: noisy + update_filters: + - class: stomp_moveit/PolynomialSmoother + poly_order: 6 + - class: stomp_moveit/TrajectoryVisualization + line_width: 0.05 + rgb: [0, 191, 255] + error_rgb: [255, 0, 0] + publish_intermediate: True + marker_topic: stomp_trajectory + marker_namespace: optimized +stomp/hand_2: + group_name: hand_2 + optimization: + num_timesteps: 60 + num_iterations: 40 + num_iterations_after_valid: 0 + num_rollouts: 30 + max_rollouts: 30 + initialization_method: 1 # [1 : LINEAR_INTERPOLATION, 2 : CUBIC_POLYNOMIAL, 3 : MININUM_CONTROL_COST] + control_cost_weight: 0.0 + task: + noise_generator: + - class: stomp_moveit/NormalDistributionSampling + stddev: [0.05, 0.05] + cost_functions: + - class: stomp_moveit/CollisionCheck + collision_penalty: 1.0 + cost_weight: 1.0 + kernel_window_percentage: 0.2 + longest_valid_joint_move: 0.05 + noisy_filters: + - class: stomp_moveit/JointLimits + lock_start: True + lock_goal: True + - class: stomp_moveit/MultiTrajectoryVisualization + line_width: 0.02 + rgb: [255, 255, 0] + marker_array_topic: stomp_trajectories + marker_namespace: noisy + update_filters: + - class: stomp_moveit/PolynomialSmoother + poly_order: 6 + - class: stomp_moveit/TrajectoryVisualization + line_width: 0.05 + rgb: [0, 191, 255] + error_rgb: [255, 0, 0] + publish_intermediate: True + marker_topic: stomp_trajectory + marker_namespace: optimized \ No newline at end of file diff --git a/src/ceti_double/launch/chomp_planning_pipeline.launch.xml b/src/ceti_double/launch/chomp_planning_pipeline.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..0ecc19f877caf89d1f372548197bec8d4ece3281 --- /dev/null +++ b/src/ceti_double/launch/chomp_planning_pipeline.launch.xml @@ -0,0 +1,23 @@ +<launch> + <arg name="start_state_max_bounds_error" default="0.1" /> + <arg name="jiggle_fraction" default="0.05" /> + <!-- The request adapters (plugins) used when planning. ORDER MATTERS! --> + <arg name="planning_adapters" + default="default_planner_request_adapters/AddTimeParameterization + default_planner_request_adapters/ResolveConstraintFrames + default_planner_request_adapters/FixWorkspaceBounds + default_planner_request_adapters/FixStartStateBounds + default_planner_request_adapters/FixStartStateCollision + default_planner_request_adapters/FixStartStatePathConstraints" + /> + + <param name="planning_plugin" value="chomp_interface/CHOMPPlanner" /> + <param name="request_adapters" value="$(arg planning_adapters)" /> + <param name="start_state_max_bounds_error" value="$(arg start_state_max_bounds_error)" /> + <param name="jiggle_fraction" value="$(arg jiggle_fraction)" /> + + <!-- Add MoveGroup capabilities specific to this pipeline --> + <!-- <param name="capabilities" value="" /> --> + + <rosparam command="load" file="$(find ceti_double)/config/chomp_planning.yaml" /> +</launch> diff --git a/src/ceti_double/launch/default_warehouse_db.launch b/src/ceti_double/launch/default_warehouse_db.launch new file mode 100644 index 0000000000000000000000000000000000000000..8b66cc996e2de59a22f510db94cff33435fc39a0 --- /dev/null +++ b/src/ceti_double/launch/default_warehouse_db.launch @@ -0,0 +1,15 @@ +<launch> + + <arg name="reset" default="false"/> + <!-- If not specified, we'll use a default database location --> + <arg name="moveit_warehouse_database_path" default="$(find ceti_double)/default_warehouse_mongo_db" /> + + <!-- Launch the warehouse with the configured database location --> + <include file="$(dirname)/warehouse.launch"> + <arg name="moveit_warehouse_database_path" value="$(arg moveit_warehouse_database_path)" /> + </include> + + <!-- If we want to reset the database, run this node --> + <node if="$(arg reset)" name="$(anon moveit_default_db_reset)" type="moveit_init_demo_warehouse" pkg="moveit_ros_warehouse" respawn="false" output="screen" /> + +</launch> diff --git a/src/ceti_double/launch/demo.launch b/src/ceti_double/launch/demo.launch new file mode 100644 index 0000000000000000000000000000000000000000..ff84767aca1541eec72f92b13d4ef363f04d40ae --- /dev/null +++ b/src/ceti_double/launch/demo.launch @@ -0,0 +1,69 @@ +<launch> + + <!-- specify the planning pipeline --> + <arg name="pipeline" default="ompl" /> + + <!-- By default, we do not start a database (it can be large) --> + <arg name="db" default="false" /> + <!-- Allow user to specify database location --> + <arg name="db_path" default="$(find ceti_double)/default_warehouse_mongo_db" /> + + <!-- By default, we are not in debug mode --> + <arg name="debug" default="false" /> + + <!-- By default, we will load or override the robot_description --> + <arg name="load_robot_description" default="true"/> + + <!-- Choose controller manager: fake, simple, or ros_control --> + <arg name="moveit_controller_manager" default="fake" /> + <!-- Set execution mode for fake execution controllers --> + <arg name="fake_execution_type" default="interpolate" /> + + <!-- By default, hide joint_state_publisher's GUI in 'fake' controller_manager mode --> + <arg name="use_gui" default="false" /> + <arg name="use_rviz" default="true" /> + + <!-- If needed, broadcast static tf for robot root --> + <node pkg="tf2_ros" type="static_transform_publisher" name="virtual_joint_broadcaster_0" args="0 0 0 0 0 0 world world" /> + + + + <group if="$(eval arg('moveit_controller_manager') == 'fake')"> + <!-- We do not have a real robot connected, so publish fake joint states via a joint_state_publisher + MoveIt's fake controller's joint states are considered via the 'source_list' parameter --> + <node name="joint_state_publisher" pkg="joint_state_publisher" type="joint_state_publisher" unless="$(arg use_gui)"> + <rosparam param="source_list">[move_group/fake_controller_joint_states]</rosparam> + </node> + <!-- If desired, a GUI version is available allowing to move the simulated robot around manually + This corresponds to moving around the real robot without the use of MoveIt. --> + <node name="joint_state_publisher" pkg="joint_state_publisher_gui" type="joint_state_publisher_gui" if="$(arg use_gui)"> + <rosparam param="source_list">[move_group/fake_controller_joint_states]</rosparam> + </node> + + <!-- Given the published joint states, publish tf for the robot links --> + <node name="robot_state_publisher" pkg="robot_state_publisher" type="robot_state_publisher" respawn="true" output="screen" /> + </group> + + <!-- Run the main MoveIt executable without trajectory execution (we do not have controllers configured by default) --> + <include file="$(dirname)/move_group.launch"> + <arg name="allow_trajectory_execution" value="true"/> + <arg name="moveit_controller_manager" value="$(arg moveit_controller_manager)" /> + <arg name="fake_execution_type" value="$(arg fake_execution_type)"/> + <arg name="info" value="true"/> + <arg name="debug" value="$(arg debug)"/> + <arg name="pipeline" value="$(arg pipeline)"/> + <arg name="load_robot_description" value="$(arg load_robot_description)"/> + </include> + + <!-- Run Rviz and load the default config to see the state of the move_group node --> + <include file="$(dirname)/moveit_rviz.launch" if="$(arg use_rviz)"> + <arg name="rviz_config" value="$(dirname)/moveit.rviz"/> + <arg name="debug" value="$(arg debug)"/> + </include> + + <!-- If database loading was enabled, start mongodb as well --> + <include file="$(dirname)/default_warehouse_db.launch" if="$(arg db)"> + <arg name="moveit_warehouse_database_path" value="$(arg db_path)"/> + </include> + +</launch> diff --git a/src/ceti_double/launch/demo_gazebo.launch b/src/ceti_double/launch/demo_gazebo.launch new file mode 100644 index 0000000000000000000000000000000000000000..a9f320c59601bb8fb909d972025dac60f735b4ca --- /dev/null +++ b/src/ceti_double/launch/demo_gazebo.launch @@ -0,0 +1,21 @@ +<launch> + + <!-- specify the planning pipeline --> + <arg name="pipeline" default="ompl" /> + + <!-- Gazebo specific options --> + <arg name="gazebo_gui" default="true"/> + <arg name="paused" default="false"/> + + <!-- launch the gazebo simulator and spawn the robot --> + <include file="$(dirname)/gazebo.launch" > + <arg name="paused" value="$(arg paused)"/> + <arg name="gazebo_gui" value="$(arg gazebo_gui)"/> + </include> + + <include file="$(dirname)/demo.launch" pass_all_args="true"> + <!-- robot description is loaded by gazebo.launch, to enable Gazebo features --> + <arg name="load_robot_description" value="false" /> + <arg name="moveit_controller_manager" value="ros_control" /> + </include> +</launch> diff --git a/src/ceti_double/launch/fake_moveit_controller_manager.launch.xml b/src/ceti_double/launch/fake_moveit_controller_manager.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..0d1d4174dfd9f348fc8150421edcd833bf6e02e0 --- /dev/null +++ b/src/ceti_double/launch/fake_moveit_controller_manager.launch.xml @@ -0,0 +1,12 @@ +<launch> + + <!-- execute the trajectory in 'interpolate' mode or jump to goal position in 'last point' mode --> + <arg name="fake_execution_type" default="interpolate" /> + + <!-- Set the param that trajectory_execution_manager needs to find the controller plugin --> + <param name="moveit_controller_manager" value="moveit_fake_controller_manager/MoveItFakeControllerManager"/> + + <!-- The rest of the params are specific to this plugin --> + <rosparam subst_value="true" file="$(find ceti_double)/config/fake_controllers.yaml"/> + +</launch> diff --git a/src/ceti_double/launch/gazebo.launch b/src/ceti_double/launch/gazebo.launch new file mode 100644 index 0000000000000000000000000000000000000000..27217c05760197b736f17b52373ea55d6f4b010e --- /dev/null +++ b/src/ceti_double/launch/gazebo.launch @@ -0,0 +1,32 @@ +<?xml version="1.0"?> +<launch> + <arg name="paused" default="false"/> + <arg name="gazebo_gui" default="true"/> + <arg name="initial_joint_positions" doc="Initial joint configuration of the robot" + default=" -J panda_1_joint1 0 -J panda_1_joint2 0 -J panda_1_joint3 0 -J panda_1_joint4 -1.5708 -J panda_1_joint5 0 -J panda_1_joint6 0 -J panda_1_joint7 0 -J panda_2_joint1 0 -J panda_2_joint2 0 -J panda_2_joint3 0 -J panda_2_joint4 -1.5708 -J panda_2_joint5 0 -J panda_2_joint6 0 -J panda_2_joint7 0"/> + + <!-- startup simulated world --> + <include file="$(find gazebo_ros)/launch/empty_world.launch"> + <arg name="world_name" default="worlds/empty.world"/> + <arg name="paused" value="true"/> + <arg name="gui" value="$(arg gazebo_gui)"/> + </include> + + <!-- send robot urdf to param server --> + <param name="robot_description" command="xacro '$(find franka_description)/robots/ceti_double.urdf.xacro'" /> + + <!-- unpause only after loading robot model --> + <arg name="unpause" value="$(eval '' if arg('paused') else '-unpause')" /> + <!-- push robot_description to factory and spawn robot in gazebo at the origin, change x,y,z arguments to spawn in a different position --> + <arg name="world_pose" value="-x 0 -y 0 -z 0" /> + <node name="spawn_gazebo_model" pkg="gazebo_ros" type="spawn_model" args="-urdf -param robot_description -model robot $(arg unpause) $(arg world_pose) $(arg initial_joint_positions)" + respawn="false" output="screen" /> + + <!-- Load joint controller parameters for Gazebo --> + <rosparam file="$(find ceti_double)/config/gazebo_controllers.yaml" /> + <!-- Spawn Gazebo ROS controllers --> + <node name="gazebo_controller_spawner" pkg="controller_manager" type="spawner" respawn="false" output="screen" args="joint_state_controller" /> + <!-- Load ROS controllers --> + <include file="$(dirname)/ros_controllers.launch"/> + +</launch> diff --git a/src/ceti_double/launch/joystick_control.launch b/src/ceti_double/launch/joystick_control.launch new file mode 100644 index 0000000000000000000000000000000000000000..9411f6e60e7b30594f6999ffc682112bc5b7dad1 --- /dev/null +++ b/src/ceti_double/launch/joystick_control.launch @@ -0,0 +1,17 @@ +<launch> + <!-- See moveit_ros/visualization/doc/joystick.rst for documentation --> + + <arg name="dev" default="/dev/input/js0" /> + + <!-- Launch joy node --> + <node pkg="joy" type="joy_node" name="joy"> + <param name="dev" value="$(arg dev)" /> <!-- Customize this to match the location your joystick is plugged in on--> + <param name="deadzone" value="0.2" /> + <param name="autorepeat_rate" value="40" /> + <param name="coalesce_interval" value="0.025" /> + </node> + + <!-- Launch python interface --> + <node pkg="moveit_ros_visualization" type="moveit_joy.py" output="screen" name="moveit_joy"/> + +</launch> diff --git a/src/ceti_double/launch/move_group.launch b/src/ceti_double/launch/move_group.launch new file mode 100644 index 0000000000000000000000000000000000000000..68fa8a9e0bcdf51f4b04191811ee460c2b6260f5 --- /dev/null +++ b/src/ceti_double/launch/move_group.launch @@ -0,0 +1,101 @@ +<launch> + + <!-- GDB Debug Option --> + <arg name="debug" default="false" /> + <arg unless="$(arg debug)" name="launch_prefix" value="" /> + <arg if="$(arg debug)" name="launch_prefix" + value="gdb -x $(dirname)/gdb_settings.gdb --ex run --args" /> + + <!-- Verbose Mode Option --> + <arg name="info" default="$(arg debug)" /> + <arg unless="$(arg info)" name="command_args" value="" /> + <arg if="$(arg info)" name="command_args" value="--debug" /> + + <!-- move_group settings --> + <arg name="pipeline" default="ompl" /> + <arg name="allow_trajectory_execution" default="true"/> + <arg name="moveit_controller_manager" default="simple" /> + <arg name="fake_execution_type" default="interpolate"/> + <arg name="max_safe_path_cost" default="1"/> + <arg name="publish_monitored_planning_scene" default="true"/> + + <arg name="capabilities" default=""/> + <arg name="disable_capabilities" default=""/> + <!-- load these non-default MoveGroup capabilities (space seperated) --> + <!-- + <arg name="capabilities" value=" + a_package/AwsomeMotionPlanningCapability + another_package/GraspPlanningPipeline + " /> + --> + + <!-- inhibit these default MoveGroup capabilities (space seperated) --> + <!-- + <arg name="disable_capabilities" value=" + move_group/MoveGroupKinematicsService + move_group/ClearOctomapService + " /> + --> + + <arg name="load_robot_description" default="false" /> + <!-- load URDF, SRDF and joint_limits configuration --> + <include file="$(dirname)/planning_context.launch"> + <arg name="load_robot_description" value="$(arg load_robot_description)" /> + </include> + + <!-- Planning Pipelines --> + <group ns="move_group/planning_pipelines"> + + <!-- OMPL --> + <include file="$(dirname)/planning_pipeline.launch.xml"> + <arg name="pipeline" value="ompl" /> + </include> + + <!-- CHOMP --> + <include file="$(dirname)/planning_pipeline.launch.xml"> + <arg name="pipeline" value="chomp" /> + </include> + + <!-- Pilz Industrial Motion --> + <include file="$(dirname)/planning_pipeline.launch.xml"> + <arg name="pipeline" value="pilz_industrial_motion_planner" /> + </include> + + <!-- Support custom planning pipeline --> + <include if="$(eval arg('pipeline') not in ['ompl', 'chomp', 'pilz_industrial_motion_planner'])" + file="$(dirname)/planning_pipeline.launch.xml"> + <arg name="pipeline" value="$(arg pipeline)" /> + </include> + </group> + + <!-- Trajectory Execution Functionality --> + <include ns="move_group" file="$(dirname)/trajectory_execution.launch.xml" if="$(arg allow_trajectory_execution)"> + <arg name="moveit_manage_controllers" value="true" /> + <arg name="moveit_controller_manager" value="$(arg moveit_controller_manager)" /> + <arg name="fake_execution_type" value="$(arg fake_execution_type)" /> + </include> + + <!-- Sensors Functionality --> + <include ns="move_group" file="$(dirname)/sensor_manager.launch.xml" if="$(arg allow_trajectory_execution)"> + <arg name="moveit_sensor_manager" value="panda" /> + </include> + + <!-- Start the actual move_group node/action server --> + <node name="move_group" launch-prefix="$(arg launch_prefix)" pkg="moveit_ros_move_group" type="move_group" respawn="false" output="screen" args="$(arg command_args)"> + <!-- Set the display variable, in case OpenGL code is used internally --> + <env name="DISPLAY" value="$(optenv DISPLAY :0)" /> + + <param name="allow_trajectory_execution" value="$(arg allow_trajectory_execution)"/> + <param name="sense_for_plan/max_safe_path_cost" value="$(arg max_safe_path_cost)"/> + <param name="default_planning_pipeline" value="$(arg pipeline)" /> + <param name="capabilities" value="$(arg capabilities)" /> + <param name="disable_capabilities" value="$(arg disable_capabilities)" /> + + <!-- Publish the planning scene of the physical robot so that rviz plugin can know actual robot --> + <param name="planning_scene_monitor/publish_planning_scene" value="$(arg publish_monitored_planning_scene)" /> + <param name="planning_scene_monitor/publish_geometry_updates" value="$(arg publish_monitored_planning_scene)" /> + <param name="planning_scene_monitor/publish_state_updates" value="$(arg publish_monitored_planning_scene)" /> + <param name="planning_scene_monitor/publish_transforms_updates" value="$(arg publish_monitored_planning_scene)" /> + </node> + +</launch> diff --git a/src/ceti_double/launch/moveit.rviz b/src/ceti_double/launch/moveit.rviz new file mode 100644 index 0000000000000000000000000000000000000000..6d8744450523884a6f9a2798686a9723beec382d --- /dev/null +++ b/src/ceti_double/launch/moveit.rviz @@ -0,0 +1,131 @@ +Panels: + - Class: rviz/Displays + Help Height: 84 + Name: Displays + Property Tree Widget: + Expanded: + - /MotionPlanning1 + Splitter Ratio: 0.5 + Tree Height: 226 + - Class: rviz/Help + Name: Help + - Class: rviz/Views + Expanded: + - /Current View1 + Name: Views + Splitter Ratio: 0.5 +Visualization Manager: + Class: "" + Displays: + - Alpha: 0.5 + Cell Size: 1 + Class: rviz/Grid + Color: 160; 160; 164 + Enabled: true + Line Style: + Line Width: 0.03 + Value: Lines + Name: Grid + Normal Cell Count: 0 + Offset: + X: 0 + Y: 0 + Z: 0 + Plane: XY + Plane Cell Count: 10 + Reference Frame: <Fixed Frame> + Value: true + - Class: moveit_rviz_plugin/MotionPlanning + Enabled: true + Name: MotionPlanning + Planned Path: + Links: ~ + Loop Animation: true + Robot Alpha: 0.5 + Show Robot Collision: false + Show Robot Visual: true + Show Trail: false + State Display Time: 0.05 s + Trajectory Topic: move_group/display_planned_path + Planning Metrics: + Payload: 1 + Show Joint Torques: false + Show Manipulability: false + Show Manipulability Index: false + Show Weight Limit: false + Planning Request: + Colliding Link Color: 255; 0; 0 + Goal State Alpha: 1 + Goal State Color: 250; 128; 0 + Interactive Marker Size: 0 + Joint Violation Color: 255; 0; 255 + Query Goal State: true + Query Start State: false + Show Workspace: false + Start State Alpha: 1 + Start State Color: 0; 255; 0 + Planning Scene Topic: move_group/monitored_planning_scene + Robot Description: robot_description + Scene Geometry: + Scene Alpha: 1 + Show Scene Geometry: true + Voxel Coloring: Z-Axis + Voxel Rendering: Occupied Voxels + Scene Robot: + Attached Body Color: 150; 50; 150 + Links: ~ + Robot Alpha: 0.5 + Show Scene Robot: true + Value: true + Enabled: true + Global Options: + Background Color: 48; 48; 48 + Fixed Frame: world + Name: root + Tools: + - Class: rviz/Interact + Hide Inactive Objects: true + - Class: rviz/MoveCamera + - Class: rviz/Select + Value: true + Views: + Current: + Class: rviz/Orbit + Distance: 2.0 + Enable Stereo Rendering: + Stereo Eye Separation: 0.06 + Stereo Focal Distance: 1 + Swap Stereo Eyes: false + Value: false + Field of View: 0.75 + Focal Point: + X: -0.1 + Y: 0.25 + Z: 0.30 + Focal Shape Fixed Size: true + Focal Shape Size: 0.05 + Invert Z Axis: false + Name: Current View + Near Clip Distance: 0.01 + Pitch: 0.5 + Target Frame: world + Yaw: -0.6232355833053589 + Saved: ~ +Window Geometry: + Displays: + collapsed: false + Height: 848 + Help: + collapsed: false + Hide Left Dock: false + Hide Right Dock: false + MotionPlanning: + collapsed: false + MotionPlanning - Trajectory Slider: + collapsed: false + QMainWindow State: 000000ff00000000fd0000000100000000000001f0000002f6fc0200000007fb000000100044006900730070006c006100790073010000003d00000173000000c900fffffffb0000000800480065006c00700000000342000000bb0000006e00fffffffb0000000a00560069006500770073000000010c000000a4000000a400fffffffb0000000c00430061006d00650072006100000002ff000001610000000000000000fb0000001e004d006f00740069006f006e00200050006c0061006e006e0069006e00670100000374000001890000000000000000fb00000044004d006f00740069006f006e0050006c0061006e006e0069006e00670020002d0020005400720061006a006500630074006f0072007900200053006c00690064006500720000000000ffffffff0000001600000016fb0000001c004d006f00740069006f006e0050006c0061006e006e0069006e006701000001b60000017d0000017d00ffffff00000315000002f600000001000000020000000100000002fc0000000100000002000000010000000a0054006f006f006c00730100000000ffffffff0000000000000000 + Views: + collapsed: false + Width: 1291 + X: 454 + Y: 25 diff --git a/src/ceti_double/launch/moveit_rviz.launch b/src/ceti_double/launch/moveit_rviz.launch new file mode 100644 index 0000000000000000000000000000000000000000..a4605c03742afe6fe27bcefd811992502a4015b8 --- /dev/null +++ b/src/ceti_double/launch/moveit_rviz.launch @@ -0,0 +1,15 @@ +<launch> + + <arg name="debug" default="false" /> + <arg unless="$(arg debug)" name="launch_prefix" value="" /> + <arg if="$(arg debug)" name="launch_prefix" value="gdb --ex run --args" /> + + <arg name="rviz_config" default="" /> + <arg if="$(eval rviz_config=='')" name="command_args" value="" /> + <arg unless="$(eval rviz_config=='')" name="command_args" value="-d $(arg rviz_config)" /> + + <node name="$(anon rviz)" launch-prefix="$(arg launch_prefix)" pkg="rviz" type="rviz" respawn="false" + args="$(arg command_args)" output="screen"> + </node> + +</launch> diff --git a/src/ceti_double/launch/ompl-chomp_planning_pipeline.launch.xml b/src/ceti_double/launch/ompl-chomp_planning_pipeline.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..b078992417c52ce7bb2dca92f9980e0a95ba24eb --- /dev/null +++ b/src/ceti_double/launch/ompl-chomp_planning_pipeline.launch.xml @@ -0,0 +1,19 @@ +<launch> + <!-- load OMPL planning pipeline, but add the CHOMP planning adapter. --> + <include file="$(find panda_moveit_config)/launch/ompl_planning_pipeline.launch.xml"> + <arg name="planning_adapters" value=" + default_planner_request_adapters/AddTimeParameterization + default_planner_request_adapters/FixWorkspaceBounds + default_planner_request_adapters/FixStartStateBounds + default_planner_request_adapters/FixStartStateCollision + default_planner_request_adapters/FixStartStatePathConstraints + chomp/OptimizerAdapter" + /> + </include> + + <!-- load chomp config --> + <rosparam command="load" file="$(find panda_moveit_config)/config/chomp_planning.yaml"/> + + <!-- override trajectory_initialization_method: Use OMPL-generated trajectory --> + <param name="trajectory_initialization_method" value="fillTrajectory"/> +</launch> diff --git a/src/ceti_double/launch/ompl_planning_pipeline.launch.xml b/src/ceti_double/launch/ompl_planning_pipeline.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..2605e1ef5c081cd8c00c1a291b3b255d601e8bf0 --- /dev/null +++ b/src/ceti_double/launch/ompl_planning_pipeline.launch.xml @@ -0,0 +1,26 @@ +<launch> + + <!-- The request adapters (plugins) used when planning with OMPL. ORDER MATTERS! --> + <arg name="planning_adapters" + default="default_planner_request_adapters/AddTimeParameterization + default_planner_request_adapters/ResolveConstraintFrames + default_planner_request_adapters/FixWorkspaceBounds + default_planner_request_adapters/FixStartStateBounds + default_planner_request_adapters/FixStartStateCollision + default_planner_request_adapters/FixStartStatePathConstraints" + /> + + <arg name="start_state_max_bounds_error" default="0.1" /> + <arg name="jiggle_fraction" default="0.05" /> + + <param name="planning_plugin" value="ompl_interface/OMPLPlanner" /> + <param name="request_adapters" value="$(arg planning_adapters)" /> + <param name="start_state_max_bounds_error" value="$(arg start_state_max_bounds_error)" /> + <param name="jiggle_fraction" value="$(arg jiggle_fraction)" /> + + <!-- Add MoveGroup capabilities specific to this pipeline --> + <!-- <param name="capabilities" value="" /> --> + + <rosparam command="load" file="$(find ceti_double)/config/ompl_planning.yaml"/> + +</launch> diff --git a/src/ceti_double/launch/panda_moveit_sensor_manager.launch.xml b/src/ceti_double/launch/panda_moveit_sensor_manager.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..5d02698d7b05f6356110c54ddd75cfbc5ed7084b --- /dev/null +++ b/src/ceti_double/launch/panda_moveit_sensor_manager.launch.xml @@ -0,0 +1,3 @@ +<launch> + +</launch> diff --git a/src/ceti_double/launch/pilz_industrial_motion_planner_planning_pipeline.launch.xml b/src/ceti_double/launch/pilz_industrial_motion_planner_planning_pipeline.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..c7c4cf500526a242e33cbd897eafd11c64ec1e7b --- /dev/null +++ b/src/ceti_double/launch/pilz_industrial_motion_planner_planning_pipeline.launch.xml @@ -0,0 +1,15 @@ +<launch> + + <!-- The request adapters (plugins) used when planning. ORDER MATTERS! --> + <arg name="planning_adapters" default="" /> + + <param name="planning_plugin" value="pilz_industrial_motion_planner::CommandPlanner" /> + <param name="request_adapters" value="$(arg planning_adapters)" /> + + <!-- Define default planner (for all groups) --> + <param name="default_planner_config" value="PTP" /> + + <!-- MoveGroup capabilities to load for this pipeline, append sequence capability --> + <param name="capabilities" value="pilz_industrial_motion_planner/MoveGroupSequenceAction + pilz_industrial_motion_planner/MoveGroupSequenceService" /> +</launch> diff --git a/src/ceti_double/launch/planning_context.launch b/src/ceti_double/launch/planning_context.launch new file mode 100644 index 0000000000000000000000000000000000000000..fac3bd82f38edce49cfb2c6395a736fdc0ffd659 --- /dev/null +++ b/src/ceti_double/launch/planning_context.launch @@ -0,0 +1,26 @@ +<launch> + <!-- By default we do not overwrite the URDF. Change the following to true to change the default behavior --> + <arg name="load_robot_description" default="false"/> + + <!-- The name of the parameter under which the URDF is loaded --> + <arg name="robot_description" default="robot_description"/> + + <!-- Load universal robot description format (URDF) --> + <param if="$(arg load_robot_description)" name="$(arg robot_description)" command="xacro '$(find franka_description)/robots/ceti_double.urdf.xacro'"/> + + <!-- The semantic description that corresponds to the URDF --> + <param name="$(arg robot_description)_semantic" textfile="$(find ceti_double)/config/panda.srdf" /> + + <!-- Load updated joint limits (override information from URDF) --> + <group ns="$(arg robot_description)_planning"> + <rosparam command="load" file="$(find ceti_double)/config/joint_limits.yaml"/> + <rosparam command="load" file="$(find ceti_double)/config/cartesian_limits.yaml"/> + </group> + + <!-- Load default settings for kinematics; these settings are overridden by settings in a node's namespace --> + <group ns="$(arg robot_description)_kinematics"> + <rosparam command="load" file="$(find ceti_double)/config/kinematics.yaml"/> + + </group> + +</launch> diff --git a/src/ceti_double/launch/planning_pipeline.launch.xml b/src/ceti_double/launch/planning_pipeline.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..4b4d0d663ae2476ae11b2fcfbda689331ebe6fbf --- /dev/null +++ b/src/ceti_double/launch/planning_pipeline.launch.xml @@ -0,0 +1,10 @@ +<launch> + + <!-- This file makes it easy to include different planning pipelines; + It is assumed that all planning pipelines are named XXX_planning_pipeline.launch --> + + <arg name="pipeline" default="ompl" /> + + <include ns="$(arg pipeline)" file="$(dirname)/$(arg pipeline)_planning_pipeline.launch.xml" /> + +</launch> diff --git a/src/ceti_double/launch/ros_control_moveit_controller_manager.launch.xml b/src/ceti_double/launch/ros_control_moveit_controller_manager.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..9ebc91c108522ddcc600320b5c1d90a039c222fe --- /dev/null +++ b/src/ceti_double/launch/ros_control_moveit_controller_manager.launch.xml @@ -0,0 +1,4 @@ +<launch> + <!-- Define MoveIt controller manager plugin --> + <param name="moveit_controller_manager" value="moveit_ros_control_interface::MoveItControllerManager" /> +</launch> diff --git a/src/ceti_double/launch/ros_controllers.launch b/src/ceti_double/launch/ros_controllers.launch new file mode 100644 index 0000000000000000000000000000000000000000..47a888521d868597ac46d6d698e16652ddc4f8df --- /dev/null +++ b/src/ceti_double/launch/ros_controllers.launch @@ -0,0 +1,11 @@ +<?xml version="1.0"?> +<launch> + + <!-- Load joint controller configurations from YAML file to parameter server --> + <rosparam file="$(find ceti_double)/config/ros_controllers.yaml" command="load"/> + + <!-- Load the controllers --> + <node name="controller_spawner" pkg="controller_manager" type="spawner" respawn="false" + output="screen" args="panda_arm1_controller hand_1_controller panda_arm2_controller hand_2_controller "/> + +</launch> diff --git a/src/ceti_double/launch/run_benchmark_ompl.launch b/src/ceti_double/launch/run_benchmark_ompl.launch new file mode 100644 index 0000000000000000000000000000000000000000..5ef42f5ea52ed5d9cf372e4c96ed86c282c8bf24 --- /dev/null +++ b/src/ceti_double/launch/run_benchmark_ompl.launch @@ -0,0 +1,21 @@ +<launch> + + <!-- This argument must specify the list of .cfg files to process for benchmarking --> + <arg name="cfg" /> + + <!-- Load URDF --> + <include file="$(dirname)/planning_context.launch"> + <arg name="load_robot_description" value="true"/> + </include> + + <!-- Start the database --> + <include file="$(dirname)/warehouse.launch"> + <arg name="moveit_warehouse_database_path" value="moveit_ompl_benchmark_warehouse"/> + </include> + + <!-- Start Benchmark Executable --> + <node name="$(anon moveit_benchmark)" pkg="moveit_ros_benchmarks" type="moveit_run_benchmark" args="$(arg cfg) --benchmark-planners" respawn="false" output="screen"> + <rosparam command="load" file="$(find ceti_double)/config/ompl_planning.yaml"/> + </node> + +</launch> diff --git a/src/ceti_double/launch/sensor_manager.launch.xml b/src/ceti_double/launch/sensor_manager.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..30de9479a937960bc6fc534db9dd25b709beeabb --- /dev/null +++ b/src/ceti_double/launch/sensor_manager.launch.xml @@ -0,0 +1,17 @@ +<launch> + + <!-- This file makes it easy to include the settings for sensor managers --> + + <!-- Params for 3D sensors config --> + <rosparam command="load" file="$(find ceti_double)/config/sensors_3d.yaml" /> + + <!-- Params for the octomap monitor --> + <!-- <param name="octomap_frame" type="string" value="some frame in which the robot moves" /> --> + <param name="octomap_resolution" type="double" value="0.025" /> + <param name="max_range" type="double" value="5.0" /> + + <!-- Load the robot specific sensor manager; this sets the moveit_sensor_manager ROS parameter --> + <arg name="moveit_sensor_manager" default="panda" /> + <include file="$(dirname)/$(arg moveit_sensor_manager)_moveit_sensor_manager.launch.xml" /> + +</launch> diff --git a/src/ceti_double/launch/setup_assistant.launch b/src/ceti_double/launch/setup_assistant.launch new file mode 100644 index 0000000000000000000000000000000000000000..6d4be6f6c37139ea49483d2a5fb3c563469fadf6 --- /dev/null +++ b/src/ceti_double/launch/setup_assistant.launch @@ -0,0 +1,16 @@ +<!-- Re-launch the MoveIt Setup Assistant with this configuration package already loaded --> +<launch> + + <!-- Debug Info --> + <arg name="debug" default="false" /> + <arg unless="$(arg debug)" name="launch_prefix" value="" /> + <arg if="$(arg debug)" name="launch_prefix" value="gdb --ex run --args" /> + + <!-- Run --> + <node pkg="moveit_setup_assistant" type="moveit_setup_assistant" name="moveit_setup_assistant" + args="--config_pkg=ceti_double" + launch-prefix="$(arg launch_prefix)" + required="true" + output="screen" /> + +</launch> diff --git a/src/ceti_double/launch/simple_moveit_controller_manager.launch.xml b/src/ceti_double/launch/simple_moveit_controller_manager.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..efabd1c2ba03ae19120b6d4c6886b0f7ee6c0f36 --- /dev/null +++ b/src/ceti_double/launch/simple_moveit_controller_manager.launch.xml @@ -0,0 +1,8 @@ +<launch> + <!-- Define the MoveIt controller manager plugin to use for trajectory execution --> + <param name="moveit_controller_manager" value="moveit_simple_controller_manager/MoveItSimpleControllerManager" /> + + <!-- Load controller list to the parameter server --> + <rosparam file="$(find ceti_double)/config/simple_moveit_controllers.yaml" /> + <rosparam file="$(find ceti_double)/config/ros_controllers.yaml" /> +</launch> diff --git a/src/ceti_double/launch/stomp_planning_pipeline.launch.xml b/src/ceti_double/launch/stomp_planning_pipeline.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..e1244d02f0194d406935101907819796d717f98e --- /dev/null +++ b/src/ceti_double/launch/stomp_planning_pipeline.launch.xml @@ -0,0 +1,25 @@ +<launch> + <!-- Stomp Plugin for MoveIt --> + <arg name="planning_plugin" value="stomp_moveit/StompPlannerManager" /> + + <arg name="start_state_max_bounds_error" value="0.1" /> + <arg name="jiggle_fraction" value="0.05" /> + <!-- The request adapters (plugins) used when planning. ORDER MATTERS! --> + <arg name="planning_adapters" + default="default_planner_request_adapters/AddTimeParameterization + default_planner_request_adapters/FixWorkspaceBounds + default_planner_request_adapters/FixStartStateBounds + default_planner_request_adapters/FixStartStateCollision + default_planner_request_adapters/FixStartStatePathConstraints" /> + + + <param name="planning_plugin" value="$(arg planning_plugin)" /> + <param name="request_adapters" value="$(arg planning_adapters)" /> + <param name="start_state_max_bounds_error" value="$(arg start_state_max_bounds_error)" /> + <param name="jiggle_fraction" value="$(arg jiggle_fraction)" /> + + <!-- Add MoveGroup capabilities specific to this pipeline --> + <!-- <param name="capabilities" value="" /> --> + + <rosparam command="load" file="$(find ceti_double)/config/stomp_planning.yaml"/> +</launch> diff --git a/src/ceti_double/launch/trajectory_execution.launch.xml b/src/ceti_double/launch/trajectory_execution.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..20c3dfc45911ec0cf5e848e70fa0129ef33123c5 --- /dev/null +++ b/src/ceti_double/launch/trajectory_execution.launch.xml @@ -0,0 +1,23 @@ +<launch> + <!-- This file summarizes all settings required for trajectory execution --> + + <!-- Define moveit controller manager plugin: fake, simple, or ros_control --> + <arg name="moveit_controller_manager" /> + <arg name="fake_execution_type" default="interpolate" /> + + <!-- Flag indicating whether MoveIt is allowed to load/unload or switch controllers --> + <arg name="moveit_manage_controllers" default="true"/> + <param name="moveit_manage_controllers" value="$(arg moveit_manage_controllers)"/> + + <!-- When determining the expected duration of a trajectory, this multiplicative factor is applied to get the allowed duration of execution --> + <param name="trajectory_execution/allowed_execution_duration_scaling" value="1.2"/> <!-- default 1.2 --> + <!-- Allow more than the expected execution time before triggering a trajectory cancel (applied after scaling) --> + <param name="trajectory_execution/allowed_goal_duration_margin" value="0.5"/> <!-- default 0.5 --> + <!-- Allowed joint-value tolerance for validation that trajectory's first point matches current robot state --> + <param name="trajectory_execution/allowed_start_tolerance" value="0.01"/> <!-- default 0.01 --> + + <!-- We use pass_all_args=true here to pass fake_execution_type, which is required by fake controllers, but not by real-robot controllers. + As real-robot controller_manager.launch files shouldn't be required to define this argument, we use the trick of passing all args. --> + <include file="$(dirname)/$(arg moveit_controller_manager)_moveit_controller_manager.launch.xml" pass_all_args="true" /> + +</launch> diff --git a/src/ceti_double/launch/warehouse.launch b/src/ceti_double/launch/warehouse.launch new file mode 100644 index 0000000000000000000000000000000000000000..0712e670f2a154054f0f6fc88eec24a6c9783d60 --- /dev/null +++ b/src/ceti_double/launch/warehouse.launch @@ -0,0 +1,15 @@ +<launch> + + <!-- The path to the database must be specified --> + <arg name="moveit_warehouse_database_path" /> + + <!-- Load warehouse parameters --> + <include file="$(dirname)/warehouse_settings.launch.xml" /> + + <!-- Run the DB server --> + <node name="$(anon mongo_wrapper_ros)" cwd="ROS_HOME" type="mongo_wrapper_ros.py" pkg="warehouse_ros_mongo"> + <param name="overwrite" value="false"/> + <param name="database_path" value="$(arg moveit_warehouse_database_path)" /> + </node> + +</launch> diff --git a/src/ceti_double/launch/warehouse_settings.launch.xml b/src/ceti_double/launch/warehouse_settings.launch.xml new file mode 100644 index 0000000000000000000000000000000000000000..e473b083bc51dba2b8701ed079f941d976b71b37 --- /dev/null +++ b/src/ceti_double/launch/warehouse_settings.launch.xml @@ -0,0 +1,16 @@ +<launch> + <!-- Set the parameters for the warehouse and run the mongodb server. --> + + <!-- The default DB port for moveit (not default MongoDB port to avoid potential conflicts) --> + <arg name="moveit_warehouse_port" default="33829" /> + + <!-- The default DB host for moveit --> + <arg name="moveit_warehouse_host" default="localhost" /> + + <!-- Set parameters for the warehouse --> + <param name="warehouse_port" value="$(arg moveit_warehouse_port)"/> + <param name="warehouse_host" value="$(arg moveit_warehouse_host)"/> + <param name="warehouse_exec" value="mongod" /> + <param name="warehouse_plugin" value="warehouse_ros_mongo::MongoDatabaseConnection" /> + +</launch> diff --git a/src/ceti_double/package.xml b/src/ceti_double/package.xml new file mode 100644 index 0000000000000000000000000000000000000000..9dfe30656ae3c41939d86ff0bd7d3ac1ca5537db --- /dev/null +++ b/src/ceti_double/package.xml @@ -0,0 +1,41 @@ +<package> + + <name>ceti_double</name> + <version>0.3.0</version> + <description> + An automatically generated package with all the configuration and launch files for using the panda with the MoveIt Motion Planning Framework + </description> + <author email="matteo.anedda@mailbox.tu-dresden.de">matteo anedda</author> + <maintainer email="matteo.anedda@mailbox.tu-dresden.de">matteo anedda</maintainer> + + <license>BSD</license> + + <url type="website">http://moveit.ros.org/</url> + <url type="bugtracker">https://github.com/ros-planning/moveit/issues</url> + <url type="repository">https://github.com/ros-planning/moveit</url> + + <buildtool_depend>catkin</buildtool_depend> + + <run_depend>moveit_ros_move_group</run_depend> + <run_depend>moveit_fake_controller_manager</run_depend> + <run_depend>moveit_kinematics</run_depend> + <run_depend>moveit_planners_ompl</run_depend> + <run_depend>moveit_ros_visualization</run_depend> + <run_depend>moveit_setup_assistant</run_depend> + <run_depend>moveit_simple_controller_manager</run_depend> + <run_depend>joint_state_publisher</run_depend> + <run_depend>joint_state_publisher_gui</run_depend> + <run_depend>robot_state_publisher</run_depend> + <run_depend>rviz</run_depend> + <run_depend>tf2_ros</run_depend> + <run_depend>xacro</run_depend> + <!-- The next 2 packages are required for the gazebo simulation. + We don't include them by default to prevent installing gazebo and all its dependencies. --> + <!-- <run_depend>joint_trajectory_controller</run_depend> --> + <!-- <run_depend>gazebo_ros_control</run_depend> --> + <!-- This package is referenced in the warehouse launch files, but does not build out of the box at the moment. Commented the dependency until this works. --> + <!-- <run_depend>warehouse_ros_mongo</run_depend> --> + <run_depend>franka_description</run_depend> + + +</package> diff --git a/src/franka_description/robots/ceti_double.urdf.xacro b/src/franka_description/robots/ceti_double.urdf.xacro new file mode 100644 index 0000000000000000000000000000000000000000..7a82590bd5e38830a449ec784b16eb35d8390c62 --- /dev/null +++ b/src/franka_description/robots/ceti_double.urdf.xacro @@ -0,0 +1,74 @@ +<?xml version="1.0" encoding="utf-8"?> +<robot xmlns:xacro="http://www.ros.org/wiki/xacro" name="panda"> + <xacro:arg name="arm_id_1" default="panda_1" /> + <xacro:arg name="arm_id_2" default="panda_2" /> + + + <xacro:include filename="panda_arm.xacro"/> + <xacro:include filename="hand.xacro"/> + + <link name="world" /> + + + <!-- Dummy Link --> + <joint name="base_joint1" type="fixed"> + <parent link="world" /> + <child link="base_1" /> + <origin xyz="0 0 0" rpy="0 0 0"/> + <axis xyz="0 0 1"/> + </joint> + + <joint name="base_joint2" type="fixed"> + <parent link="world" /> + <child link="base_2" /> + <origin xyz="0 0 0" rpy="0 0 0"/> + <axis xyz="0 0 1"/> + </joint> + + + <link name="base_1"> + <visual> + <origin xyz="-1 0 0.4425" rpy="0 0 0"/> + <geometry> + <box size="0.8 0.8 0.885" /> + </geometry> + <material name="White"> + <color rgba="1.0 1.0 1.0 1.0"/> + </material> + </visual> + <collision> + <origin xyz="-1 0 0.4425" rpy="0 0 0"/> + <geometry> + <box size="0.8 0.8 0.885" /> + </geometry> + </collision> + </link> + + <link name="base_2"> + <visual> + <origin xyz="1 0 0.4425" rpy="0 0 0"/> + <geometry> + <box size="0.8 0.8 0.885" /> + </geometry> + <material name="White"> + <color rgba="1.0 1.0 1.0 1.0"/> + </material> + </visual> + <collision> + <origin xyz="1 0 0.4425" rpy="0 0 0"/> + <geometry> + <box size="0.8 0.8 0.885" /> + </geometry> + </collision> + </link> + + + <!-- right arm with gripper --> + <xacro:panda_arm arm_id="$(arg arm_id_1)" connected_to="base_1" xyz="-1.22 0 0.885" /> + <xacro:hand ns="$(arg arm_id_1)" rpy="0 0 ${-pi/4}" connected_to="$(arg arm_id_1)_link8" /> + + <!-- left arm with gripper --> + <xacro:panda_arm arm_id="$(arg arm_id_2)" connected_to="base_2" xyz="0.78 0 0.885" /> + <xacro:hand ns="$(arg arm_id_2)" rpy="0 0 ${-pi/4}" connected_to="$(arg arm_id_2)_link8"/> + +</robot> diff --git a/src/franka_description/robots/dual_panda_example.urdf.xacro b/src/franka_description/robots/dual_panda_example.urdf.xacro index 49145e13ead28d1fa383e95d75ddb66ea85a25eb..45b4d14e42b6e5f6a5ec5b4afe0652414de1c5fd 100644 --- a/src/franka_description/robots/dual_panda_example.urdf.xacro +++ b/src/franka_description/robots/dual_panda_example.urdf.xacro @@ -17,9 +17,7 @@ <link name="world"/> - - <!-- right arm with gripper --> <xacro:panda_arm arm_id="$(arg arm_id_1)" connected_to="world" xyz="${pos_1}" /> <xacro:hand ns="$(arg arm_id_1)" rpy="0 0 ${-pi/4}" connected_to="$(arg arm_id_1)_link8" /> diff --git a/src/franka_description/robots/panda_arm_hand.urdf.xacro b/src/franka_description/robots/panda_arm_hand.urdf.xacro index 12af2d0de123548446f7ba476da3305789d7b07f..5c424c2c3d257e77585abaa5464325916388fd48 100644 --- a/src/franka_description/robots/panda_arm_hand.urdf.xacro +++ b/src/franka_description/robots/panda_arm_hand.urdf.xacro @@ -7,8 +7,23 @@ <xacro:include filename="panda.gazebo.xacro"/> <xacro:include filename="panda.transmission.xacro"/> - - <link name="world"/> + <link name="base"> + <visual> + <origin xyz="0 0 0.4425" rpy="0 0 0"/> + <geometry> + <box size="0.8 0.8 0.885" /> + </geometry> + <material name="White"> + <color rgba="1.0 1.0 1.0 1.0"/> + </material> + </visual> + <collision> + <origin xyz="0 0 0.4425" rpy="0 0 0"/> + <geometry> + <box size="0.8 0.8 0.885" /> + </geometry> + </collision> + </link> <xacro:arg name="GOAL" default='Base_task'/> @@ -17,7 +32,7 @@ <xacro:property name="pos_1" value="${props['Basispositionen']['panda_arm1']}" /> - <xacro:panda_arm arm_id="panda" connected_to="world" xyz="0 0 0"/> + <xacro:panda_arm arm_id="panda" connected_to="base" xyz="-0.22 0 0.885"/> <xacro:hand ns="panda" rpy="0 0 ${-pi/4}" connected_to="panda_link8"/> diff --git a/src/mtc/include/impl/abstract_robot.h b/src/mtc/include/impl/abstract_robot.h index 7ae7a3d2aaa0e33351de945e770561100cf45960..f91ad3e46b578272891ce48711238efb62386ad5 100644 --- a/src/mtc/include/impl/abstract_robot.h +++ b/src/mtc/include/impl/abstract_robot.h @@ -19,7 +19,6 @@ class Abstract_robot { private: std::string _name; tf2::Transform _tf; - std::vector<Abstract_wing> _observers; public: @@ -27,9 +26,7 @@ class Abstract_robot { inline std::string get_name() { return _name;} inline tf2::Transform get_tf() { return _tf;} - inline void notify() { for(Abstract_wing& wing : _observers) wing.update(_tf);} - inline std::vector<Abstract_wing> get_observers() { return _observers;} - + virtual void notify()= 0; }; diff --git a/src/mtc/include/impl/abstract_wing.h b/src/mtc/include/impl/abstract_wing.h index 8c3b263194566314cfd84602706ac3b465717be6..dcaf5c04771b803a87166972d8e87430adce950f 100644 --- a/src/mtc/include/impl/abstract_wing.h +++ b/src/mtc/include/impl/abstract_wing.h @@ -22,9 +22,9 @@ class Abstract_wing { Abstract_wing(tf2::Transform tf) { _relative_tf = tf;}; inline tf2::Transform get_tf() { return _relative_tf;} - virtual tf2::Transform get_world_tf(tf2::Transform& tf) = 0; - void set_world_tf(tf2::Transform& tf) { _world_tf = get_world_tf(tf);}; - virtual void update(tf2::Transform& tf)=0; + inline tf2::Transform get_world_tf(tf2::Transform& tf) { return tf * _relative_tf;} + void set_world_tf(tf2::Transform& tf) { _world_tf = get_world_tf(tf);} + virtual void update(tf2::Transform tf)=0; }; diff --git a/src/mtc/include/impl/robot.h b/src/mtc/include/impl/robot.h index 28f4dc50fd146ebf0246d11549a677da97ae8066..727702de8a8112f66c4d1c7ec4bb4fc3cb18dbf1 100644 --- a/src/mtc/include/impl/robot.h +++ b/src/mtc/include/impl/robot.h @@ -12,12 +12,15 @@ #include <pcl/octree/octree.h> #include "impl/abstract_robot.h" +#include "impl/abstract_wing.h" class Robot : public Abstract_robot{ + std::vector<Abstract_wing*> _observers; + public: Robot(std::string name, tf2::Transform tf) : Abstract_robot(name, tf){}; - - + void notify() override {for(Abstract_wing* wing : _observers) wing->update(this->get_tf());} + inline std::vector<Abstract_wing*> get_observers() { return _observers;} }; diff --git a/src/mtc/include/impl/wing.h b/src/mtc/include/impl/wing.h index d62738640c1ca873ce7c1f84a34c2d99248d75b9..ec275cc754913e6c0cc221221f2d29b4c0f91f89 100644 --- a/src/mtc/include/impl/wing.h +++ b/src/mtc/include/impl/wing.h @@ -17,8 +17,7 @@ class Wing : public Abstract_wing{ public: Wing(tf2::Transform tf) : Abstract_wing(tf) {}; - inline tf2::Transform get_world_tf(tf2::Transform& tf) { return tf * this->get_tf();} - inline void update(tf2::Transform& tf) override; + void update(tf2::Transform tf) override {this->set_world_tf(tf);}; }; diff --git a/src/mtc/src/base_routine.cpp b/src/mtc/src/base_routine.cpp index b0ab2e5666c2deefd60132bc324a92f02c2d951c..c0beb58fb53594761cb1faf2a82fcd58006d25ed 100644 --- a/src/mtc/src/base_routine.cpp +++ b/src/mtc/src/base_routine.cpp @@ -23,14 +23,15 @@ int main(int argc, char **argv){ Abstract_map_loader* map_loader = new Map_loader(map, task); Abstract_strategy* strategy = new Base_by_rotation(); - Abstract_robot* ceti = new Robot(std::string("Robot_arm1"), tf2::Transform(tf2::Quaternion(0,0,0,1), tf2::Vector3(0,0,0.4425f))); - Abstract_wing* right_wing = new Wing(tf2::Transform(tf2::Quaternion(0,0,0,1), tf2::Vector3(0,0.6525f,ceti->get_tf().getOrigin().getZ()))); - Abstract_wing* left_wing = new Wing(tf2::Transform(tf2::Quaternion(0,0,0,1), tf2::Vector3(0,-0.6525f,ceti->get_tf().getOrigin().getZ()))); - Abstract_wing* mid_wing = new Wing(tf2::Transform(tf2::Quaternion(0,0,0,1), tf2::Vector3(0.6525f,0,ceti->get_tf().getOrigin().getZ()))); + Abstract_robot* robo = new Robot(std::string("Robot_arm1"), tf2::Transform(tf2::Quaternion(0,0,0,1), tf2::Vector3(0,0,0.4425f))); + Abstract_wing* right_wing = new Wing(tf2::Transform(tf2::Quaternion(0,0,0,1), tf2::Vector3(0,0.6525f,robo->get_tf().getOrigin().getZ()))); + Abstract_wing* left_wing = new Wing(tf2::Transform(tf2::Quaternion(0,0,0,1), tf2::Vector3(0,-0.6525f,robo->get_tf().getOrigin().getZ()))); + Abstract_wing* mid_wing = new Wing(tf2::Transform(tf2::Quaternion(0,0,0,1), tf2::Vector3(0.6525f,0,robo->get_tf().getOrigin().getZ()))); - ceti->get_observers().push_back(*right_wing); - ceti->get_observers().push_back(*left_wing); - ceti->get_observers().push_back(*mid_wing); + Robot* ceti = (Robot*) robo; + ceti->get_observers().push_back(right_wing); + ceti->get_observers().push_back(left_wing); + ceti->get_observers().push_back(mid_wing); map_loader->set_strategy(strategy); @@ -40,7 +41,7 @@ int main(int argc, char **argv){ free(map_loader); free(strategy); - free(ceti); + free(robo); free(right_wing); free(left_wing); free(mid_wing); diff --git a/src/mtc/src/grasp_pipeline.cpp b/src/mtc/src/grasp_pipeline.cpp index 3cb15e6b9245477633841e47bb409934bd1bad6a..12f13b23f780b808c615495be66b66c7df430a4e 100644 --- a/src/mtc/src/grasp_pipeline.cpp +++ b/src/mtc/src/grasp_pipeline.cpp @@ -590,10 +590,10 @@ int main(int argc, char* argv[]) moveit_grasps::GraspPipeline tester; std::string object_name = "pick_target"; - - for (float x = 0 - dimension_x; x <= 0 + dimension_x; x+= resolution){ + + for (float x = 0 - dimension_x; x <= -0.22f + dimension_x; x+= resolution){ for(float y = 0 - dimension_y; y <= 0 + dimension_y; y+= resolution){ - for(float z = 0 - dimension_z; z <= 0 + dimension_z; z+= resolution){ + for(float z = 0 - dimension_z; z <= 0.885f + dimension_z; z+= resolution){ //tester.reachGrasp(x,y,z, object_name, x_depth, y_depth, z_depth); } tester.reachGrasp(x,y,dimension_z, object_name, x_depth, y_depth, z_depth); diff --git a/src/mtc/src/impl/map_loader.cpp b/src/mtc/src/impl/map_loader.cpp index cefbd202df04c7ef03a1ba53a84b7c060059fd1f..c963aa6f01e46606f219ae8180167f98e7624f8a 100644 --- a/src/mtc/src/impl/map_loader.cpp +++ b/src/mtc/src/impl/map_loader.cpp @@ -99,8 +99,6 @@ void Map_loader::base_calculation(){ for(int i = 0; i < base_target_map.size(); i++) for(int j = 0; j < base_target_map[i].size(); j++) for(int k = 0; k < base_target_map[i][j].size(); k++) ROS_INFO("%i ", base_target_map[i][j].size()); ROS_INFO("start cloud quantization..."); - - }