document and code for Handy arm include tutorials, mechanical files and ROS-related packages.
Doc includes tutorials about how to build your own robot arm. Contents contain the whole process starting from how to do assembly in Solidworks in order to make urdf generation easier to use MoveIt! setup assistant to build your own robot arm MoveIt! package.
Mechanical includes 3DParts and Assembly two folders. 3DParts folder maintains all the files including Solidworks file, 3Dprinting file and drawing that belong to individual piece. Assembly holds models for the whole arm and each link.
ros folder keeps all ROS-related packages to the handy arm, which includes description, control, gazebo and MoveIt! package. There are two versions of Handy, one is the normal model which the other one is mesh-simplified model. Each has the four above packages.
-
If you'd like to use finalarm_gazebo package, you should git clone balabala packages to your workspace since gazebo has dependencies on these packages if you want to load controllers in gazebo.
-
If you just need finalarm_control, finalarm_description and finalarm_moveit_config packages, in order to compile all packages out, you additionally need a package named dynamixel_motor which applies designed controllers for dynamixel motors.
Ensure that the current user is part of the dialout
group.
If you get permission issues connecting to /dev/ttyUSB0
, run the following and logout+login.
sudo usermod -aG dialout $USER
Launch handy with the following commands:
# start a node responsible for managing loaded controllers
roslaunch finalarm_control controller_manager.launch
# load configuration for individual controller
roslaunch finalarm_control start_controller.launch
# publish integrated information of controllers and transformations between links
roslaunch finalarm_description robot_state_pub.launch
# node for motion planning, collision checking, etc. jobs
roslaunch finalarm_moveit_config move_group.launch
# rviz for visualization
roslaunch finalarm_moveit_config moveit_rviz.launch
# launch the file you write for Handy to do something like picking object
roslaunch handy_experiment pick.launch
You can run the above using docker-compose
instead:
docker-compose up
# node for motion planning, collision checking, etc. jobs
roslaunch finalarm_moveit_config move_group.launch
# rviz for visualization
roslaunch finalarm_moveit_config moveit_rviz.launch
Read docs/docker.md for more details.
Here's a list of launch files that can be tested without access to the physical robot.
# check for urdf loading
roslaunch finalarm_description display.launch
# check robot position topics
roslaunch finalarm_description gazebo.launch
roslaunch finalarm_gazebo robot_world.launch
roslaunch finalarm_gazebo robot_world.launch control_mode:=position
# check operation of robot
roslaunch finalarm_moveit_config demo.launch
# check gazebo and moveit operate together
roslaunch finalarm_gazebo robot_world_moveit.launch
roslaunch finalarm_simplified_description display.launch
roslaunch finalarm_simplified_description gazebo.launch
roslaunch finalarm_simplified_gazebo robot_world.launch
roslaunch finalarm_simplified_gazebo robot_world_urdf.launch
roslaunch finalarm_simplified_gazebo robot_world_xacro.launch
roslaunch finalarm_simplified_moveit_config demo.launch
roslaunch finalarm_simplified_gazebo robot_world_moveit.launch
These are useful for manual testing, at least until some form of automated testing is implemented.