Saltar al contenido principal

Guía de Integración ROS2 de reBot Arm B601-RS

reBot Arm B601-RS

License: MITROS2 Humble | JazzyPython VersionVersion v0.3.0Platform

ROS2 Control · SocketCAN · Visualización en RViz · Soporte MoveIt 2 · Compensación de Gravedad

Este tutorial muestra cómo controlar el reBot Arm B601-RS a través del espacio de trabajo ROS2 rebotarm_ros2. El espacio de trabajo encapsula el SDK de Python reBotArm_control_py, incluyendo cinemática inversa basada en Pinocchio, planificación de trayectorias y compensación de gravedad, en tópicos, servicios y acciones de ROS2. Esto facilita el uso de planificación de alto nivel, visualización en RViz, compensación de gravedad, control del gripper y desarrollo de aplicaciones personalizadas.

nota

Este tutorial usa Ubuntu 24.04 + ROS2 Jazzy como entorno de referencia principal. ROS2 Humble / Ubuntu 22.04 pueden seguir el mismo flujo de trabajo.

reBot Arm B601-RS MoveIt 2 demo

Características del Proyecto

  1. Interfaces ROS2 Estándar
    Proporciona interfaces comunes como /rebotarm/joint_states, /rebotarm/arm_status, FollowJointTrajectory, GripperCommand y MoveToPose.

  2. Nodos Listos para Usar de Cinemática, Planificación de Trayectorias y Compensación de Gravedad
    Proporciona cinemática directa/inversa, planificación de trayectorias, compensación de gravedad y soporte de visualización en RViz listos para usar.

  3. Integración con MoveIt 2
    Incluye configuración de MoveIt 2 y demostraciones de aplicación, soportando planificación simulada mediante el plugin MotionPlanning de RViz y ejecución en hardware real a través del nodo de control de hardware.

Especificaciones

El hardware para este tutorial es proporcionado por Seeed Studio.

ParámetroEspecificación
Modelo de Brazo RobóticoreBot Arm B601-RS
Grados de Libertad6-DOF + Gripper
ComunicaciónCAN
Canal CAN Predeterminadocan0
Modo de Control de Brazo Predeterminadomit
Sistema RecomendadoUbuntu 24.04 + ROS2 Jazzy + Python 3.12
Sistema de ReferenciaUbuntu 22.04 + ROS2 Humble + Python 3.10

Lista de Materiales (BOM)

ComponenteCantidadIncluido
Brazo Robótico reBot Arm B601-RS1
Gripper1
Adaptador CAN1
Adaptador de Alimentación1
Cable de Comunicación1
PC Host con Ubuntu1Preparado por el usuario

Cableado

  1. Conecta el adaptador CAN al bus CAN del brazo robótico.
  2. Conecta el motor del gripper al mismo bus CAN.
  3. Enciende el brazo robótico y conecta el adaptador CAN al host.
  4. Confirma que el host reconoce la interfaz CAN:
ip -br link

Levanta la interfaz CAN:

sudo ip link set can0 down 2>/dev/null
sudo ip link set can0 type can bitrate 1000000 restart-ms 100
sudo ip link set can0 up
ip -details link show can0

Requisitos de Entorno

ElementoRequisito Recomendado
Sistema OperativoUbuntu 24.04, Ubuntu 22.04 se puede usar como referencia
ROS2Jazzy, Humble se puede usar como referencia
PythonPython del sistema. Jazzy suele usar 3.12, mientras que Humble suele usar 3.10

Pasos de Instalación

Paso 0. Completar la Preparación Básica del Brazo Robótico

Antes de comenzar la integración con ROS2, completa la Guía Rápida de Inicio de reBot Arm B601-RS, incluyendo el montaje, la configuración de ID de los motores, la inicialización de la posición cero y otras preparaciones básicas.

Paso 1. Instalar la Versión de ROS2 para tu Sistema Ubuntu

Consulta la guía de instalación de ROS2 en el Wiki de Seeed Studio o la documentación oficial de ROS2:

Paso 2. Instalar Herramientas de Compilación y Dependencias de ROS

Instala colcon, pip, Git y los paquetes de ROS requeridos por este espacio de trabajo. Los siguientes comandos usan el valor de ROS_DISTRO en la terminal actual:

sudo apt update
sudo apt install -y python3-colcon-common-extensions python3-pip git
sudo apt install -y \
ros-${ROS_DISTRO}-control-msgs \
ros-${ROS_DISTRO}-trajectory-msgs \
ros-${ROS_DISTRO}-tf-transformations \
ros-${ROS_DISTRO}-robot-state-publisher \
ros-${ROS_DISTRO}-rviz2 \
ros-${ROS_DISTRO}-pinocchio

Verifica después de la instalación:

source /opt/ros/${ROS_DISTRO}/setup.bash
python3 -c "import pinocchio; print('pinocchio', pinocchio.__version__)"

Paso 3. Clonar el Repositorio de Código

Da preferencia al repositorio oficial Seeed-Projects:

git clone https://github.com/Seeed-Projects/reBotArmController_ROS2.git rebotarm_ros2
cd rebotarm_ros2

También puedes usar el repositorio de desarrollo actual:

git clone https://github.com/EclipseaHime017/reBotArmController_ROS2.git rebotarm_ros2
cd rebotarm_ros2

Paso 4. Instalar motorbridge

Instala motorbridge desde la fuente oficial de PyPI:

python3 -m pip install --user --break-system-packages --index-url https://pypi.org/simple motorbridge

Si usas Ubuntu 22.04 / ROS2 Humble, normalmente puedes eliminar --break-system-packages:

python3 -m pip install --user --index-url https://pypi.org/simple motorbridge

Paso 5. Obtener el SDK de Bajo Nivel

mkdir -p third_party
git clone https://github.com/vectorBH6/reBotArm_control_py.git third_party/reBotArm_control_py

Paso 6. Compilar el Espacio de Trabajo

source /opt/ros/${ROS_DISTRO}/setup.bash
colcon build --symlink-install
source install/setup.bash

Verifica las entradas ejecutables:

ros2 pkg executables rebotarmcontroller

Las entradas esperadas incluyen al menos:

rebotarmcontroller reBotArmController
rebotarmcontroller GravityCompensation
rebotarmcontroller GripperControl
rebotarmcontroller MoveTo
rebotarmcontroller MoveToPose

Inicio Rápido

precaución

Antes de usar el brazo robótico, ten en cuenta lo siguiente: El controlador del brazo robótico tiene un alto grado de libertad. Antes de habilitar el controlador o alimentar el brazo, asegúrate de que el área de trabajo esté libre de personas y obstáculos. Revisa cuidadosamente cada comando de movimiento para evitar accidentes. La operación peligrosa está estrictamente prohibida; eres responsable de cualquier consecuencia.

Iniciar el Sistema Completo

Primero confirma que la interfaz CAN está levantada:

ip -details link show can0

El arranque completo inicia:

  • Nodo de control reBotArmController
  • robot_state_publisher
  • RViz opcional
cd your/path/to/rebotarm_ros2
source install/setup.bash
ros2 launch rebotarm_bringup bringup.launch.py model:=rs channel:=can0

Si solo usas B601-RS durante mucho tiempo, puedes cambiar manualmente default_model en src/rebotarm_bringup/config/rebotarm_hardware.yaml a rs. Después de eso, puedes omitir model:=rs y solo mantener el parámetro real del canal CAN:

ros2 launch rebotarm_bringup bringup.launch.py channel:=can0

Iniciar la Visualización en RViz

ros2 launch rebotarm_bringup bringup.launch.py model:=rs channel:=can0 use_rviz:=true

Si el modelo aparece demasiado pequeño en RViz, ajusta la vista desde el panel Views a la izquierda:

  • Establece Target Frame en base_link
  • Cambia el tipo de vista a Move Camera
  • Ajusta Distance, por ejemplo a 1.0 o 1.5
  • Confirma que Fixed Frame está configurado en base_link

Iniciar Solo el Nodo de Control

Si no se necesitan URDF y RViz:

ros2 launch rebotarm_bringup driver.launch.py model:=rs channel:=can0

Usa ros launch para iniciar el nodo, porque el archivo launch pasa la configuración de hardware desde rebotarm_bringup/config.

Namespace de ROS2

El namespace predeterminado es:

/rebotarm

Por lo tanto, todos los tópicos, servicios y acciones tienen el prefijo /rebotarm, por ejemplo:

/rebotarm/joint_states
/rebotarm/enable
/rebotarm/move_to_pose

Si necesitas múltiples brazos robóticos, puedes cambiar el namespace en tiempo de lanzamiento:

ros2 launch rebotarm_bringup bringup.launch.py model:=rs channel:=can0 arm_namespace:=right_arm

En este caso, /rebotarm/joint_states se convierte en /right_arm/joint_states.

APIs Comunes

Tópicos de Estado

APITipoDescripción
/rebotarm/joint_statessensor_msgs/msg/JointStatePosiciones, velocidades y esfuerzos de las 6 articulaciones, incluyendo articulaciones visuales del gripper para RViz
/rebotarm/arm_statusrebotarm_msgs/msg/ArmStatusModo de control, estado habilitado, máquina de estados y códigos de error
/rebotarm/joints/<joint>/staterebotarm_msgs/msg/JointMotorStateEstado del motor de una sola articulación
/rebotarm/gripper/staterebotarm_msgs/msg/JointMotorStateEstado del motor del gripper

Ejemplos:

ros2 topic echo /rebotarm/joint_states --once
ros2 topic echo /rebotarm/arm_status --once

Servicios

APITipoDescripción
/rebotarm/enablestd_srvs/srv/TriggerHabilitar el brazo robótico
/rebotarm/disablestd_srvs/srv/TriggerDeshabilitar el brazo robótico
/rebotarm/safe_homestd_srvs/srv/TriggerVolver a la posición segura de inicio
/rebotarm/set_zerorebotarm_msgs/srv/SetZeroEstablecer la posición cero para todas las articulaciones o una sola articulación
/rebotarm/move_to_pose_ikrebotarm_msgs/srv/MoveToPoseIKPrecomprobación de IK y solución de articulaciones objetivo
/rebotarm/gripper/setrebotarm_msgs/srv/SetGripperEstablecer la posición del motor del gripper en rad
/rebotarm/gripper/openrebotarm_msgs/srv/GripperCommandAbrir el gripper según el valor configurado
/rebotarm/gripper/closerebotarm_msgs/srv/GripperCommandCerrar el gripper según el valor configurado
/rebotarm/gravity_compensation/startstd_srvs/srv/TriggerIniciar la compensación de gravedad
/rebotarm/gravity_compensation/stopstd_srvs/srv/TriggerDetener la compensación de gravedad

Acciones

APITipoDescripción
/rebotarm/move_to_poserebotarm_msgs/action/MoveToPoseMovimiento de la pose del efector final
/rebotarm/follow_joint_trajectorycontrol_msgs/action/FollowJointTrajectoryPunto de entrada estándar compatible con trayectorias articulares
/rebotarm/gripper/commandcontrol_msgs/action/GripperCommandAcción estándar de pinza

Ejemplos de control básico

1. Habilitar el brazo robótico

ros2 service call /rebotarm/enable std_srvs/srv/Trigger

2. Mover a una pose del efector final

ros2 action send_goal /rebotarm/move_to_pose rebotarm_msgs/action/MoveToPose \
"{target_pose: {position: {x: 0.30, y: 0.0, z: 0.30}, orientation: {x: 0.0, y: 0.0, z: 0.0, w: 1.0}}, duration: 2.0}"

La acción move_to_pose se ejecuta mediante el controlador de pose final del SDK. El modo de control del brazo B601-RS es mit por defecto en rebotarm_hardware.yaml.

3. Enviar un objetivo articular

ros2 action send_goal /rebotarm/follow_joint_trajectory \
control_msgs/action/FollowJointTrajectory \
"{trajectory: {joint_names: ['joint1','joint2','joint3','joint4','joint5','joint6'],
points: [{positions: [0.1,0,0,0,0,0], time_from_start: {sec: 5}}]}}"

4. Controlar la pinza

ros2 service call /rebotarm/gripper/open rebotarm_msgs/srv/GripperCommand "{}"
ros2 service call /rebotarm/gripper/close rebotarm_msgs/srv/GripperCommand "{}"

También puedes enviar una posición explícita del motor de la pinza:

ros2 service call /rebotarm/gripper/set rebotarm_msgs/srv/SetGripper "{position: 5.0}"

5. Posición segura de origen y deshabilitar

ros2 service call /rebotarm/safe_home std_srvs/srv/Trigger
ros2 service call /rebotarm/disable std_srvs/srv/Trigger

Ejemplos de demostración

Todos los ejemplos suponen que reBotArmController ya se está ejecutando:

cd your/path/to/rebotarm_ros2
source install/setup.bash
ros2 launch rebotarm_bringup bringup.launch.py model:=rs channel:=can0

Ejemplo de movimiento articular

Controla las 6 articulaciones a la vez. La unidad es rad:

ros2 run rebotarmcontroller MoveTo -- \
0.20 -0.20 -0.20 -0.20 0.10 -0.10 \
--duration 8.0

Controlar solo una articulación:

ros2 run rebotarmcontroller MoveTo -- --joint joint3 --position -0.20 --duration 5.0

Ejemplo de pose del efector final

ros2 run rebotarmcontroller MoveToPose -- --x 0.30 --y 0.0 --z 0.30 --qw 1.0 --duration 2.0

Ejemplo de compensación de gravedad

ros2 run rebotarmcontroller GravityCompensation

El script primero llama a /rebotarm/enable, luego inicia la compensación de gravedad. Cuando presionas Ctrl+C, el script llama a los siguientes servicios en orden:

  1. /rebotarm/gravity_compensation/stop
  2. /rebotarm/safe_home
  3. /rebotarm/disable

Esto detiene primero la compensación de gravedad, luego mueve el brazo de vuelta a la posición segura de origen y lo deshabilita.

También puedes llamar a los servicios manualmente:

ros2 service call /rebotarm/enable std_srvs/srv/Trigger
ros2 service call /rebotarm/gravity_compensation/start std_srvs/srv/Trigger
ros2 service call /rebotarm/gravity_compensation/stop std_srvs/srv/Trigger
ros2 service call /rebotarm/safe_home std_srvs/srv/Trigger
ros2 service call /rebotarm/disable std_srvs/srv/Trigger

Ejemplo de pinza interactiva

ros2 run rebotarmcontroller GripperControl

Después de iniciar, introduce:

o / open    Open the gripper
c / close Close the gripper
q / quit Quit

Configuración

Los archivos de configuración predeterminados se encuentran en:

src/rebotarm_bringup/config/
ArchivoDescripción
rebotarm_hardware.yamlSelección de hardware de capa superior de ROS2 y anulaciones de parámetros del SDK para B601-RS
driver_params.yamlEjemplos de parámetros de ROS

El default_model en la parte superior de rebotarm_hardware.yaml puede ser dm por defecto. Si quieres que B601-RS sea el modelo predeterminado, cámbialo a:

default_model: rs

Después de este cambio, B601-RS se usará automáticamente cuando no se pase explícitamente model:=....

Parámetros de lanzamiento comunes:

ParámetroPredeterminadoDescripción
hardware_configrebotarm_hardware.yaml incorporado desde bringupRuta de configuración de hardware de capa superior de ROS2
modelrsEste tutorial pasa explícitamente rs para seleccionar la configuración de B601-RS
channelcan0Canal SocketCAN
joint_state_rate100.0Frecuencia de publicación de /rebotarm/joint_states
cmd_arbitrationrejectArbitraje de comandos de articulaciones de bajo nivel durante la ejecución de trayectorias, reject o preempt
arm_namespacerebotarmPrefijo de espacio de nombres de ROS
frame_idbase_linkMarco base del brazo robótico
ee_frame_idgripper_endMarco del efector final
use_rvizfalseIndica si se inicia el bringup de RViz
disable_after_safe_hometrueControla si los motores se deshabilitan después de completar la posición segura de origen

Configuración clave predeterminada para B601-RS en rebotarm_hardware.yaml:

ElementoPredeterminado
Canal de comunicacióncan0
Modo de control del brazomit
Posición de apertura de la pinza5.0
Posición de cierre de la pinza0.0
Ganancia de salida de compensación de gravedad para las articulaciones 2/31.5

Tópicos de comandos de bajo nivel

El espacio de trabajo de ROS2 también proporciona tópicos de depuración de motores de bajo nivel:

APITipoDescripción
/rebotarm/joints/<joint>/cmd/mitrebotarm_msgs/msg/JointMitCmdComando MIT bruto de una sola articulación
/rebotarm/joints/<joint>/cmd/pos_velrebotarm_msgs/msg/JointPosVelCmdComando bruto de posición-velocidad de una sola articulación
/rebotarm/gripper/cmd/mitrebotarm_msgs/msg/JointMitCmdComando MIT bruto de la pinza
/rebotarm/gripper/cmd/pos_velrebotarm_msgs/msg/JointPosVelCmdComando bruto de posición-velocidad de la pinza
precaución

Los tópicos de comandos de bajo nivel están pensados para depuración y experimentos. No realizan IK, planificación de trayectorias ni comprobaciones de validez de URDF. Para movimiento a nivel de aplicación, es preferible usar servicios y acciones como /move_to_pose, /follow_joint_trajectory y /gripper/set.

MoveIt 2

MoveIt 2 es un framework de planificación de movimiento para brazos robóticos. Aquí es principalmente responsable de la cinemática inversa, la comprobación de colisiones, la planificación de trayectorias y la ejecución de trayectorias. El paquete de demostración mantiene los flujos de aplicación separados del controlador de bajo nivel. Para más detalles, consulta la Documentación oficial de MoveIt 2.

El contenido relacionado con MoveIt se divide en dos paquetes:

PaquetePropósito
rebotarm_moveit_configModelo del robot, SRDF, cinemática, límites articulares, configuración del controlador y de RViz
rebotarm_moveit_demosDemos de aplicación basadas en MoveIt 2

El entorno MoveIt utiliza hardware simulado a través de ros2_control y move_group para la planificación y ejecución. Es adecuado para validar el modelo, la IK, la planificación de trayectorias y el flujo de demostración en RViz.

Este repositorio también es compatible con hardware real. Antes de conectar hardware real, asegúrate de que la configuración cero del brazo, las direcciones de las articulaciones, los límites articulares, los límites de velocidad y el rango de apertura/cierre de la pinza sean correctos, o mantén la configuración predeterminada del repositorio.

Configuración del entorno MoveIt

Primero asegúrate de que el entorno ROS2 esté disponible. El siguiente comando instala dependencias para el ROS_DISTRO actualmente cargado:

sudo apt update
sudo apt install -y \
ros-${ROS_DISTRO}-moveit \
ros-${ROS_DISTRO}-moveit-configs-utils \
ros-${ROS_DISTRO}-moveit-kinematics \
ros-${ROS_DISTRO}-moveit-planners-ompl \
ros-${ROS_DISTRO}-moveit-simple-controller-manager \
ros-${ROS_DISTRO}-ros2-control \
ros-${ROS_DISTRO}-ros2-controllers \
ros-${ROS_DISTRO}-xacro

La configuración y las demos de MoveIt están incluidas en este espacio de trabajo. Después de instalar las dependencias, vuelve a compilar el espacio de trabajo:

cd your/path/to/rebotarm_ros2
colcon build --symlink-install
source install/setup.bash

Verifica los paquetes de MoveIt y los puntos de entrada de las demos:

ros2 pkg list | grep rebotarm_moveit
ros2 pkg executables rebotarm_moveit_demos

Las entradas esperadas incluyen al menos:

rebotarm_moveit_demos draw_square
rebotarm_moveit_demos pick_place

Usar MoveIt

La planificación con MoveIt se puede usar a través de la interfaz gráfica de RViz o llamando a nodos, tanto en simulación como en escenas reales.

Usar MoveIt en simulación

MoveIt utiliza la interfaz de hardware virtual de ros2_control para la simulación en RViz:

cd your/path/to/rebotarm_ros2
source install/setup.bash
ros2 launch rebotarm_moveit_config demo.launch.py model:=rs

Por defecto esto inicia:

  • move_group
  • robot_state_publisher
  • ros2_control_node
  • joint_state_broadcaster
  • rebotarm_controller
  • gripper_controller
  • RViz con el plugin MoveIt MotionPlanning

RViz se abre automáticamente y carga el modelo B601-RS. Puedes controlar el movimiento mediante el panel de la interfaz gráfica a la izquierda.

Para ejecutar el entorno MoveIt sin RViz:

ros2 launch rebotarm_moveit_config demo.launch.py model:=rs use_rviz:=false

Usar MoveIt con hardware reBotArm

Para escenas reales, inicia primero el nodo de control de hardware y luego inicia el entorno MoveIt para hardware real:

ros2 launch rebotarm_bringup driver.launch.py model:=rs channel:=can0

En otra terminal:

cd your/path/to/rebotarm_ros2
source install/setup.bash
ros2 launch rebotarm_moveit_config hardware.launch.py model:=rs
precaución

Antes de ejecutar cualquier demo en hardware real, asegúrate de que el espacio de trabajo del brazo robótico esté libre de personas y obstáculos, verifica primero la trayectoria planificada en RViz y estate preparado para detener el controlador en cualquier momento.

Ejecutar la demo de dibujar un cuadrado

Inicia primero el entorno MoveIt y luego ejecuta en otra terminal:

cd your/path/to/rebotarm_ros2
source install/setup.bash
ros2 launch rebotarm_moveit_demos draw_square.launch.py model:=rs

draw_square mueve gripper_tcp a través de las cuatro esquinas de un rectángulo coplanar. Los parámetros predeterminados están en:

src/rebotarm_moveit_demos/config/draw_square_rs.yaml

Parámetros comunes:

ParámetroDescripción
start_pointPosición de reinicio de las articulaciones antes de que comience la demo
rectangle_centerCentro del rectángulo en base_link
rectangle_width / rectangle_heightDimensiones del rectángulo en metros
tcp_rpyOrientación del TCP, con una pinza orientada hacia abajo por defecto
tcp_yaw_offsetsValores alternativos de yaw de IK usados para evitar grandes giros de la articulación 6

draw_square es útil para verificar si MoveIt IK, la planificación de trayectorias y la ejecución funcionan correctamente. Si la planificación falla, primero comprueba si el estado articular inicial, el centro del rectángulo, la orientación del TCP y los límites articulares son razonables.

Ejecutar la demo de Pick-place

Inicia primero el entorno de MoveIt y luego ejecuta en otra terminal:

cd your/path/to/rebotarm_ros2
source install/setup.bash
ros2 launch rebotarm_moveit_demos pick_place.launch.py model:=rs

Los parámetros predeterminados están en:

src/rebotarm_moveit_demos/config/pick_place_rs.yaml

Parámetros comunes:

ParámetroDescripción
ready_pointPosición articular de preparado usada antes y después de pick/place
pick_positionPosición centro-inferior del objeto en base_link
pick_tcp_rpy / place_tcp_rpyOrientación del TCP para pick y place
object_dimensionsDimensiones del objeto de la escena de planificación en metros
max_gripper_widthApertura total máxima del gripper, por defecto 0.09m
open_gripper_position / grasp_gripper_position / closed_gripper_positionPosiciones articulares simuladas del gripper de un solo lado
hardware_open_gripper_position / hardware_closed_gripper_positionPosiciones de apertura/cierre del motor del gripper de hardware

pick_place añade un objeto objetivo a la escena de planificación, abre el gripper, se mueve a la pose de pick, cierra el gripper, se mueve a la pose de place y suelta el objeto. Las posiciones articulares simuladas del gripper y las posiciones reales del motor del gripper de hardware son parámetros diferentes. Antes de ejecutar en hardware real, confirma la dirección de apertura/cierre del gripper y sus límites.

Archivos de configuración de MoveIt

ArchivoDescripción
rebotarm_moveit_config/config/rebotarm_rs.urdf.xacroModelo de robot B601-RS usado por MoveIt, incluyendo el gripper y gripper_tcp
rebotarm_moveit_config/config/rebotarm_rs.ros2_control.xacroDescripción de hardware simulado de ros2_control para simulación
rebotarm_moveit_config/config/rebotarm_rs.srdfGrupos de MoveIt, efector final, estados predeterminados y configuración semántica
rebotarm_moveit_config/config/kinematics.yamlConfiguración del solucionador de IK
rebotarm_moveit_config/config/joint_limits.yamlLímites articulares usados por la planificación de MoveIt
rebotarm_moveit_config/config/ompl_planning.yamlParámetros del planificador OMPL
rebotarm_moveit_config/config/moveit_controllers.yamlConfiguración del controlador de ejecución de trayectorias de MoveIt para simulación
rebotarm_moveit_config/config/moveit_hardware_controllers.yamlConfiguración del controlador de ejecución de trayectorias de MoveIt para hardware real
rebotarm_moveit_config/config/ros2_controllers.yamlConfiguración de controladores de ros2_control para simulación
rebotarm_moveit_config/config/initial_positions.yamlPosiciones articulares iniciales para hardware simulado
rebotarm_moveit_demos/config/draw_square_rs.yamlParámetros de la demo de dibujar cuadrado
rebotarm_moveit_demos/config/pick_place_rs.yamlParámetros de la demo de Pick-place

Preguntas frecuentes (FAQ)

1. Aparece socketcan write failed: Network is down al iniciar

Esto significa que la interfaz CAN aún no se ha levantado. Primero comprueba la interfaz:

ip -details link show can0

Reinicia CAN:

sudo ip link set can0 down 2>/dev/null
sudo ip link set can0 type can bitrate 1000000 restart-ms 100
sudo ip link set can0 up

2. No se puede encontrar can0

Primero confirma que el adaptador CAN está conectado y comprueba el nombre de la interfaz:

ip -br link

Si usas PCAN-USB:

sudo modprobe peak_usb
ip -br link

Si el nombre de la interfaz no es can0, reemplaza channel al lanzar:

ros2 launch rebotarm_bringup bringup.launch.py model:=rs channel:=can1

3. El modelo del robot no se muestra en RViz

Comprueba lo siguiente:

  • Si el workspace ha sido cargado con: source install/setup.bash
  • Si Fixed Frame está configurado como base_link
  • Si robot_state_publisher se inició correctamente
  • Si la ruta de los meshes del URDF es package://rebotarm_bringup/description/...

Si el modelo se muestra pero la vista es incómoda, cambia el tipo de vista a Move Camera en el panel Views de RViz, establece Target Frame en base_link y ajusta Distance.

4. La planificación de MoveIt falla

Si la demo imprime MoveIt planning failed, comprueba lo siguiente:

  • Confirma que demo.launch.py o hardware.launch.py se ha iniciado y que move_group se está ejecutando correctamente.
  • Confirma que el estado articular actual no está obsoleto y que /joint_states o /rebotarm/joint_states se está publicando con normalidad.
  • Confirma que el punto objetivo está dentro del espacio de trabajo alcanzable y que la orientación objetivo no hace que la muñeca o el gripper colisionen con el cuerpo del brazo.
  • Confirma que los límites articulares y de velocidad en joint_limits.yaml coinciden con el brazo robótico actual.
  • Primero planifica manualmente en el plugin MotionPlanning de RViz. Ejecuta la demo solo después de confirmar que la trayectoria está libre de colisiones.

5. Aparece una advertencia de puerto SHM de FastDDS

Si la terminal muestra algo como:

[RTPS_TRANSPORT_SHM Error] Failed init_port fastrtps_port7002: open_and_lock_file failed

Esto suele deberse a archivos de bloqueo de memoria compartida de FastDDS sobrantes después de que un proceso ROS2 anterior saliera de forma anómala. Si los servicios y acciones siguen respondiendo con normalidad, esta advertencia normalmente no afecta al control.

Para limpiarlo, detén primero los procesos ROS2 relacionados y luego ejecuta:

pkill -f ros2
pkill -f reBotArmController
rm -f /dev/shm/fastrtps_port*

Si quieres omitir temporalmente el transporte por memoria compartida, establece lo siguiente antes de lanzar ROS2:

export FASTDDS_BUILTIN_TRANSPORTS=UDPv4

6. ¿Qué pasa si uso Humble?

Los usuarios de Humble pueden seguir el mismo flujo de trabajo, reemplazar jazzy por humble en los comandos e instalar las dependencias correspondientes según la documentación oficial de Humble. Después de cambiar de distribución ROS2, ejecuta colcon build de nuevo.

7. No se puede encontrar pinocchio

Si un nodo o un comando de verificación informa:

ModuleNotFoundError: No module named 'pinocchio'

Primero asegúrate de que el paquete Pinocchio para tu distribución ROS2 esté instalado:

sudo apt install -y ros-${ROS_DISTRO}-pinocchio

Luego asegúrate de que la terminal actual haya cargado el entorno de ROS2:

source /opt/ros/${ROS_DISTRO}/setup.bash
python3 -c "import pinocchio; print(pinocchio.__version__)"

Si aún no se puede encontrar, comprueba si la ruta de búsqueda de Python actual contiene la ruta de paquetes Python de ROS2:

python3 -c "import sys; print('\n'.join(sys.path))"

Después de cargar Jazzy, deberías ver una ruta similar a /opt/ros/jazzy/lib/python3.12/site-packages. Si usas Humble, reemplaza jazzy por humble en los comandos.

Contacto

Referencias

Loading Comments...