프로젝트 웹사이트: https://mobile-aloha.github.io/
코드베이스는 ALOHA 리포지토리: ALOHA repo, 에서 분기되었으며, Mobile ALOHA 하드웨어를 사용한 원격 조작 및 데이터 수집을 위한 구현을 포함하고 있습니다.
TALOHA를 구축하려면 하드웨어 조립 튜토리얼: Hardware Assembly Tutorial 과 아래의 빠른 시작 가이드를 따르세요.
모방 학습 알고리즘을 훈련시키려면 ACT for Mobile ALOHA: ACT for Mobile ALOHA which is forked from ACT도 설치해야 합니다.
config
: 각 로봇의 구성 파일로, 바인딩해야 하는 포트를 지정합니다. 자세한 내용은 빠른 시작 가이드를 참조하세요.launch
: 4대의 카메라와 4대의 로봇을 위한 ROS 실행 파일입니다.aloha_scripts
: 원격 조작 및 데이터 수집을 위한 Python 코드입니다.
현재 테스트 및 작동하는 구성:
- ✅ Ubuntu 18.04 + ROS 1 noetic
- ✅ Ubuntu 20.04 + ROS 1 noetic
진행 중인 테스트(호환성 작업 진행 중):
- 🚧 ROS 2
- 🚧 >= Ubuntu 22.04
- https://docs.trossenrobotics.com/interbotix_xsarms_docs/에 따라 ROS 및 interbotix 소프트웨어를 설치합니다.
- 이렇게 하면
src
를 포함하는 디렉토리~/interbotix_ws
가 생성됩니다. - 이 저장소를
~/interbotix_ws/src
안에 git clone합니다. source /opt/ros/noetic/setup.sh && source ~/interbotix_ws/devel/setup.sh
sudo apt-get install ros-noetic-usb-cam && sudo apt-get install ros-noetic-cv-bridge
~/interbotix_ws
내에서catkin_make
를 실행하고 빌드가 성공적인지 확인합니다.~/interbotix_ws/src/interbotix_ros_toolboxes/interbotix_xs_toolbox/interbotix_xs_modules/src/interbotix_xs_modules/arm.py
로 이동하여 함수publish_positions
를 찾습니다.self.T_sb = mr.FKinSpace(self.robot_des.M, self.robot_des.Slist, self.joint_commands)
를self.T_sb = None
으로 변경하세요. 이렇게 하면 코드가 매 단계마다 FK를 계산하지 않아 원격 조작이 지연되는 것을 방지할 수 있습니다.
The goal of this section is to run roslaunch aloha 4arms_teleop.launch
, which starts
communication with 4 robots and 3 cameras. It should work after finishing the following steps:
Step 1: Connect 4 robots to the computer via USB, and power on. Do not use extension cable or usb hub.
-
To check if the robot is connected, install dynamixel wizard here
-
Dynamixel wizard is a very helpful debugging tool that connects to individual motors of the robot. It allows things such as rebooting the motor (very useful!), torque on/off, and sending commands. However, it has no knowledge about the kinematics of the robot, so be careful about collisions. The robot will collapse if motors are torque off i.e. there is no automatically engaged brakes in joints.
-
Open Dynamixel wizard, go into
options
and select:- Protocal 2.0
- All ports
- 1000000 bps
- ID range from 0-10
-
Note: repeat above everytime before you scan.
-
Then hit
Scan
. There should be 4 devices showing up, each with 9 motors. -
One issue that arises is the port each robot binds to can change over time, e.g. a robot that is initially
ttyUSB0
might suddenly becomettyUSB5
. To resolve this, we bind each robot to a fixed symlink port with the following mapping:ttyDXL_master_right
: right master robot (master: the robot that the operator would be holding)ttyDXL_puppet_right
: right puppet robot (puppet: the robot that performs the task)ttyDXL_master_left
: left master robotttyDXL_puppet_left
: left puppet robot
-
Take
ttyDXL_master_right
: right master robot as an example:-
Find the port that the right master robot is currently binding to, e.g.
ttyUSB0
-
run
udevadm info --name=/dev/ttyUSB0 --attribute-walk | grep serial
to obtain the serial number. Use the first one that shows up, the format should look similar toFT6S4DSP
. -
sudo vim /etc/udev/rules.d/99-fixed-interbotix-udev.rules
and add the following line:SUBSYSTEM=="tty", ATTRS{serial}=="<serial number here>", ENV{ID_MM_DEVICE_IGNORE}="1", ATTR{device/latency_timer}="1", SYMLINK+="ttyDXL_master_right"
-
This will make sure the right master robot is always binding to
ttyDXL_master_right
-
Repeat with the rest of 3 arms.
-
-
To apply the changes, run
sudo udevadm control --reload && sudo udevadm trigger
-
If successful, you should be able to find
ttyDXL*
in your/dev
Step 2: Set max current for gripper motors
- Open Dynamixel Wizard, and select the wrist motor for puppet arms. The name of it should be
[ID:009] XM430-W350
- Tip: the LED on the base of robot will flash when it is talking to Dynamixel Wizard. This will help determine which robot is selected.
- Find
38 Current Limit
, enter300
, then hitsave
at the bottom. - Repeat this for both puppet robots.
- This limits the max current through gripper motors, to prevent overloading errors.
Step 3: Setup 3 cameras
-
You may use usb hub here, but maximum 2 cameras per hub for reasonable latency.
-
To make sure all 3 cameras are binding to a consistent port, similar steps are needed.
-
Cameras are by default binding to
/dev/video{0, 1, 2...}
, while we want to have symlinks{CAM_RIGHT_WRIST, CAM_LEFT_WRIST, CAM_HIGH}
-
Take
CAM_RIGHT_WRIST
as an example, and let's say it is now binding to/dev/video0
. runudevadm info --name=/dev/video0 --attribute-walk | grep serial
to obtain it's serial. Use the first one that shows up, the format should look similar to0E1A2B2F
. -
Then
sudo vim /etc/udev/rules.d/99-fixed-interbotix-udev.rules
and add the following lineSUBSYSTEM=="video4linux", ATTRS{serial}=="<serial number here>", ATTR{index}=="0", ATTRS{idProduct}=="085c", ATTR{device/latency_timer}="1", SYMLINK+="CAM_RIGHT_WRIST"
-
Repeat this for
{CAM_LEFT_WRIST, CAM_HIGH}
in additional toCAM_RIGHT_WRIST
-
To apply the changes, run
sudo udevadm control --reload && sudo udevadm trigger
-
If successful, you should be able to find
{CAM_RIGHT_WRIST, CAM_LEFT_WRIST, CAM_HIGH}
in your/dev
Step 4: Setup the AgileX Tracer base
- Connect the base to the computer via the stock CANBUS-to-USB cable, and power on.
- Install SDK from AgileX
pip3 install pyagxrobots
- Enable gs_usb kernel module
sudo modprobe gs_usb
- Bring up the CAN device
sudo ip link set can0 up type can bitrate 500000
- If no error occured in the previous steps, you should be able to see the can device now by using command
ifconfig -a
- Install and use can-utils to test the hardware
sudo apt install can-utils
- Testing commands:
# receiving data from can0 candump can0
At this point, have a new terminal
conda deactivate # if conda shows up by default
source /opt/ros/noetic/setup.sh && source ~/interbotix_ws/devel/setup.sh
roslaunch aloha 4arms_teleop.launch
If no error message is showing up, the computer should be successfully connected to all 3 cameras, all 4 robot arms and the robot base.
- Make sure Dynamixel Wizard is disconnected, and no app is using webcam's stream. It will prevent ROS from connecting to these devices.
conda create -n aloha python=3.8.10
conda activate aloha
pip install torchvision
pip install torch
pip install pyquaternion
pip install pyyaml
pip install rospkg
pip install pexpect
pip install mujoco
pip install dm_control
pip install opencv-python
pip install matplotlib
pip install einops
pip install packaging
pip install h5py
pip install tqdm
pip install wandb
Notice: Before running the commands below, be sure to place all 4 robots in their sleep positions, and open master robot's gripper. All robots will rise to a height that is easy for teleoperation.
# ROS terminal
conda deactivate
source /opt/ros/noetic/setup.sh && source ~/interbotix_ws/devel/setup.sh
roslaunch aloha 4arms_teleop.launch
# Right hand terminal
conda activate aloha
cd ~/interbotix_ws/src/aloha/aloha_scripts
python3 one_side_teleop.py right
# Left hand terminal
conda activate aloha
cd ~/interbotix_ws/src/aloha/aloha_scripts
python3 one_side_teleop.py left
The teleoperation will start when the master side gripper is closed.
To set up a new terminal, run:
conda activate aloha
cd ~/interbotix_ws/src/aloha/aloha_scripts
The one_side_teleop.py
we ran is for testing teleoperation and has no data collection. To collect data for an episode, run:
python3 record_episodes.py --dataset_dir <data save dir> --episode_idx 0
This will store a hdf5 file at <data save dir>
.
To change episode length and other params, edit constants.py
directly.
To visualize the episode collected, run:
python3 visualize_episodes.py --dataset_dir <data save dir> --episode_idx 0
To replay the episode collected with real robot, run:
python3 replay_episodes.py --dataset_dir <data save dir> --episode_idx 0
To lower 4 robots before e.g. cutting off power, run:
python3 sleep.py