us.ihmc.simulationconstructionset.FloatingJoint Maven / Gradle / Ivy
package us.ihmc.simulationconstructionset;
import net.jafama.FastMath;
import us.ihmc.euclid.matrix.interfaces.RotationMatrixReadOnly;
import us.ihmc.euclid.orientation.interfaces.Orientation3DReadOnly;
import us.ihmc.euclid.referenceFrame.ReferenceFrame;
import us.ihmc.euclid.referenceFrame.interfaces.FrameVector3DBasics;
import us.ihmc.euclid.transform.interfaces.RigidBodyTransformReadOnly;
import us.ihmc.euclid.tuple3D.Vector3D;
import us.ihmc.euclid.tuple3D.interfaces.Tuple3DBasics;
import us.ihmc.euclid.tuple3D.interfaces.Tuple3DReadOnly;
import us.ihmc.euclid.tuple3D.interfaces.Vector3DBasics;
import us.ihmc.euclid.tuple3D.interfaces.Vector3DReadOnly;
import us.ihmc.euclid.tuple4D.Quaternion;
import us.ihmc.euclid.tuple4D.interfaces.QuaternionBasics;
import us.ihmc.euclid.tuple4D.interfaces.QuaternionReadOnly;
import us.ihmc.simulationconstructionset.physics.engine.featherstone.FloatingJointPhysics;
import us.ihmc.yoVariables.euclid.YoPoint3D;
import us.ihmc.yoVariables.euclid.YoQuaternion;
import us.ihmc.yoVariables.euclid.YoVector3D;
import us.ihmc.yoVariables.registry.YoRegistry;
import us.ihmc.yoVariables.variable.YoBoolean;
import us.ihmc.yoVariables.variable.YoDouble;
public class FloatingJoint extends Joint implements FloatingSCSJoint
{
private static final long serialVersionUID = 6863566500545068060L;
private YoBoolean isPinned;
public final YoDouble q_x, q_y, q_z; // in world-fixed frame
public final YoDouble qd_x;
public final YoDouble qd_y;
public final YoDouble qd_z; // in world-fixed frame
public final YoDouble q_qs;
public final YoDouble q_qx;
public final YoDouble q_qy;
public final YoDouble q_qz; // Unit quaternion (Euler parameters). q_qs is the 'scalar part', q_q{x,y,z} form the vector part
public final YoDouble qd_wx;
public final YoDouble qd_wy;
public final YoDouble qd_wz; // angular velocity, expressed in body-fixed frame.
public final YoDouble qdd_x, qdd_y, qdd_z; // in world-fixed frame
public final YoDouble qdd_wx, qdd_wy, qdd_wz; // angular acceleration, expressed in body-fixed frame.
public final YoPoint3D position;
public final YoQuaternion quaternion;
public final YoVector3D linearVelocity;
public final YoVector3D angularVelocity;
public final YoVector3D linearAcceleration;
public final YoVector3D angularAcceleration;
private final boolean createYawPitchRollYoVariable;
public final YoDouble q_yaw, q_pitch, q_roll; // in world-fixed frame.
public FloatingJoint(String jname, Tuple3DReadOnly offset, Robot rob)
{
this(jname, null, offset, rob, false);
}
public FloatingJoint(String jname, Tuple3DReadOnly offset, Robot rob, boolean createYawPitchRollYoVariable)
{
this(jname, null, offset, rob, createYawPitchRollYoVariable);
}
public FloatingJoint(String jname, String varName, Tuple3DReadOnly offset, Robot rob)
{
this(jname, varName, offset, rob, false);
}
public FloatingJoint(String jname, String varName, Tuple3DReadOnly offset, Robot rob, boolean createYawPitchRollYoVariable)
{
super(jname, offset, rob, 6);
physics = new FloatingJointPhysics(this);
YoRegistry registry = rob.getRobotsYoRegistry();
this.createYawPitchRollYoVariable = createYawPitchRollYoVariable;
if (varName == null)
{
varName = "";
}
else if (!varName.isEmpty())
{
varName += "_";
}
q_x = new YoDouble("q_" + varName + "x", "FloatingJoint x position", registry);
q_y = new YoDouble("q_" + varName + "y", "FloatingJoint y position", registry);
q_z = new YoDouble("q_" + varName + "z", "FloatingJoint z position", registry);
qd_x = new YoDouble("qd_" + varName + "x", "FloatingJoint x velocity", registry);
qd_y = new YoDouble("qd_" + varName + "y", "FloatingJoint y velocity", registry);
qd_z = new YoDouble("qd_" + varName + "z", "FloatingJoint z velocity", registry);
qdd_x = new YoDouble("qdd_" + varName + "x", "FloatingJoint x acceleration", registry);
qdd_y = new YoDouble("qdd_" + varName + "y", "FloatingJoint yx acceleration", registry);
qdd_z = new YoDouble("qdd_" + varName + "z", "FloatingJoint z acceleration", registry);
q_qs = new YoDouble("q_" + varName + "qs", "FloatingJoint orientation quaternion qs", registry);
q_qs.set(1.0);
q_qx = new YoDouble("q_" + varName + "qx", "FloatingJoint orientation quaternion qx", registry);
q_qy = new YoDouble("q_" + varName + "qy", "FloatingJoint orientation quaternion qy", registry);
q_qz = new YoDouble("q_" + varName + "qz", "FloatingJoint orientation quaternion qz", registry);
qd_wx = new YoDouble("qd_" + varName + "wx", "FloatingJoint rotational velocity about x", registry);
qd_wy = new YoDouble("qd_" + varName + "wy", "FloatingJoint rotational velocity about y", registry);
qd_wz = new YoDouble("qd_" + varName + "wz", "FloatingJoint rotational velocity about z", registry);
qdd_wx = new YoDouble("qdd_" + varName + "wx", "FloatingJoint rotational acceleration about x", registry);
qdd_wy = new YoDouble("qdd_" + varName + "wy", "FloatingJoint rotational acceleration about y", registry);
qdd_wz = new YoDouble("qdd_" + varName + "wz", "FloatingJoint rotational acceleration about z", registry);
position = new YoPoint3D(q_x, q_y, q_z);
quaternion = new YoQuaternion(q_qx, q_qy, q_qz, q_qs);
linearVelocity = new YoVector3D(qd_x, qd_y, qd_z);
angularVelocity = new YoVector3D(qd_wx, qd_wy, qd_wz);
linearAcceleration = new YoVector3D(qdd_x, qdd_y, qdd_z);
angularAcceleration = new YoVector3D(qdd_wx, qdd_wy, qdd_wz);
if (createYawPitchRollYoVariable)
{
q_yaw = new YoDouble("q_" + varName + "yaw", "FloatingJoint yaw orientation", registry);
q_pitch = new YoDouble("q_" + varName + "pitch", "FloatingJoint pitch orientation", registry);
q_roll = new YoDouble("q_" + varName + "roll", "FloatingJoint roll orientation", registry);
}
else
{
q_yaw = null;
q_pitch = null;
q_roll = null;
}
isPinned = new YoBoolean(jname + "IsPinned", "Whether this FloatingJoint is pinned or not", registry);
jointTransform3D.set(quaternion, position);
physics.u_i = null;
}
public void setPositionAndVelocity(double x, double y, double z, double dx, double dy, double dz)
{
position.set(x, y, z);
linearVelocity.set(dx, dy, dz);
}
public void setPositionAndVelocity(Tuple3DReadOnly position, Tuple3DReadOnly velocity)
{
this.position.set(position);
linearVelocity.set(velocity);
}
public void setPosition(Tuple3DReadOnly position)
{
this.position.set(position);
}
public void setPosition(double x, double y, double z)
{
position.set(x, y, z);
}
@Override
public void setVelocity(Tuple3DReadOnly velocity)
{
linearVelocity.set(velocity);
}
public void setVelocity(double xd, double yd, double zd)
{
linearVelocity.set(xd, yd, zd);
}
public void setAcceleration(Tuple3DReadOnly acceleration)
{
linearAcceleration.set(acceleration);
}
public void setOrientation(Orientation3DReadOnly orientation)
{
quaternion.set(orientation);
}
public void setYawPitchRoll(double yaw, double pitch, double roll)
{
quaternion.setYawPitchRoll(yaw, pitch, roll);
}
public void setYawPitchRoll(double yaw, double pitch, double roll, double wz, double wy, double wx)
{
setYawPitchRoll(yaw, pitch, roll);
angularVelocity.set(wx, wy, wz);
}
/**
* @deprecated Use {@link #setOrientation(Orientation3DReadOnly)} instead.
*/
public void setRotation(RotationMatrixReadOnly rotation)
{
setOrientation((Orientation3DReadOnly) rotation);
}
/**
* @deprecated Use {@link #setOrientation(Orientation3DReadOnly)} instead.
*/
public void setQuaternion(QuaternionReadOnly q)
{
setOrientation((Orientation3DReadOnly) q);
}
@Override
public void setRotationAndTranslation(RigidBodyTransformReadOnly transform)
{
setOrientation(transform.getRotation());
setPosition(transform.getTranslation());
}
@Override
public void setAngularVelocityInBody(Vector3DReadOnly angularVelocityInBody)
{
angularVelocity.set(angularVelocityInBody);
}
public void setAngularAccelerationInBody(Vector3DReadOnly angularAccelerationInBody)
{
angularAcceleration.set(angularAccelerationInBody);
}
public void getPosition(YoDouble x, YoDouble y, YoDouble z)
{
x.set(q_x.getDoubleValue());
y.set(q_y.getDoubleValue());
z.set(q_z.getDoubleValue());
}
public void getVelocity(YoDouble xDot, YoDouble yDot, YoDouble zDot)
{
xDot.set(qd_x.getDoubleValue());
yDot.set(qd_y.getDoubleValue());
zDot.set(qd_z.getDoubleValue());
}
@Override
public void getVelocity(FrameVector3DBasics linearVelocityToPack)
{
linearVelocityToPack.setIncludingFrame(ReferenceFrame.getWorldFrame(), linearVelocity);
}
@Override
public void getAngularVelocity(FrameVector3DBasics angularVelocityToPack, ReferenceFrame bodyFrame)
{
angularVelocityToPack.setIncludingFrame(bodyFrame, angularVelocity);
}
public void getPositionAndVelocity(YoDouble x, YoDouble y, YoDouble z, YoDouble xDot, YoDouble yDot, YoDouble zDot)
{
getPosition(x, y, z);
getVelocity(xDot, yDot, zDot);
}
public void getPosition(Tuple3DBasics position)
{
position.set(this.position);
}
public void getVelocity(Tuple3DBasics velocity)
{
velocity.set(linearVelocity);
}
public void getPositionAndVelocity(Tuple3DBasics position, Tuple3DBasics velocity)
{
getPosition(position);
getVelocity(velocity);
}
public YoDouble getQx()
{
return q_x;
}
public YoDouble getQy()
{
return q_y;
}
public YoDouble getQz()
{
return q_z;
}
public YoPoint3D getPosition()
{
return position;
}
public YoDouble getQdx()
{
return qd_x;
}
public YoDouble getQdy()
{
return qd_y;
}
public YoDouble getQdz()
{
return qd_z;
}
public YoVector3D getLinearVelocity()
{
return linearVelocity;
}
public YoDouble getQddx()
{
return qdd_x;
}
public YoDouble getQddy()
{
return qdd_y;
}
public YoDouble getQddz()
{
return qdd_z;
}
public YoVector3D getLinearAcceleration()
{
return linearAcceleration;
}
public YoDouble getQuaternionQs()
{
return q_qs;
}
public YoDouble getQuaternionQx()
{
return q_qx;
}
public YoDouble getQuaternionQy()
{
return q_qy;
}
public YoDouble getQuaternionQz()
{
return q_qz;
}
public YoQuaternion getOrientation()
{
return quaternion;
}
public Quaternion getQuaternion()
{
return new Quaternion(quaternion);
}
public void getQuaternion(QuaternionBasics quaternionToPack)
{
quaternionToPack.set(quaternion);
}
public YoDouble getAngularVelocityX()
{
return qd_wx;
}
public YoDouble getAngularVelocityY()
{
return qd_wy;
}
public YoDouble getAngularVelocityZ()
{
return qd_wz;
}
public YoVector3D getAngularVelocity()
{
return angularVelocity;
}
public Vector3D getAngularVelocityInBody()
{
return new Vector3D(angularVelocity);
}
public void getAngularVelocityInBody(Vector3DBasics vectorToPack)
{
vectorToPack.set(angularVelocity);
}
public YoDouble getAngularAccelerationX()
{
return qdd_wx;
}
public YoDouble getAngularAccelerationY()
{
return qdd_wy;
}
public YoDouble getAngularAccelerationZ()
{
return qdd_wz;
}
public YoVector3D getAngularAcceleration()
{
return angularAcceleration;
}
public Vector3D getAngularAccelerationInBody()
{
return new Vector3D(angularAcceleration);
}
public void getAngularAccelerationInBody(Vector3DBasics angularAccelerationInBodyToPack)
{
angularAccelerationInBodyToPack.set(angularAcceleration);
}
public void getAngularAcceleration(FrameVector3DBasics angularAccelerationToPack, ReferenceFrame bodyFrame)
{
angularAccelerationToPack.setIncludingFrame(bodyFrame, angularAcceleration);
}
public void getLinearAccelerationInWorld(Vector3DBasics accelerationInWorldToPack)
{
accelerationInWorldToPack.set(linearAcceleration);
}
public void getLinearAcceleration(FrameVector3DBasics linearAccelerationToPack)
{
linearAccelerationToPack.setIncludingFrame(ReferenceFrame.getWorldFrame(), linearAcceleration);
}
public void getYawPitchRoll(YoDouble yaw, YoDouble pitch, YoDouble roll)
{
double pitchArgument = -2.0 * q_qx.getDoubleValue() * q_qz.getDoubleValue() + 2.0 * q_qs.getDoubleValue() * q_qy.getDoubleValue();
pitch.set(FastMath.asin(pitchArgument));
if (Math.abs(pitch.getDoubleValue()) < 0.49 * Math.PI)
{
yaw.set(FastMath.atan2(2.0 * q_qx.getDoubleValue() * q_qy.getDoubleValue() + 2.0 * q_qz.getDoubleValue() * q_qs.getDoubleValue(),
1.0 - 2.0 * q_qy.getDoubleValue() * q_qy.getDoubleValue() - 2.0 * q_qz.getDoubleValue() * q_qz.getDoubleValue())); // Math.asin(q_qs.val * q_qz.val * 2.0);
roll.set(FastMath.atan2(2.0 * q_qy.getDoubleValue() * q_qz.getDoubleValue() + 2.0 * q_qx.getDoubleValue() * q_qs.getDoubleValue(),
1.0 - 2.0 * q_qx.getDoubleValue() * q_qx.getDoubleValue() - 2.0 * q_qy.getDoubleValue() * q_qy.getDoubleValue())); // Math.asin(q_qs.val * q_qx.val * 2.0);
}
else
{
yaw.set(2.0 * FastMath.atan2(q_qz.getDoubleValue(), q_qs.getDoubleValue()));
roll.set(0.0);
}
}
public double[] getYawPitchRoll()
{
double[] yawPitchRollToReturn = new double[3];
double pitchArgument = -2.0 * q_qx.getDoubleValue() * q_qz.getDoubleValue() + 2.0 * q_qs.getDoubleValue() * q_qy.getDoubleValue();
double pitch = 0.0, roll = 0.0, yaw = 0.0;
pitch = FastMath.asin(pitchArgument);
if (Math.abs(pitch) < 0.49 * Math.PI)
{
yaw = FastMath.atan2(2.0 * q_qx.getDoubleValue() * q_qy.getDoubleValue() + 2.0 * q_qz.getDoubleValue() * q_qs.getDoubleValue(),
1.0 - 2.0 * q_qy.getDoubleValue() * q_qy.getDoubleValue() - 2.0 * q_qz.getDoubleValue() * q_qz.getDoubleValue()); // Math.asin(q_qs.val * q_qz.val * 2.0);
roll = FastMath.atan2(2.0 * q_qy.getDoubleValue() * q_qz.getDoubleValue() + 2.0 * q_qx.getDoubleValue() * q_qs.getDoubleValue(),
1.0 - 2.0 * q_qx.getDoubleValue() * q_qx.getDoubleValue() - 2.0 * q_qy.getDoubleValue() * q_qy.getDoubleValue()); // Math.asin(q_qs.val * q_qx.val * 2.0);
}
else
{
yaw = 2.0 * FastMath.atan2(q_qz.getDoubleValue(), q_qs.getDoubleValue());
roll = 0.0;
}
yawPitchRollToReturn[0] = yaw;
yawPitchRollToReturn[1] = pitch;
yawPitchRollToReturn[2] = roll;
return yawPitchRollToReturn;
}
/**
* Indicates whether this floating joint is fixed or not. This field differs from
* {@link #isDynamic()} as when it is pinned, the subtree attached to this joint is still simulated.
*/
public boolean isPinned()
{
return isPinned.getValue();
}
/**
* Indicates whether this floating joint is fixed or not. This field differs from
* {@link #isDynamic()} as when it is pinned, the subtree attached to this joint is still simulated.
*/
public void setPinned(boolean isPinned)
{
this.isPinned.set(isPinned);
}
@Override
public void update()
{
jointTransform3D.set(quaternion, position);
if (createYawPitchRollYoVariable)
{
getYawPitchRoll(q_yaw, q_pitch, q_roll);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy