|
|
|
@@ -27,47 +27,79 @@ MinitaurSetup::~MinitaurSetup()
|
|
|
|
delete m_data;
|
|
|
|
delete m_data;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void MinitaurSetup::resetPose()
|
|
|
|
void MinitaurSetup::setDesiredMotorAngle(class b3RobotSimulatorClientAPI* sim, const char* motorName, double desiredAngle, double maxTorque, double kp, double kd)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
#if 0
|
|
|
|
b3RobotSimulatorJointMotorArgs controlArgs(CONTROL_MODE_POSITION_VELOCITY_PD);
|
|
|
|
def resetPose(self):
|
|
|
|
controlArgs.m_maxTorqueValue = maxTorque;
|
|
|
|
#right front leg
|
|
|
|
controlArgs.m_kd = kd;
|
|
|
|
self.disableAllMotors()
|
|
|
|
controlArgs.m_kp = kp;
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['motor_front_rightR_joint'],1.57)
|
|
|
|
controlArgs.m_targetPosition = desiredAngle;
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['knee_front_rightR_link'],-2.2)
|
|
|
|
sim->setJointMotorControl(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId[motorName],controlArgs);
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['motor_front_rightL_joint'],-1.57)
|
|
|
|
}
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['knee_front_rightL_link'],2.2)
|
|
|
|
|
|
|
|
p.createConstraint(self.quadruped,self.jointNameToId['knee_front_rightR_link'],self.quadruped,self.jointNameToId['knee_front_rightL_link'],p.JOINT_POINT2POINT,[0,0,0],[0,0.01,0.2],[0,-0.015,0.2])
|
|
|
|
|
|
|
|
self.setMotorAngleByName('motor_front_rightR_joint', 1.57)
|
|
|
|
|
|
|
|
self.setMotorAngleByName('motor_front_rightL_joint',-1.57)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#left front leg
|
|
|
|
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['motor_front_leftR_joint'],1.57)
|
|
|
|
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['knee_front_leftR_link'],-2.2)
|
|
|
|
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['motor_front_leftL_joint'],-1.57)
|
|
|
|
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['knee_front_leftL_link'],2.2)
|
|
|
|
|
|
|
|
p.createConstraint(self.quadruped,self.jointNameToId['knee_front_leftR_link'],self.quadruped,self.jointNameToId['knee_front_leftL_link'],p.JOINT_POINT2POINT,[0,0,0],[0,-0.01,0.2],[0,0.015,0.2])
|
|
|
|
|
|
|
|
self.setMotorAngleByName('motor_front_leftR_joint', 1.57)
|
|
|
|
|
|
|
|
self.setMotorAngleByName('motor_front_leftL_joint',-1.57)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#right back leg
|
|
|
|
void MinitaurSetup::resetPose(class b3RobotSimulatorClientAPI* sim)
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['motor_back_rightR_joint'],1.57)
|
|
|
|
{
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['knee_back_rightR_link'],-2.2)
|
|
|
|
//release all motors
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['motor_back_rightL_joint'],-1.57)
|
|
|
|
int numJoints = sim->getNumJoints(m_data->m_quadrupedUniqueId);
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['knee_back_rightL_link'],2.2)
|
|
|
|
for (int i=0;i<numJoints;i++)
|
|
|
|
p.createConstraint(self.quadruped,self.jointNameToId['knee_back_rightR_link'],self.quadruped,self.jointNameToId['knee_back_rightL_link'],p.JOINT_POINT2POINT,[0,0,0],[0,0.01,0.2],[0,-0.015,0.2])
|
|
|
|
{
|
|
|
|
self.setMotorAngleByName('motor_back_rightR_joint', 1.57)
|
|
|
|
b3RobotSimulatorJointMotorArgs controlArgs(CONTROL_MODE_VELOCITY);
|
|
|
|
self.setMotorAngleByName('motor_back_rightL_joint',-1.57)
|
|
|
|
controlArgs.m_maxTorqueValue = 0;
|
|
|
|
|
|
|
|
sim->setJointMotorControl(m_data->m_quadrupedUniqueId,i,controlArgs);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//right front leg
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["motor_front_rightR_joint"],1.57);
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_front_rightR_link"],-2.2);
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["motor_front_rightL_joint"],-1.57);
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_front_rightL_link"],2.2);
|
|
|
|
|
|
|
|
b3JointInfo jointInfo;
|
|
|
|
|
|
|
|
jointInfo.m_jointType = ePoint2PointType;
|
|
|
|
|
|
|
|
jointInfo.m_parentFrame[0] = 0; jointInfo.m_parentFrame[1] = 0.01; jointInfo.m_parentFrame[2] = 0.2;
|
|
|
|
|
|
|
|
jointInfo.m_childFrame[0] = 0; jointInfo.m_childFrame[1] = -0.015; jointInfo.m_childFrame[2] = 0.2;
|
|
|
|
|
|
|
|
sim->createConstraint(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_front_rightR_link"],
|
|
|
|
|
|
|
|
m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_front_rightL_link"],&jointInfo);
|
|
|
|
|
|
|
|
setDesiredMotorAngle(sim,"motor_front_rightR_joint",1.57);
|
|
|
|
|
|
|
|
setDesiredMotorAngle(sim,"motor_front_rightL_joint",-1.57);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//left front leg
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["motor_front_leftR_joint"],1.57);
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_front_leftR_link"],-2.2);
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["motor_front_leftL_joint"],-1.57);
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_front_leftL_link"],2.2);
|
|
|
|
|
|
|
|
jointInfo.m_parentFrame[0] = 0; jointInfo.m_parentFrame[1] = -0.01; jointInfo.m_parentFrame[2] = 0.2;
|
|
|
|
|
|
|
|
jointInfo.m_childFrame[0] = 0; jointInfo.m_childFrame[1] = 0.015; jointInfo.m_childFrame[2] = 0.2;
|
|
|
|
|
|
|
|
sim->createConstraint(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_front_leftR_link"],
|
|
|
|
|
|
|
|
m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_front_leftL_link"],&jointInfo);
|
|
|
|
|
|
|
|
setDesiredMotorAngle(sim,"motor_front_leftR_joint", 1.57);
|
|
|
|
|
|
|
|
setDesiredMotorAngle(sim,"motor_front_leftL_joint", -1.57);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//right back leg
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["motor_back_rightR_joint"],1.57);
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_back_rightR_link"],-2.2);
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["motor_back_rightL_joint"],-1.57);
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_back_rightL_link"],2.2);
|
|
|
|
|
|
|
|
jointInfo.m_parentFrame[0] = 0; jointInfo.m_parentFrame[1] = 0.01; jointInfo.m_parentFrame[2] = 0.2;
|
|
|
|
|
|
|
|
jointInfo.m_childFrame[0] = 0; jointInfo.m_childFrame[1] = -0.015; jointInfo.m_childFrame[2] = 0.2;
|
|
|
|
|
|
|
|
sim->createConstraint(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_back_rightR_link"],
|
|
|
|
|
|
|
|
m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_back_rightL_link"],&jointInfo);
|
|
|
|
|
|
|
|
setDesiredMotorAngle(sim,"motor_back_rightR_joint", 1.57);
|
|
|
|
|
|
|
|
setDesiredMotorAngle(sim,"motor_back_rightL_joint", -1.57);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//left back leg
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["motor_back_leftR_joint"],1.57);
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_back_leftR_link"],-2.2);
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["motor_back_leftL_joint"],-1.57);
|
|
|
|
|
|
|
|
sim->resetJointState(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_back_leftL_link"],2.2);
|
|
|
|
|
|
|
|
jointInfo.m_parentFrame[0] = 0; jointInfo.m_parentFrame[1] = -0.01; jointInfo.m_parentFrame[2] = 0.2;
|
|
|
|
|
|
|
|
jointInfo.m_childFrame[0] = 0; jointInfo.m_childFrame[1] = 0.015; jointInfo.m_childFrame[2] = 0.2;
|
|
|
|
|
|
|
|
sim->createConstraint(m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_back_leftR_link"],
|
|
|
|
|
|
|
|
m_data->m_quadrupedUniqueId,*m_data->m_jointNameToId["knee_back_leftL_link"],&jointInfo);
|
|
|
|
|
|
|
|
setDesiredMotorAngle(sim,"motor_back_leftR_joint", 1.57);
|
|
|
|
|
|
|
|
setDesiredMotorAngle(sim,"motor_back_leftL_joint", -1.57);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#left back leg
|
|
|
|
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['motor_back_leftR_joint'],1.57)
|
|
|
|
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['knee_back_leftR_link'],-2.2)
|
|
|
|
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['motor_back_leftL_joint'],-1.57)
|
|
|
|
|
|
|
|
p.resetJointState(self.quadruped,self.jointNameToId['knee_back_leftL_link'],2.2)
|
|
|
|
|
|
|
|
p.createConstraint(self.quadruped,self.jointNameToId['knee_back_leftR_link'],self.quadruped,self.jointNameToId['knee_back_leftL_link'],p.JOINT_POINT2POINT,[0,0,0],[0,-0.01,0.2],[0,0.015,0.2])
|
|
|
|
|
|
|
|
self.setMotorAngleByName('motor_back_leftR_joint', 1.57)
|
|
|
|
|
|
|
|
self.setMotorAngleByName('motor_back_leftL_joint',-1.57)
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int MinitaurSetup::setupMinitaur(class b3RobotSimulatorClientAPI* sim, const b3Vector3& startPos, const b3Quaternion& startOrn)
|
|
|
|
int MinitaurSetup::setupMinitaur(class b3RobotSimulatorClientAPI* sim, const b3Vector3& startPos, const b3Quaternion& startOrn)
|
|
|
|
@@ -90,7 +122,7 @@ int MinitaurSetup::setupMinitaur(class b3RobotSimulatorClientAPI* sim, const b3V
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
resetPose();
|
|
|
|
resetPose(sim);
|
|
|
|
|
|
|
|
|
|
|
|
return m_data->m_quadrupedUniqueId;
|
|
|
|
return m_data->m_quadrupedUniqueId;
|
|
|
|
}
|
|
|
|
}
|