-
Notifications
You must be signed in to change notification settings - Fork 85
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #132 from elephantrobotics/280_gazebo_melodic
add 280 m5 gazebo for melodic
- Loading branch information
Showing
40 changed files
with
2,493 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
cmake_minimum_required(VERSION 3.1.3) | ||
project(mycobot_280_gazebo_moveit) | ||
|
||
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}) |
5 changes: 5 additions & 0 deletions
5
mycobot_280/mycobot_280_gazebo_moveit/config/cartesian_limits.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
cartesian_limits: | ||
max_trans_vel: 1 | ||
max_trans_acc: 2.25 | ||
max_trans_dec: -5 | ||
max_rot_vel: 1.57 |
18 changes: 18 additions & 0 deletions
18
mycobot_280/mycobot_280_gazebo_moveit/config/chomp_planning.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -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.01 | ||
use_pseudo_inverse: false | ||
pseudo_inverse_ridge_factor: 1e-4 | ||
joint_update_limit: 0.1 | ||
collision_clearence: 0.2 | ||
collision_threshold: 0.07 | ||
use_stochastic_descent: true | ||
enable_failure_recovery: true | ||
max_recovery_attempts: 5 |
13 changes: 13 additions & 0 deletions
13
mycobot_280/mycobot_280_gazebo_moveit/config/fake_controllers.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
controller_list: | ||
- name: fake_mycobot_280_gazebo_controller | ||
type: $(arg fake_execution_type) | ||
joints: | ||
- joint2_to_joint1 | ||
- joint3_to_joint2 | ||
- joint4_to_joint3 | ||
- joint5_to_joint4 | ||
- joint6_to_joint5 | ||
- joint6output_to_joint6 | ||
initial: # Define initial robot poses. | ||
- group: mycobot_280_gazebo | ||
pose: HOME |
49 changes: 49 additions & 0 deletions
49
mycobot_280/mycobot_280_gazebo_moveit/config/firefighter.srdf
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
<?xml version="1.0" ?> | ||
<!--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="firefighter"> | ||
<!--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="mycobot_280_gazebo"> | ||
<chain base_link="g_base" tip_link="joint6_flange" /> | ||
</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="HOME" group="mycobot_280_gazebo"> | ||
<joint name="joint2_to_joint1" value="0" /> | ||
<joint name="joint3_to_joint2" value="0" /> | ||
<joint name="joint4_to_joint3" value="0" /> | ||
<joint name="joint5_to_joint4" value="0" /> | ||
<joint name="joint6_to_joint5" value="0" /> | ||
<joint name="joint6output_to_joint6" value="0" /> | ||
</group_state> | ||
<group_state name="FORWARD" group="mycobot_280_gazebo"> | ||
<joint name="joint2_to_joint1" value="0" /> | ||
<joint name="joint3_to_joint2" value="1.5706" /> | ||
<joint name="joint4_to_joint3" value="0" /> | ||
<joint name="joint5_to_joint4" value="0" /> | ||
<joint name="joint6_to_joint5" value="0" /> | ||
<joint name="joint6output_to_joint6" value="0" /> | ||
</group_state> | ||
<!--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_base_joint" type="fixed" parent_frame="very_base" child_link="g_base" /> | ||
<!--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="g_base" link2="joint1" reason="Adjacent" /> | ||
<disable_collisions link1="g_base" link2="joint2" reason="Never" /> | ||
<disable_collisions link1="g_base" link2="joint3" reason="Never" /> | ||
<disable_collisions link1="g_base" link2="joint4" reason="Never" /> | ||
<disable_collisions link1="g_base" link2="joint5" reason="Never" /> | ||
<disable_collisions link1="g_base" link2="joint6" reason="Never" /> | ||
<disable_collisions link1="g_base" link2="joint6_flange" reason="Never" /> | ||
<disable_collisions link1="joint1" link2="joint2" reason="Adjacent" /> | ||
<disable_collisions link1="joint2" link2="joint3" reason="Adjacent" /> | ||
<disable_collisions link1="joint3" link2="joint4" reason="Adjacent" /> | ||
<disable_collisions link1="joint4" link2="joint5" reason="Adjacent" /> | ||
<disable_collisions link1="joint5" link2="joint6" reason="Adjacent" /> | ||
<disable_collisions link1="joint5" link2="joint6_flange" reason="Never" /> | ||
<disable_collisions link1="joint6" link2="joint6_flange" reason="Adjacent" /> | ||
</robot> |
34 changes: 34 additions & 0 deletions
34
mycobot_280/mycobot_280_gazebo_moveit/config/joint_limits.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
# joint_limits.yaml allows the dynamics properties specified in the URDF to be overwritten or augmented as needed | ||
# 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: | ||
joint2_to_joint1: | ||
has_velocity_limits: false | ||
max_velocity: 0 | ||
has_acceleration_limits: false | ||
max_acceleration: 0 | ||
joint3_to_joint2: | ||
has_velocity_limits: false | ||
max_velocity: 0 | ||
has_acceleration_limits: false | ||
max_acceleration: 0 | ||
joint4_to_joint3: | ||
has_velocity_limits: false | ||
max_velocity: 0 | ||
has_acceleration_limits: false | ||
max_acceleration: 0 | ||
joint5_to_joint4: | ||
has_velocity_limits: false | ||
max_velocity: 0 | ||
has_acceleration_limits: false | ||
max_acceleration: 0 | ||
joint6_to_joint5: | ||
has_velocity_limits: false | ||
max_velocity: 0 | ||
has_acceleration_limits: false | ||
max_acceleration: 0 | ||
joint6output_to_joint6: | ||
has_velocity_limits: false | ||
max_velocity: 0 | ||
has_acceleration_limits: false | ||
max_acceleration: 0 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
mycobot_280_gazebo: | ||
kinematics_solver: kdl_kinematics_plugin/KDLKinematicsPlugin | ||
kinematics_solver_search_resolution: 0.005 | ||
kinematics_solver_timeout: 0.005 |
147 changes: 147 additions & 0 deletions
147
mycobot_280/mycobot_280_gazebo_moveit/config/ompl_planning.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,147 @@ | ||
planner_configs: | ||
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 | ||
mycobot_280_gazebo: | ||
planner_configs: | ||
- SBL | ||
- EST | ||
- LBKPIECE | ||
- BKPIECE | ||
- KPIECE | ||
- RRT | ||
- RRTConnect | ||
- RRTstar | ||
- TRRT | ||
- PRM | ||
- PRMstar | ||
- FMT | ||
- BFMT | ||
- PDST | ||
- STRIDE | ||
- BiTRRT | ||
- LBTRRT | ||
- BiEST | ||
- ProjEST | ||
- LazyPRM | ||
- LazyPRMstar | ||
- SPARS | ||
- SPARStwo |
55 changes: 55 additions & 0 deletions
55
mycobot_280/mycobot_280_gazebo_moveit/config/ros_controllers.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
# Simulation settings for using moveit_sim_controllers | ||
moveit_sim_hw_interface: | ||
joint_model_group: mycobot_280_gazebo | ||
joint_model_group_pose: HOME | ||
|
||
generic_hw_control_loop: | ||
loop_hz: 300 | ||
cycle_time_error_threshold: 0.01 | ||
# Settings for ros_control hardware interface | ||
hardware_interface: | ||
joints: | ||
- joint2_to_joint1 | ||
- joint3_to_joint2 | ||
- joint4_to_joint3 | ||
- joint5_to_joint4 | ||
- joint6_to_joint5 | ||
- joint6output_to_joint6 | ||
sim_control_mode: 0 # 0: position, 1: velocity | ||
# Publish all joint states | ||
# Creates the /joint_states topic necessary in ROS | ||
joint_state_controller: | ||
type: joint_state_controller/JointStateController | ||
publish_rate: 50 | ||
|
||
# PID controller settings for each joint | ||
gazebo_ros_control/pid_gains: | ||
joint2_to_joint1: {p: 100.0, i: 0.01, d: 10.0} | ||
joint3_to_joint2: {p: 100.0, i: 0.01, d: 10.0} | ||
joint4_to_joint3: {p: 100.0, i: 0.01, d: 10.0} | ||
joint5_to_joint4: {p: 100.0, i: 0.01, d: 10.0} | ||
joint6_to_joint5: {p: 100.0, i: 0.01, d: 10.0} | ||
joint6output_to_joint6: {p: 100.0, i: 0.01, d: 10.0} | ||
|
||
mycobot_position_controller: | ||
type: position_controllers/JointTrajectoryController | ||
joints: | ||
- joint2_to_joint1 | ||
- joint3_to_joint2 | ||
- joint4_to_joint3 | ||
- joint5_to_joint4 | ||
- joint6_to_joint5 | ||
- joint6output_to_joint6 | ||
|
||
controller_list: | ||
- name: mycobot_position_controller | ||
action_ns: follow_joint_trajectory | ||
type: FollowJointTrajectory | ||
default: true | ||
joints: | ||
- joint2_to_joint1 | ||
- joint3_to_joint2 | ||
- joint4_to_joint3 | ||
- joint5_to_joint4 | ||
- joint6_to_joint5 | ||
- joint6output_to_joint6 |
23 changes: 23 additions & 0 deletions
23
mycobot_280/mycobot_280_gazebo_moveit/config/sensors_3d.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
# The name of this file shouldn't be changed, or else the Setup Assistant won't detect it | ||
sensors: | ||
- filtered_cloud_topic: filtered_cloud | ||
max_range: 5.0 | ||
max_update_rate: 1.0 | ||
padding_offset: 0.1 | ||
padding_scale: 1.0 | ||
point_cloud_topic: /head_mount_kinect/depth_registered/points | ||
point_subsample: 1 | ||
sensor_plugin: occupancy_map_monitor/PointCloudOctomapUpdater | ||
- far_clipping_plane_distance: 5.0 | ||
filtered_cloud_topic: filtered_cloud | ||
image_topic: /head_mount_kinect/depth_registered/image_raw | ||
max_range: 5.0 | ||
max_update_rate: 1.0 | ||
near_clipping_plane_distance: 0.3 | ||
padding_offset: 0.03 | ||
padding_scale: 4.0 | ||
point_cloud_topic: /head_mount_kinect/depth_registered/points | ||
point_subsample: 1 | ||
queue_size: 5 | ||
sensor_plugin: occupancy_map_monitor/DepthImageOctomapUpdater | ||
shadow_threshold: 0.2 |
Oops, something went wrong.