us.ihmc.scs2.simulation.bullet.physicsEngine.BulletMultiBodyRobot Maven / Gradle / Ivy
package us.ihmc.scs2.simulation.bullet.physicsEngine;
import java.util.ArrayList;
import java.util.HashMap;
import org.bytedeco.bullet.BulletDynamics.btMultiBody;
import org.bytedeco.bullet.BulletDynamics.btMultiBodyConstraint;
import org.bytedeco.bullet.LinearMath.btVector3;
import us.ihmc.scs2.simulation.bullet.physicsEngine.parameters.YoBulletMultiBodyJointParameters;
import us.ihmc.scs2.simulation.bullet.physicsEngine.parameters.YoBulletMultiBodyParameters;
public class BulletMultiBodyRobot
{
private final btMultiBody btMultiBody;
private final HashMap jointNameToBulletJointIndexMap;
private final ArrayList allBulletMultiBodyLinkColliders = new ArrayList<>();
private final ArrayList allBtMultiBodyConstraints = new ArrayList<>();
public BulletMultiBodyRobot(int numberOfLinks,
double rootBodyMass,
btVector3 rootBodyIntertia,
boolean fixedBase,
boolean canSleep,
HashMap jointNameToBulletJointIndexMap)
{
btMultiBody = new btMultiBody(numberOfLinks, rootBodyMass, rootBodyIntertia, fixedBase, canSleep);
this.jointNameToBulletJointIndexMap = jointNameToBulletJointIndexMap;
}
public btMultiBody getBtMultiBody()
{
return btMultiBody;
}
public ArrayList getBulletMultiBodyLinkColliderArray()
{
return allBulletMultiBodyLinkColliders;
}
public BulletMultiBodyLinkCollider getBulletMultiBodyLinkCollider(int index)
{
return allBulletMultiBodyLinkColliders.get(index);
}
public ArrayList getBtMultiBodyConstraintArray()
{
return allBtMultiBodyConstraints;
}
public HashMap getJointNameToBulletJointIndexMap()
{
return jointNameToBulletJointIndexMap;
}
public void addBulletMuliBodyLinkCollider(BulletMultiBodyLinkCollider bulletMultiBodyLinkCollider)
{
allBulletMultiBodyLinkColliders.add(bulletMultiBodyLinkCollider);
}
public void addBtMultiBodyConstraint(btMultiBodyConstraint btMultiBodyConstraint)
{
allBtMultiBodyConstraints.add(btMultiBodyConstraint);
}
public void finalizeMultiDof(YoBulletMultiBodyParameters bulletMultiBodyParameters, YoBulletMultiBodyJointParameters bulletMultiBodyJointParameters)
{
setMultiBodyParameters(bulletMultiBodyParameters);
setMultiBodyJointParameters(bulletMultiBodyJointParameters);
btMultiBody.finalizeMultiDof();
}
public void setMultiBodyParameters(YoBulletMultiBodyParameters bulletMultiBodyParameters)
{
btMultiBody.setHasSelfCollision(bulletMultiBodyParameters.getHasSelfCollision());
btMultiBody.setCanSleep(bulletMultiBodyParameters.getCanSleep());
btMultiBody.setUseGyroTerm(bulletMultiBodyParameters.getUseGyroTerm());
btMultiBody.useGlobalVelocities(bulletMultiBodyParameters.getUseGlobalVelocities());
btMultiBody.useRK4Integration(bulletMultiBodyParameters.getUseRK4Integration());
btMultiBody.setLinearDamping(bulletMultiBodyParameters.getLinearDamping());
btMultiBody.setAngularDamping(bulletMultiBodyParameters.getAngularDamping());
btMultiBody.setMaxAppliedImpulse(bulletMultiBodyParameters.getMaxAppliedImpulse());
btMultiBody.setMaxCoordinateVelocity(bulletMultiBodyParameters.getMaxCoordinateVelocity());
}
public void setMultiBodyJointParameters(YoBulletMultiBodyJointParameters bulletMultiBodyJointParameters)
{
for (BulletMultiBodyLinkCollider bulletMultiBodyLinkCollider : allBulletMultiBodyLinkColliders)
{
bulletMultiBodyLinkCollider.setFriction(bulletMultiBodyJointParameters.getJointFriction());
bulletMultiBodyLinkCollider.setRestitution(bulletMultiBodyJointParameters.getJointRestitution());
bulletMultiBodyLinkCollider.setHitFraction(bulletMultiBodyJointParameters.getJointHitFraction());
bulletMultiBodyLinkCollider.setRollingFriction(bulletMultiBodyJointParameters.getJointRollingFriction());
bulletMultiBodyLinkCollider.setSpinningFriction(bulletMultiBodyJointParameters.getJointSpinningFriction());
bulletMultiBodyLinkCollider.setContactProcessingThreshold(bulletMultiBodyJointParameters.getJointContactProcessingThreshold());
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy