4.6 KiB
unitree_sdk2py
unitree_sdk2 python 接口
安装
依赖
- python>=3.8
- cyclonedds==0.10.2
- numpy
- opencv-python
安装 unitree_sdk2py
在终端中执行:
cd ~
sudo apt install python3-pip
git clone https://github.com/unitreerobotics/unitree_sdk2py.git
cd unitree_sdk2py
pip3 install -e .
FAQ
1. pip3 install -e .
遇到报错
Could not locate cyclonedds. Try to set CYCLONEDDS_HOME or CMAKE_PREFIX_PATH
该错误提示找不到 cyclonedds 路径。首先编译安装cyclonedds:
cd ~
git clone https://github.com/eclipse-cyclonedds/cyclonedds -b releases/0.10.x
cd cyclonedds && mkdir build install && cd build
cmake .. -DCMAKE_INSTALL_PREFIX=../install
cmake --build . --target install
进入 unitree_sdk2py 目录,设置 CYCLONEDDS_HOME
为刚刚编译好的 cyclonedds 所在路径,再安装unitree_sdk2py
cd ~/unitree_sdk2py
export CYCLONEDDS_HOME="~/cyclonedds/install"
pip3 install -e .
详细见: https://pypi.org/project/cyclonedds/#installing-with-pre-built-binaries
使用
python sdk2 接口与 unitree_skd2的接口保持一致,通过请求响应或订阅发布topic实现机器人的状态获取和控制。相应的例程位于/example
目录下。在运行例程前,需要根据文档 https://support.unitree.com/home/zh/developer/Quick_start 配置好机器人的网络连接。
DDS通讯
在终端中执行:
python3 ./example/helloworld/publisher.py
打开新的终端,执行:
python3 ./example/helloworld/subscriber.py
可以看到终端输出的数据信息。publisher.py
和 subscriber.py
传输的数据定义在 user_data.py
中,用户可以根据需要自行定义需要传输的数据结构。
高层状态和控制
高层接口的数据结构和控制方式与unitree_sdk2一致。具体可见:https://support.unitree.com/home/zh/developer/sports_services
高层状态
终端中执行:
python3 ./example/high_level/read_highstate.py enp2s0
其中 enp2s0
为机器人所连接的网卡名称,请根据实际情况修改。
高层控制
终端中执行:
python3 ./example/high_level/sportmode_test.py enp2s0
其中 enp2s0
为机器人所连接的网卡名称,请根据实际情况修改。
该例程提供了几种测试方法,可根据测试需要选择:
test.StandUpDown() # 站立趴下
# test.VelocityMove() # 速度控制
# test.BalanceAttitude() # 姿态控制
# test.TrajectoryFollow() # 轨迹跟踪
# test.SpecialMotions() # 特殊动作
底层状态和控制
底层接口的数据结构和控制方式与unitree_sdk2一致。具体可见:https://support.unitree.com/home/zh/developer/Basic_services
底层状态
终端中执行:
python3 ./example/low_level/lowlevel_control.py enp2s0
其中 enp2s0
为机器人所连接的网卡名称,请根据实际情况修改。程序会输出右前腿hip关节的状态、IMU和电池电压信息。
底层电机控制
首先使用 app 关闭高层运动服务(sport_mode),否则会导致指令冲突。 终端中执行:
python3 ./example/low_level/lowlevel_control.py enp2s0
其中 enp2s0
为机器人所连接的网卡名称,请根据实际情况修改。左后腿 hip 关节会保持在0角度 (安全起见,这里设置 kp=10, kd=1),左后腿 calf 关节将持续输出 1Nm 的转矩。
遥控器状态获取
终端中执行:
python3 ./example/wireless_controller/wireless_controller.py enp2s0
其中 enp2s0
为机器人所连接的网卡名称,请根据实际情况修改。
终端将输出每一个按键的状态。对于遥控器按键的定义和数据结构可见: https://support.unitree.com/home/zh/developer/Get_remote_control_status
前置摄像头
使用opencv获取前置摄像头(确保在有图形界面的系统下运行, 按 ESC 退出程序):
python3 ./example/front_camera/camera_opencv.py enp2s0
其中 enp2s0
为机器人所连接的网卡名称,请根据实际情况修改。
避障开关
python3 ./example/obstacles_avoid_switch/obstacles_avoid_switch.py enp2s0
其中 enp2s0
为机器人所连接的网卡名称,请根据实际情况修改。机器人将循环开启和关闭避障功能。关于避障服务,详细见 https://support.unitree.com/home/zh/developer/ObstaclesAvoidClient
灯光音量控制
python3 ./example/vui_client/vui_client_example.py enp2s0
其中 enp2s0
为机器人所连接的网卡名称,请根据实际情况修改。机器人将循环调节音量和灯光亮度。该接口详细见 https://support.unitree.com/home/zh/developer/VuiClient