us.ihmc.simulationconstructionset.FloatingPlanarJoint Maven / Gradle / Ivy
package us.ihmc.simulationconstructionset;
import us.ihmc.euclid.referenceFrame.ReferenceFrame;
import us.ihmc.euclid.referenceFrame.interfaces.FrameVector3DBasics;
import us.ihmc.euclid.rotationConversion.YawPitchRollConversion;
import us.ihmc.euclid.transform.RigidBodyTransform;
import us.ihmc.euclid.transform.interfaces.RigidBodyTransformReadOnly;
import us.ihmc.euclid.tuple2D.interfaces.Tuple2DReadOnly;
import us.ihmc.euclid.tuple3D.Vector3D;
import us.ihmc.euclid.tuple3D.interfaces.Tuple3DReadOnly;
import us.ihmc.euclid.tuple3D.interfaces.Vector3DReadOnly;
import us.ihmc.euclid.tuple4D.Quaternion;
import us.ihmc.euclid.yawPitchRoll.YawPitchRoll;
import us.ihmc.robotics.robotDescription.Plane;
import us.ihmc.simulationconstructionset.physics.engine.featherstone.FloatingPlanarJointPhysics;
import us.ihmc.yoVariables.registry.YoRegistry;
import us.ihmc.yoVariables.registry.YoVariableList;
import us.ihmc.yoVariables.variable.YoDouble;
public class FloatingPlanarJoint extends Joint implements FloatingSCSJoint
{
private static final long serialVersionUID = -1627814016079577790L;
public YoDouble q_t1;
public YoDouble q_t2;
public YoDouble qd_t1;
public YoDouble qd_t2;
public YoDouble q_rot;
public YoDouble qd_rot;
public YoDouble qdd_t1, qdd_t2, qdd_rot;
public Plane type = Plane.XZ;
public YoDouble getQ_t1()
{
return q_t1;
}
public YoDouble getQ_t2()
{
return q_t2;
}
public YoDouble getQd_t1()
{
return qd_t1;
}
public YoDouble getQd_t2()
{
return qd_t2;
}
public YoDouble getQ_rot()
{
return q_rot;
}
public YoDouble getQd_rot()
{
return qd_rot;
}
public YoDouble getQdd_t1()
{
return qdd_t1;
}
public YoDouble getQdd_t2()
{
return qdd_t2;
}
public YoDouble getQdd_rot()
{
return qdd_rot;
}
YoVariableList floatingJointVars;
public FloatingPlanarJoint(String jname, Robot rob)
{
this(jname, rob, Plane.XZ);
physics = new FloatingPlanarJointPhysics(this);
}
public FloatingPlanarJoint(String jname, Tuple3DReadOnly offset, Robot rob)
{
this(jname, offset, rob, Plane.XZ);
physics = new FloatingPlanarJointPhysics(this);
}
public FloatingPlanarJoint(String jname, Robot rob, Plane type)
{
this(jname, new Vector3D(), rob, type);
}
public FloatingPlanarJoint(String jname, Tuple3DReadOnly offset, Robot rob, Plane type)
{
super(jname, offset, rob, 3);
physics = new FloatingPlanarJointPhysics(this);
this.type = type;
floatingJointVars = new YoVariableList(jname + " jointVars"); // rob.getVars();
String t1_name, t2_name, rot_name;
if (type == Plane.XY)
{
t1_name = "x";
t2_name = "y";
rot_name = "yaw";
}
else if (type == Plane.XZ)
{
t1_name = "x";
t2_name = "z";
rot_name = "pitch";
}
else
{
t1_name = "y";
t2_name = "z";
rot_name = "roll";
}
YoRegistry registry = rob.getRobotsYoRegistry();
q_t1 = new YoDouble("q_" + t1_name, "PlanarFloatingJoint " + t1_name + " position", registry);
q_t2 = new YoDouble("q_" + t2_name, "PlanarFloatingJoint " + t2_name + " position", registry);
q_rot = new YoDouble("q_" + rot_name, "PlanarFloatingJoint " + rot_name + " angle", registry);
qd_t1 = new YoDouble("qd_" + t1_name, "PlanarFloatingJoint " + t1_name + " linear velocity", registry);
qd_t2 = new YoDouble("qd_" + t2_name, "PlanarFloatingJoint " + t2_name + " linear velocity", registry);
qd_rot = new YoDouble("qd_" + rot_name, "PlanarFloatingJoint " + rot_name + " angular velocity", registry);
qdd_t1 = new YoDouble("qdd_" + t1_name, "PlanarFloatingJoint " + t1_name + " linear acceleration", registry);
qdd_t2 = new YoDouble("qdd_" + t2_name, "PlanarFloatingJoint " + t2_name + " linear acceleration", registry);
qdd_rot = new YoDouble("qdd_" + rot_name, "PlanarFloatingJoint " + rot_name + " angular acceleration", registry);
// rob.getVars().addVariables(floatingJointVars);
setFloatingTransform3D(jointTransform3D);
physics.u_i = null;
}
public FloatingPlanarJoint(String jname, String varName, Robot rob, Plane type)
{
this(jname, varName, new Vector3D(), rob, type);
}
public FloatingPlanarJoint(String jname, String varName, Tuple3DReadOnly offset, Robot rob, Plane type)
{
super(jname, offset, rob, 6);
physics = new FloatingPlanarJointPhysics(this);
this.type = type;
floatingJointVars = new YoVariableList(jname + " jointVars"); // rob.getVars();
String t1_name, t2_name, rot_name;
if (type == Plane.XY)
{
t1_name = varName + "_x";
t2_name = varName + "_y";
rot_name = varName + "_yaw";
}
else if (type == Plane.XZ)
{
t1_name = varName + "x";
t2_name = varName + "z";
rot_name = varName + "pitch";
}
else
{
t1_name = varName + "y";
t2_name = varName + "z";
rot_name = varName + "roll";
}
YoRegistry registry = rob.getRobotsYoRegistry();
q_t1 = new YoDouble("q_" + t1_name, "PlanarFloatingJoint " + t1_name + " position", registry);
q_t2 = new YoDouble("q_" + t2_name, "PlanarFloatingJoint " + t2_name + " position", registry);
q_rot = new YoDouble("q_" + rot_name, "PlanarFloatingJoint " + rot_name + " angle", registry);
qd_t1 = new YoDouble("qd_" + t1_name, "PlanarFloatingJoint " + t1_name + " linear velocity", registry);
qd_t2 = new YoDouble("qd_" + t2_name, "PlanarFloatingJoint " + t2_name + " linear velocity", registry);
qd_rot = new YoDouble("qd_" + rot_name, "PlanarFloatingJoint " + rot_name + " angular velocity", registry);
qdd_t1 = new YoDouble("qdd_" + t1_name, "PlanarFloatingJoint " + t1_name + " linear acceleration", registry);
qdd_t2 = new YoDouble("qdd_" + t2_name, "PlanarFloatingJoint " + t2_name + " linear acceleration", registry);
qdd_rot = new YoDouble("qdd_" + rot_name, "PlanarFloatingJoint " + rot_name + " angular acceleration", registry);
// rob.getVars().addVariables(floatingJointVars);
setFloatingTransform3D(jointTransform3D);
physics.u_i = null;
}
public void setCartesianPosition(double t1, double t2)
{
q_t1.set(t1);
q_t2.set(t2);
}
public void setCartesianPosition(double t1, double t2, double t1Dot, double t2Dot)
{
q_t1.set(t1);
q_t2.set(t2);
qd_t1.set(t1Dot);
qd_t2.set(t2Dot);
}
public void setCartesianPosition(Tuple2DReadOnly position, Tuple2DReadOnly velocity)
{
q_t1.set(position.getX());
q_t2.set(position.getY());
qd_t1.set(velocity.getX());
qd_t2.set(velocity.getY());
}
public void setCartesianVelocity(Tuple2DReadOnly velocity)
{
qd_t1.set(velocity.getX());
qd_t2.set(velocity.getY());
}
public void setCartesianVelocity(double t1Dot, double t2Dot)
{
qd_t1.set(t1Dot);
qd_t2.set(t2Dot);
}
public void setRotation(double theta)
{
q_rot.set(theta);
}
public void setRotation(double theta, double thetaDot)
{
q_rot.set(theta);
qd_rot.set(thetaDot);
}
public void setRotationalVelocity(double thetaDot)
{
qd_rot.set(thetaDot);
}
protected YoVariableList getJointVars()
{
return floatingJointVars;
}
@Override
protected void update()
{
setFloatingTransform3D(jointTransform3D);
}
private Vector3D position = new Vector3D();
protected void setFloatingTransform3D(RigidBodyTransform t1)
{
if (type == Plane.YZ)
{
position.set(0.0, q_t1.getDoubleValue(), q_t2.getDoubleValue());
t1.setRotationRollAndZeroTranslation(q_rot.getDoubleValue());
}
else if (type == Plane.XZ)
{
position.set(q_t1.getDoubleValue(), 0.0, q_t2.getDoubleValue());
t1.setRotationPitchAndZeroTranslation(q_rot.getDoubleValue());
}
else
{
position.set(q_t1.getDoubleValue(), q_t2.getDoubleValue(), 0.0);
t1.setRotationYawAndZeroTranslation(q_rot.getDoubleValue());
}
t1.getTranslation().set(position);
}
public Plane getType()
{
return type;
}
private final YawPitchRoll yawPitchRoll = new YawPitchRoll();
@Override
public void setRotationAndTranslation(RigidBodyTransformReadOnly transform)
{
Quaternion rotation = new Quaternion();
rotation.set(transform.getRotation());
YawPitchRollConversion.convertQuaternionToYawPitchRoll(rotation, yawPitchRoll);
Vector3D translation = new Vector3D();
translation.set(transform.getTranslation());
switch (type)
{
case XY:
setRotation(yawPitchRoll.getRoll());
setCartesianPosition(translation.getX(), translation.getY());
break;
case XZ:
setRotation(yawPitchRoll.getPitch());
setCartesianPosition(translation.getX(), translation.getZ());
break;
default:
setRotation(yawPitchRoll.getYaw());
setCartesianPosition(translation.getY(), translation.getZ());
break;
}
}
@Override
public void setVelocity(Tuple3DReadOnly velocity)
{
switch (type)
{
case XY:
setCartesianVelocity(velocity.getX(), velocity.getY());
break;
case XZ:
setCartesianVelocity(velocity.getX(), velocity.getZ());
break;
default:
setCartesianVelocity(velocity.getY(), velocity.getZ());
break;
}
}
@Override
public void setAngularVelocityInBody(Vector3DReadOnly angularVelocityInBody)
{
switch (type)
{
case XY:
setRotationalVelocity(angularVelocityInBody.getZ());
break;
case XZ:
setRotationalVelocity(angularVelocityInBody.getY());
break;
default:
setRotationalVelocity(angularVelocityInBody.getX());
break;
}
}
@Override
public void getVelocity(FrameVector3DBasics linearVelocityToPack)
{
switch (type)
{
case XY:
linearVelocityToPack.setIncludingFrame(ReferenceFrame.getWorldFrame(), qd_t1.getDoubleValue(), qd_t2.getDoubleValue(), 0.0);
break;
case XZ:
linearVelocityToPack.setIncludingFrame(ReferenceFrame.getWorldFrame(), qd_t1.getDoubleValue(), 0.0, qd_t2.getDoubleValue());
break;
default:
linearVelocityToPack.setIncludingFrame(ReferenceFrame.getWorldFrame(), 0.0, qd_t1.getDoubleValue(), qd_t2.getDoubleValue());
break;
}
}
@Override
public void getAngularVelocity(FrameVector3DBasics angularVelocityToPack, ReferenceFrame bodyFrame)
{
switch (type)
{
case XY:
angularVelocityToPack.setIncludingFrame(bodyFrame, 0.0, 0.0, qd_rot.getDoubleValue());
break;
case XZ:
angularVelocityToPack.setIncludingFrame(bodyFrame, 0.0, qd_rot.getDoubleValue(), 0.0);
break;
default:
angularVelocityToPack.setIncludingFrame(bodyFrame, qd_rot.getDoubleValue(), 0.0, 0.0);
break;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy