Настройка программного обеспечения

Установка SDK, настройка драйвера CAN, настройка контроллера ROS2, интеграция LeRobot для O6, примеры API Python и основные проблемы, связанные с устранением неполадок. От новой установки Ubuntu до движущейся руки.

Перейти в раздел:

Шаг 1 — Установка SDK

Установка SDK

LinkerBot O6 SDK обеспечивает привязку Python к интерфейсу CAN-шины руки. Он входит в пакет платформы RoboticsCenter.

Создайте виртуальную среду (рекомендуется)

python3 -m venv ~/.venvs/linkerbot-o6
source ~/.venvs/linkerbot-o6/bin/activate

Установите SDK

pip install roboticscenter

Проверьте установку

python3 -c "from linkerbot import LinkerBotO6; print('SDK ready')"

Установить из исходного кода (необязательно)

git clone https://github.com/linkerbot/linkerbot_sdk.git
cd linkerbot_sdk
pip install -e .
Шаг 2 — Настройка драйвера CAN

Настройка драйвера CAN

LinkerBot O6 использует ту же архитектуру SocketCAN, что и OpenArm 101. Если вы настроили CAN для OpenArm, этот процесс идентичен. Драйверы CAN-шины встроены в ядро ​​Linux.

Загрузка модулей ядра

sudo modprobe can
sudo modprobe can_raw
sudo modprobe slcan   # for USB CAN adapters (CANable)

Поднимите CAN-интерфейс

# Find the USB serial device
ls /dev/ttyACM*

# Bring up CAN interface at 1 Mbps
sudo slcand -o -c -s8 /dev/ttyACM0 can0
sudo ip link set up can0

Убедитесь, что интерфейс работает

ip link show can0
# Expected: can0: <NOARP,UP,LOWER_UP> mtu 16 ...

Проверка связи CAN

sudo apt install can-utils -y
candump can0
# Power on the O6 and look for motor heartbeat packets

Сделать постоянным при перезагрузках

Создайте службу systemd или добавьте в /etc/rc.local. См. Руководство по настройке SocketCAN — процедура идентична для O6.

Шаг 3 — Контроллеры ROS2

Настройка контроллера ROS2

The linkerbot_ros2 Пакет предоставляет полный аппаратный интерфейс ros2_control для O6. Он включает в себя ложный аппаратный режим для тестирования без руки.

Установите ROS2 Humble

sudo apt update && sudo apt install software-properties-common curl -y
sudo curl -sSL https://raw.githubusercontent.com/ros/rosdistro/master/ros.asc | \
  sudo apt-key add -
sudo sh -c 'echo "deb http://packages.ros.org/ros2/ubuntu jammy main" \
  > /etc/apt/sources.list.d/ros2.list'
sudo apt update
sudo apt install ros-humble-desktop ros-humble-ros2-control \
  ros-humble-ros2-controllers ros-humble-joint-state-publisher-gui -y

Клонировать и собрать linkerbot_ros2

mkdir -p ~/o6_ws/src && cd ~/o6_ws/src
git clone https://github.com/linkerbot/linkerbot_ros2.git
cd ~/o6_ws
source /opt/ros/humble/setup.bash
colcon build --symlink-install

Запуск в ложном аппаратном режиме (рука не требуется)

source ~/o6_ws/install/setup.bash
ros2 launch linkerbot_ros2 o6.launch.py use_fake_hardware:=true

Запуск на реальном оборудовании

ros2 launch linkerbot_ros2 o6.launch.py \
  use_fake_hardware:=false \
  can_interface:=can0

Проверка совместных состояний

ros2 topic echo /joint_states
Шаг 4 — ЛеРобот для O6

Интеграция LeRobot для O6

LeRobot изначально поддерживает LinkerBot O6. Настройте тип своего робота и следуйте стандартному рабочему процессу LeRobot для записи и обучения.

Установить ЛеРобот

pip install lerobot

Настройте своего робота O6

# ~/.lerobot/robots/linkerbot_o6.yaml
robot_type: linkerbot_o6
can_interface: can0
num_joints: 6
camera_names:
  - wrist_cam
  - overhead_cam

Запись набора данных

python -m lerobot.scripts.control_robot \
  --robot.type=linkerbot_o6 \
  --control.type=record \
  --control.fps=30 \
  --control.repo_id=your-username/o6-pick-place \
  --control.num_episodes=50 \
  --control.single_task="Pick up the red cube"

Загрузить в HuggingFace Hub

huggingface-cli login
python -m lerobot.scripts.push_dataset_to_hub \
  --repo_id=your-username/o6-pick-place

См. Страница сбора данных для полного рабочего процесса, включая проверки качества.

Шаг 5 — API Python

Примеры API Python

LinkerBot Python SDK обеспечивает прямое совместное управление без необходимости использования ROS2. Тот же шаблон, что и в OpenArm SDK.

Базовый совместный контроль

from linkerbot import LinkerBotO6

# Connect to the arm
arm = LinkerBotO6(can_interface="can0")
arm.connect()
arm.enable_all()

# Move joint 1 to 45 degrees (0.785 rad)
arm.set_position(joint_id=1, position=0.785, kp=50, kd=1)

# Read current state
state = arm.get_state()
print(f"Positions (rad): {state.positions}")
print(f"Velocities (rad/s): {state.velocities}")
print(f"Torques (Nm): {state.torques}")

# Safe shutdown
arm.disable_all()
arm.disconnect()

Считайте все соединения в контуре управления

import time
from linkerbot import LinkerBotO6

arm = LinkerBotO6(can_interface="can0", control_rate_hz=500)
arm.connect()
arm.enable_all()

for _ in range(500):  # 1 second at 500 Hz
    state = arm.get_state()
    print(state.positions)
    time.sleep(1 / 500)

arm.disable_all()
arm.disconnect()

Выполнение траектории

from linkerbot import LinkerBotO6, JointTrajectory
import numpy as np

arm = LinkerBotO6(can_interface="can0")
arm.connect()
arm.enable_all()

# Define a waypoint trajectory
waypoints = [
    [0.0, 0.0, 0.0, 0.0, 0.0, 0.0],
    [0.5, -0.3, 0.8, 0.0, 0.4, 0.0],
    [0.0, 0.0, 0.0, 0.0, 0.0, 0.0],
]
durations = [2.0, 2.0, 2.0]  # seconds per segment

traj = JointTrajectory(waypoints=waypoints, durations=durations)
arm.execute_trajectory(traj)

arm.disable_all()
arm.disconnect()
Поиск неисправностей

Топ-3 распространенных проблемы

Ошибка 1 CAN-интерфейс не найден: no such device can0

Интерфейс SocketCAN не работает. Почти всегда из-за того, что USB CAN адаптер не подключен или не загружены модули ядра.

Исправить:

# 1. Verify USB adapter is detected
lsusb | grep -i "can\|serial"

# 2. Load the kernel modules
sudo modprobe can && sudo modprobe can_raw && sudo modprobe slcan

# 3. Bring up the interface
sudo slcand -o -c -s8 /dev/ttyACM0 can0
sudo ip link set up can0

# 4. Verify
ip link show can0
Ошибка 2 Суставы не реагируют после arm.enable_all()

Двигатели не получают команды. Чаще всего возникает из-за неправильных идентификаторов CAN, ошибок в кадрах шины CAN или недостаточного напряжения питания.

Исправить:

# 1. Check for CAN error frames
candump can0 | grep -i "error"

# 2. Check power supply — O6 requires 24V @ 150W minimum

# 3. Scan for motors and verify IDs
python3 -c "from linkerbot import LinkerBotO6; a=LinkerBotO6('can0'); a.scan_motors()"

# 4. Power cycle the arm and retry
Ошибка 3 LeRobot не может подключиться: robot not found

LeRobot не может найти конфигурацию робота O6 или интерфейс CAN не работает при запуске LeRobot.

Исправить:

# 1. Verify CAN interface is up before starting LeRobot
ip link show can0

# 2. Verify config file path and format
cat ~/.lerobot/robots/linkerbot_o6.yaml

# 3. Test direct SDK connection first
python3 -c "
from linkerbot import LinkerBotO6
a = LinkerBotO6(can_interface='can0')
a.connect()
print('Connected:', a.get_state())
a.disconnect()"

# 4. Then retry LeRobot
python -m lerobot.scripts.control_robot \
  --robot.type=linkerbot_o6 \
  --control.type=teleoperate

Все еще застрял? Опубликовать в Форум SVRC или посетите О6 вики.

Программное обеспечение работает? Начните сбор данных.

Как только O6 начнет двигаться, следующим шагом будет телеуправление и запись набора данных с помощью LeRobot.