This repository contains a collection of Xacro macros for generating URDF files tailored to HEBI components and systems. These macros enable modular and reusable robot descriptions, including predefined macros for complete systems.
Before proceeding, it is recommended to familiarize yourself with the HRDF format, which you can find here.
Currently, HEBI <joint>
tags and the following optional attributes are not supported for actuator
, link
, bracket
, and end-effector
(except of Custom
type):
mass_offset
com_trans_offset
mass
com_rot
com_trans
ixx
,iyy
,izz
,ixy
,ixz
,iyz
A script is provided to convert HRDF files into URDF Xacro format at scripts/urdf_generator.py
Ensure the following Python libraries are installed:
hebi-py
numpy
scipy
lxml
Install dependencies via:
pip3 install --user hebi-py numpy scipy lxml
For more details on using Xacro macros, refer to the ROS Wiki.
python3 scripts/urdf_generator.py [-h] [--actuators ACTUATORS [ACTUATORS ...]] [--meshdir MESHDIR] [--outputdir OUTPUTDIR] [--ignore-base-link] filename
filename
: Path to an HRDF file or a HEBI Config file.ignore-base-link
: Flag to not include base link and joint connectingbase_link
with first element of the robot. Turned on for bases such as Daisy.- The script extracts actuator names directly from the config file and processes the HRDF file path.
To ensure compatibility with other packages of the HEBI ROS 2 APIs, save the URDF as <robot_name>.urdf.xacro
in the urdf/kits
folder.
After generation, visualize the URDF using RViz with the following command:
ros2 launch hebi_description view_arm.launch.py hebi_arm:=<your_robot_name>
NOTE: Remember to build your workspace and source your setup before running the above command.
A successful launch will display a RViz window showing the arm and a GUI to control the arm's joints, similar to this image:
This repository provides several xacro
macros for HEBI components that can be used to create robots for simulation or visualization.
Note: The mesh files in the Xacros are scaled by default to 0.001 in the the HEBI component xacro
macros.
Represents a HEBI actuator.
Required attributes:
name
: Unique identifier for referencing this actuator.child
: The element attached to the actuator's output (name of the HEBI component).type
: Actuator type (X5_1
,X5_4
,X5_9
,X8_3
,X8_9
, orX8_16
).
Note: Since the actuator is a joint, the name
is set for the <joint>
tag and the actuator link name is set as <name>/body
.
Optional attribute:
limits
: Position limits in radians. Format:${[<low>,<high>]}
. Example:${[-${pi}, ${pi}]}
for one full revolution centered at 0. If not defined, assumes a continuously rotatable revolute joint.
Required attributes:
name
: Unique identifier for referencing this link.child
: The element attached to the link's output.extension
: Link extension in meters, per documented convention on docs.hebi.us.twist
: Twist between input and output frames in radians, per documented convention on docs.hebi.us.
Required attributes:
name
: Unique identifier for referencing this bracket.type
: Bracket type (X5LightLeft
,X5LightRight
,X5HeavyLeftInside
,X5HeavyLeftOutside
,X5HeavyRightInside
, orX5HeavyRightOutside
).
Note: Brackets are always followed by <xacro:output>
tags for connecting to other components.
Required attributes:
name
: Unique identifier for referencing this output.parent
: The parent element of the URDF joint.child
: The child element of the URDF joint.
Optional attribute:
type
: Same as the bracket type if preceded by a bracket. If provided, the properties of the joint will be loaded accordingly.
Same properties as HRDF <rigid-body>
tag, with an additional property mesh_scale
to set the scaling factor of the mesh. Defaults to 0.001 0.001 0.001
.
Represents a HEBI gripper (currently only parallel jaws style).
Required attributes:
name
: Unique identifier for referencing this gripper.type
: Gripper type (currently onlyparallel
is supported).
Represents the end of a robot (allows the final joint in another actuator
, link
, or bracket
to be completed).
Required attribute:
name
: Unique identifier for referencing this end effector.