2023-01-30 20:28:13 +08:00
|
|
|
import sys
|
|
|
|
sys.path.append("../lib")
|
|
|
|
import unitree_arm_interface
|
|
|
|
import time
|
|
|
|
import numpy as np
|
|
|
|
|
2023-02-09 10:32:09 +08:00
|
|
|
print("Press ctrl+\ to quit process.")
|
|
|
|
|
2023-01-30 20:28:13 +08:00
|
|
|
np.set_printoptions(precision=3, suppress=True)
|
2023-02-02 18:25:14 +08:00
|
|
|
arm = unitree_arm_interface.ArmInterface(hasGripper=True)
|
2023-01-30 20:28:13 +08:00
|
|
|
armState = unitree_arm_interface.ArmFSMState
|
|
|
|
arm.loopOn()
|
|
|
|
|
|
|
|
# 1. highcmd_basic : armCtrlInJointCtrl
|
|
|
|
arm.labelRun("forward")
|
|
|
|
arm.startTrack(armState.JOINTCTRL)
|
|
|
|
for i in range(0, 1000):
|
2023-04-26 16:16:38 +08:00
|
|
|
arm.jointCtrlCmd(np.array([0,0,0,-1,0,0,-1]), 1.0)
|
2023-02-02 18:25:14 +08:00
|
|
|
time.sleep(arm._ctrlComp.dt)
|
2023-01-30 20:28:13 +08:00
|
|
|
|
|
|
|
# 2. highcmd_basic : armCtrlByFSM
|
|
|
|
arm.labelRun("forward")
|
2023-04-26 16:16:38 +08:00
|
|
|
arm.MoveJ(np.array([0.5,0.1,0.1,0.5,-0.2,0.5]), 0.0, 2.0)
|
|
|
|
arm.MoveL(np.array([0,0,0,0.45,-0.2,0.2]), -1.0, 0.5)
|
|
|
|
arm.MoveC(np.array([0,0,0,0.45,0,0.4]), np.array([0,0,0,0.45,0.2,0.2]), 0.0, 0.5)
|
2023-01-30 20:28:13 +08:00
|
|
|
|
|
|
|
# 3. highcmd_basic : armCtrlInCartesian
|
|
|
|
arm.labelRun("forward")
|
|
|
|
arm.startTrack(armState.CARTESIAN)
|
|
|
|
for i in range(0, 1000):
|
2023-04-26 16:16:38 +08:00
|
|
|
arm.cartesianCtrlCmd(np.array([0,0,0,0,0,-1,-1]), 0.3, 0.2)
|
2023-02-02 18:25:14 +08:00
|
|
|
time.sleep(arm._ctrlComp.dt)
|
2023-01-30 20:28:13 +08:00
|
|
|
|
|
|
|
arm.backToStart()
|
|
|
|
arm.loopOff()
|
|
|
|
|