If you have any questions or need assistance with usage, feel free to contact support@unitree.com.
support motor: GO-M8010-6 motor、A1 motor、 B1 motor
gcc >= 5.4.0 (for x86 platform)
gcc >= 7.5.0 (for Arm platform)
run gcc --version command to check your gcc version
mkdir build
cd build
cmake ..
make
If the compilation is successful, many C++ example executable files will be generated in the build folder. Then run the examples with 'sudo', for example:
sudo ./example_a1_motor
If you need to run the Python example, please enter the "python" folder. Then run the examples with 'sudo', for example:
sudo python3 example_a1_motor.py
The code snippet below demonstrates an example of assigning values to the command structure cmd
in example_a1_motor.cpp
. It should be noted that the commands are all for the rotor side. However, the commands we usually compute are for the output side. Therefore, when assigning values, we need to consider the conversion between them.
cmd.motorType = MotorType::A1;
data.motorType = MotorType::A1;
cmd.mode = queryMotorMode(MotorType::A1,MotorMode::FOC);
cmd.id = 0;
cmd.kp = 0.0;
cmd.kd = 2;
cmd.q = 0.0;
cmd.dq = -6.28*queryGearRatio(MotorType::A1);
cmd.tau = 0.0;
serial.sendRecv(&cmd,&data);
Typically, for kp and kd, assuming the motor's gear ratio is r, when calculating kp and kd on the rotor side, we need to convert kp and kd on the output side by dividing them by the square of r.
This conversion relationship is demonstrated in the example example_a1_motor_output.cpp
.By the way, in the example example_a1_motor_output.cpp
, the kp on the rotor side is additionally divided by 26.07, and the kd on the rotor side is additionally multiplied by 100.0. These are magic numbers for the A1 and B1 motor. When controlling other motors, there is no need to consider these additional steps.