2022-11-11 18:17:07 +08:00
|
|
|
#ifndef __UNITREEARM_H
|
|
|
|
#define __UNITREEARM_H
|
|
|
|
|
2022-12-07 11:17:44 +08:00
|
|
|
#include "unitree_arm_sdk/control/ctrlComponents.h"
|
2022-11-11 18:17:07 +08:00
|
|
|
|
2022-11-16 16:23:36 +08:00
|
|
|
namespace UNITREE_ARM {
|
|
|
|
|
2022-11-11 18:17:07 +08:00
|
|
|
class unitreeArm{
|
|
|
|
public:
|
2022-11-15 16:05:20 +08:00
|
|
|
unitreeArm(bool hasUnitreeGripper);
|
|
|
|
~unitreeArm();
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Change z1_ctrl state to fsm, wait until change complete
|
|
|
|
* Input: ArmFSMState
|
|
|
|
* Output: Whether swtich to fsm correctly
|
|
|
|
* Note: eaxmple: Only State_Passive could switch to State_LowCmd
|
|
|
|
*/
|
|
|
|
bool setFsm(ArmFSMState fsm);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Move arm to home position
|
|
|
|
* wait until arrival home position, and then switch to State_JointCtrl
|
|
|
|
* Input: None
|
|
|
|
* Output: None
|
|
|
|
*/
|
|
|
|
void backToStart();
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Move arm to label position
|
|
|
|
* wait until arrival label position, and then switch to State_JointCtrl
|
|
|
|
* Input: label
|
|
|
|
* which should exist in z1_controller/config/saveArmStates.csv.
|
|
|
|
* The number of characters in label cannot be greater than 10.(char name[10])
|
|
|
|
* Output: None
|
|
|
|
*/
|
|
|
|
void labelRun(std::string label);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Save current position as a label to saveArmStates.csv
|
|
|
|
* Switch to State_JointCtrl when done
|
|
|
|
* Input: label
|
|
|
|
* name to save, which shouldn't exist in z1_controller/config/saveArmStates.csv.
|
|
|
|
* The number of characters in label cannot be greater than 10.(char name[10])
|
|
|
|
* Output: None
|
|
|
|
*/
|
|
|
|
void labelSave(std::string label);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Save current position as a label to saveArmStates.csv
|
|
|
|
* Switch to State_JointCtrl when done
|
|
|
|
* Input: label
|
|
|
|
* name to save, which shouldn't exist in z1_controller/config/saveArmStates.csv.
|
|
|
|
* The number of characters in label cannot be greater than 10.(char name[10])
|
|
|
|
* Output: None
|
|
|
|
*/
|
|
|
|
void teach(std::string label);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Switch to State_Teach
|
|
|
|
* Input: label
|
|
|
|
* Teach trajectory will be save as Traj_label.csv in directory z1_controller/config/
|
|
|
|
* The number of characters in label cannot be greater than 10.(char name[10])
|
|
|
|
* Output: None
|
|
|
|
*/
|
|
|
|
void teachRepeat(std::string label);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Calibrate the motor, make current position as home position
|
|
|
|
* Input: None
|
|
|
|
* Output: None
|
|
|
|
*/
|
|
|
|
void calibration();
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Move the robot in a joint path
|
2023-01-28 16:02:16 +08:00
|
|
|
* Input: posture: target position, (rx ry rz x y z), unit: meter
|
2022-11-15 16:05:20 +08:00
|
|
|
* maxSpeed: the maximum joint speed when robot is moving, unit: radian/s
|
|
|
|
* range:[0, pi]
|
|
|
|
* Output: None
|
|
|
|
*/
|
|
|
|
bool MoveJ(Vec6 posture, double maxSpeed);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Move the robot in a joint path, and control the gripper at the same time
|
2023-01-28 16:02:16 +08:00
|
|
|
* Input: posture: target position, (rx ry rz x y z), unit: meter
|
2022-11-15 16:05:20 +08:00
|
|
|
* gripperPos: target angular
|
|
|
|
* uint: radian
|
2022-12-07 11:17:44 +08:00
|
|
|
* range:[-pi/2, 0]
|
2022-11-15 16:05:20 +08:00
|
|
|
* maxSpeed: the maximum joint speed when robot is moving
|
|
|
|
* unit: radian/s
|
|
|
|
* range:[0, pi]
|
|
|
|
* Output: whether posture has inverse kinematics
|
|
|
|
*/
|
|
|
|
bool MoveJ(Vec6 posture, double gripperPos, double maxSpeed);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Move the robot in a linear path
|
2023-01-28 16:02:16 +08:00
|
|
|
* Input: posture: target position, (rx ry rz x y z), unit: meter
|
2022-11-15 16:05:20 +08:00
|
|
|
* maxSpeed: the maximum joint speed when robot is moving, unit: m/s
|
|
|
|
* Output: whether posture has inverse kinematics
|
|
|
|
*/
|
|
|
|
bool MoveL(Vec6 posture, double maxSpeed);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Move the robot in a linear path, and control the gripper at the same time
|
2023-01-28 16:02:16 +08:00
|
|
|
* Input: posture: target position, (rx ry rz x y z), unit: meter
|
2022-11-15 16:05:20 +08:00
|
|
|
* gripperPos: target angular, uint: radian
|
2022-12-07 11:17:44 +08:00
|
|
|
* range:[-pi/2, 0]
|
2022-11-15 16:05:20 +08:00
|
|
|
* maxSpeed: the maximum joint speed when robot is moving, unit: m/s
|
|
|
|
* Output: whether posture has inverse kinematics
|
|
|
|
*/
|
|
|
|
bool MoveL(Vec6 posture, double gripperPos, double maxSpeed);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Move the robot in a circular path
|
|
|
|
* Input: middle posture: determine the shape of the circular path
|
2023-01-28 16:02:16 +08:00
|
|
|
* endPosture: target position, (rx ry rz x y z), unit: meter
|
2022-11-15 16:05:20 +08:00
|
|
|
* maxSpeed: the maximum joint speed when robot is moving, unit: m/s
|
|
|
|
* Output: whether posture has inverse kinematics
|
|
|
|
*/
|
|
|
|
bool MoveC(Vec6 middlePosutre, Vec6 endPosture, double maxSpeed);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Move the robot in a circular path, and control the gripper at the same time
|
|
|
|
* Input: middle posture: determine the shape of the circular path
|
2023-01-28 16:02:16 +08:00
|
|
|
* endPosture: target position, (rx ry rz x y z), unit: meter
|
2022-11-15 16:05:20 +08:00
|
|
|
* gripperPos: target angular, uint: radian
|
2022-12-07 11:17:44 +08:00
|
|
|
* range:[-pi/2, 0]
|
2022-11-15 16:05:20 +08:00
|
|
|
* maxSpeed: the maximum joint speed when robot is moving, unit: m/s
|
|
|
|
* Output: whether posture has inverse kinematics
|
|
|
|
*/
|
|
|
|
bool MoveC(Vec6 middlePosutre, Vec6 endPosture, double gripperPos, double maxSpeed);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: Control robot with q&qd command in joint space or posture command in cartesian space
|
|
|
|
* Input: fsm: ArmFSMState::JOINTCTRL or ArmFSMState::CARTESIAN
|
|
|
|
* Output: whether posture has inverse kinematics
|
|
|
|
* Description: 1. ArmFSMState::JOINTCTRL,
|
|
|
|
* if you run function startTrack(ArmFSMState::JOINTCTRL),
|
|
|
|
* firstly, the following parameters will be set at the first time:
|
|
|
|
* q : <---- lowstate->getQ()
|
|
|
|
* qd: <---- lowstate->getQd()
|
|
|
|
* gripperQ: <---- lowstate->getGripperQ()
|
|
|
|
* gripperQd: <---- lowstate->getGripperQd()
|
|
|
|
* then you can change these parameters to control robot
|
|
|
|
* 2. ArmFSMState::CARTESIAN,
|
2022-12-07 11:17:44 +08:00
|
|
|
* if you run function startTrack(ArmFSMState::CARTESIAN),
|
2022-11-15 16:05:20 +08:00
|
|
|
* firstly, the following parameters will be set at the first time:
|
2022-12-07 11:17:44 +08:00
|
|
|
* twist.setZero()
|
2022-12-14 20:27:01 +08:00
|
|
|
* then you can change it to control robot, [Based on the object coordinate system]
|
2022-11-15 16:05:20 +08:00
|
|
|
*/
|
|
|
|
void startTrack(ArmFSMState fsm);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
/*
|
|
|
|
* Function: send udp message to z1_ctrl and receive udp message from it
|
|
|
|
* Input: None
|
|
|
|
* Output: None
|
|
|
|
* Description: sendRecvThread will run sendRecv() at a frequency of 500Hz
|
|
|
|
* ctrlcomp.sendRecv() is called in unitreeArm.sendRecv(),
|
|
|
|
* and set command parameters in unitreeArm to lowcmd automatically
|
|
|
|
* If you want to control robot under JOINTCTRL, CARTESIAN or LOWCMD,
|
|
|
|
* instead of MovecJ, MoveL, MoveC, and so on
|
|
|
|
* it is recommended to create your own thread to process command parameters
|
|
|
|
* (see stratTrack() description)
|
|
|
|
* and execute sendRecv() at the end of thread
|
|
|
|
*/
|
|
|
|
void sendRecv();
|
2022-11-11 18:17:07 +08:00
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-12-07 11:17:44 +08:00
|
|
|
/*
|
|
|
|
* Function: whether to wait for the command to finish
|
|
|
|
* Input: true or false
|
|
|
|
* Output: None
|
|
|
|
* Description: For example, MoveJ will send a trajectory command to z1_controller and then
|
|
|
|
* run usleep() to wait for the trajectory execution to complete.
|
|
|
|
* If set [wait] to false, MoveJ will send command only and user should judge
|
|
|
|
* for youself whether the command is complete.
|
|
|
|
* Method 1: if(_ctrlComp->recvState.state != fsm)
|
|
|
|
* After trajectory complete, the FSM will switch to ArmFSMState::JOINTCTRL
|
|
|
|
* automatically
|
|
|
|
* Method 2: if((lowState->endPosture - endPostureGoal).norm() < error)
|
|
|
|
* Check whether current posture reaches the target
|
|
|
|
* Related functions:
|
|
|
|
* MoveJ(), MoveL(), MoveC(), backToStart(), labelRun(), teachRepeat()
|
|
|
|
*/
|
|
|
|
void setWait(bool Y_N);
|
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-12-07 11:17:44 +08:00
|
|
|
/*
|
|
|
|
* Function: set q & qd command automatically by input parameters
|
2023-02-02 15:33:23 +08:00
|
|
|
* Input: directions: movement directions [include gripper], range:[-1,1]
|
2022-12-07 11:17:44 +08:00
|
|
|
* J1, J2, J3, J4, J5, J6, gripper
|
|
|
|
* jointSpeed: range: [0, pi]
|
|
|
|
* Output: None
|
|
|
|
* Description: The function is typically used to control the robot by keyboard or joystick
|
|
|
|
* When a key is pressed, the directions[i] sets to 1 or -1, and the function will
|
|
|
|
* automatically execute the following command:
|
|
|
|
* qd = directions * jointSpeed
|
|
|
|
* q += qd * _ctrlComp->dt
|
|
|
|
* if directions == 0, the robot stop moving
|
|
|
|
*/
|
|
|
|
void jointCtrlCmd(Vec7 directions, double jointSpeed);
|
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-12-07 11:17:44 +08:00
|
|
|
/*
|
2023-01-28 16:02:16 +08:00
|
|
|
* Function: set spatial velocity command automatically by input parameters
|
2023-02-02 15:33:23 +08:00
|
|
|
* Input: directions: movement directions [include gripper], range:[-1,1]
|
2023-01-28 16:02:16 +08:00
|
|
|
* rx, ry, rz, x, y, z, gripper
|
2022-12-07 11:17:44 +08:00
|
|
|
* oriSpeed: range: [0, 0.6]
|
|
|
|
* posSpeed: range: [0, 0.3]
|
|
|
|
* gripper joint speed is set to 1.0
|
|
|
|
* Output: None
|
|
|
|
* Description: The function is typically used to control the robot by keyboard or joystick
|
|
|
|
* When a key is pressed, the directions[i] is set to 1 or -1, and the function will
|
|
|
|
* automatically execute the following command:
|
2022-12-14 20:27:01 +08:00
|
|
|
* postureDelta = directions * speed
|
|
|
|
* postureGoal = postureDelta + posturePast
|
|
|
|
* Tgoal = postureToHomo(postureGoal)
|
|
|
|
* Tpast = postureToHomo(posturePast)
|
2023-01-28 16:02:16 +08:00
|
|
|
* omega = so3ToVec(MatrixLog3( Tpast.Rot.Transpose * Tgoal.Rot ))
|
|
|
|
* v = Tdelta.t
|
|
|
|
* twist = (omega, v)
|
2022-12-07 11:17:44 +08:00
|
|
|
* if directions == 0, the robot stop moving
|
|
|
|
*/
|
|
|
|
void cartesianCtrlCmd(Vec7 directions, double oriSpeed, double posSpeed);
|
|
|
|
|
2023-02-01 20:24:51 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
//command parameters
|
|
|
|
Vec6 q, qd, tau;
|
2022-12-07 11:17:44 +08:00
|
|
|
Vec6 twist;//spatial velocity: [omega, v]'
|
2022-11-15 16:05:20 +08:00
|
|
|
double gripperQ, gripperW, gripperTau;
|
2022-12-07 11:17:44 +08:00
|
|
|
Vec7 directions;
|
2022-11-11 18:17:07 +08:00
|
|
|
|
2022-11-15 16:05:20 +08:00
|
|
|
LoopFunc *sendRecvThread;
|
|
|
|
LowlevelCmd *lowcmd;//same as _ctrlComp->lowcmd
|
|
|
|
LowlevelState *lowstate;//same as _ctrlComp->lowstate
|
|
|
|
CtrlComponents *_ctrlComp;
|
2022-12-07 11:17:44 +08:00
|
|
|
|
|
|
|
private:
|
|
|
|
bool _isWait = true;
|
|
|
|
Vec6 _qPast;
|
|
|
|
Vec6 _endPosturePast, _endPostureDelta, _endPostureGoal;
|
2022-11-11 18:17:07 +08:00
|
|
|
};
|
|
|
|
|
2022-11-16 16:23:36 +08:00
|
|
|
}
|
2022-11-11 18:17:07 +08:00
|
|
|
#endif
|