#include #include #include //#include//for windows #include//for linux #include "DynamixelHandler.h" // Global variables DynamixelHandler _oDxlHandler; std::string _poppyDxlPortName = "/dev/ttyUSB0"; float _poppyDxlProtocol = 2.0; int _poppyDxlBaudRate = 1000000; int _nbJoints = 6; float _minJointCmd = 0; float _maxJointCmd = 1023; float _minJointAngle = -180.0f; float _maxJointAngle = 180.0f; int _targetJointTorqueGripper = 1140; float _proportionnalIncrement = 0.025f; float _proportionnalIncrementAbove = 0.01f; float _threshold= 1.9; int convertAnglesToJointCmd(float fJointAngle) { // y = ax + b float a = (_maxJointCmd-_minJointCmd) / (_maxJointAngle - _minJointAngle); float b = _minJointCmd - a * _minJointAngle; float jointCmd = a * fJointAngle + b; return (int)jointCmd; } int convertJointCmdToAngles(float fJointCmd) { // y = ax + b float a = (_maxJointCmd-_minJointCmd) / (_maxJointAngle - _minJointAngle); float b = _minJointCmd - a * _minJointAngle; float fJointAngle = (fJointCmd - b)/a; return (int)fJointAngle; } void goToHomePosition() { std::vector l_vTargetJointPosition; for (int l_joint = 0; l_joint < _nbJoints; l_joint++) l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); _oDxlHandler.sendTargetJointPosition(l_vTargetJointPosition); } void goToPlayingPosition() { std::vector l_vTargetJointPosition; l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-45.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(45.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(38.0f)); //mettre pince à convertAnglesToJointCmd(38.0f) (à revérifier si ça ne change pas avec un poppy différent) _oDxlHandler.sendTargetJointPosition(l_vTargetJointPosition); } void currentPos() { // read current joint position std::vector l_vCurrentJointPosition; _oDxlHandler.readCurrentJointPosition(l_vCurrentJointPosition); // display current joint position std::cout << "vCurrentJointPosition= ("; for (int l_joint=0; l_joint < l_vCurrentJointPosition.size(); l_joint++) std::cout << l_vCurrentJointPosition[l_joint] << ", "; std::cout << ")" << std::endl; } int closeGripper() { //read current joint 6 torque std::vector l_vCurrentJointTorque; _oDxlHandler.readCurrentJointTorque(l_vCurrentJointTorque); //read current joint 6 position std::vector l_vCurrentJointPosition; _oDxlHandler.readCurrentJointPosition(l_vCurrentJointPosition); int joint6Position = l_vCurrentJointPosition[5]; // display current joint 6 torque std::cout << "CurrentJoint6Torque= "; std::cout << l_vCurrentJointTorque[5] << std::endl; int joint6Torque = l_vCurrentJointTorque[5]; int jointTorqueDiff = joint6Torque - _targetJointTorqueGripper; float angleIncrement = -jointTorqueDiff * _proportionnalIncrement; std::cout<< "increment= " << angleIncrement<< std::endl; float targetJoint6Position = joint6Position + angleIncrement; std::cout << "joint torque diff= " < _threshold) { //read current joint 6 torque std::vector l_vCurrentJointTorque; _oDxlHandler.readCurrentJointTorque(l_vCurrentJointTorque); //read current joint 6 position std::vector l_vCurrentJointPosition; _oDxlHandler.readCurrentJointPosition(l_vCurrentJointPosition); int joint6Position = l_vCurrentJointPosition[5]; // display current joint 6 torque std::cout << "vCurrentJoint6Torque= "; std::cout << l_vCurrentJointTorque[5] << std::endl; int joint6Torque = l_vCurrentJointTorque[5]; int jointTorqueDiff = joint6Torque - _targetJointTorqueGripper; if (jointTorqueDiff < 0) { float angleIncrement = -jointTorqueDiff * _proportionnalIncrement; } else{ float angleIncrement = 0; } std::cout<< "increment= " << angleIncrement<< std::endl; float targetJoint6Position = joint6Position + angleIncrement; std::cout << "joint torque diff= " < l_vTargetJointPosition; for (int l_joint = 0; l_joint < _nbJoints-1; l_joint++) l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); //l_vTargetJointPosition.push_back(convertAnglesToJointCmd(90.0f)); //l_vTargetJointPosition.push_back(convertAnglesToJointCmd(90.0f)); //l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-90.0f)); //l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-90.0f)); //l_vTargetJointPosition.push_back(convertAnglesToJointCmd(45.0f)); l_vTargetJointPosition.push_back(targetJoint6Position); _oDxlHandler.sendTargetJointPosition(l_vTargetJointPosition); std::cout << convertJointCmdToAngles(targetJoint6Position) << std::endl; } return (int)joint6Torque; } void playNote(int myNote) { goToPlayingPosition(); std::vector l_vTargetJointPosition; switch(myNote){ case 1: l_vTargetJointPosition.push_back(convertAnglesToJointCmd(25.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-55.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(20.0f)); break; case 2: l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-35.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-55.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(20.0f)); break; case 3: l_vTargetJointPosition.push_back(convertAnglesToJointCmd(25.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-55.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(20.0f)); break; case 4: l_vTargetJointPosition.push_back(convertAnglesToJointCmd(25.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-55.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(20.0f)); break; case 5: l_vTargetJointPosition.push_back(convertAnglesToJointCmd(25.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-55.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(20.0f)); break; case 6: l_vTargetJointPosition.push_back(convertAnglesToJointCmd(25.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-55.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(20.0f)); break; case 7: l_vTargetJointPosition.push_back(convertAnglesToJointCmd(25.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-55.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(20.0f)); break; case 8: l_vTargetJointPosition.push_back(convertAnglesToJointCmd(25.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-55.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(20.0f)); break; case 9: l_vTargetJointPosition.push_back(convertAnglesToJointCmd(25.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-55.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(20.0f)); break; default: l_vTargetJointPosition.push_back(convertAnglesToJointCmd(25.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(-55.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(0.0f)); l_vTargetJointPosition.push_back(convertAnglesToJointCmd(20.0f)); break; } l_vTargetJointPosition.push_back(convertAnglesToJointCmd(38.0f)); //mettre pince à convertAnglesToJointCmd(38.0f) (à revérifier si ça ne change pas avec un poppy différent) _oDxlHandler.sendTargetJointPosition(l_vTargetJointPosition); sleep(1); //time period in seconds } int main() { std::cout << "===Initialization of the Dynamixel Motor communication====" << std::endl; _oDxlHandler.setDeviceName(_poppyDxlPortName); _oDxlHandler.setProtocolVersion(_poppyDxlProtocol); _oDxlHandler.openPort(); _oDxlHandler.setBaudRate(_poppyDxlBaudRate); _oDxlHandler.enableTorque(true); std::cout << std::endl; currentPos(); goToPlayingPosition(); currentPos(); //int gripperTorque = closeGripper(); goToPlayingPosition(); goToPlayingPosition();goToPlayingPosition();goToPlayingPosition();goToPlayingPosition();goToPlayingPosition();goToPlayingPosition(); currentPos(); playNote(1); playNote(2); // wait 1s std::this_thread::sleep_for(std::chrono::milliseconds(1000)); std::cout << "===Closing the Dynamixel Motor communication====" << std::endl; _oDxlHandler.enableTorque(false); _oDxlHandler.closePort(); std::cout << std::endl; return 0; }