ycheng517 / ar4_ros_driver

ROS 2 driver for the AR4 robot arm
MIT License
45 stars 18 forks source link
gazebo moveit2 robotic-arm robotics ros2 ros2-control

AR4 ROS Driver

ROS 2 driver of the AR4 robot arm from Annin Robotics. Tested with ROS 2 Iron on Ubuntu 22.04.

Supports:

Features:

This is a refresh of ar3_core.

Video Demo:

Motion Planning using RViz and Moveit:

AR4 ROS 2 Driver Demo

Startup, Calibration, and Servo Gripper Demo

Overview

Installation

Firmware Flashing

The Teensy and Arduino Nano sketches provided in ar_microcontrollers are compatible with the default hardware. To flash it, follow the same procedure as specified in AR4 Robot Setup.

[Optional] Running in Docker Container

A docker container and run script has been provided that can be used to run the robot and any GUI programs. It requires an NVIDIA GPU, and the NVIDIA Container Toolkit to be installed. Then you can start the docker container with:

docker build -t ar4_ros_driver .
./run_in_docker.sh

Usage

There are two modules that you will always need to run:

  1. Arm module - this can be for either a real-world or simulated arm

    • For controlling the real-world arm, you will need to run the ar_hardware_interface module
    • For the simulated arm, you will need to run the ar_gazebo module
    • Either of the modules will load the necessary hardware descriptions for MoveIt
  2. MoveIt module - the ar_moveit_config module provides the MoveIt interface and RViz GUI.

The various use cases of the modules and instructions to run them are described below:


MoveIt Demo in RViz

If you are unfamiliar with MoveIt, it is recommended to start with this to explore planning with MoveIt in RViz. This contains neither a real-world nor a simulated arm but just a model loaded within RViz for visualisation.

The robot description, moveit interface and RViz will all be loaded in the single demo launch file

ros2 launch ar_moveit_config demo.launch.py

Control real-world arm with MoveIt in RViz

Start the ar_hardware_interface module, which will load configs and the robot description:

ros2 launch ar_hardware_interface ar_hardware.launch.py \
  calibrate:=True

Available Launch Arguments:

⚠️📏 Note: Calibration is required after flashing firmware to the Teensy board, and power cycling the robot and/or the Teensy board. It can be skipped in subsequent runs with calibrate:=False.

Start MoveIt and RViz:

ros2 launch ar_moveit_config ar_moveit.launch.py

Available Launch Arguments:

You can now plan in RViz and control the real-world arm. Joint commands and joint states will be updated through the hardware interface.


Control simulated arm in Gazebo with MoveIt in RViz

Start the ar_gazebo module, which will start the Gazebo simulator and load the robot description.

ros2 launch ar_gazebo ar_gazebo.launch.py

Start Moveit and RViz:

ros2 launch ar_moveit_config ar_moveit.launch.py use_sim_time:=true include_gripper:=True

You can now plan in RViz and control the simulated arm.


Hand-Eye Calibration

See ar4_hand_eye_calibration