Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Provide detailed and coarse collision models #199

Merged
merged 20 commits into from
Apr 22, 2022
Merged
Show file tree
Hide file tree
Changes from 18 commits
Commits
Show all changes
20 commits
Select commit Hold shift + click to select a range
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .ci/Dockerfile.melodic
Original file line number Diff line number Diff line change
Expand Up @@ -12,4 +12,5 @@ RUN apt-get update -y && apt-get install -y \
ros-melodic-gazebo-dev \
ros-melodic-gazebo-ros-control \
ros-melodic-orocos-kdl \
ros-melodic-urdfdom-py \
&& rm -rf /var/lib/apt/lists/*
1 change: 1 addition & 0 deletions .ci/Dockerfile.noetic
Original file line number Diff line number Diff line change
Expand Up @@ -12,4 +12,5 @@ RUN apt-get update -y && apt-get install -y \
ros-noetic-eigen-conversions \
ros-noetic-gazebo-dev \
ros-noetic-gazebo-ros-control \
ros-noetic-urdfdom-py \
&& rm -rf /var/lib/apt/lists/*
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
*.pyc
2 changes: 2 additions & 0 deletions franka_description/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -10,3 +10,5 @@ install(DIRECTORY meshes
install(DIRECTORY robots
DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION}
)

catkin_add_nosetests(test/urdf.py)
1 change: 1 addition & 0 deletions franka_description/package.xml
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,5 @@
<buildtool_depend>catkin</buildtool_depend>

<exec_depend>xacro</exec_depend>
<test_depend>rosunit</test_depend>
</package>
1 change: 1 addition & 0 deletions franka_description/robots/hand.urdf.xacro
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<robot xmlns:xacro="http://www.ros.org/wiki/xacro" name="hand">
<xacro:include filename="utils.xacro" />
<xacro:include filename="hand.xacro"/>
<xacro:hand arm_id="panda" safety_distance="0.03"/>
</robot>
119 changes: 72 additions & 47 deletions franka_description/robots/hand.xacro
Original file line number Diff line number Diff line change
@@ -1,93 +1,118 @@
<?xml version="1.0" encoding="utf-8"?>
<robot xmlns:xacro="http://www.ros.org/wiki/xacro" name="hand">
<!-- safety_distance: Minimum safety distance in [m] by which the collision volumes are expanded and which is enforced during robot motions -->
<xacro:macro name="hand" params="connected_to:='' arm_id:='panda' rpy:='0 0 0' xyz:='0 0 0' safety_distance:=0">
<xacro:macro name="hand" params="connected_to:='' arm_id:='panda' rpy:='0 0 0' xyz:='0 0 0' safety_distance:=0 description_pkg:=franka_description">
<xacro:unless value="${connected_to == ''}">
<joint name="${arm_id}_hand_joint" type="fixed">
<parent link="${connected_to}"/>
<child link="${arm_id}_hand"/>
<origin xyz="${xyz}" rpy="${rpy}"/>
<parent link="${connected_to}" />
<child link="${arm_id}_hand" />
<origin xyz="${xyz}" rpy="${rpy}" />
</joint>
</xacro:unless>
<link name="${arm_id}_hand">

<xacro:link_with_sc name="hand">
<self_collision_geometries>
<xacro:collision_capsule xyz="0 0 0.04" direction="y" radius="${0.04+safety_distance}" length="0.1" />
<xacro:collision_capsule xyz="0 0 0.10" direction="y" radius="${0.02+safety_distance}" length="0.1" />
</self_collision_geometries>
</xacro:link_with_sc>

<!-- Define the hand_tcp frame -->
<link name="${arm_id}_hand_tcp" />
<joint name="${arm_id}_hand_tcp_joint" type="fixed">
<origin xyz="0 0 0.1034" rpy="0 0 0" />
<parent link="${arm_id}_hand" />
<child link="${arm_id}_hand_tcp" />
</joint>
<link name="${arm_id}_leftfinger">
<visual>
<geometry>
<mesh filename="package://franka_description/meshes/visual/hand.dae"/>
<mesh filename="package://${description_pkg}/meshes/visual/finger.dae" />
</geometry>
</visual>
<!-- screw mount -->
<collision>
<origin xyz="0 0 0.04" rpy="0 ${pi/2} ${pi/2}"/>
<origin xyz="0 18.5e-3 11e-3" rpy="0 0 0" />
<geometry>
<cylinder radius="${0.04+safety_distance}" length="0.1" />
<box size="22e-3 15e-3 20e-3" />
</geometry>
</collision>
<!-- cartriage sledge -->
<collision>
<origin xyz="0 -0.05 0.04" rpy="0 0 0"/>
<origin xyz="0 6.8e-3 2.2e-3" rpy="0 0 0" />
<geometry>
<sphere radius="${0.04+safety_distance}" />
<box size="22e-3 8.8e-3 3.8e-3" />
</geometry>
</collision>
<!-- diagonal finger -->
<collision>
<origin xyz="0 0.05 0.04" rpy="0 0 0"/>
<origin xyz="0 15.9e-3 28.35e-3" rpy="${pi/6} 0 0" />
<geometry>
<sphere radius="${0.04+safety_distance}" />
<box size="17.5e-3 7e-3 23.5e-3" />
</geometry>
</collision>
<!-- rubber tip with which to grasp -->
<collision>
<origin xyz="0 0 0.1" rpy="0 ${pi/2} ${pi/2}"/>
<origin xyz="0 7.58e-3 45.25e-3" rpy="0 0 0" />
<geometry>
<cylinder radius="${0.02+safety_distance}" length="0.1" />
<box size="17.5e-3 15.2e-3 18.5e-3" />
</geometry>
</collision>
<xacro:inertial_props name="leftfinger" />
</link>
<link name="${arm_id}_rightfinger">
<visual>
<origin xyz="0 0 0" rpy="0 0 ${pi}" />
<geometry>
<mesh filename="package://${description_pkg}/meshes/visual/finger.dae" />
</geometry>
</visual>
<!-- screw mount -->
<collision>
<origin xyz="0 -0.05 0.1" rpy="0 0 0"/>
<origin xyz="0 -18.5e-3 11e-3" rpy="0 0 0" />
<geometry>
<sphere radius="${0.02+safety_distance}" />
<box size="22e-3 15e-3 20e-3" />
</geometry>
</collision>
<!-- cartriage sledge -->
<collision>
<origin xyz="0 0.05 0.1" rpy="0 0 0"/>
<origin xyz="0 -6.8e-3 2.2e-3" rpy="0 0 0" />
<geometry>
<sphere radius="${0.02+safety_distance}" />
<box size="22e-3 8.8e-3 3.8e-3" />
</geometry>
</collision>
</link>
<!-- Define the hand_tcp frame -->
<link name="${arm_id}_hand_tcp" />
<joint name="${arm_id}_hand_tcp_joint" type="fixed">
<origin xyz="0 0 0.1034" rpy="0 0 0" />
<parent link="${arm_id}_hand" />
<child link="${arm_id}_hand_tcp" />
</joint>
<link name="${arm_id}_leftfinger">
<visual>
<!-- diagonal finger -->
<collision>
<origin xyz="0 -15.9e-3 28.35e-3" rpy="${-pi/6} 0 0" />
<geometry>
<mesh filename="package://franka_description/meshes/visual/finger.dae"/>
<box size="17.5e-3 7e-3 23.5e-3" />
</geometry>
</visual>
</link>
<link name="${arm_id}_rightfinger">
<visual>
<origin xyz="0 0 0" rpy="0 0 ${pi}"/>
</collision>
<!-- rubber tip with which to grasp -->
<collision>
<origin xyz="0 -7.58e-3 45.25e-3" rpy="0 0 0" />
<geometry>
<mesh filename="package://franka_description/meshes/visual/finger.dae"/>
<box size="17.5e-3 15.2e-3 18.5e-3" />
</geometry>
</visual>
</link>
</collision>
<xacro:inertial_props name="rightfinger" />
</link>
<joint name="${arm_id}_finger_joint1" type="prismatic">
<parent link="${arm_id}_hand"/>
<child link="${arm_id}_leftfinger"/>
<origin xyz="0 0 0.0584" rpy="0 0 0"/>
<axis xyz="0 1 0"/>
<limit effort="100" lower="0.0" upper="0.04" velocity="0.2"/>
<parent link="${arm_id}_hand" />
<child link="${arm_id}_leftfinger" />
<origin xyz="0 0 0.0584" rpy="0 0 0" />
<axis xyz="0 1 0" />
<limit effort="100" lower="0.0" upper="0.04" velocity="0.2" />
<dynamics damping="0.3" />
</joint>
<joint name="${arm_id}_finger_joint2" type="prismatic">
<parent link="${arm_id}_hand"/>
<child link="${arm_id}_rightfinger"/>
<origin xyz="0 0 0.0584" rpy="0 0 0"/>
<axis xyz="0 -1 0"/>
<limit effort="100" lower="0.0" upper="0.04" velocity="0.2"/>
<parent link="${arm_id}_hand" />
<child link="${arm_id}_rightfinger" />
<origin xyz="0 0 0.0584" rpy="0 0 0" />
<axis xyz="0 -1 0" />
<limit effort="100" lower="0.0" upper="0.04" velocity="0.2" />
<mimic joint="${arm_id}_finger_joint1" />
<dynamics damping="0.3" />
</joint>
</xacro:macro>
</robot>
137 changes: 137 additions & 0 deletions franka_description/robots/inertial.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,137 @@
# This file does not contain official inertial properties
rhaschke marked this conversation as resolved.
Show resolved Hide resolved
# of panda robot. The values are from the identification
# results published in: Identification of the Franka Emika
# PandaRobot With Retrieval of Feasible Parameters Using
# Penalty-Based Optimization
# by: Claudio Gaz, Marco Cognetti, Alexander Oliva,
# Paolo Robuffo Giordano, Alessandro de Luca
link0:
origin:
xyz: -0.041018 -0.00014 0.049974
rpy: 0 0 0
mass: 0.629769
inertia:
xx: 0.00315
yy: 0.00388
zz: 0.004285
xy: 8.2904E-07
xz: 0.00015
yz: 8.2299E-06

link1:
origin:
xyz: 0.003875 0.002081 -0.04762
rpy: 0 0 0
mass: 4.970684
inertia:
xx: 0.70337
yy: 0.70661
zz: 0.0091170
xy: -0.00013900
xz: 0.0067720
yz: 0.019169

link2:
origin:
xyz: -0.003141 -0.02872 0.003495
rpy: 0 0 0
mass: 0.646926
inertia:
xx: 0.0079620
yy: 2.8110e-02
zz: 2.5995e-02
xy: -3.9250e-3
xz: 1.0254e-02
yz: 7.0400e-04

link3:
origin:
xyz: 2.7518e-02 3.9252e-02 -6.6502e-02
rpy: 0 0 0
mass: 3.228604
inertia:
xx: 3.7242e-02
yy: 3.6155e-02
zz: 1.0830e-02
xy: -4.7610e-03
xz: -1.1396e-02
yz: -1.2805e-02

link4:
origin:
xyz: -5.317e-02 1.04419e-01 2.7454e-02
rpy: 0 0 0
mass: 3.587895
inertia:
xx: 2.5853e-02
yy: 1.9552e-02
zz: 2.8323e-02
xy: 7.7960e-03
xz: -1.3320e-03
yz: 8.6410e-03

link5:
origin:
xyz: -1.1953e-02 4.1065e-02 -3.8437e-02
rpy: 0 0 0
mass: 1.225946
inertia:
xx: 3.5549e-02
yy: 2.9474e-02
zz: 8.6270e-03
xy: -2.1170e-03
xz: -4.0370e-03
yz: 2.2900e-04

link6:
origin:
xyz: 6.0149e-02 -1.4117e-02 -1.0517e-02
rpy: 0 0 0
mass: 1.666555
inertia:
xx: 1.9640e-03
yy: 4.3540e-03
zz: 5.4330e-03
xy: 1.0900e-04
xz: -1.1580e-03
yz: 3.4100e-04

link7:
origin:
xyz: 1.0517e-02 -4.252e-03 6.1597e-02
rpy: 0 0 0
mass: 7.35522e-01
inertia:
xx: 1.2516e-02
yy: 1.0027e-02
zz: 4.8150e-03
xy: -4.2800e-04
xz: -1.1960e-03
yz: -7.4100e-04

hand:
origin:
xyz: -0.01 0 0.03
rpy: 0 0 0
mass: 0.73
inertia:
xx: 0.001
yy: 0.0025
zz: 0.0017
xy: 0
xz: 0
yz: 0

leftfinger: &finger
origin:
xyz: 0 0 0
rpy: 0 0 0
mass: 0.015
inertia:
xx: 2.3749999999999997e-06
yy: 2.3749999999999997e-06
zz: 7.5e-07
xy: 0
xz: 0
yz: 0
rightfinger: *finger
41 changes: 20 additions & 21 deletions franka_description/robots/panda_arm.urdf.xacro
Original file line number Diff line number Diff line change
Expand Up @@ -8,34 +8,25 @@
<!-- Is the robot being simulated in gazebo?" -->
<xacro:arg name="gazebo" default="false" />

<xacro:unless value="$(arg gazebo)">
<!-- Create a URDF for a real hardware -->
<xacro:include filename="$(find franka_description)/robots/panda_arm.xacro" />
<xacro:panda_arm arm_id="$(arg arm_id)" safety_distance="0.03"/>
<!-- Load interial properties. Property is implicitly passed to macros. -->
<xacro:property name="inertial" value="${xacro.load_yaml('inertial.yaml')}" />

<xacro:if value="$(arg hand)">
<xacro:include filename="$(find franka_description)/robots/hand.xacro"/>
<xacro:hand arm_id="$(arg arm_id)" rpy="0 0 ${-pi/4}" connected_to="$(arg arm_id)_link8" safety_distance="0.03"/>
</xacro:if>
</xacro:unless>
<xacro:include filename="utils.xacro" />
<xacro:include filename="panda_arm.xacro" />

<xacro:panda_arm arm_id="$(arg arm_id)" safety_distance="0.03"/>

<xacro:if value="$(arg hand)">
<xacro:include filename="hand.xacro"/>
<xacro:hand arm_id="$(arg arm_id)" rpy="0 0 ${-pi/4}" connected_to="$(arg arm_id)_link8" safety_distance="0.03"/>
</xacro:if>

<!-- Define additional Gazebo tags -->
<xacro:if value="$(arg gazebo)">

<xacro:arg name="xyz" default="0 0 0" />
<xacro:arg name="rpy" default="0 0 0" />

<!-- Create a simulatable URDF -->
<xacro:include filename="$(find franka_description)/robots/utils.xacro" />
<xacro:include filename="$(find franka_description)/robots/panda_gazebo.xacro" />

<xacro:panda_arm arm_id="$(arg arm_id)" />

<xacro:if value="$(arg hand)">
<xacro:hand arm_id="$(arg arm_id)" rpy="0 0 ${-pi/4}" connected_to="$(arg arm_id)_link8" />
<xacro:gazebo-joint joint="$(arg arm_id)_finger_joint1" transmission="hardware_interface/EffortJointInterface" />
<xacro:gazebo-joint joint="$(arg arm_id)_finger_joint2" transmission="hardware_interface/EffortJointInterface" />
</xacro:if>

<!-- Gazebo requires a joint to a link called "world" for statically mounted robots -->
<link name="world" />
<joint name="world_joint" type="fixed">
Expand Down Expand Up @@ -74,6 +65,14 @@
tip="$(arg arm_id)_joint8"
/>

<xacro:if value="$(arg hand)">
<xacro:gazebo-joint joint="$(arg arm_id)_finger_joint1" transmission="hardware_interface/EffortJointInterface" />
<xacro:gazebo-joint joint="$(arg arm_id)_finger_joint2" transmission="hardware_interface/EffortJointInterface" />
<!-- Friction specific material for Rubber/Rubber contact -->
<xacro:gazebo-friction link="$(arg arm_id)_leftfinger" mu="1.13" />
<xacro:gazebo-friction link="$(arg arm_id)_rightfinger" mu="1.13" />
</xacro:if>

<gazebo>
<plugin name="gazebo_ros_control" filename="libgazebo_ros_control.so">
<controlPeriod>0.001</controlPeriod>
Expand Down
Loading