unitree_sdk2_python/README zh.md

122 lines
4.6 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

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