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

us.ihmc.scs2.simulation.bullet.physicsEngine.parameters.BulletContactSolverInfoParameters Maven / Gradle / Ivy

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

import org.bytedeco.bullet.global.BulletDynamics;

public class BulletContactSolverInfoParameters
{
   // @formatter:off
   private double tau;                                               //m_tau
   private double damping;                                           //m_damping - global non-contact constraint damping, can be locally overridden by constraints during 'getInfo2'.
   private double friction;                                          //m_friction
   private double timeStep;                                          //m_timeStep
   private double restitution;                                       //m_restitution
   private int numberOfIterations;                                   //m_numIterations
   private double maxErrorReduction;                                 //m_maxErrorReduction
   private double successiveOverRelaxationTerm;                      //m_sor
   private double errorReductionForNonContactConstraints;            //m_erp
   private double errorReductionForContactConstraints;               //m_erp2
   private double constraintForceMixingForContactsAndNonContacts;    //m_globalCfm
   private double errorReductionForFrictionConstraints;              //m_frictionERP
   private double constraintForceMixingForFrictionConstraints;       //m_frictionCFM
   private int splitImpulse;                                         //m_splitImpulse - 0 = false or 1 = true
   private double splitImpulsePenetrationThreshold;                  //m_splitImpulsePenetrationThreshold
   private double splitImpulseTurnErp;                               //m_splitImpulseTurnErp
   private double linearSlop;                                        //m_linearSlop - Used in btMultiBodyConstraintSolver if (!isFriction), adds linearSlop to distance of manifoldPoint
   private double warmstartingFactor;                                //m_warmstartingFactor
   private int solverMode;                                           //m_solverMode
   private int restingContactRestitutionThreshold;                   //m_restingContactRestitutionThreshold - unused as of 2.81
   private int minimumSolverBatchSize;                               //m_minimumSolverBatchSize - try to combine islands until the amount of constraints reaches this limit
   private double maxGyroscopicForce;                                //m_maxGyroscopeForce it is only used for 'explicit' version of gyroscopic force
   private double singleAxisRollingFrictionThreshold;                //m_singleAxisRollingFrictionThreshold - if the velocity is above this threshold, it will use a single constraint row (axis), otherwise 3 rows.
   private double leastSquaresResidualThreshold;                     //m_leastSquaresResidualThreshold
   private double restitutionVelocityThreshold;                      //m_restitutionVelocityThreshold - if the relative velocity is below this threshold, there is zero restitution
   // @formatter:on

   public static BulletContactSolverInfoParameters defaultBulletContactSolverInfoParameters()
   {
      BulletContactSolverInfoParameters bulletContactSolverInfoParameters = new BulletContactSolverInfoParameters();
      bulletContactSolverInfoParameters.setTau(0.6);
      bulletContactSolverInfoParameters.setDamping(1.0);
      bulletContactSolverInfoParameters.setFriction(0.3);
      bulletContactSolverInfoParameters.setTimeStep(1.0 / 60.0);
      bulletContactSolverInfoParameters.setRestitution(0.0);
      bulletContactSolverInfoParameters.setMaxErrorReduction(20.0);
      bulletContactSolverInfoParameters.setNumberOfIterations(10);
      bulletContactSolverInfoParameters.setErrorReductionForNonContactConstraints(0.2);
      bulletContactSolverInfoParameters.setErrorReductionForContactConstraints(0.2);
      bulletContactSolverInfoParameters.setConstraintForceMixingForContactsAndNonContacts(0.0);
      bulletContactSolverInfoParameters.setErrorReductionForFrictionConstraints(0.2);
      bulletContactSolverInfoParameters.setConstraintForceMixingForFrictionConstraints(0.0);
      bulletContactSolverInfoParameters.setSuccessiveOverRelaxationTerm(1.0);
      bulletContactSolverInfoParameters.setSplitImpulse(1);
      bulletContactSolverInfoParameters.setSplitImpulsePenetrationThreshold(-0.04);
      bulletContactSolverInfoParameters.setSplitImpulseTurnErp(0.1);
      bulletContactSolverInfoParameters.setLinearSlop(0.0);
      bulletContactSolverInfoParameters.setWarmstartingFactor(0.85);
      bulletContactSolverInfoParameters.setSolverMode(BulletDynamics.SOLVER_USE_WARMSTARTING
                                                      | BulletDynamics.SOLVER_SIMD
                                                      | BulletDynamics.SOLVER_USE_2_FRICTION_DIRECTIONS);
      bulletContactSolverInfoParameters.setRestingContactRestitutionThreshold(2);
      bulletContactSolverInfoParameters.setMinimumSolverBatchSize(128);
      bulletContactSolverInfoParameters.setMaxGyroscopicForce(100.0);
      bulletContactSolverInfoParameters.setSingleAxisRollingFrictionThreshold(1e30);
      bulletContactSolverInfoParameters.setLeastSquaresResidualThreshold(0.0);
      bulletContactSolverInfoParameters.setRestitutionVelocityThreshold(0.2);

      return bulletContactSolverInfoParameters;
   }

   public BulletContactSolverInfoParameters()
   {

   }

   public double getTau()
   {
      return tau;
   }

   public void setTau(double tau)
   {
      this.tau = tau;
   }

   public double getDamping()
   {
      return damping;
   }

   public void setDamping(double damping)
   {
      this.damping = damping;
   }

   public double getFriction()
   {
      return friction;
   }

   public void setFriction(double friction)
   {
      this.friction = friction;
   }

   public double getTimeStep()
   {
      return timeStep;
   }

   public void setTimeStep(double timeStep)
   {
      this.timeStep = timeStep;
   }

   public double getRestitution()
   {
      return restitution;
   }

   public void setRestitution(double restitution)
   {
      this.restitution = restitution;
   }

   public int getNumberOfIterations()
   {
      return numberOfIterations;
   }

   public void setNumberOfIterations(int numberOfIterations)
   {
      this.numberOfIterations = numberOfIterations;
   }

   public double getMaxErrorReduction()
   {
      return maxErrorReduction;
   }

   public void setMaxErrorReduction(double maxErrorReduction)
   {
      this.maxErrorReduction = maxErrorReduction;
   }

   public double getSuccessiveOverRelaxationTerm()
   {
      return successiveOverRelaxationTerm;
   }

   public void setSuccessiveOverRelaxationTerm(double successiveOverRelaxationTerm)
   {
      this.successiveOverRelaxationTerm = successiveOverRelaxationTerm;
   }

   public double getErrorReductionForNonContactConstraints()
   {
      return errorReductionForNonContactConstraints;
   }

   public void setErrorReductionForNonContactConstraints(double errorReductionForNonContactConstraints)
   {
      this.errorReductionForNonContactConstraints = errorReductionForNonContactConstraints;
   }

   public double getErrorReductionForContactConstraints()
   {
      return errorReductionForContactConstraints;
   }

   public void setErrorReductionForContactConstraints(double errorRecutionForContactConstraints)
   {
      this.errorReductionForContactConstraints = errorRecutionForContactConstraints;
   }

   public double getConstraintForceMixingForContactsAndNonContacts()
   {
      return constraintForceMixingForContactsAndNonContacts;
   }

   public void setConstraintForceMixingForContactsAndNonContacts(double constraintForceMixingForContactsAndNonContacts)
   {
      this.constraintForceMixingForContactsAndNonContacts = constraintForceMixingForContactsAndNonContacts;
   }

   public double getErrorReductionForFrictionConstraints()
   {
      return errorReductionForFrictionConstraints;
   }

   public void setErrorReductionForFrictionConstraints(double errorReductionForFrictionConstraints)
   {
      this.errorReductionForFrictionConstraints = errorReductionForFrictionConstraints;
   }

   public double getConstraintForceMixingForFrictionConstraints()
   {
      return constraintForceMixingForFrictionConstraints;
   }

   public void setConstraintForceMixingForFrictionConstraints(double constraintForceMixingForFrictionConstraints)
   {
      this.constraintForceMixingForFrictionConstraints = constraintForceMixingForFrictionConstraints;
   }

   public int getSplitImpulse()
   {
      return splitImpulse;
   }

   public void setSplitImpulse(int splitImpulse)
   {
      this.splitImpulse = splitImpulse;
   }

   public double getSplitImpulsePenetrationThreshold()
   {
      return splitImpulsePenetrationThreshold;
   }

   public void setSplitImpulsePenetrationThreshold(double splitImpulsePenetrationThreshold)
   {
      this.splitImpulsePenetrationThreshold = splitImpulsePenetrationThreshold;
   }

   public double getSplitImpulseTurnErp()
   {
      return splitImpulseTurnErp;
   }

   public void setSplitImpulseTurnErp(double splitImpulseTurnErp)
   {
      this.splitImpulseTurnErp = splitImpulseTurnErp;
   }

   public double getLinearSlop()
   {
      return linearSlop;
   }

   public void setLinearSlop(double linearSlop)
   {
      this.linearSlop = linearSlop;
   }

   public double getWarmstartingFactor()
   {
      return warmstartingFactor;
   }

   public void setWarmstartingFactor(double warmstartingFactor)
   {
      this.warmstartingFactor = warmstartingFactor;
   }

   public int getSolverMode()
   {
      return solverMode;
   }

   public void setSolverMode(int solverMode)
   {
      this.solverMode = solverMode;
   }

   public int getRestingContactRestitutionThreshold()
   {
      return restingContactRestitutionThreshold;
   }

   public void setRestingContactRestitutionThreshold(int restingContactRestitutionThreshold)
   {
      this.restingContactRestitutionThreshold = restingContactRestitutionThreshold;
   }

   public int getMinimumSolverBatchSize()
   {
      return minimumSolverBatchSize;
   }

   public void setMinimumSolverBatchSize(int minimumSolverBatchSize)
   {
      this.minimumSolverBatchSize = minimumSolverBatchSize;
   }

   public double getMaxGyroscopicForce()
   {
      return maxGyroscopicForce;
   }

   public void setMaxGyroscopicForce(double maxGyroscopicForce)
   {
      this.maxGyroscopicForce = maxGyroscopicForce;
   }

   public double getSingleAxisRollingFrictionThreshold()
   {
      return singleAxisRollingFrictionThreshold;
   }

   public void setSingleAxisRollingFrictionThreshold(double singleAxisRollingFrictionThreshold)
   {
      this.singleAxisRollingFrictionThreshold = singleAxisRollingFrictionThreshold;
   }

   public double getLeastSquaresResidualThreshold()
   {
      return leastSquaresResidualThreshold;
   }

   public void setLeastSquaresResidualThreshold(double leastSquaresResidualThreshold)
   {
      this.leastSquaresResidualThreshold = leastSquaresResidualThreshold;
   }

   public double getRestitutionVelocityThreshold()
   {
      return restitutionVelocityThreshold;
   }

   public void setRestitutionVelocityThreshold(double restitutionVelocityThreshold)
   {
      this.restitutionVelocityThreshold = restitutionVelocityThreshold;
   }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy