lowstate command interface added
This commit is contained in:
parent
a0d3374a77
commit
f452ab732d
|
@ -160,9 +160,13 @@ cython_debug/
|
|||
#.idea/
|
||||
.vscode
|
||||
|
||||
deploy/ros2_ws/log
|
||||
deploy/ros2_ws/install
|
||||
deploy/ros2_ws/build
|
||||
deploy/robot_ws/log
|
||||
deploy/robot_ws/install
|
||||
deploy/robot_ws/build
|
||||
|
||||
deploy/dock_ws/log
|
||||
deploy/dock_ws/install
|
||||
deploy/dock_ws/build
|
||||
|
||||
_isaac_sim
|
||||
.vscode
|
|
@ -20,6 +20,6 @@ do
|
|||
idlc -l ../../idl/libcycloneddsidlcxx.so.0.10.2 $file
|
||||
done
|
||||
cd ../..
|
||||
rm -r ../cpp_bridge/include/go2py
|
||||
mv msgs/cpp ../cpp_bridge/include/go2py
|
||||
# rm -r ../cpp_bridge/include/go2py
|
||||
# mv msgs/cpp ../cpp_bridge/include/go2py
|
||||
echo -e "${GREEN} Done with DDS type generation${NC}"
|
|
@ -1,11 +0,0 @@
|
|||
Imu
|
||||
|
||||
Imu
|
||||
|
||||
LowCmd
|
||||
|
||||
LowCmd
|
||||
|
||||
LowState
|
||||
|
||||
LowState
|
|
@ -1,31 +0,0 @@
|
|||
"""
|
||||
Generated by Eclipse Cyclone DDS idlc Python Backend
|
||||
Cyclone DDS IDL version: v0.11.0
|
||||
Module: msgs
|
||||
IDL file: Imu.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 msgs
|
||||
|
||||
|
||||
@dataclass
|
||||
@annotate.final
|
||||
@annotate.autoid("sequential")
|
||||
class Imu(idl.IdlStruct, typename="msgs.Imu"):
|
||||
q: types.array[types.float32, 4]
|
||||
gyro: types.array[types.float32, 3]
|
||||
accel: types.array[types.float32, 3]
|
||||
rpy: types.array[types.float32, 3]
|
||||
tmp: types.uint8
|
||||
|
||||
|
|
@ -1,32 +0,0 @@
|
|||
"""
|
||||
Generated by Eclipse Cyclone DDS idlc Python Backend
|
||||
Cyclone DDS IDL version: v0.11.0
|
||||
Module: msgs
|
||||
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 msgs
|
||||
|
||||
|
||||
@dataclass
|
||||
@annotate.final
|
||||
@annotate.autoid("sequential")
|
||||
class LowCmd(idl.IdlStruct, typename="msgs.LowCmd"):
|
||||
q: types.array[types.float32, 12]
|
||||
dq: types.array[types.float32, 12]
|
||||
tau_ff: types.array[types.float32, 12]
|
||||
kp: types.array[types.float32, 12]
|
||||
kv: types.array[types.float32, 12]
|
||||
e_stop: types.uint8
|
||||
|
||||
|
|
@ -1,39 +0,0 @@
|
|||
"""
|
||||
Generated by Eclipse Cyclone DDS idlc Python Backend
|
||||
Cyclone DDS IDL version: v0.11.0
|
||||
Module: msgs
|
||||
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 msgs
|
||||
|
||||
|
||||
@dataclass
|
||||
@annotate.final
|
||||
@annotate.autoid("sequential")
|
||||
class LowState(idl.IdlStruct, typename="msgs.LowState"):
|
||||
q: types.array[types.float32, 12]
|
||||
dq: types.array[types.float32, 12]
|
||||
ddq: types.array[types.float32, 12]
|
||||
tau_est: types.array[types.float32, 12]
|
||||
tmp: types.array[types.float32, 12]
|
||||
contact: types.array[types.float32, 4]
|
||||
quat: types.array[types.float32, 4]
|
||||
gyro: types.array[types.float32, 3]
|
||||
accel: types.array[types.float32, 3]
|
||||
rpy: types.array[types.float32, 3]
|
||||
imu_tmp: types.uint8
|
||||
voltage: types.float32
|
||||
current: types.float32
|
||||
|
||||
|
|
@ -1,11 +0,0 @@
|
|||
"""
|
||||
Generated by Eclipse Cyclone DDS idlc Python Backend
|
||||
Cyclone DDS IDL version: v0.11.0
|
||||
Module: msgs
|
||||
|
||||
"""
|
||||
|
||||
from ._Imu import Imu
|
||||
from ._LowCmd import LowCmd
|
||||
from ._LowState import LowState
|
||||
__all__ = ["Imu", "LowCmd", "LowState", ]
|
|
@ -12,7 +12,7 @@ from rclpy.executors import MultiThreadedExecutor
|
|||
from geometry_msgs.msg import TransformStamped
|
||||
from Go2Py.joy import xKeySwitch, xRockerBtn
|
||||
from geometry_msgs.msg import TwistStamped
|
||||
from unitree_go.msg import LowState
|
||||
from unitree_go.msg import LowState, LowCmd
|
||||
from nav_msgs.msg import Odometry
|
||||
|
||||
|
||||
|
@ -57,7 +57,6 @@ class ROS2ExecutorManager:
|
|||
if self.executor_thread:
|
||||
self.executor_thread.join()
|
||||
|
||||
|
||||
class GO2Real(Node):
|
||||
def __init__(
|
||||
self,
|
||||
|
@ -70,6 +69,7 @@ class GO2Real(Node):
|
|||
self.mode = mode
|
||||
self.node_name = "go2py_highlevel_subscriber"
|
||||
self.highcmd_topic = "/go2/twist_cmd"
|
||||
self.lowcmd_topic = "/go2/lowcmd"
|
||||
self.joint_state_topic = "/go2/joint_states"
|
||||
self.lowstate_topic = "/lowstate"
|
||||
super().__init__(self.node_name)
|
||||
|
@ -77,6 +77,7 @@ class GO2Real(Node):
|
|||
self.lowstate_subscriber = self.create_subscription(
|
||||
LowState, self.lowstate_topic, self.lowstate_callback, 1
|
||||
)
|
||||
self.lowcmd_publisher = self.create_publisher(LowCmd, self.lowcmd_topic, 1)
|
||||
|
||||
self.odometry_subscriber = self.create_subscription(
|
||||
Odometry, "/utlidar/robot_odom", self.odom_callback, 1
|
||||
|
@ -94,6 +95,8 @@ class GO2Real(Node):
|
|||
self.ωz_max = ωz_max
|
||||
self.ωz_min = -ωz_max
|
||||
self.running = True
|
||||
self.setCommands = {'lowstate':self.setCommandsLow,
|
||||
'highstate':self.setCommandsHigh}[self.mode]
|
||||
|
||||
def lowstate_callback(self, msg):
|
||||
"""
|
||||
|
@ -169,7 +172,6 @@ class GO2Real(Node):
|
|||
|
||||
keySwitch = xKeySwitch(*btn)
|
||||
rockerBtn = xRockerBtn(head, keySwitch, lx, rx, ry, L2, ly)
|
||||
|
||||
return rockerBtn
|
||||
|
||||
def getCommandFromRemote(self):
|
||||
|
@ -191,18 +193,25 @@ class GO2Real(Node):
|
|||
batteryState = self.state.bms
|
||||
return batteryState.SOC
|
||||
|
||||
def setCommands(self, v_x, v_y, ω_z, bodyHeight=0.0, footRaiseHeight=0.0, mode=2):
|
||||
if self.mode == 'highlevel':
|
||||
self.cmd_watchdog_timer = time.time()
|
||||
_v_x, _v_y, _ω_z = self.clip_velocity(v_x, v_y, ω_z)
|
||||
self.highcmd.header.stamp = self.get_clock().now().to_msg()
|
||||
self.highcmd.header.frame_id = "base_link"
|
||||
self.highcmd.twist.linear.x = _v_x
|
||||
self.highcmd.twist.linear.y = _v_y
|
||||
self.highcmd.twist.angular.z = _ω_z
|
||||
self.highcmd_publisher.publish(self.highcmd)
|
||||
else:
|
||||
raise NotImplementedError("Low level control command is not implemented yet")
|
||||
def setCommandsHigh(self, v_x, v_y, ω_z, bodyHeight=0.0, footRaiseHeight=0.0, mode=2):
|
||||
self.cmd_watchdog_timer = time.time()
|
||||
_v_x, _v_y, _ω_z = self.clip_velocity(v_x, v_y, ω_z)
|
||||
self.highcmd.header.stamp = self.get_clock().now().to_msg()
|
||||
self.highcmd.header.frame_id = "base_link"
|
||||
self.highcmd.twist.linear.x = _v_x
|
||||
self.highcmd.twist.linear.y = _v_y
|
||||
self.highcmd.twist.angular.z = _ω_z
|
||||
self.highcmd_publisher.publish(self.highcmd)
|
||||
|
||||
def setCommandsLow(q, dq, kp, kd, tau_ff):
|
||||
assert q.size == qd.size == kp.size == kd.size == tau_ff.size == 12, "q, dq, kp, kd, tau_ff should have size 12"
|
||||
lowcmd = LowCmd()
|
||||
lowcmd.motor_cmd.q = q.tolist()
|
||||
lowcmd.motor_cmd.dq = dq.tolist()
|
||||
lowcmd.motor_cmd.kp = kp.tolist()
|
||||
lowcmd.motor_cmd.kd = kd.tolist()
|
||||
lowcmd.motor_cmd.tau_ff = tau_ff.tolist()
|
||||
self.lowcmd_publisher.publish(lowcmd)
|
||||
|
||||
def close(self):
|
||||
self.running = False
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue