Browse Source

Add motion mode support for H1_2

- Add motion_mode parameter to H1_2_ArmController constructor
- Use kTopicLowCommand_Motion publisher when motion_mode is enabled
- Add motion control logic in motor state control loop
- Add gradual weight transition during homing sequence for motion mode
- Update main teleop script to pass motion mode flag to H1_2_ArmController
main
Brandon 7 months ago
committed by GitHub
parent
commit
c840b5f6e2
No known key found for this signature in database GPG Key ID: B5690EEEBB952194
  1. 14
      teleop/robot_control/robot_arm.py
  2. 2
      teleop/teleop_hand_and_arm.py

14
teleop/robot_control/robot_arm.py

@ -625,8 +625,9 @@ class G1_23_JointIndex(IntEnum):
kNotUsedJoint5 = 34 kNotUsedJoint5 = 34
class H1_2_ArmController: class H1_2_ArmController:
def __init__(self, simulation_mode = False):
def __init__(self, motion_mode = False, simulation_mode = False):
self.simulation_mode = simulation_mode self.simulation_mode = simulation_mode
self.motion_mode = motion_mode
logger_mp.info("Initialize H1_2_ArmController...") logger_mp.info("Initialize H1_2_ArmController...")
self.q_target = np.zeros(14) self.q_target = np.zeros(14)
@ -652,6 +653,10 @@ class H1_2_ArmController:
ChannelFactoryInitialize(1) ChannelFactoryInitialize(1)
else: else:
ChannelFactoryInitialize(0) ChannelFactoryInitialize(0)
if self.motion_mode:
self.lowcmd_publisher = ChannelPublisher(kTopicLowCommand_Motion, hg_LowCmd)
else:
self.lowcmd_publisher = ChannelPublisher(kTopicLowCommand_Debug, hg_LowCmd) self.lowcmd_publisher = ChannelPublisher(kTopicLowCommand_Debug, hg_LowCmd)
self.lowcmd_publisher.Init() self.lowcmd_publisher.Init()
self.lowstate_subscriber = ChannelSubscriber(kTopicLowState, hg_LowState) self.lowstate_subscriber = ChannelSubscriber(kTopicLowState, hg_LowState)
@ -726,6 +731,9 @@ class H1_2_ArmController:
return cliped_arm_q_target return cliped_arm_q_target
def _ctrl_motor_state(self): def _ctrl_motor_state(self):
if self.motion_mode:
self.msg.motor_cmd[H1_2_JointIndex.kNotUsedJoint0].q = 1.0;
while True: while True:
start_time = time.time() start_time = time.time()
@ -791,6 +799,10 @@ class H1_2_ArmController:
while current_attempts < max_attempts: while current_attempts < max_attempts:
current_q = self.get_current_dual_arm_q() current_q = self.get_current_dual_arm_q()
if np.all(np.abs(current_q) < tolerance): if np.all(np.abs(current_q) < tolerance):
if self.motion_mode:
for weight in np.linspace(1, 0, num=101):
self.msg.motor_cmd[H1_2_JointIndex.kNotUsedJoint0].q = weight;
time.sleep(0.02)
logger_mp.info("[H1_2_ArmController] both arms have reached the home position.") logger_mp.info("[H1_2_ArmController] both arms have reached the home position.")
break break
current_attempts += 1 current_attempts += 1

2
teleop/teleop_hand_and_arm.py

@ -145,7 +145,7 @@ if __name__ == '__main__':
arm_ctrl = G1_23_ArmController(motion_mode=args.motion, simulation_mode=args.sim) arm_ctrl = G1_23_ArmController(motion_mode=args.motion, simulation_mode=args.sim)
elif args.arm == "H1_2": elif args.arm == "H1_2":
arm_ik = H1_2_ArmIK() arm_ik = H1_2_ArmIK()
arm_ctrl = H1_2_ArmController(simulation_mode=args.sim)
arm_ctrl = H1_2_ArmController(motion_mode=args.motion, simulation_mode=args.sim)
elif args.arm == "H1": elif args.arm == "H1":
arm_ik = H1_ArmIK() arm_ik = H1_ArmIK()
arm_ctrl = H1_ArmController(simulation_mode=args.sim) arm_ctrl = H1_ArmController(simulation_mode=args.sim)

Loading…
Cancel
Save