2022-12-07 11:17:44 +08:00
|
|
|
#include "unitree_arm_sdk/control/unitreeArm.h"
|
2022-09-13 19:52:44 +08:00
|
|
|
|
2022-11-16 16:23:36 +08:00
|
|
|
using namespace UNITREE_ARM;
|
|
|
|
|
2022-09-19 17:08:57 +08:00
|
|
|
class Z1ARM : public unitreeArm{
|
2022-09-13 19:52:44 +08:00
|
|
|
public:
|
2022-11-15 16:05:20 +08:00
|
|
|
Z1ARM():unitreeArm(true){};
|
2022-09-19 17:08:57 +08:00
|
|
|
~Z1ARM(){};
|
2022-09-13 19:52:44 +08:00
|
|
|
void armCtrlByFSM();
|
2022-12-07 11:17:44 +08:00
|
|
|
void armCtrlInJointCtrl();
|
|
|
|
void armCtrlInCartesian();
|
2022-11-11 18:17:07 +08:00
|
|
|
void printState();
|
2023-07-06 16:09:07 +08:00
|
|
|
|
|
|
|
double gripper_pos = 0.0;
|
|
|
|
double joint_speed = 2.0;
|
|
|
|
double cartesian_speed = 0.5;
|
2022-09-13 19:52:44 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2022-09-19 17:08:57 +08:00
|
|
|
void Z1ARM::armCtrlByFSM() {
|
2022-09-13 19:52:44 +08:00
|
|
|
Vec6 posture[2];
|
2023-07-06 16:09:07 +08:00
|
|
|
gripper_pos = 0.0;
|
2022-09-13 19:52:44 +08:00
|
|
|
|
2022-11-11 18:17:07 +08:00
|
|
|
std::cout << "[TO STATE]" << std::endl;
|
2022-09-13 19:52:44 +08:00
|
|
|
labelRun("forward");
|
2022-11-11 18:17:07 +08:00
|
|
|
|
2022-09-13 19:52:44 +08:00
|
|
|
std::cout << "[MOVEJ]" << std::endl;
|
|
|
|
posture[0]<<0.5,0.1,0.1,0.5,-0.2,0.5;
|
2023-07-06 16:09:07 +08:00
|
|
|
joint_speed = 2.0;
|
|
|
|
MoveJ(posture[0], gripper_pos, joint_speed);
|
2022-09-13 19:52:44 +08:00
|
|
|
|
|
|
|
std::cout << "[MOVEL]" << std::endl;
|
|
|
|
posture[0] << 0,0,0,0.45,-0.2,0.2;
|
2023-07-06 16:09:07 +08:00
|
|
|
cartesian_speed = 0.5;
|
|
|
|
MoveL(posture[0], gripper_pos, cartesian_speed);
|
2023-01-28 16:02:16 +08:00
|
|
|
|
2022-09-13 19:52:44 +08:00
|
|
|
std::cout << "[MOVEC]" << std::endl;
|
2022-11-11 18:17:07 +08:00
|
|
|
posture[0] << 0,0,0,0.45,0,0.4;
|
2022-09-13 19:52:44 +08:00
|
|
|
posture[1] << 0,0,0,0.45,0.2,0.2;
|
2023-07-06 16:09:07 +08:00
|
|
|
MoveC(posture[0], posture[1], gripper_pos, cartesian_speed);
|
2022-09-13 19:52:44 +08:00
|
|
|
}
|
|
|
|
|
2022-12-07 11:17:44 +08:00
|
|
|
void Z1ARM::armCtrlInJointCtrl(){
|
2022-11-11 18:17:07 +08:00
|
|
|
labelRun("forward");
|
|
|
|
startTrack(ArmFSMState::JOINTCTRL);
|
2022-09-13 19:52:44 +08:00
|
|
|
|
2022-12-07 11:17:44 +08:00
|
|
|
for(int i(0); i<1000;i++){
|
2023-01-28 16:02:16 +08:00
|
|
|
directions<< 0, 0, 0, -1, 0, 0, -1;
|
2023-07-06 16:09:07 +08:00
|
|
|
joint_speed = 1.0;
|
|
|
|
jointCtrlCmd(directions, joint_speed);
|
2022-11-11 18:17:07 +08:00
|
|
|
usleep(_ctrlComp->dt*1000000);
|
2022-09-19 17:08:57 +08:00
|
|
|
}
|
|
|
|
}
|
2022-09-13 19:52:44 +08:00
|
|
|
|
2022-12-07 11:17:44 +08:00
|
|
|
void Z1ARM::armCtrlInCartesian(){
|
2022-09-19 17:08:57 +08:00
|
|
|
labelRun("forward");
|
2022-11-11 18:17:07 +08:00
|
|
|
startTrack(ArmFSMState::CARTESIAN);
|
2022-12-07 11:17:44 +08:00
|
|
|
|
2023-07-06 16:09:07 +08:00
|
|
|
double angular_vel = 0.3;
|
|
|
|
double linear_vel = 0.3;
|
2023-01-28 16:02:16 +08:00
|
|
|
for(int i(0); i<2000;i++){
|
|
|
|
directions<< 0, 0, 0, 0, 0, -1, -1;
|
2023-07-06 16:09:07 +08:00
|
|
|
|
|
|
|
cartesianCtrlCmd(directions, angular_vel, linear_vel);
|
2022-11-11 18:17:07 +08:00
|
|
|
usleep(_ctrlComp->dt*1000000);
|
2022-09-13 19:52:44 +08:00
|
|
|
}
|
2022-11-11 18:17:07 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void Z1ARM::printState(){
|
|
|
|
std::cout<<"------ joint State ------"<<std::endl;
|
2022-11-15 16:05:20 +08:00
|
|
|
std::cout<<"qState: "<<lowstate->getQ().transpose()<<std::endl;
|
|
|
|
std::cout<<"qdState: "<<lowstate->getQd().transpose()<<std::endl;
|
|
|
|
std::cout<<"tauState: "<<lowstate->getTau().transpose()<<std::endl;
|
2022-11-11 18:17:07 +08:00
|
|
|
|
|
|
|
std::cout<<"------ Endeffector Cartesian Posture ------"<<std::endl;
|
2023-02-02 18:25:14 +08:00
|
|
|
std::cout<<"roll pitch yaw x y z"<<std::endl;
|
2022-11-15 16:05:20 +08:00
|
|
|
std::cout<<lowstate->endPosture.transpose()<<std::endl;
|
2022-09-19 17:08:57 +08:00
|
|
|
}
|
2022-09-13 19:52:44 +08:00
|
|
|
|
2022-09-19 17:08:57 +08:00
|
|
|
int main() {
|
2022-11-15 16:05:20 +08:00
|
|
|
std::cout << std::fixed << std::setprecision(3);
|
|
|
|
Z1ARM arm;
|
2022-11-11 18:17:07 +08:00
|
|
|
arm.sendRecvThread->start();
|
2022-09-19 17:08:57 +08:00
|
|
|
|
|
|
|
arm.backToStart();
|
|
|
|
|
2023-01-28 16:02:16 +08:00
|
|
|
size_t demo = 3;
|
|
|
|
for(size_t demo = 1; demo < 4; demo++)
|
2022-11-11 18:17:07 +08:00
|
|
|
switch (demo)
|
|
|
|
{
|
|
|
|
case 1:
|
|
|
|
arm.armCtrlByFSM();
|
|
|
|
break;
|
|
|
|
case 2:
|
2022-12-07 11:17:44 +08:00
|
|
|
arm.armCtrlInJointCtrl();
|
2022-11-11 18:17:07 +08:00
|
|
|
break;
|
2022-11-15 16:05:20 +08:00
|
|
|
case 3:
|
2022-12-07 11:17:44 +08:00
|
|
|
arm.armCtrlInCartesian();
|
2022-11-11 18:17:07 +08:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2022-09-19 17:08:57 +08:00
|
|
|
|
|
|
|
arm.backToStart();
|
2022-11-11 18:17:07 +08:00
|
|
|
arm.setFsm(ArmFSMState::PASSIVE);
|
|
|
|
arm.sendRecvThread->shutdown();
|
2022-09-13 19:52:44 +08:00
|
|
|
return 0;
|
|
|
|
}
|