z1_sdk/examples/lowcmd_development.cpp

47 lines
1.4 KiB
C++
Raw Normal View History

#include "unitree_arm_sdk/control/unitreeArm.h"
2022-11-11 18:17:07 +08:00
2022-11-16 16:23:36 +08:00
using namespace UNITREE_ARM;
2022-11-11 18:17:07 +08:00
int main(int argc, char *argv[]) {
std::cout << std::fixed << std::setprecision(3);
2023-07-12 20:11:26 +08:00
bool hasGripper = true;
unitreeArm arm(hasGripper);
2022-11-11 18:17:07 +08:00
arm.sendRecvThread->start();
arm.backToStart();
arm.setFsm(ArmFSMState::PASSIVE);
arm.setFsm(ArmFSMState::LOWCMD);
std::vector<double> KP, KW;
KP = arm._ctrlComp->lowcmd->kp;
KW = arm._ctrlComp->lowcmd->kd;
arm._ctrlComp->lowcmd->setControlGain(KP, KW);
2024-09-25 10:21:03 +08:00
// arm._ctrlComp->lowcmd->setGripperGain(KP[KP.size()-1], KW[KW.size()-1]);
2022-11-11 18:17:07 +08:00
arm.sendRecvThread->shutdown();
2023-07-12 20:11:26 +08:00
Vec6 initQ = arm.lowstate->getQ();
double duration = 1000;
Vec6 targetQ;
targetQ << 0, 1.5, -1, -0.54, 0, 0;
Timer timer(arm._ctrlComp->dt);
for(int i(0); i<duration; i++){
arm.q = initQ * (1-i/duration) + targetQ * (i/duration);
arm.qd = (targetQ - initQ) / (duration * arm._ctrlComp->dt);
arm.tau = arm._ctrlComp->armModel->inverseDynamics(arm.q, arm.qd, Vec6::Zero(), Vec6::Zero());
arm.gripperQ = -(i/duration);
arm.setArmCmd(arm.q, arm.qd, arm.tau);
arm.setGripperCmd(arm.gripperQ, arm.gripperW, arm.gripperTau);
arm.sendRecv();
timer.sleep();
2022-07-20 11:20:01 +08:00
}
2022-11-11 18:17:07 +08:00
arm.sendRecvThread->start();
2022-07-20 11:20:01 +08:00
arm.setFsm(ArmFSMState::JOINTCTRL);
2022-11-11 18:17:07 +08:00
arm.backToStart();
arm.setFsm(ArmFSMState::PASSIVE);
arm.sendRecvThread->shutdown();
2022-07-20 11:20:01 +08:00
return 0;
}