All Downloads are FREE. Search and download functionalities are using the official Maven repository.

us.ihmc.scs2.simulation.bullet.physicsEngine.BulletRobotLinkJoint Maven / Gradle / Ivy

package us.ihmc.scs2.simulation.bullet.physicsEngine;

import us.ihmc.euclid.tuple3D.Vector3D;
import us.ihmc.mecano.spatial.Wrench;
import us.ihmc.scs2.simulation.robot.multiBodySystem.interfaces.SimOneDoFJointBasics;
import us.ihmc.scs2.simulation.screwTools.RigidBodyWrenchRegistry;
import us.ihmc.yoVariables.registry.YoRegistry;
import us.ihmc.yoVariables.variable.YoDouble;

public class BulletRobotLinkJoint extends BulletRobotLinkBasics
{
   private final SimOneDoFJointBasics simOneDofJoint;
   private final Vector3D force = new Vector3D();
   private final Vector3D torque = new Vector3D();
   private final Wrench wrenchToAdd;

   private final YoDouble bulletLinkAppliedForceX;
   private final YoDouble bulletLinkAppliedForceY;
   private final YoDouble bulletLinkAppliedForceZ;
   private final YoDouble bulletLinkAppliedTorqueX;
   private final YoDouble bulletLinkAppliedTorqueY;
   private final YoDouble bulletLinkAppliedTorqueZ;

   public BulletRobotLinkJoint(SimOneDoFJointBasics simOneDoFJoint,
                               int bulletJointIndex,
                               RigidBodyWrenchRegistry rigidBodyWrenchRegistry,
                               YoRegistry yoRegistry,
                               BulletMultiBodyLinkCollider bulletMultiBodyLinkCollider)
   {
      super(simOneDoFJoint.getSuccessor(), rigidBodyWrenchRegistry, bulletMultiBodyLinkCollider);
      this.simOneDofJoint = simOneDoFJoint;

      wrenchToAdd = new Wrench(getSimRigidBody().getBodyFixedFrame(), getSimRigidBody().getBodyFixedFrame());

      bulletLinkAppliedForceX = new YoDouble(simOneDoFJoint.getName() + "_btAppliedForceX", yoRegistry);
      bulletLinkAppliedForceY = new YoDouble(simOneDoFJoint.getName() + "_btAppliedForceY", yoRegistry);
      bulletLinkAppliedForceZ = new YoDouble(simOneDoFJoint.getName() + "_btAppliedForceZ", yoRegistry);
      bulletLinkAppliedTorqueX = new YoDouble(simOneDoFJoint.getName() + "_btAppliedTorqueX", yoRegistry);
      bulletLinkAppliedTorqueY = new YoDouble(simOneDoFJoint.getName() + "_btAppliedTorqueY", yoRegistry);
      bulletLinkAppliedTorqueZ = new YoDouble(simOneDoFJoint.getName() + "_btAppliedTorqueZ", yoRegistry);
   }

   public void pushStateToBullet()
   {
      updateBulletLinkColliderTransformFromMecanoRigidBody();

      getBulletMultiBodyLinkCollider().setJointPos(simOneDofJoint.getQ());
      getBulletMultiBodyLinkCollider().setJointVel(simOneDofJoint.getQd());
      getBulletMultiBodyLinkCollider().addJointTorque(simOneDofJoint.getTau());
   }

   public void pullStateFromBullet(double dt)
   {
      double jointPosition = getBulletMultiBodyLinkCollider().getJointPos();
      simOneDofJoint.setQ(jointPosition);
      double jointPVel = getBulletMultiBodyLinkCollider().getJointVel();
      simOneDofJoint.setQdd((jointPVel - simOneDofJoint.getQd()) / dt);
      simOneDofJoint.setQd(jointPVel);

      getBulletMultiBodyLinkCollider().getAppliedConstraintForce(force);
      bulletLinkAppliedForceX.set(force.getX());
      bulletLinkAppliedForceY.set(force.getY());
      bulletLinkAppliedForceZ.set(force.getZ());

      getBulletMultiBodyLinkCollider().getAppliedConstraintTorque(torque);
      bulletLinkAppliedTorqueX.set(torque.getX());
      bulletLinkAppliedTorqueY.set(torque.getY());
      bulletLinkAppliedTorqueZ.set(torque.getZ());

      wrenchToAdd.set(torque, force);
      getRigidBodyWrenchRegistry().addWrench(getSimRigidBody(), wrenchToAdd);
   }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy