add unitree_sdk2py

This commit is contained in:
yangning wu 2024-04-26 21:26:50 +08:00
commit 41209cd3ca
142 changed files with 6074 additions and 0 deletions

36
.gitignore vendored Normal file
View File

@ -0,0 +1,36 @@
# Generated by MacOS
.DS_Store
# Generated by Windows
Thumbs.db
# Applications
*.app
*.exe
*.war
# Large media files
*.mp4
*.tiff
*.avi
*.flv
*.mov
*.wmv
*.jpg
*.png
# VS Code
.vscode
# other
*.egg-info
__pycache__
# IDEs
.idea
# cache
.pytest_cache
# JetBrains IDE
.idea/

121
README zh.md Normal file
View File

@ -0,0 +1,121 @@
# unitree_sdk2py
unitree_sdk2 python 接口
# 安装
## 依赖
- python>=3.8
- cyclonedds==0.10.2
- numpy
- opencv-python
## 安装 unitree_sdk2py
在终端中执行:
```bash
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 .` 遇到报错
```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_sdk2py 目录,设置 `CYCLONEDDS_HOME` 为刚刚编译好的 cyclonedds 所在路径再安装unitree_sdk2py
```bash
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通讯
在终端中执行:
```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

112
README.md Normal file
View File

@ -0,0 +1,112 @@
# unitree_sdk2py
Python interface for unitree sdk2
# Installation
## Dependencies
- Python >= 3.8
- cyclonedds == 0.10.2
- numpy
- opencv-python
## Install unitree_sdk2py
Execute the following commands in the terminal:
```bash
cd ~
sudo apt install python3-pip
git clone https://github.com/unitreerobotics/unitree_sdk2py.git
cd unitree_sdk2py
pip3 install -e .
```
## FAQ
##### 1. Error when `pip3 install -e .`:
```bash
Could not locate cyclonedds. Try to set CYCLONEDDS_HOME or CMAKE_PREFIX_PATH
```
This error mentions that the cyclonedds path could not be found. First compile and install 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
```
Enter the unitree_sdk2py directory, set `CYCLONEDDS_HOME` to the path of the cyclonedds you just compiled, and then install unitree_sdk2py.
```bash
cd ~/unitree_sdk2py
export CYCLONEDDS_HOME="~/cyclonedds/install"
pip3 install -e .
```
For details, see: https://pypi.org/project/cyclonedds/#installing-with-pre-built-binaries
# Usage
The Python sdk2 interface maintains consistency with the unitree_sdk2 interface, achieving robot status acquisition and control through request-response or topic subscription/publishing. Example programs are located in the `/example` directory. Before running the examples, configure the robot's network connection as per the instructions in the document at https://support.unitree.com/home/en/developer/Quick_start.
## DDS Communication
In the terminal, execute:
```bash
python3 ./example/helloworld/publisher.py
```
Open a new terminal and execute:
```bash
python3 ./example/helloworld/subscriber.py
```
You will see the data output in the terminal. The data structure transmitted between `publisher.py` and `subscriber.py` is defined in `user_data.py`, and users can define the required data structure as needed.
## High-Level Status and Control
The high-level interface maintains consistency with unitree_sdk2 in terms of data structure and control methods. For detailed information, refer to https://support.unitree.com/home/en/developer/sports_services.
### High-Level Status
Execute the following command in the terminal:
```bash
python3 ./example/high_level/read_highstate.py enp2s0
```
Replace `enp2s0` with the name of the network interface to which the robot is connected,.
### High-Level Control
Execute the following command in the terminal:
```bash
python3 ./example/high_level/sportmode_test.py enp2s0
```
Replace `enp2s0` with the name of the network interface to which the robot is connected. This example program provides several test methods, and you can choose the required tests as follows:
```python
test.StandUpDown() # Stand up and lie down
# test.VelocityMove() # Velocity control
# test.BalanceAttitude() # Attitude control
# test.TrajectoryFollow() # Trajectory tracking
# test.SpecialMotions() # Special motions
```
## Low-Level Status and Control
The low-level interface maintains consistency with unitree_sdk2 in terms of data structure and control methods. For detailed information, refer to https://support.unitree.com/home/en/developer/Basic_services.
### Low-Level Status
Execute the following command in the terminal:
```bash
python3 ./example/low_level/lowlevel_control.py enp2s0
```
Replace `enp2s0` with the name of the network interface to which the robot is connected. The program will output the state of the right front leg hip joint, IMU, and battery voltage.
### Low-Level Motor Control
First, use the app to turn off the high-level motion service (sport_mode) to prevent conflicting instructions.
Execute the following command in the terminal:
```bash
python3 ./example/low_level/lowlevel_control.py enp2s0
```
Replace `enp2s0` with the name of the network interface to which the robot is connected. The left hind leg hip joint will maintain a 0-degree position (for safety, set kp=10, kd=1), and the left hind leg calf joint will continuously output 1Nm of torque.
## Wireless Controller Status
Execute the following command in the terminal:
```bash
python3 ./example/wireless_controller/wireless_controller.py enp2s0
```
Replace `enp2s0` with the name of the network interface to which the robot is connected. The terminal will output the status of each key. For the definition and data structure of the remote control keys, refer to https://support.unitree.com/home/en/developer/Get_remote_control_status.
## Front Camera
Use OpenCV to obtain the front camera (ensure to run on a system with a graphical interface, and press ESC to exit the program):
```bash
python3 ./example/front_camera/camera_opencv.py enp2s0
```
Replace `enp2s0` with the name of the network interface to which the robot is connected.
## Obstacle Avoidance Switch
```bash
python3 ./example/obstacles_avoid_switch/obstacles_avoid_switch.py enp2s0
```
Replace `enp2s0` with the name of the network interface to which the robot is connected. The robot will cycle obstacle avoidance on and off. For details on the obstacle avoidance service, see https://support.unitree.com/home/en/developer/ObstaclesAvoidClient
## Light and volume control
```bash
python3 ./example/vui_client/vui_client_example.py enp2s0
```
Replace `enp2s0` with the name of the network interface to which the robot is connected.T he robot will cycle the volume and light brightness. The interface is detailed at https://support.unitree.com/home/en/developer/VuiClient

View File

@ -0,0 +1,41 @@
from unitree_sdk2py.core.channel import ChannelFactortyInitialize
from unitree_sdk2py.go2.video.video_client import VideoClient
import cv2
import numpy as np
import sys
if __name__ == "__main__":
if len(sys.argv)>1:
ChannelFactortyInitialize(0, sys.argv[1])
else:
ChannelFactortyInitialize(0)
client = VideoClient() # Create a video client
client.SetTimeout(3.0)
client.Init()
code, data = client.GetImageSample()
# Request normal when code==0
while code == 0:
# Get Image data from Go2 robot
code, data = client.GetImageSample()
# Convert to numpy image
image_data = np.frombuffer(bytes(data), dtype=np.uint8)
image = cv2.imdecode(image_data, cv2.IMREAD_COLOR)
# Display image
cv2.imshow("front_camera", image)
# Press ESC to stop
if cv2.waitKey(20) == 27:
break
if code != 0:
print("Get image sample error. code:", code)
else:
# Capture an image
cv2.imwrite("front_image.jpg", image)
cv2.destroyWindow("front_camera")

View File

@ -0,0 +1,30 @@
import time
import os
import sys
from unitree_sdk2py.core.channel import ChannelFactortyInitialize
from unitree_sdk2py.go2.video.video_client import VideoClient
if __name__ == "__main__":
if len(sys.argv)>1:
ChannelFactortyInitialize(0, sys.argv[1])
else:
ChannelFactortyInitialize(0)
client = VideoClient()
client.SetTimeout(3.0)
client.Init()
print("##################GetImageSample###################")
code, data = client.GetImageSample()
if code != 0:
print("get image sample error. code:", code)
else:
imageName = "./img.jpg"
print("ImageName:", imageName)
with open(imageName, "+wb") as f:
f.write(bytes(data))
time.sleep(1)

View File

@ -0,0 +1,28 @@
import time
from unitree_sdk2py.core.channel import ChannelPublisher, ChannelFactortyInitialize
from user_data import *
if __name__ == "__main__":
ChannelFactortyInitialize()
# Create a publisher to publish the data defined in UserData class
pub = ChannelPublisher("topic", UserData)
pub.Init()
for i in range(30):
# Create a Userdata message
msg = UserData(" ", 0)
msg.string_data = "Hello world"
msg.float_data = time.time()
# Publish message
if pub.Write(msg, 0.5):
print("Publish success. msg:", msg)
else:
print("Waitting for subscriber.")
time.sleep(1)
pub.Close()

View File

@ -0,0 +1,20 @@
import time
from unitree_sdk2py.core.channel import ChannelSubscriber, ChannelFactortyInitialize
from user_data import *
if __name__ == "__main__":
ChannelFactortyInitialize()
# Create a subscriber to subscribe the data defined in UserData class
sub = ChannelSubscriber("topic", UserData)
sub.Init()
while True:
msg = sub.Read()
if msg is not None:
print("Subscribe success. msg:", msg)
else:
print("No data subscribed.")
break
sub.Close()

View File

@ -0,0 +1,9 @@
from dataclasses import dataclass
from cyclonedds.idl import IdlStruct
# This class defines user data consisting of a float data and a string data
@dataclass
class UserData(IdlStruct, typename="UserData"):
string_data: str
float_data: float

View File

@ -0,0 +1,23 @@
import time
import sys
from unitree_sdk2py.core.channel import ChannelSubscriber, ChannelFactortyInitialize
from unitree_sdk2py.idl.default import unitree_go_msg_dds__SportModeState_
from unitree_sdk2py.idl.unitree_go.msg.dds_ import SportModeState_
def HighStateHandler(msg: SportModeState_):
print("Position: ", msg.position)
print("Velocity: ", msg.velocity)
print("Yaw velocity: ", msg.yaw_speed)
print("Foot position in body frame: ", msg.foot_position_body)
print("Foot velocity in body frame: ", msg.foot_speed_body)
if __name__ == "__main__":
ChannelFactortyInitialize(0, "enp3s0")
sub = ChannelSubscriber("rt/sportmodestate", SportModeState_)
sub.Init(HighStateHandler, 10)
while True:
time.sleep(10.0)

View File

@ -0,0 +1,144 @@
import time
import sys
from unitree_sdk2py.core.channel import ChannelSubscriber, ChannelFactortyInitialize
from unitree_sdk2py.idl.default import unitree_go_msg_dds__SportModeState_
from unitree_sdk2py.idl.unitree_go.msg.dds_ import SportModeState_
from unitree_sdk2py.go2.sport.sport_client import (
SportClient,
PathPoint,
SPORT_PATH_POINT_SIZE,
)
import math
class SportModeTest:
def __init__(self) -> None:
# Time count
self.t = 0
self.dt = 0.01
# Initial poition and yaw
self.px0 = 0
self.py0 = 0
self.yaw0 = 0
self.client = SportClient() # Create a sport client
self.client.SetTimeout(10.0)
self.client.Init()
def GetInitState(self, robot_state: SportModeState_):
self.px0 = robot_state.position[0]
self.py0 = robot_state.position[1]
self.yaw0 = robot_state.imu_state.rpy[2]
def StandUpDown(self):
self.client.StandDown()
print("Stand down !!!")
time.sleep(1)
self.client.StandUp()
print("Stand up !!!")
time.sleep(1)
self.client.StandDown()
print("Stand down !!!")
time.sleep(1)
self.client.Damp()
def VelocityMove(self):
elapsed_time = 1
for i in range(int(elapsed_time / self.dt)):
self.client.Move(0.3, 0, 0.3) # vx, vy vyaw
time.sleep(self.dt)
self.client.StopMove()
def BalanceAttitude(self):
self.client.Euler(0.1, 0.2, 0.3) # roll, pitch, yaw
self.client.BalanceStand()
def TrajectoryFollow(self):
time_seg = 0.2
time_temp = self.t - time_seg
path = []
for i in range(SPORT_PATH_POINT_SIZE):
time_temp += time_seg
px_local = 0.5 * math.sin(0.5 * time_temp)
py_local = 0
yaw_local = 0
vx_local = 0.25 * math.cos(0.5 * time_temp)
vy_local = 0
vyaw_local = 0
path_point_tmp = PathPoint(0, 0, 0, 0, 0, 0, 0)
path_point_tmp.timeFromStart = i * time_seg
path_point_tmp.x = (
px_local * math.cos(self.yaw0)
- py_local * math.sin(self.yaw0)
+ self.px0
)
path_point_tmp.y = (
px_local * math.sin(self.yaw0)
+ py_local * math.cos(self.yaw0)
+ self.py0
)
path_point_tmp.yaw = yaw_local + self.yaw0
path_point_tmp.vx = vx_local * math.cos(self.yaw0) - vy_local * math.sin(
self.yaw0
)
path_point_tmp.vy = vx_local * math.sin(self.yaw0) + vy_local * math.cos(
self.yaw0
)
path_point_tmp.vyaw = vyaw_local
path.append(path_point_tmp)
self.client.TrajectoryFollow(path)
def SpecialMotions(self):
self.client.RecoveryStand()
print("RecoveryStand !!!")
time.sleep(1)
self.client.Stretch()
print("Sit !!!")
time.sleep(1)
self.client.RecoveryStand()
print("RecoveryStand !!!")
time.sleep(1)
# Robot state
robot_state = unitree_go_msg_dds__SportModeState_()
def HighStateHandler(msg: SportModeState_):
global robot_state
robot_state = msg
if __name__ == "__main__":
if len(sys.argv)>1:
ChannelFactortyInitialize(0, sys.argv[1])
else:
ChannelFactortyInitialize(0)
sub = ChannelSubscriber("rt/sportmodestate", SportModeState_)
sub.Init(HighStateHandler, 10)
time.sleep(1)
test = SportModeTest()
test.GetInitState(robot_state)
print("Start test !!!")
while True:
test.t += test.dt
test.StandUpDown()
# test.VelocityMove()
# test.BalanceAttitude()
# test.TrajectoryFollow()
# test.SpecialMotions()
time.sleep(test.dt)

View File

@ -0,0 +1,60 @@
import time
import sys
from unitree_sdk2py.core.channel import ChannelPublisher, ChannelFactortyInitialize
from unitree_sdk2py.core.channel import ChannelSubscriber, ChannelFactortyInitialize
from unitree_sdk2py.idl.default import unitree_go_msg_dds__LowCmd_
from unitree_sdk2py.idl.unitree_go.msg.dds_ import LowCmd_
from unitree_sdk2py.utils.crc import CRC
from unitree_sdk2py.utils.thread import Thread
import unitree_legged_const as go2
crc = CRC()
if __name__ == '__main__':
if len(sys.argv)>1:
ChannelFactortyInitialize(0, sys.argv[1])
else:
ChannelFactortyInitialize(0)
# Create a publisher to publish the data defined in UserData class
pub = ChannelPublisher("rt/lowcmd", LowCmd_)
pub.Init()
cmd = unitree_go_msg_dds__LowCmd_()
cmd.head[0]=0xFE
cmd.head[1]=0xEF
cmd.level_flag = 0xFF
cmd.gpio = 0
for i in range(20):
cmd.motor_cmd[i].mode = 0x01 # (PMSM) mode
cmd.motor_cmd[i].q= go2.PosStopF
cmd.motor_cmd[i].kp = 0
cmd.motor_cmd[i].dq = go2.VelStopF
cmd.motor_cmd[i].kd = 0
cmd.motor_cmd[i].tau = 0
while True:
# Toque controle, set RL_2 toque
cmd.motor_cmd[go2.LegID["RL_2"]].q = 0.0 # Set to stop position(rad)
cmd.motor_cmd[go2.LegID["RL_2"]].kp = 0.0
cmd.motor_cmd[go2.LegID["RL_2"]].dq = 0.0 # Set to stop angular velocity(rad/s)
cmd.motor_cmd[go2.LegID["RL_2"]].kd = 0.0
cmd.motor_cmd[go2.LegID["RL_2"]].tau = 1.0 # target toque is set to 1N.m
# Poinstion(rad) control, set RL_0 rad
cmd.motor_cmd[go2.LegID["RL_0"]].q = 0.0 # Taregt angular(rad)
cmd.motor_cmd[go2.LegID["RL_0"]].kp = 10.0 # Poinstion(rad) control kp gain
cmd.motor_cmd[go2.LegID["RL_0"]].dq = 0.0 # Taregt angular velocity(rad/ss)
cmd.motor_cmd[go2.LegID["RL_0"]].kd = 1.0 # Poinstion(rad) control kd gain
cmd.motor_cmd[go2.LegID["RL_0"]].tau = 0.0 # Feedforward toque 1N.m
cmd.crc = crc.Crc(cmd)
#Publish message
if pub.Write(cmd):
print("Publish success. msg:", cmd.crc)
else:
print("Waitting for subscriber.")
time.sleep(0.002)

View File

@ -0,0 +1,27 @@
import time
import sys
from unitree_sdk2py.core.channel import ChannelSubscriber, ChannelFactortyInitialize
from unitree_sdk2py.idl.default import unitree_go_msg_dds__LowState_
from unitree_sdk2py.idl.unitree_go.msg.dds_ import LowState_
import unitree_legged_const as go2
def LowStateHandler(msg: LowState_):
# print front right hip motor states
print("FR_0 motor state: ", msg.motor_state[go2.LegID["FR_0"]])
print("IMU state: ", msg.imu_state)
print("Battery state: voltage: ", msg.power_v, "current: ", msg.power_a)
if __name__ == "__main__":
if len(sys.argv)>1:
ChannelFactortyInitialize(0, sys.argv[1])
else:
ChannelFactortyInitialize(0)
sub = ChannelSubscriber("rt/lowstate", LowState_)
sub.Init(LowStateHandler, 10)
while True:
time.sleep(10.0)

View File

@ -0,0 +1,20 @@
LegID = {
"FR_0": 0, # Front right hip
"FR_1": 1, # Front right thigh
"FR_2": 2, # Front right calf
"FL_0": 3,
"FL_1": 4,
"FL_2": 5,
"RR_0": 6,
"RR_1": 7,
"RR_2": 8,
"RL_0": 9,
"RL_1": 10,
"RL_2": 11,
}
HIGHLEVEL = 0xEE
LOWLEVEL = 0xFF
TRIGERLEVEL = 0xF0
PosStopF = 2.146e9
VelStopF = 16000.0

View File

@ -0,0 +1,94 @@
import time
import sys
from unitree_sdk2py.core.channel import ChannelFactortyInitialize
from unitree_sdk2py.go2.obstacles_avoid.obstacles_avoid_client import ObstaclesAvoidClient
if __name__ == "__main__":
if len(sys.argv)>1:
ChannelFactortyInitialize(0, sys.argv[1])
else:
ChannelFactortyInitialize(0)
client = ObstaclesAvoidClient()
client.SetTimeout(3.0)
client.Init()
while True:
print("##################GetServerApiVersion###################")
code, serverAPiVersion = client.GetServerApiVersion()
if code != 0:
print("get server api error. code:", code)
else:
print("get server api version:", serverAPiVersion)
if serverAPiVersion != client.GetApiVersion():
print("api version not equal.")
time.sleep(3)
print("##################SwitchGet###################")
code, enable = client.SwitchGet()
if code != 0:
print("switch get error. code:", code)
else:
print("switch get success. enable:", enable)
time.sleep(3)
print("##################SwitchSet (on)###################")
code = client.SwitchSet(True)
if code != 0:
print("switch set error. code:", code)
else:
print("switch set success.")
time.sleep(3)
print("##################SwitchGet###################")
code, enable1 = client.SwitchGet()
if code != 0:
print("switch get error. code:", code)
else:
print("switch get success. enable:", enable1)
time.sleep(3)
print("##################SwitchSet (off)###################")
code = client.SwitchSet(False)
if code != 0:
print("switch set error. code:", code)
else:
print("switch set success.")
time.sleep(3)
print("##################SwitchGet###################")
code, enable1 = client.SwitchGet()
if code != 0:
print("switch get error. code:", code)
else:
print("switch get success. enable:", enable1)
time.sleep(3)
print("##################SwitchSet (enable)###################")
code = client.SwitchSet(enable)
if code != 0:
print("switch set error. code:", code)
else:
print("switch set success. enable:", enable)
time.sleep(3)
print("##################SwitchGet###################")
code, enable = client.SwitchGet()
if code != 0:
print("switch get error. code:", code)
else:
print("switch get success. enable:", enable)
time.sleep(3)

View File

@ -0,0 +1,77 @@
import time
import sys
from unitree_sdk2py.core.channel import ChannelFactortyInitialize
from unitree_sdk2py.go2.vui.vui_client import VuiClient
if __name__ == "__main__":
if len(sys.argv)>1:
ChannelFactortyInitialize(0, sys.argv[1])
else:
ChannelFactortyInitialize(0)
client = VuiClient()
client.SetTimeout(3.0)
client.Init()
for i in range(1, 11):
print("#################GetBrightness####################")
code, level = client.GetBrightness()
if code != 0:
print("get brightness error. code:", code)
else:
print("get brightness success. level:", level)
time.sleep(1)
print("#################SetBrightness####################")
code = client.SetBrightness(i)
if code != 0:
print("set brightness error. code:", code)
else:
print("set brightness success. level:", i)
time.sleep(1)
print("#################SetBrightness 0####################")
code = client.SetBrightness(0)
if code != 0:
print("set brightness error. code:", code)
else:
print("set brightness 0 success.")
for i in range(1, 11):
print("#################GetVolume####################")
code, level = client.GetVolume()
if code != 0:
print("get volume error. code:", code)
else:
print("get volume success. level:", level)
time.sleep(1)
print("#################SetVolume####################")
code = client.SetVolume(i)
if code != 0:
print("set volume error. code:", code)
else:
print("set volume success. level:", i)
time.sleep(1)
print("#################SetVolume 0####################")
code = client.SetVolume(0)
if code != 0:
print("set volume error. code:", code)
else:
print("set volume 0 success.")

View File

@ -0,0 +1,55 @@
import time
import sys
from unitree_sdk2py.core.channel import ChannelSubscriber, ChannelFactortyInitialize
from unitree_sdk2py.idl.default import unitree_go_msg_dds__WirelessController_
from unitree_sdk2py.idl.unitree_go.msg.dds_ import WirelessController_
key_state = [
["R1", 0],
["L1", 0],
["start", 0],
["select", 0],
["R2", 0],
["L2", 0],
["F1", 0],
["F2", 0],
["A", 0],
["B", 0],
["X", 0],
["Y", 0],
["up", 0],
["right", 0],
["down", 0],
["left", 0],
]
def WirelessControllerHandler(msg: WirelessController_):
global key_state
print("lx: ", msg.lx)
print("lx: ", msg.ly)
print("lx: ", msg.rx)
print("lx: ", msg.ry)
print("keys: ", msg.keys)
#Update key state
for i in range(16):
key_state[i][1] = (msg.keys & (1 << i)) >> i
print(key_state)
if __name__ == "__main__":
if len(sys.argv)>1:
ChannelFactortyInitialize(0, sys.argv[1])
else:
ChannelFactortyInitialize(0)
sub = ChannelSubscriber("rt/wirelesscontroller", WirelessController_)
sub.Init(WirelessControllerHandler, 10)
while True:
time.sleep(10.0)

16
setup.py Normal file
View File

@ -0,0 +1,16 @@
from setuptools import setup, find_packages
setup(name='unitree_sdk2py',
version='1.0.0',
author='Unitree',
author_email='unitree@unitree.com',
license="BSD-3-Clause",
packages=find_packages(),
description='Unitree robot sdk version 2 for python',
python_requires='>=3.8',
install_requires=[
"cyclonedds==0.10.2",
"numpy",
"opencv-python",
],
)

View File

@ -0,0 +1,9 @@
from . import idl, utils, core, rpc, go2
__all__ = [
"idl"
"utils"
"core",
"rpc",
"go2",
]

View File

@ -0,0 +1,290 @@
import time
from typing import Any, Callable
from threading import Thread, Event
from cyclonedds.domain import Domain, DomainParticipant
from cyclonedds.internal import dds_c_t
from cyclonedds.pub import DataWriter
from cyclonedds.sub import DataReader
from cyclonedds.topic import Topic
from cyclonedds.qos import Qos
from cyclonedds.core import DDSException, Listener
from cyclonedds.util import duration
from cyclonedds.internal import dds_c_t, InvalidSample
# for channel config
from .channel_config import ChannelConfigAutoDetermine, ChannelConfigHasInterface
# for singleton
from ..utils.singleton import Singleton
from ..utils.bqueue import BQueue
"""
" class ChannelReader
"""
"""
" class Channel
"""
class Channel:
"""
" internal class __Reader
"""
class __Reader:
def __init__(self):
self.__reader = None
self.__handler = None
self.__queue = None
self.__queueEnable = False
self.__threadEvent = None
self.__threadReader = None
def Init(self, participant: DomainParticipant, topic: Topic, qos: Qos = None, handler: Callable = None, queueLen: int = 0):
if handler is None:
self.__reader = DataReader(participant, topic, qos)
else:
self.__handler = handler
if queueLen > 0:
self.__queueEnable = True
self.__queue = BQueue(queueLen)
self.__threadEvent = Event()
self.__threadReader = Thread(target=self.__ChannelReaderThreadFunc, name="ch_reader", daemon=True)
self.__threadReader.start()
self.__reader = DataReader(participant, topic, qos, Listener(on_data_available=self.__OnDataAvailable))
def Read(self, timeout: float = None):
sample = None
try:
if timeout is None:
sample = self.__reader.take_one()
else:
sample = self.__reader.take_one(timeout=duration(seconds=timeout))
except DDSException as e:
print("[Reader] catch DDSException msg:", e.msg)
except TimeoutError as e:
print("[Reader] take sample timeout")
except:
print("[Reader] take sample error")
return sample
def Close(self):
if self.__reader is not None:
del self.__reader
if self.__queueEnable:
self.__threadEvent.set()
self.__queue.Interrupt()
self.__queue.Clear()
self.__threadReader.join()
def __OnDataAvailable(self, reader: DataReader):
samples = []
try:
samples = reader.take(1)
except DDSException as e:
print("[Reader] catch DDSException error. msg:", e.msg)
return
except TimeoutError as e:
print("[Reader] take sample timeout")
return
except:
print("[Reader] take sample error")
return
if samples is None:
return
# check invalid sample
sample = samples[0]
if isinstance(sample, InvalidSample):
return
# do sample
if self.__queueEnable:
self.__queue.Put(sample)
else:
self.__handler(sample)
def __ChannelReaderThreadFunc(self):
while not self.__threadEvent.is_set():
sample = self.__queue.Get()
if sample is not None:
self.__handler(sample)
"""
" internal class __Writer
"""
class __Writer:
def __init__(self):
self.__writer = None
self.__publication_matched_count = 0
def Init(self, participant: DomainParticipant, topic: Topic, qos: Qos = None):
self.__writer = DataWriter(participant, topic, qos, Listener(on_publication_matched=self.__OnPublicationMatched))
time.sleep(0.2)
def Write(self, sample: Any, timeout: float = None):
waitsec = 0.0 if timeout is None else timeout
# check publication_matched_count
while waitsec > 0.0 and self.__publication_matched_count == 0:
time.sleep(0.1)
waitsec = waitsec - 0.1
# print(time.time())
# check waitsec
if timeout is not None and waitsec <= 0.0:
return False
try:
self.__writer.write(sample)
except DDSException as e:
print("[Writer] catch DDSException error. msg:", e.msg)
return False
except Exception as e:
print("[Writer] write sample error. msg:", e.args())
return False
return True
def Close(self):
if self.__writer is not None:
del self.__writer
def __OnPublicationMatched(self, writer: DataWriter, status: dds_c_t.publication_matched_status):
self.__publication_matched_count = status.current_count
# channel __init__
def __init__(self, participant: DomainParticipant, name: str, type: Any, qos: Qos = None):
self.__reader = self.__Reader()
self.__writer = self.__Writer()
self.__participant = participant
self.__topic = Topic(self.__participant, name, type, qos)
def SetWriter(self, qos: Qos = None):
self.__writer.Init(self.__participant, self.__topic, qos)
def SetReader(self, qos: Qos = None, handler: Callable = None, queueLen: int = 0):
self.__reader.Init(self.__participant, self.__topic, qos, handler, queueLen)
def Write(self, sample: Any, timeout: float = None):
return self.__writer.Write(sample, timeout)
def Read(self, timeout: float = None):
return self.__reader.Read(timeout)
def CloseReader(self):
self.__reader.Close()
def CloseWriter(self):
self.__writer.Close()
"""
" class ChannelFactory
"""
class ChannelFactory(Singleton):
__domain = None
__participant = None
__qos = None
def __init__(self):
super().__init__()
def Init(self, id: int, networkInterface: str = None, qos: Qos = None):
config = None
# choose config
if networkInterface is None:
config = ChannelConfigAutoDetermine
else:
config = ChannelConfigHasInterface.replace('$__IF_NAME__$', networkInterface)
try:
self.__domain = Domain(id, config)
except DDSException as e:
print("[ChannelFactory] create domain error. msg:", e.msg)
return False
except:
print("[ChannelFactory] create domain error.")
return False
try:
self.__participant = DomainParticipant(id)
except DDSException as e:
print("[ChannelFactory] create domain participant error. msg:", e.msg)
return False
except:
print("[ChannelFactory] create domain participant error")
return False
self.__qos = qos
return True
def CreateChannel(self, name: str, type: Any):
return Channel(self.__participant, name, type, self.__qos)
def CreateSendChannel(self, name: str, type: Any):
channel = self.CreateChannel(name, type)
channel.SetWriter(None)
return channel
def CreateRecvChannel(self, name: str, type: Any, handler: Callable = None, queueLen: int = 0):
channel = self.CreateChannel(name, type)
channel.SetReader(None, handler, queueLen)
return channel
"""
" class ChannelPublisher
"""
class ChannelPublisher:
def __init__(self, name: str, type: Any):
factory = ChannelFactory()
self.__channel = factory.CreateChannel(name, type)
self.__inited = False
def Init(self):
if not self.__inited:
self.__channel.SetWriter(None)
self.__inited = True
def Close(self):
self.__channel.CloseWriter()
self.__inited = False
def Write(self, sample: Any, timeout: float = None):
return self.__channel.Write(sample, timeout)
"""
" class ChannelSubscriber
"""
class ChannelSubscriber:
def __init__(self, name: str, type: Any):
factory = ChannelFactory()
self.__channel = factory.CreateChannel(name, type)
self.__inited = False
def Init(self, handler: Callable = None, queueLen: int = 0):
if not self.__inited:
self.__channel.SetReader(None, handler, queueLen)
self.__inited = True
def Close(self):
self.__channel.CloseReader()
self.__inited = False
def Read(self, timeout: int = None):
return self.__channel.Read(timeout)
"""
" function ChannelFactortyInitialize. used to intialize channel everenment.
"""
def ChannelFactortyInitialize(id: int = 0, networkInterface: str = None):
factory = ChannelFactory()
if not factory.Init(id, networkInterface):
raise Exception("channel factory init error.")

View File

@ -0,0 +1,25 @@
ChannelConfigHasInterface = '''<?xml version="1.0" encoding="UTF-8" ?>
<CycloneDDS>
<Domain Id="any">
<General>
<Interfaces>
<NetworkInterface name="$__IF_NAME__$" priority="default" multicast="default"/>
</Interfaces>
</General>
<Tracing>
<Verbosity>config</Verbosity>
<OutputFile>/tmp/cdds.LOG</OutputFile>
</Tracing>
</Domain>
</CycloneDDS>'''
ChannelConfigAutoDetermine = '''<?xml version="1.0" encoding="UTF-8" ?>
<CycloneDDS>
<Domain Id="any">
<General>
<Interfaces>
<NetworkInterface autodetermine=\"true\" priority=\"default\" multicast=\"default\" />
</Interfaces>
</General>
</Domain>
</CycloneDDS>'''

View File

@ -0,0 +1,34 @@
from enum import Enum
"""
" Enum ChannelType
"""
class ChannelType(Enum):
SEND = 0
RECV = 1
"""
" function GetClientChannelName
"""
def GetClientChannelName(serviceName: str, channelType: ChannelType):
name = "rt/api/" + serviceName
if channelType == ChannelType.SEND:
name += "/request"
else:
name += "/response"
return name
"""
" function GetClientChannelName
"""
def GetServerChannelName(serviceName: str, channelType: ChannelType):
name = "rt/api/" + serviceName
if channelType == ChannelType.SEND:
name += "/response"
else:
name += "/request"
return name

View File

@ -0,0 +1,17 @@
"""
" service name
"""
OBSTACLES_AVOID_SERVICE_NAME = "obstacles_avoid"
"""
" service api version
"""
OBSTACLES_AVOID_API_VERSION = "1.0.0.1"
"""
" api id
"""
OBSTACLES_AVOID_API_ID_SWITCH_SET = 1001
OBSTACLES_AVOID_API_ID_SWITCH_GET = 1002

View File

@ -0,0 +1,40 @@
import json
from ...rpc.client import Client
from .obstacles_avoid_api import *
"""
" class ObstaclesAvoidClient
"""
class ObstaclesAvoidClient(Client):
def __init__(self):
super().__init__(OBSTACLES_AVOID_SERVICE_NAME, False)
def Init(self):
# set api version
self._SetApiVerson(OBSTACLES_AVOID_API_VERSION)
# regist api
self._RegistApi(OBSTACLES_AVOID_API_ID_SWITCH_SET, 0)
self._RegistApi(OBSTACLES_AVOID_API_ID_SWITCH_GET, 0)
# 1001
def SwitchSet(self, on: bool):
p = {}
p["enable"] = on
parameter = json.dumps(p)
code, data = self._Call(OBSTACLES_AVOID_API_ID_SWITCH_SET, parameter)
return code
# 1002
def SwitchGet(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(OBSTACLES_AVOID_API_ID_SWITCH_GET, parameter)
if code == 0:
d = json.loads(data)
return code, d["enable"]
else:
return code, None

View File

@ -0,0 +1,25 @@
"""
" service name
"""
ROBOT_STATE_SERVICE_NAME = "robot_state"
"""
" service api version
"""
ROBOT_STATE_API_VERSION = "1.0.0.1"
"""
" api id
"""
ROBOT_STATE_API_ID_SERVICE_SWITCH = 1001
ROBOT_STATE_API_ID_REPORT_FREQ = 1002
ROBOT_STATE_API_ID_SERVICE_LIST = 1003
"""
" error code
"""
ROBOT_STATE_ERR_SERVICE_SWITCH = 5201
ROBOT_STATE_ERR_SERVICE_PROTECTED = 5202

View File

@ -0,0 +1,84 @@
import json
from ...rpc.client import Client
from ...rpc.client_internal import *
from .robot_state_api import *
"""
" class ServiceState
"""
class ServiceState:
def __init__(self, name: str = None, status: int = None, protect: bool = None):
self.name = name
self.status = status
self.protect = protect
"""
" class RobotStateClient
"""
class RobotStateClient(Client):
def __init__(self):
super().__init__(ROBOT_STATE_SERVICE_NAME, False)
def Init(self):
# set api version
self._SetApiVerson(ROBOT_STATE_API_VERSION)
# regist api
self._RegistApi(ROBOT_STATE_API_ID_SERVICE_SWITCH, 0)
self._RegistApi(ROBOT_STATE_API_ID_REPORT_FREQ, 0)
self._RegistApi(ROBOT_STATE_API_ID_SERVICE_LIST, 0)
def ServiceList(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(ROBOT_STATE_API_ID_SERVICE_LIST, parameter)
if code != 0:
return code, None
lst = []
d = json.loads(data)
for t in d:
s = ServiceState()
s.name = t["name"]
s.status = t["status"]
s.protect = t["protect"]
lst.append(s)
return code, lst
def ServiceSwitch(self, name: str, switch: bool):
p = {}
p["name"] = name
p["switch"] = int(switch)
parameter = json.dumps(p)
code, data = self._Call(ROBOT_STATE_API_ID_SERVICE_SWITCH, parameter)
if code != 0:
return code
d = json.loads(data)
status = d["status"]
if status == 5:
return ROBOT_STATE_ERR_SERVICE_PROTECTED
if status != 0 and status != 1:
return ROBOT_STATE_ERR_SERVICE_SWITCH
return code
def SetReportFreq(self, interval: int, duration: int):
p = {}
p["interval"] = interval
p["duration"] = duration
parameter = json.dumps(p)
code, data = self._Call(ROBOT_STATE_API_ID_REPORT_FREQ, p)
return code

View File

@ -0,0 +1,61 @@
"""
" service name
"""
SPORT_SERVICE_NAME = "sport"
"""
" service api version
"""
SPORT_API_VERSION = "1.0.0.1"
"""
" api id
"""
SPROT_API_ID_DAMP = 1001
SPROT_API_ID_BALANCESTAND = 1002
SPROT_API_ID_STOPMOVE = 1003
SPROT_API_ID_STANDUP = 1004
SPROT_API_ID_STANDDOWN = 1005
SPROT_API_ID_RECOVERYSTAND = 1006
SPROT_API_ID_EULER = 1007
SPROT_API_ID_MOVE = 1008
SPROT_API_ID_SIT = 1009
SPROT_API_ID_RISESIT = 1010
SPROT_API_ID_SWITCHGAIT = 1011
SPROT_API_ID_TRIGGER = 1012
SPROT_API_ID_BODYHEIGHT = 1013
SPROT_API_ID_FOOTRAISEHEIGHT = 1014
SPROT_API_ID_SPEEDLEVEL = 1015
SPROT_API_ID_HELLO = 1016
SPROT_API_ID_STRETCH = 1017
SPROT_API_ID_TRAJECTORYFOLLOW = 1018
SPROT_API_ID_CONTINUOUSGAIT = 1019
SPROT_API_ID_CONTENT = 1020
SPROT_API_ID_WALLOW = 1021
SPROT_API_ID_DANCE1 = 1022
SPROT_API_ID_DANCE2 = 1023
SPROT_API_ID_GETBODYHEIGHT = 1024
SPROT_API_ID_GETFOOTRAISEHEIGHT = 1025
SPROT_API_ID_GETSPEEDLEVEL = 1026
SPROT_API_ID_SWITCHJOYSTICK = 1027
SPROT_API_ID_POSE = 1028
SPROT_API_ID_SCRAPE = 1029
SPROT_API_ID_FRONTFLIP = 1030
SPROT_API_ID_FRONTJUMP = 1031
SPROT_API_ID_FRONTPOUNCE = 1032
SPROT_API_ID_WIGGLEHIPS = 1033
SPROT_API_ID_GETSTATE = 1034
SPROT_API_ID_ECONOMICGAIT = 1035
SPROT_API_ID_HEART = 1036
"""
" error code
"""
# client side
SPORT_ERR_CLIENT_POINT_PATH = 4101
# server side
SPORT_ERR_SERVER_OVERTIME = 4201
SPROT_ERR_SERVER_NOT_INIT = 4202

View File

@ -0,0 +1,364 @@
import json
from ...rpc.client import Client
from .sport_api import *
"""
" SPORT_PATH_POINT_SIZE
"""
SPORT_PATH_POINT_SIZE = 30
"""
" class PathPoint
"""
class PathPoint:
def __init__(self, timeFromStart: float, x: float, y: float, yaw: float, vx: float, vy: float, vyaw: float):
self.timeFromStart = timeFromStart
self.x = x
self.y = y
self.yaw = yaw
self.vx = vx
self.vy = vy
self.vyaw = vyaw
"""
" class SportClient
"""
class SportClient(Client):
def __init__(self, enableLease: bool = False):
super().__init__(SPORT_SERVICE_NAME, enableLease)
def Init(self):
# set api version
self._SetApiVerson(SPORT_API_VERSION)
# regist api
self._RegistApi(SPROT_API_ID_DAMP, 0)
self._RegistApi(SPROT_API_ID_BALANCESTAND, 0)
self._RegistApi(SPROT_API_ID_STOPMOVE, 0)
self._RegistApi(SPROT_API_ID_STANDUP, 0)
self._RegistApi(SPROT_API_ID_STANDDOWN, 0)
self._RegistApi(SPROT_API_ID_RECOVERYSTAND, 0)
self._RegistApi(SPROT_API_ID_EULER, 0)
self._RegistApi(SPROT_API_ID_MOVE, 0)
self._RegistApi(SPROT_API_ID_SIT, 0)
self._RegistApi(SPROT_API_ID_RISESIT, 0)
self._RegistApi(SPROT_API_ID_SWITCHGAIT, 0)
self._RegistApi(SPROT_API_ID_TRIGGER, 0)
self._RegistApi(SPROT_API_ID_BODYHEIGHT, 0)
self._RegistApi(SPROT_API_ID_FOOTRAISEHEIGHT, 0)
self._RegistApi(SPROT_API_ID_SPEEDLEVEL, 0)
self._RegistApi(SPROT_API_ID_HELLO, 0)
self._RegistApi(SPROT_API_ID_STRETCH, 0)
self._RegistApi(SPROT_API_ID_TRAJECTORYFOLLOW, 0)
self._RegistApi(SPROT_API_ID_CONTINUOUSGAIT, 0)
# self._RegistApi(SPROT_API_ID_CONTENT, 0)
self._RegistApi(SPROT_API_ID_WALLOW, 0)
self._RegistApi(SPROT_API_ID_DANCE1, 0)
self._RegistApi(SPROT_API_ID_DANCE2, 0)
# self._RegistApi(SPROT_API_ID_GETBODYHEIGHT, 0)
# self._RegistApi(SPROT_API_ID_GETFOOTRAISEHEIGHT, 0)
# self._RegistApi(SPROT_API_ID_GETSPEEDLEVEL, 0)
self._RegistApi(SPROT_API_ID_SWITCHJOYSTICK, 0)
self._RegistApi(SPROT_API_ID_POSE, 0)
self._RegistApi(SPROT_API_ID_SCRAPE, 0)
self._RegistApi(SPROT_API_ID_FRONTFLIP, 0)
self._RegistApi(SPROT_API_ID_FRONTJUMP, 0)
self._RegistApi(SPROT_API_ID_FRONTPOUNCE, 0)
self._RegistApi(SPROT_API_ID_WIGGLEHIPS, 0)
self._RegistApi(SPROT_API_ID_GETSTATE, 0)
self._RegistApi(SPROT_API_ID_ECONOMICGAIT, 0)
self._RegistApi(SPROT_API_ID_HEART, 0)
# 1001
def Damp(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_DAMP, parameter)
return code
# 1002
def BalanceStand(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_BALANCESTAND, parameter)
return code
# 1003
def StopMove(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_STOPMOVE, parameter)
return code
# 1004
def StandUp(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_STANDUP, parameter)
return code
# 1005
def StandDown(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_STANDDOWN, parameter)
return code
# 1006
def RecoveryStand(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_RECOVERYSTAND, parameter)
return code
# 1007
def Euler(self, roll: float, pitch: float, yaw: float):
p = {}
p["x"] = roll
p["y"] = pitch
p["z"] = yaw
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_EULER, parameter)
return code
# 1008
def Move(self, vx: float, vy: float, vyaw: float):
p = {}
p["x"] = vx
p["y"] = vy
p["z"] = vyaw
parameter = json.dumps(p)
code = self._CallNoReply(SPROT_API_ID_MOVE, parameter)
return code
# 1009
def Sit(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_SIT, parameter)
return code
#1010
def RiseSit(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_RISESIT, parameter)
return code
# 1011
def SwitchGait(self, t: int):
p = {}
p["data"] = t
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_SWITCHGAIT, parameter)
return code
# 1012
def Trigger(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_TRIGGER, parameter)
return code
# 1013
def BodyHeight(self, height: float):
p = {}
p["data"] = height
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_BODYHEIGHT, parameter)
return code
# 1014
def FootRaiseHeight(self, height: float):
p = {}
p["data"] = height
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_FOOTRAISEHEIGHT, parameter)
return code
# 1015
def SpeedLevel(self, level: int):
p = {}
p["data"] = level
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_SPEEDLEVEL, parameter)
return code
# 1016
def Hello(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_HELLO, parameter)
return code
# 1017
def Stretch(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_STRETCH, parameter)
return code
# 1018
def TrajectoryFollow(self, path: list):
l = len(path)
if l != SPORT_PATH_POINT_SIZE:
return SPORT_ERR_CLIENT_POINT_PATH
path_p = []
for i in range(l):
point = path[i]
p = {}
p["t_from_start"] = point.timeFromStart
p["x"] = point.x
p["y"] = point.y
p["yaw"] = point.yaw
p["vx"] = point.vx
p["vy"] = point.vy
p["vyaw"] = point.vyaw
path_p.append(p)
parameter = json.dumps(path_p)
code = self._CallNoReply(SPROT_API_ID_TRAJECTORYFOLLOW, parameter)
return code
# 1019
def ContinuousGait(self, flag: int):
p = {}
p["data"] = flag
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_CONTINUOUSGAIT, parameter)
return code
# # 1020
# def Content(self):
# p = {}
# parameter = json.dumps(p)
# code, data = self._Call(SPROT_API_ID_CONTENT, parameter)
# return code
# 1021
def Wallow(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_WALLOW, parameter)
return code
# 1022
def Dance1(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_DANCE1, parameter)
return code
# 1023
def Dance2(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_DANCE2, parameter)
return code
# 1025
def GetFootRaiseHeight(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_GETFOOTRAISEHEIGHT, parameter)
if code == 0:
d = json.loads(data)
return code, d["data"]
else:
return code, None
# 1026
def GetSpeedLevel(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_GETSPEEDLEVEL, parameter)
if code == 0:
d = json.loads(data)
return code, d["data"]
else:
return code, None
# 1027
def SwitchJoystick(self, on: bool):
p = {}
p["data"] = on
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_SWITCHJOYSTICK, parameter)
return code
# 1028
def Pose(self, flag: bool):
p = {}
p["data"] = flag
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_POSE, parameter)
return code
# 1029
def Scrape(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_SCRAPE, parameter)
return code
# 1030
def FrontFlip(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_FRONTFLIP, parameter)
return code
# 1031
def FrontJump(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_FRONTJUMP, parameter)
return code
# 1032
def FrontPounce(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_FRONTPOUNCE, parameter)
return code
# 1033
def WiggleHips(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_WIGGLEHIPS, parameter)
return code
# 1034
def GetState(self, keys: list):
parameter = json.dumps(keys)
code, data = self._Call(SPROT_API_ID_GETSTATE, parameter)
if code == 0:
return code, json.loads(data)
else:
return code, None
# 1035
def EconomicGait(self, flag: bool):
p = {}
p["data"] = flag
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_ECONOMICGAIT, parameter)
return code
# 1036
def Heart(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(SPROT_API_ID_HEART, parameter)
return code

View File

@ -0,0 +1,16 @@
"""
" service name
"""
VIDEO_SERVICE_NAME = "videohub"
"""
" service api version
"""
VIDEO_API_VERSION = "1.0.0.1"
"""
" api id
"""
VIDEO_API_ID_GETIMAGESAMPLE = 1001

View File

@ -0,0 +1,23 @@
import json
from ...rpc.client import Client
from .video_api import *
"""
" class VideoClient
"""
class VideoClient(Client):
def __init__(self):
super().__init__(VIDEO_SERVICE_NAME, False)
def Init(self):
# set api version
self._SetApiVerson(VIDEO_API_VERSION)
# regist api
self._RegistApi(VIDEO_API_ID_GETIMAGESAMPLE, 0)
# 1001
def GetImageSample(self):
return self._CallBinary(VIDEO_API_ID_GETIMAGESAMPLE, [])

View File

@ -0,0 +1,21 @@
"""
" service name
"""
VUI_SERVICE_NAME = "vui"
"""
" service api version
"""
VUI_API_VERSION = "1.0.0.1"
"""
" api id
"""
VUI_API_ID_SETSWITCH = 1001
VUI_API_ID_GETSWITCH = 1002
VUI_API_ID_SETVOLUME = 1003
VUI_API_ID_GETVOLUME = 1004
VUI_API_ID_SETBRIGHTNESS = 1005
VUI_API_ID_GETBRIGHTNESS = 1006

View File

@ -0,0 +1,86 @@
import json
from ...rpc.client import Client
from .vui_api import *
"""
" class VideoClient
"""
class VuiClient(Client):
def __init__(self):
super().__init__(VUI_SERVICE_NAME, False)
def Init(self):
# set api version
self._SetApiVerson(VUI_API_VERSION)
# regist api
self._RegistApi(VUI_API_ID_SETSWITCH, 0)
self._RegistApi(VUI_API_ID_GETSWITCH, 0)
self._RegistApi(VUI_API_ID_SETVOLUME, 0)
self._RegistApi(VUI_API_ID_GETVOLUME, 0)
self._RegistApi(VUI_API_ID_SETBRIGHTNESS, 0)
self._RegistApi(VUI_API_ID_GETBRIGHTNESS, 0)
# 1001
def SetSwitch(self, enable: int):
p = {}
p["enable"] = enable
parameter = json.dumps(p)
code, data = self._Call(VUI_API_ID_SETSWITCH, parameter)
return code
# 1002
def GetSwitch(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(VUI_API_ID_GETSWITCH, parameter)
if code == 0:
d = json.loads(data)
return code, d["enable"]
else:
return code, None
# 1003
def SetVolume(self, level: int):
p = {}
p["volume"] = level
parameter = json.dumps(p)
code, data = self._Call(VUI_API_ID_SETVOLUME, parameter)
return code
# 1006
def GetVolume(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(VUI_API_ID_GETVOLUME, parameter)
if code == 0:
d = json.loads(data)
return code, d["volume"]
else:
return code, None
# 1005
def SetBrightness(self, level: int):
p = {}
p["brightness"] = level
parameter = json.dumps(p)
code, data = self._Call(VUI_API_ID_SETBRIGHTNESS, parameter)
return code
# 1006
def GetBrightness(self):
p = {}
parameter = json.dumps(p)
code, data = self._Call(VUI_API_ID_GETBRIGHTNESS, parameter)
if code == 0:
d = json.loads(data)
return code, d["brightness"]
else:
return code, None

View File

@ -0,0 +1,10 @@
from . import builtin_interfaces, geometry_msgs, sensor_msgs, std_msgs, unitree_go, unitree_api
__all__ = [
"builtin_interfaces",
"geometry_msgs",
"sensor_msgs",
"std_msgs",
"unitree_go",
"unitree_api",
]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: builtin_interfaces
"""
from . import msg
__all__ = ["msg", ]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: builtin_interfaces.msg
"""
from . import dds_
__all__ = ["dds_", ]

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: builtin_interfaces.msg.dds_
IDL file: Time_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import builtin_interfaces
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Time_(idl.IdlStruct, typename="builtin_interfaces.msg.dds_.Time_"):
sec: types.int32
nanosec: types.uint32

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: builtin_interfaces.msg.dds_
"""
from ._Time_ import Time_
__all__ = ["Time_", ]

View File

@ -0,0 +1,205 @@
from .builtin_interfaces.msg.dds_ import *
from .std_msgs.msg.dds_ import *
from .geometry_msgs.msg.dds_ import *
from .nav_msgs.msg.dds_ import *
from .sensor_msgs.msg.dds_ import *
from .unitree_go.msg.dds_ import *
from .unitree_api.msg.dds_ import *
"""
" builtin_interfaces_msgs.msg.dds_ dafault
"""
def builtin_interfaces_msgs_msg_dds__Time_():
return Time_(0, 0)
"""
" std_msgs.msg.dds_ dafault
"""
def std_msgs_msg_dds__Header_():
return Header_(builtin_interfaces_msgs_msg_dds__Time_(), "")
def std_msgs_msg_dds__String_():
return String_("")
"""
" geometry_msgs.msg.dds_ dafault
"""
def geometry_msgs_msg_dds__Point_():
return Point_(0.0, 0.0, 0.0)
def geometry_msgs_msg_dds__Point32_():
return Point32_(0.0, 0.0, 0.0)
def geometry_msgs_msg_dds__PointStamped_():
return PointStamped_(std_msgs_msg_dds__Header_(), geometry_msgs_msg_dds__Point_())
def geometry_msgs_msg_dds__Quaternion_():
return Quaternion_(0.0, 0.0, 0.0, 0.0)
def geometry_msgs_msg_dds__Vector3_():
return Vector3_(0.0, 0.0, 0.0)
def geometry_msgs_msg_dds__Pose_():
return Pose_(geometry_msgs_msg_dds__Point_(), geometry_msgs_msg_dds__Quaternion_())
def geometry_msgs_msg_dds__Pose2D_():
return Pose2D_(0.0, 0.0, 0.0)
def geometry_msgs_msg_dds__PoseStamped_():
return PoseStamped_(std_msgs_msg_dds__Header_(), geometry_msgs_msg_dds__Pose_())
def geometry_msgs_msg_dds__PoseWithCovariance_():
return PoseWithCovariance_(geometry_msgs_msg_dds__Pose_(), [
0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0,
0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0
])
def geometry_msgs_msg_dds__PoseWithCovarianceStamped_():
return PoseWithCovarianceStamped_(std_msgs_msg_dds__Header_(), geometry_msgs_msg_dds__PoseWithCovariance_())
def geometry_msgs_msg_dds__QuaternionStamped_():
return QuaternionStamped_(std_msgs_msg_dds__Header_(), geometry_msgs_msg_dds__Quaternion_())
def geometry_msgs_msg_dds__Twist_():
return Twist_(geometry_msgs_msg_dds__Vector3_(), geometry_msgs_msg_dds__Vector3_())
def geometry_msgs_msg_dds__TwistStamped_():
return TwistStamped_(std_msgs_msg_dds__Header_(), geometry_msgs_msg_dds__Twist_())
def geometry_msgs_msg_dds__TwistWithCovariance_():
return TwistWithCovariance_(geometry_msgs_msg_dds__Twist_(), [
0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0,
0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0
])
def geometry_msgs_msg_dds__TwistWithCovarianceStamped_():
return TwistWithCovarianceStamped_(std_msgs_msg_dds__Header_(), geometry_msgs_msg_dds__TwistWithCovariance_())
"""
" nav_msgs.msg.dds_ dafault
"""
def nav_msgs_msg_dds__MapMetaData_():
return MapMetaData_(builtin_interfaces_msgs_msg_dds__Time_(), 0, 0, geometry_msgs_msg_dds__Pose_())
def nav_msgs_msg_dds__OccupancyGrid_():
return OccupancyGrid_(std_msgs_msg_dds__Header_(), nav_msgs_msg_dds__MapMetaData_(), [])
def nav_msgs_msg_dds__Odometry_():
return Odometry_(std_msgs_msg_dds__Header_(), "", geometry_msgs_msg_dds__PoseWithCovariance_(), geometry_msgs_msg_dds__TwistWithCovariance_())
"""
" sensor_msgs.msg.dds_ dafault
"""
def sensor_msgs_msg_dds__PointField_Constants_PointField_():
return PointField_("", 0, 0, 0)
def sensor_msgs_msg_dds__PointField_Constants_PointCloud2_():
return PointCloud2_(std_msgs_msg_dds__Header_(), 0, 0, [], False, 0, 0, [], False)
"""
" unitree_go.msg.dds_ dafault
"""
def unitree_go_msg_dds__AudioData_():
return AudioData_(0, [])
def unitree_go_msg_dds__BmsCmd_():
return BmsCmd_(0, [0, 0, 0])
def unitree_go_msg_dds__BmsState_():
return BmsState_(0, 0, 0, 0, 0, 0, [0, 0], [0, 0], [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0])
def unitree_go_msg_dds__Error_():
return Error_(0, 0)
def unitree_go_msg_dds__Go2FrontVideoData_():
return Go2FrontVideoData_(0, [], [], [])
def unitree_go_msg_dds__HeightMap_():
return HeightMap_(0.0, "", 0.0, 0, 0, [0.0, 0.0], [])
def unitree_go_msg_dds__IMUState_():
return IMUState_([0.0, 0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0], 0)
def unitree_go_msg_dds__InterfaceConfig_():
return InterfaceConfig_(0, 0, [0, 0])
def unitree_go_msg_dds__LidarState_():
return LidarState_(0.0, "", "", "", 0.0, 0.0, 0, 0.0, 0.0, 0, 0, 0.0, 0.0, [0.0, 0.0, 0.0], 0.0, 0, 0)
def unitree_go_msg_dds__MotorCmd_():
return MotorCmd_(0, 0.0, 0.0, 0.0, 0.0, 0.0, [0, 0, 0])
def unitree_go_msg_dds__MotorState_():
return MotorState_(0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0, 0, [0, 0])
def unitree_go_msg_dds__LowCmd_():
return LowCmd_([0, 0], 0, 0, [0, 0], [0, 0], 0, [unitree_go_msg_dds__MotorCmd_() for i in range(20)], unitree_go_msg_dds__BmsCmd_(),
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], [0, 0], 0, 0, 0)
def unitree_go_msg_dds__LowState_():
return LowState_([0, 0], 0, 0, [0, 0], [0, 0], 0, unitree_go_msg_dds__IMUState_(), [unitree_go_msg_dds__MotorState_() for i in range(20)],
unitree_go_msg_dds__BmsState_(), [0, 0, 0, 0], [0, 0, 0, 0], 0,
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
0, 0, 0, 0, 0.0, 0.0, [0, 0, 0, 0], 0, 0)
def unitree_go_msg_dds__Req_():
return Req_("", "")
def unitree_go_msg_dds__Res_():
return Res_("", [], "")
def unitree_go_msg_dds__TimeSpec_():
return TimeSpec_(0, 0)
def unitree_go_msg_dds__PathPoint_():
return PathPoint_(0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0)
def unitree_go_msg_dds__SportModeState_():
return SportModeState_(unitree_go_msg_dds__TimeSpec_(), 0, unitree_go_msg_dds__IMUState_(), 0, 0, 0, 0.0, [0.0, 0.0, 0.0], 0.0,
[0.0, 0.0, 0.0], 0.0, [0.0, 0.0, 0.0, 0.0], [0, 0, 0, 0], [0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0],
[0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0],[unitree_go_msg_dds__PathPoint_() for i in range(10)])
def unitree_go_msg_dds__UwbState_():
return UwbState_([0, 0], 0, 0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, [0.0, 0.0], 0, 0, 0)
def unitree_go_msg_dds__UwbSwitch_():
return UwbSwitch_(0)
def unitree_go_msg_dds__WirelessController_():
return WirelessController_(0.0, 0.0, 0.0, 0.0, 0)
"""
" unitree_api.msg.dds_ dafault
"""
def unitree_api_msg_dds__RequestIdentity_():
return RequestIdentity_(0, 0)
def unitree_api_msg_dds__RequestLease_():
return RequestLease_(0)
def unitree_api_msg_dds__RequestPolicy_():
return RequestPolicy_(0, False)
def unitree_api_msg_dds__RequestHeader_():
return RequestHeader_(unitree_api_msg_dds__RequestIdentity_(), unitree_api_msg_dds__RequestLease_(), unitree_api_msg_dds__RequestPolicy_())
def unitree_api_msg_dds__Request_():
return Request_(unitree_api_msg_dds__RequestHeader_(), "", [])
def unitree_api_msg_dds__ResponseStatus_():
return ResponseStatus_(0)
def unitree_api_msg_dds__ResponseHeader_():
return ResponseHeader_(unitree_api_msg_dds__RequestIdentity_(), unitree_api_msg_dds__ResponseStatus_())
def unitree_api_msg_dds__Response_():
return Response_(unitree_api_msg_dds__ResponseHeader_(), "", [])

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs
"""
from . import msg
__all__ = ["msg", ]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg
"""
from . import dds_
__all__ = ["dds_", ]

View File

@ -0,0 +1,29 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: Point32_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Point32_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.Point32_"):
x: types.float32
y: types.float32
z: types.float32

View File

@ -0,0 +1,31 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: PointStamped_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
# if TYPE_CHECKING:
# import std_msgs.msg.dds_
@dataclass
@annotate.final
@annotate.autoid("sequential")
class PointStamped_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.PointStamped_"):
header: 'unitree_sdk2py.idl.std_msgs.msg.dds_.Header_'
point: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.Point_'

View File

@ -0,0 +1,29 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: Point_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Point_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.Point_"):
x: types.float64
y: types.float64
z: types.float64

View File

@ -0,0 +1,29 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: Pose2D_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Pose2D_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.Pose2D_"):
x: types.float64
y: types.float64
theta: types.float64

View File

@ -0,0 +1,32 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: PoseStamped_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
# if TYPE_CHECKING:
# import std_msgs.msg.dds_
@dataclass
@annotate.final
@annotate.autoid("sequential")
class PoseStamped_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.PoseStamped_"):
header: 'unitree_sdk2py.idl.std_msgs.msg.dds_.Header_'
pose: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.Pose_'

View File

@ -0,0 +1,32 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: PoseWithCovarianceStamped_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
# if TYPE_CHECKING:
# import std_msgs.msg.dds_
@dataclass
@annotate.final
@annotate.autoid("sequential")
class PoseWithCovarianceStamped_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.PoseWithCovarianceStamped_"):
header: 'unitree_sdk2py.idl.std_msgs.msg.dds_.Header_'
pose: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.PoseWithCovariance_'

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: PoseWithCovariance_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
@dataclass
@annotate.final
@annotate.autoid("sequential")
class PoseWithCovariance_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.PoseWithCovariance_"):
pose: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.Pose_'
covariance: types.array[types.float64, 36]

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: Pose_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Pose_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.Pose_"):
position: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.Point_'
orientation: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.Quaternion_'

View File

@ -0,0 +1,32 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: QuaternionStamped_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
# if TYPE_CHECKING:
# import std_msgs.msg.dds_
@dataclass
@annotate.final
@annotate.autoid("sequential")
class QuaternionStamped_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.QuaternionStamped_"):
header: 'unitree_sdk2py.idl.std_msgs.msg.dds_.Header_'
quaternion: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.Quaternion_'

View File

@ -0,0 +1,30 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: Quaternion_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Quaternion_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.Quaternion_"):
x: types.float64
y: types.float64
z: types.float64
w: types.float64

View File

@ -0,0 +1,32 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: TwistStamped_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
# if TYPE_CHECKING:
# import std_msgs.msg.dds_
@dataclass
@annotate.final
@annotate.autoid("sequential")
class TwistStamped_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.TwistStamped_"):
header: 'unitree_sdk2py.idl.std_msgs.msg.dds_.Header_'
twist: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.Twist_'

View File

@ -0,0 +1,32 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: TwistWithCovarianceStamped_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
# if TYPE_CHECKING:
# import std_msgs.msg.dds_
@dataclass
@annotate.final
@annotate.autoid("sequential")
class TwistWithCovarianceStamped_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.TwistWithCovarianceStamped_"):
header: 'unitree_sdk2py.idl.std_msgs.msg.dds_.Header_'
twist: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.TwistWithCovariance_'

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: TwistWithCovariance_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
@dataclass
@annotate.final
@annotate.autoid("sequential")
class TwistWithCovariance_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.TwistWithCovariance_"):
twist: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.Twist_'
covariance: types.array[types.float64, 36]

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: Twist_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Twist_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.Twist_"):
linear: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.Vector3_'
angular: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.Vector3_'

View File

@ -0,0 +1,29 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
IDL file: Vector3_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import geometry_msgs
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Vector3_(idl.IdlStruct, typename="geometry_msgs.msg.dds_.Vector3_"):
x: types.float64
y: types.float64
z: types.float64

View File

@ -0,0 +1,23 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: geometry_msgs.msg.dds_
"""
from ._Point32_ import Point32_
from ._Point_ import Point_
from ._PointStamped_ import PointStamped_
from ._Pose2D_ import Pose2D_
from ._Pose_ import Pose_
from ._PoseStamped_ import PoseStamped_
from ._PoseWithCovariance_ import PoseWithCovariance_
from ._PoseWithCovarianceStamped_ import PoseWithCovarianceStamped_
from ._Quaternion_ import Quaternion_
from ._QuaternionStamped_ import QuaternionStamped_
from ._Twist_ import Twist_
from ._TwistStamped_ import TwistStamped_
from ._TwistWithCovariance_ import TwistWithCovariance_
from ._TwistWithCovarianceStamped_ import TwistWithCovarianceStamped_
from ._Vector3_ import Vector3_
__all__ = ["Point32_", "Point_", "PointStamped_", "Pose2D_", "Pose_", "PoseStamped_", "PoseWithCovariance_", "PoseWithCovarianceStamped_", "Quaternion_", "QuaternionStamped_", "Twist_", "TwistStamped_", "TwistWithCovariance_", "TwistWithCovarianceStamped_", "Vector3_", ]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: nav_msgs
"""
from . import msg
__all__ = ["msg", ]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: nav_msgs.msg
"""
from . import dds_
__all__ = ["dds_", ]

View File

@ -0,0 +1,35 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: nav_msgs.msg.dds_
IDL file: MapMetaData_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import nav_msgs
# if TYPE_CHECKING:
# import builtin_interfaces.msg.dds_
# import geometry_msgs.msg.dds_
@dataclass
@annotate.final
@annotate.autoid("sequential")
class MapMetaData_(idl.IdlStruct, typename="nav_msgs.msg.dds_.MapMetaData_"):
map_load_time: 'unitree_sdk2py.idl.builtin_interfaces.msg.dds_.Time_'
resolution: types.float32
width: types.uint32
height: types.uint32
origin: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.Pose_'

View File

@ -0,0 +1,33 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: nav_msgs.msg.dds_
IDL file: OccupancyGrid_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import nav_msgs
# if TYPE_CHECKING:
# import std_msgs.msg.dds_
@dataclass
@annotate.final
@annotate.autoid("sequential")
class OccupancyGrid_(idl.IdlStruct, typename="nav_msgs.msg.dds_.OccupancyGrid_"):
header: 'unitree_sdk2py.idl.std_msgs.msg.dds_.Header_'
info: 'unitree_sdk2py.idl.nav_msgs.msg.dds_.MapMetaData_'
data: types.sequence[types.uint8]

View File

@ -0,0 +1,35 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: nav_msgs.msg.dds_
IDL file: Odometry_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import nav_msgs
# if TYPE_CHECKING:
# import geometry_msgs.msg.dds_
# import std_msgs.msg.dds_
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Odometry_(idl.IdlStruct, typename="nav_msgs.msg.dds_.Odometry_"):
header: 'unitree_sdk2py.idl.std_msgs.msg.dds_.Header_'
child_frame_id: str
pose: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.PoseWithCovariance_'
twist: 'unitree_sdk2py.idl.geometry_msgs.msg.dds_.TwistWithCovariance_'

View File

@ -0,0 +1,11 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: nav_msgs.msg.dds_
"""
from ._MapMetaData_ import MapMetaData_
from ._OccupancyGrid_ import OccupancyGrid_
from ._Odometry_ import Odometry_
__all__ = ["MapMetaData_", "OccupancyGrid_", "Odometry_", ]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: sensor_msgs
"""
from . import msg
__all__ = ["msg", ]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: sensor_msgs.msg
"""
from . import dds_
__all__ = ["dds_", ]

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: sensor_msgs.msg.dds_.PointField_Constants
IDL file: PointField_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import sensor_msgs
INT8_ = 1
UINT8_ = 2
INT16_ = 3
UINT16_ = 4
INT32_ = 5
UINT32_ = 6
FLOAT32_ = 7
FLOAT64_ = 8

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: sensor_msgs.msg.dds_.PointField_Constants
"""
from ._PointField_ import FLOAT32_, FLOAT64_, INT16_, INT32_, INT8_, UINT16_, UINT32_, UINT8_
__all__ = ["FLOAT32_", "FLOAT64_", "INT16_", "INT32_", "INT8_", "UINT16_", "UINT32_", "UINT8_", ]

View File

@ -0,0 +1,39 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: sensor_msgs.msg.dds_
IDL file: PointCloud2_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import sensor_msgs
# if TYPE_CHECKING:
# import std_msgs.msg.dds_
@dataclass
@annotate.final
@annotate.autoid("sequential")
class PointCloud2_(idl.IdlStruct, typename="sensor_msgs.msg.dds_.PointCloud2_"):
header: 'unitree_sdk2py.idl.std_msgs.msg.dds_.Header_'
height: types.uint32
width: types.uint32
fields: types.sequence['unitree_sdk2py.idl.sensor_msgs.msg.dds_.PointField_']
is_bigendian: bool
point_step: types.uint32
row_step: types.uint32
data: types.sequence[types.uint8]
is_dense: bool

View File

@ -0,0 +1,30 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: sensor_msgs.msg.dds_
IDL file: PointField_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import sensor_msgs
@dataclass
@annotate.final
@annotate.autoid("sequential")
class PointField_(idl.IdlStruct, typename="sensor_msgs.msg.dds_.PointField_"):
name: str
offset: types.uint32
datatype: types.uint8
count: types.uint32

View File

@ -0,0 +1,11 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: sensor_msgs.msg.dds_
"""
from . import PointField_Constants
from ._PointCloud2_ import PointCloud2_
from ._PointField_ import PointField_
__all__ = ["PointField_Constants", "PointCloud2_", "PointField_", ]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: std_msgs
"""
from . import msg
__all__ = ["msg", ]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: std_msgs.msg
"""
from . import dds_
__all__ = ["dds_", ]

View File

@ -0,0 +1,32 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: std_msgs.msg.dds_
IDL file: Header_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import std_msgs
# if TYPE_CHECKING:
# import builtin_interfaces.msg.dds_
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Header_(idl.IdlStruct, typename="std_msgs.msg.dds_.Header_"):
stamp: 'unitree_sdk2py.idl.builtin_interfaces.msg.dds_.Time_'
frame_id: str

View File

@ -0,0 +1,27 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: std_msgs.msg.dds_
IDL file: String_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import std_msgs
@dataclass
@annotate.final
@annotate.autoid("sequential")
class String_(idl.IdlStruct, typename="std_msgs.msg.dds_.String_"):
data: str

View File

@ -0,0 +1,10 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: std_msgs.msg.dds_
"""
from ._Header_ import Header_
from ._String_ import String_
__all__ = ["Header_", "String_", ]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.10.2
Module: unitree_api
"""
from . import msg
__all__ = ["msg", ]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.10.2
Module: unitree_api.msg
"""
from . import dds_
__all__ = ["dds_", ]

View File

@ -0,0 +1,29 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.10.2
Module: unitree_api.msg.dds_
IDL file: RequestHeader_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_api
@dataclass
@annotate.final
@annotate.autoid("sequential")
class RequestHeader_(idl.IdlStruct, typename="unitree_api.msg.dds_.RequestHeader_"):
identity: 'unitree_sdk2py.idl.unitree_api.msg.dds_.RequestIdentity_'
lease: 'unitree_sdk2py.idl.unitree_api.msg.dds_.RequestLease_'
policy: 'unitree_sdk2py.idl.unitree_api.msg.dds_.RequestPolicy_'

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.10.2
Module: unitree_api.msg.dds_
IDL file: RequestIdentity_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_api
@dataclass
@annotate.final
@annotate.autoid("sequential")
class RequestIdentity_(idl.IdlStruct, typename="unitree_api.msg.dds_.RequestIdentity_"):
id: types.int64
api_id: types.int64

View File

@ -0,0 +1,27 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.10.2
Module: unitree_api.msg.dds_
IDL file: RequestLease_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_api
@dataclass
@annotate.final
@annotate.autoid("sequential")
class RequestLease_(idl.IdlStruct, typename="unitree_api.msg.dds_.RequestLease_"):
id: types.int64

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.10.2
Module: unitree_api.msg.dds_
IDL file: RequestPolicy_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_api
@dataclass
@annotate.final
@annotate.autoid("sequential")
class RequestPolicy_(idl.IdlStruct, typename="unitree_api.msg.dds_.RequestPolicy_"):
priority: types.int32
noreply: bool

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.10.2
Module: unitree_api.msg.dds_
IDL file: Request_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_api
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Request_(idl.IdlStruct, typename="unitree_api.msg.dds_.Request_"):
header: 'unitree_sdk2py.idl.unitree_api.msg.dds_.RequestHeader_'
parameter: str
binary: types.sequence[types.uint8]

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.10.2
Module: unitree_api.msg.dds_
IDL file: ResponseHeader_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_api
@dataclass
@annotate.final
@annotate.autoid("sequential")
class ResponseHeader_(idl.IdlStruct, typename="unitree_api.msg.dds_.ResponseHeader_"):
identity: 'unitree_sdk2py.idl.unitree_api.msg.dds_.RequestIdentity_'
status: 'unitree_sdk2py.idl.unitree_api.msg.dds_.ResponseStatus_'

View File

@ -0,0 +1,27 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.10.2
Module: unitree_api.msg.dds_
IDL file: ResponseStatus_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_api
@dataclass
@annotate.final
@annotate.autoid("sequential")
class ResponseStatus_(idl.IdlStruct, typename="unitree_api.msg.dds_.ResponseStatus_"):
code: types.int32

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.10.2
Module: unitree_api.msg.dds_
IDL file: Response_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_api
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Response_(idl.IdlStruct, typename="unitree_api.msg.dds_.Response_"):
header: 'unitree_sdk2py.idl.unitree_api.msg.dds_.ResponseHeader_'
data: str
binary: types.sequence[types.uint8]

View File

@ -0,0 +1,16 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.10.2
Module: unitree_api.msg.dds_
"""
from ._RequestHeader_ import RequestHeader_
from ._RequestIdentity_ import RequestIdentity_
from ._RequestLease_ import RequestLease_
from ._RequestPolicy_ import RequestPolicy_
from ._Request_ import Request_
from ._ResponseHeader_ import ResponseHeader_
from ._ResponseStatus_ import ResponseStatus_
from ._Response_ import Response_
__all__ = ["RequestHeader_", "RequestIdentity_", "RequestLease_", "RequestPolicy_", "Request_", "ResponseHeader_", "ResponseStatus_", "Response_", ]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go
"""
from . import msg
__all__ = ["msg", ]

View File

@ -0,0 +1,9 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg
"""
from . import dds_
__all__ = ["dds_", ]

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: AudioData_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class AudioData_(idl.IdlStruct, typename="unitree_go.msg.dds_.AudioData_"):
time_frame: types.uint64
data: types.sequence[types.uint8]

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: BmsCmd_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class BmsCmd_(idl.IdlStruct, typename="unitree_go.msg.dds_.BmsCmd_"):
off: types.uint8
reserve: types.array[types.uint8, 3]

View File

@ -0,0 +1,35 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: BmsState_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class BmsState_(idl.IdlStruct, typename="unitree_go.msg.dds_.BmsState_"):
version_high: types.uint8
version_low: types.uint8
status: types.uint8
soc: types.uint8
current: types.int32
cycle: types.uint16
bq_ntc: types.array[types.uint8, 2]
mcu_ntc: types.array[types.uint8, 2]
cell_vol: types.array[types.uint16, 15]

View File

@ -0,0 +1,28 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: Error_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Error_(idl.IdlStruct, typename="unitree_go.msg.dds_.Error_"):
source: types.uint32
state: types.uint32

View File

@ -0,0 +1,30 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: Go2FrontVideoData_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class Go2FrontVideoData_(idl.IdlStruct, typename="unitree_go.msg.dds_.Go2FrontVideoData_"):
time_frame: types.uint64
video720p: types.sequence[types.uint8]
video360p: types.sequence[types.uint8]
video180p: types.sequence[types.uint8]

View File

@ -0,0 +1,33 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: HeightMap_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class HeightMap_(idl.IdlStruct, typename="unitree_go.msg.dds_.HeightMap_"):
stamp: types.float64
frame_id: str
resolution: types.float32
width: types.uint32
height: types.uint32
origin: types.array[types.float32, 2]
data: types.sequence[types.float32]

View File

@ -0,0 +1,31 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: IMUState_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class IMUState_(idl.IdlStruct, typename="unitree_go.msg.dds_.IMUState_"):
quaternion: types.array[types.float32, 4]
gyroscope: types.array[types.float32, 3]
accelerometer: types.array[types.float32, 3]
rpy: types.array[types.float32, 3]
temperature: types.uint8

View File

@ -0,0 +1,29 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: InterfaceConfig_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class InterfaceConfig_(idl.IdlStruct, typename="unitree_go.msg.dds_.InterfaceConfig_"):
mode: types.uint8
value: types.uint8
reserve: types.array[types.uint8, 2]

View File

@ -0,0 +1,43 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: LidarState_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class LidarState_(idl.IdlStruct, typename="unitree_go.msg.dds_.LidarState_"):
stamp: types.float64
firmware_version: str
software_version: str
sdk_version: str
sys_rotation_speed: types.float32
com_rotation_speed: types.float32
error_state: types.uint8
cloud_frequency: types.float32
cloud_packet_loss_rate: types.float32
cloud_size: types.uint32
cloud_scan_num: types.uint32
imu_frequency: types.float32
imu_packet_loss_rate: types.float32
imu_rpy: types.array[types.float32, 3]
serial_recv_stamp: types.float64
serial_buffer_size: types.uint32
serial_buffer_read: types.uint32

View File

@ -0,0 +1,40 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: LowCmd_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class LowCmd_(idl.IdlStruct, typename="unitree_go.msg.dds_.LowCmd_"):
head: types.array[types.uint8, 2]
level_flag: types.uint8
frame_reserve: types.uint8
sn: types.array[types.uint32, 2]
version: types.array[types.uint32, 2]
bandwidth: types.uint16
motor_cmd: types.array['unitree_sdk2py.idl.unitree_go.msg.dds_.MotorCmd_', 20]
bms_cmd: 'unitree_sdk2py.idl.unitree_go.msg.dds_.BmsCmd_'
wireless_remote: types.array[types.uint8, 40]
led: types.array[types.uint8, 12]
fan: types.array[types.uint8, 2]
gpio: types.uint8
reserve: types.uint32
crc: types.uint32

View File

@ -0,0 +1,48 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: LowState_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class LowState_(idl.IdlStruct, typename="unitree_go.msg.dds_.LowState_"):
head: types.array[types.uint8, 2]
level_flag: types.uint8
frame_reserve: types.uint8
sn: types.array[types.uint32, 2]
version: types.array[types.uint32, 2]
bandwidth: types.uint16
imu_state: 'unitree_sdk2py.idl.unitree_go.msg.dds_.IMUState_'
motor_state: types.array['unitree_sdk2py.idl.unitree_go.msg.dds_.MotorState_', 20]
bms_state: 'unitree_sdk2py.idl.unitree_go.msg.dds_.BmsState_'
foot_force: types.array[types.int16, 4]
foot_force_est: types.array[types.int16, 4]
tick: types.uint32
wireless_remote: types.array[types.uint8, 40]
bit_flag: types.uint8
adc_reel: types.float32
temperature_ntc1: types.uint8
temperature_ntc2: types.uint8
power_v: types.float32
power_a: types.float32
fan_frequency: types.array[types.uint16, 4]
reserve: types.uint32
crc: types.uint32

View File

@ -0,0 +1,33 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: MotorCmd_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class MotorCmd_(idl.IdlStruct, typename="unitree_go.msg.dds_.MotorCmd_"):
mode: types.uint8
q: types.float32
dq: types.float32
tau: types.float32
kp: types.float32
kd: types.float32
reserve: types.array[types.uint32, 3]

View File

@ -0,0 +1,37 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: MotorState_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class MotorState_(idl.IdlStruct, typename="unitree_go.msg.dds_.MotorState_"):
mode: types.uint8
q: types.float32
dq: types.float32
ddq: types.float32
tau_est: types.float32
q_raw: types.float32
dq_raw: types.float32
ddq_raw: types.float32
temperature: types.uint8
lost: types.uint32
reserve: types.array[types.uint32, 2]

View File

@ -0,0 +1,33 @@
"""
Generated by Eclipse Cyclone DDS idlc Python Backend
Cyclone DDS IDL version: v0.11.0
Module: unitree_go.msg.dds_
IDL file: PathPoint_.idl
"""
from enum import auto
from typing import TYPE_CHECKING, Optional
from dataclasses import dataclass
import cyclonedds.idl as idl
import cyclonedds.idl.annotations as annotate
import cyclonedds.idl.types as types
# root module import for resolving types
# import unitree_go
@dataclass
@annotate.final
@annotate.autoid("sequential")
class PathPoint_(idl.IdlStruct, typename="unitree_go.msg.dds_.PathPoint_"):
t_from_start: types.float32
x: types.float32
y: types.float32
yaw: types.float32
vx: types.float32
vy: types.float32
vyaw: types.float32

Some files were not shown because too many files have changed in this diff Show More