43 :
btMultiBodyDynamicsWorld(dispatcher, pairCache, (btMultiBodyConstraintSolver*)constraintSolver, collisionConfiguration),
44 m_deformableBodySolver(deformableBodySolver),
48 m_drawNodeTree =
true;
49 m_drawFaceTree =
false;
50 m_drawClusterTree =
false;
51 m_sbi.m_broadphase = pairCache;
52 m_sbi.m_dispatcher = dispatcher;
53 m_sbi.m_sparsesdf.Initialize();
54 m_sbi.m_sparsesdf.setDefaultVoxelsz(0.005);
55 m_sbi.m_sparsesdf.Reset();
58 m_sbi.water_density = 0;
59 m_sbi.water_offset = 0;
61 m_sbi.m_gravity.setValue(0, -9.8, 0);
65 m_useProjection =
false;
72 delete m_solverDeformableBodyIslandCallback;
78 if (0 != m_internalPreTickCallback)
80 (*m_internalPreTickCallback)(
this, timeStep);
91 btMultiBodyDynamicsWorld::performDiscreteCollisionDetection();
111 btMultiBodyDynamicsWorld::updateActions(timeStep);
120 for (
int i = 0;
i < m_softBodies.size(); ++
i)
122 m_softBodies[
i]->m_softSoftCollision =
true;
125 for (
int i = 0;
i < m_softBodies.size(); ++
i)
127 for (
int j =
i; j < m_softBodies.size(); ++j)
129 m_softBodies[
i]->defaultCollisionHandler(m_softBodies[j]);
133 for (
int i = 0;
i < m_softBodies.size(); ++
i)
135 m_softBodies[
i]->m_softSoftCollision =
false;
141 for (
int i = 0;
i < m_softBodies.size();
i++)
165 BT_PROFILE(
"btDeformableMultiBodyDynamicsWorld::applyRepulsionForce");
166 for (
int i = 0;
i < m_softBodies.size();
i++)
178 BT_PROFILE(
"btDeformableMultiBodyDynamicsWorld::performGeometricCollisions");
180 for (
int i = 0;
i < m_softBodies.size(); ++
i)
185 m_softBodies[
i]->updateFaceTree(
true,
false);
186 m_softBodies[
i]->updateNodeTree(
true,
false);
187 for (
int j = 0; j < m_softBodies[
i]->m_faces.size(); ++j)
196 for (
int r = 0; r < m_ccdIterations; ++r)
198 for (
int i = 0;
i < m_softBodies.size(); ++
i)
221 for (
int i = 0;
i < m_softBodies.size(); ++
i)
223 for (
int j =
i; j < m_softBodies.size(); ++j)
227 if (psb1->isActive() && psb2->isActive())
229 m_softBodies[
i]->geometricCollisionHandler(m_softBodies[j]);
234 int penetration_count = 0;
235 for (
int i = 0;
i < m_softBodies.size(); ++
i)
243 if (penetration_count == 0)
249 for (
int i = 0;
i < m_softBodies.size(); ++
i)
262 BT_PROFILE(
"btDeformableMultiBodyDynamicsWorld::softBodySelfCollision");
263 for (
int i = 0;
i < m_softBodies.size();
i++)
285 if (pushVelocity[0] != 0.f || pushVelocity[1] != 0 || pushVelocity[2] != 0 || turnVelocity[0] != 0.f || turnVelocity[1] != 0 || turnVelocity[2] != 0)
288 rb->setWorldTransform(newTransform);
300 for (
int i = 0;
i < m_softBodies.size(); ++
i)
307 btScalar clampDeltaV = maxDisplacement / timeStep;
308 for (
int c = 0; c < 3; c++)
310 if (node.
m_v[c] > clampDeltaV)
312 node.
m_v[c] = clampDeltaV;
314 if (node.
m_v[c] < -clampDeltaV)
316 node.
m_v[c] = -clampDeltaV;
331 if (a.
m_cti.
m_colObj->getInternalType() == btCollisionObject::CO_FEATHERSTONE_LINK)
334 if (multibodyLinkCol)
338 const btTransform& wtr = multibodyLinkCol->getWorldTransform();
340 wtr.invXform(n->
m_x),
362 t1.getX(), t1.getY(), t1.getZ(),
363 t2.getX(), t2.getY(), t2.getZ());
364 const int ndof = multibodyLinkCol->
m_multiBody->getNumDofs() + 6;
366 a.
m_c0 =
rot.transpose() * local_impulse_matrix *
rot;
381 BT_PROFILE(
"btDeformableMultiBodyDynamicsWorld::solveConstraints");
383 m_deformableBodySolver->backupVelocity();
393 m_deformableBodySolver->m_objective->m_projection.setProjection();
395 m_deformableBodySolver->m_objective->m_projection.setLagrangeMultiplier();
400 m_deformableBodySolver->setupDeformableSolve(m_implicit);
404 m_deformableBodySolver->solveDeformableConstraints(timeStep);
410 m_deformableBodySolver->setConstraints(m_solverInfo);
418 m_solverDeformableBodyIslandCallback->setup(&m_solverInfo, constraintsPtr, m_sortedConstraints.size(), sortedMultiBodyConstraints,
m_sortedMultiBodyConstraints.size(), getDebugDrawer());
449 m_solverDeformableBodyIslandCallback->processConstraints();
458 bool isSleeping =
false;
460 if (bod->getBaseCollider() && bod->getBaseCollider()->getActivationState() ==
ISLAND_SLEEPING)
464 for (
int b = 0;
b < bod->getNumLinks();
b++)
466 if (bod->getLink(
b).m_collider && bod->getLink(
b).m_collider->getActivationState() ==
ISLAND_SLEEPING)
477 if (bod->internalNeedsJointFeedback())
479 if (!bod->isUsingRK4Integration())
481 if (bod->internalNeedsJointFeedback())
483 bool isConstraintPass =
true;
485 getSolverInfo().m_jointFeedbackInWorldSpace,
486 getSolverInfo().m_jointFeedbackInJointFrame);
497 bod->processDeltaVeeMultiDof2();
503 m_softBodies.push_back(body);
510 collisionFilterGroup,
511 collisionFilterMask);
518 m_deformableBodySolver->predictMotion(timeStep);
523 m_internalTime += timeStep;
524 m_deformableBodySolver->setImplicit(m_implicit);
525 m_deformableBodySolver->setLineSearch(m_lineSearch);
526 m_deformableBodySolver->reinitialize(m_softBodies, timeStep);
527 btDispatcherInfo& dispatchInfo = btMultiBodyDynamicsWorld::getDispatchInfo();
530 dispatchInfo.
m_debugDraw = btMultiBodyDynamicsWorld::getDebugDrawer();
531 btMultiBodyDynamicsWorld::getSolverInfo().m_timeStep = timeStep;
534 m_deformableBodySolver->m_useProjection =
true;
535 m_deformableBodySolver->m_objective->m_projection.m_useStrainLimiting =
true;
536 m_deformableBodySolver->m_objective->m_preconditioner = m_deformableBodySolver->m_objective->m_massPreconditioner;
540 m_deformableBodySolver->m_useProjection =
false;
541 m_deformableBodySolver->m_objective->m_projection.m_useStrainLimiting =
false;
542 m_deformableBodySolver->m_objective->m_preconditioner = m_deformableBodySolver->m_objective->m_KKTPreconditioner;
582 bool isSleeping =
false;
584 if (bod->getBaseCollider() && bod->getBaseCollider()->getActivationState() ==
ISLAND_SLEEPING)
588 for (
int b = 0;
b < bod->getNumLinks();
b++)
590 if (bod->getLink(
b).m_collider && bod->getLink(
b).m_collider->getActivationState() ==
ISLAND_SLEEPING)
599 bool isConstraintPass =
false;
601 if (!bod->isUsingRK4Integration())
603 bod->computeAccelerationsArticulatedBodyAlgorithmMultiDof(m_solverInfo.m_timeStep,
605 getSolverInfo().m_jointFeedbackInWorldSpace,
606 getSolverInfo().m_jointFeedbackInJointFrame);
610 btAssert(
" RK4Integration is not supported");
627 if (body->isActive())
637 bool isSleeping =
false;
639 if (bod->getBaseCollider() && bod->getBaseCollider()->getActivationState() ==
ISLAND_SLEEPING)
643 for (
int b = 0;
b < bod->getNumLinks();
b++)
645 if (bod->getLink(
b).m_collider && bod->getLink(
b).m_collider->getActivationState() ==
ISLAND_SLEEPING)
651 bod->addBaseForce(-
m_gravity * bod->getBaseMass());
653 for (
int j = 0; j < bod->getNumLinks(); ++j)
655 bod->addLinkForce(j, -
m_gravity * bod->getLinkMass(j));
663 if (0 != m_internalTickCallback)
665 (*m_internalTickCallback)(
this, timeStep);
668 if (0 != m_solverCallback)
670 (*m_solverCallback)(m_internalTime,
this);
676 if (0 != m_solverCallback)
678 (*m_solverCallback)(m_internalTime,
this);
686 for (
int i = 0;
i < forces.
size(); ++
i)
690 forces[
i]->addSoftBody(psb);
698 force->
setIndices(m_deformableBodySolver->m_objective->getIndices());
706 int removed_index = -1;
707 for (
int i = 0;
i < forces.
size(); ++
i)
711 forces[
i]->removeSoftBody(psb);
712 if (forces[
i]->m_softBodies.
size() == 0)
717 if (removed_index >= 0)
724 for (
int i = 0;
i < forces.
size(); ++
i)
726 forces[
i]->removeSoftBody(psb);
733 m_softBodies.remove(body);
736 m_deformableBodySolver->reinitialize(m_softBodies,
btScalar(-1));
745 btDiscreteDynamicsWorld::removeCollisionObject(collisionObject);
752 int numSimulationSubSteps = 0;
761 numSimulationSubSteps = int(
m_localTime / fixedTimeStep);
762 m_localTime -= numSimulationSubSteps * fixedTimeStep;
768 fixedTimeStep = timeStep;
773 numSimulationSubSteps = 0;
778 numSimulationSubSteps = 1;
784 if (getDebugDrawer())
789 if (numSimulationSubSteps)
792 int clampedSimulationSteps = (numSimulationSubSteps > maxSubSteps) ? maxSubSteps : numSimulationSubSteps;
796 for (
int i = 0;
i < clampedSimulationSteps;
i++)
810 CProfileManager::Increment_Frame_Counter();
813 return numSimulationSubSteps;
#define DISABLE_DEACTIVATION
#define WANTS_DEACTIVATION
btCollisionShape
The btCollisionShape class provides an interface for collision shapes that can be shared among btColl...
btSimulationIslandManager * m_islandManager
virtual void saveKinematicState(btScalar timeStep)
btAlignedObjectArray< btRigidBody * > m_nonStaticRigidBodies
virtual void synchronizeMotionStates()
btCollisionWorld * getCollisionWorld()
virtual int getNumConstraints() const
btAlignedObjectArray< btTypedConstraint * > m_constraints
bool m_latencyMotionStateInterpolation
btConstraintSolver * m_constraintSolver
void startProfiling(btScalar timeStep)
btMatrix3x3
The btMatrix3x3 class implements a 3x3 rotation matrix, to perform linear algebra in combination with...
bool gDisableDeactivation
float btScalar
The btScalar type abstracts floating point numbers, to easily switch between double and single floati...
SIMD_FORCE_INLINE bool btFuzzyZero(btScalar x)
btSequentialImpulseConstraintSolverMt int btPersistentManifold int btTypedConstraint int const btContactSolverInfo & infoGlobal
static btMatrix3x3 OuterProduct(const btScalar *v1, const btScalar *v2, const btScalar *v3, const btScalar *u1, const btScalar *u2, const btScalar *u3, int ndof)
static SIMD_FORCE_INLINE btVector3 generateUnitOrthogonalVector(const btVector3 &u)
static SIMD_FORCE_INLINE void findJacobian(const btMultiBodyLinkCollider *multibodyLinkCol, btMultiBodyJacobianData &jacobianData, const btVector3 &contact_point, const btVector3 &dir)
btSoftBody implementation by Nathanael Presson
static btMatrix3x3 Diagonal(btScalar x)
btTypedConstraint(btTypedConstraintType type, btRigidBody &rbA)
btVector3
btVector3 can be used to represent 3D points and vectors. It has an un-used w component to suit 16-by...
SIMD_FORCE_INLINE btVector3 btCross(const btVector3 &v1, const btVector3 &v2)
Return the cross product of two vectors.
SIMD_FORCE_INLINE int size() const
return the number of elements in the array
void removeAtIndex(int index)
SIMD_FORCE_INLINE void push_back(const T &_Val)
virtual void removeCollisionObject(btCollisionObject *collisionObject)
virtual void addCollisionObject(btCollisionObject *collisionObject, int collisionFilterGroup=btBroadphaseProxy::DefaultFilter, int collisionFilterMask=btBroadphaseProxy::AllFilter)
void applyRigidBodyGravity(btScalar timeStep)
btDeformableMultiBodyDynamicsWorld(btDispatcher *dispatcher, btBroadphaseInterface *pairCache, btDeformableMultiBodyConstraintSolver *constraintSolver, btCollisionConfiguration *collisionConfiguration, btDeformableBodySolver *deformableBodySolver=0)
void removeCollisionObject(btCollisionObject *collisionObject)
virtual void addSoftBody(btSoftBody *body, int collisionFilterGroup=btBroadphaseProxy::DefaultFilter, int collisionFilterMask=btBroadphaseProxy::AllFilter)
void removeSoftBodyForce(btSoftBody *psb)
void removeSoftBody(btSoftBody *body)
void reinitialize(btScalar timeStep)
void positionCorrection(btScalar timeStep)
virtual void predictUnconstraintMotion(btScalar timeStep)
void afterSolverCallbacks(btScalar timeStep)
void applyRepulsionForce(btScalar timeStep)
virtual void debugDrawWorld()
void solveConstraints(btScalar timeStep)
void addForce(btSoftBody *psb, btDeformableLagrangianForce *force)
void softBodySelfCollision()
void performGeometricCollisions(btScalar timeStep)
virtual void integrateTransforms(btScalar timeStep)
void removeForce(btSoftBody *psb, btDeformableLagrangianForce *force)
virtual void internalSingleStepSimulation(btScalar timeStep)
void updateActivationState(btScalar timeStep)
virtual ~btDeformableMultiBodyDynamicsWorld()
void solveContactConstraints()
virtual int stepSimulation(btScalar timeStep, int maxSubSteps=1, btScalar fixedTimeStep=btScalar(1.)/btScalar(60.))
btSoftBodyArray & getSoftBodyArray()
void beforeSolverCallbacks(btScalar timeStep)
void performDeformableCollisionDetection()
virtual int getDebugMode() const =0
btAlignedObjectArray< btMultiBodyConstraint * > m_multiBodyConstraints
virtual void clearForces()
virtual void updateActivationState(btScalar timeStep)
btAlignedObjectArray< btMatrix3x3 > m_scratch_m
btAlignedObjectArray< btVector3 > m_scratch_v
virtual void predictUnconstraintMotion(btScalar timeStep)
virtual void calculateSimulationIslands()
virtual void integrateTransforms(btScalar timeStep)
btAlignedObjectArray< btMultiBody * > m_multiBodies
btAlignedObjectArray< btScalar > m_scratch_r
btAlignedObjectArray< btMultiBodyConstraint * > m_sortedMultiBodyConstraints
btMultiBodyDynamicsWorld(btDispatcher *dispatcher, btBroadphaseInterface *pairCache, btMultiBodyConstraintSolver *constraintSolver, btCollisionConfiguration *collisionConfiguration)
virtual void clearMultiBodyConstraintForces()
virtual void applyGravity()
virtual void debugDrawWorld()
static btMultiBodyLinkCollider * upcast(btCollisionObject *colObj)
btMultiBody * m_multiBody
void integrateVelocities(btScalar step)
void setTurnVelocity(const btVector3 &v)
void setPushVelocity(const btVector3 &v)
btVector3 getPushVelocity() const
btVector3 getTurnVelocity() const
btMultiBodyJacobianData jacobianData_t1
btMultiBodyJacobianData jacobianData_normal
btMultiBodyJacobianData jacobianData_t2
void interpolateRenderMesh()
void defaultCollisionHandler(const btCollisionObjectWrapper *pcoWrap)
btSoftBodyWorldInfo * m_worldInfo
void setSoftBodySolver(btSoftBodySolver *softBodySolver)
btAlignedObjectArray< DeformableFaceNodeContact > m_faceNodeContacts
void updateDeactivation(btScalar timeStep)
void applyRepulsionForce(btScalar timeStep, bool applySpringForce)
btAlignedObjectArray< DeformableNodeRigidAnchor > m_deformableAnchors
btSoftBodyWorldInfo * getWorldInfo()
static const btSoftBody * upcast(const btCollisionObject *colObj)
MatBase< C, R > inverse(MatBase< C, R >) RET
VecBase< float, 3 > cross(VecOp< float, 3 >, VecOp< float, 3 >) RET
class btIDebugDraw * m_debugDraw
btAlignedObjectArray< btScalar > m_deltaVelocitiesUnitImpulse
btAlignedObjectArray< btScalar > m_jacobians
static void Draw(btSoftBody *psb, btIDebugDraw *idraw, int drawflags=fDrawFlags::Std)
static void DrawFrame(btSoftBody *psb, btIDebugDraw *idraw)
btSparseSdf< 3 > m_sparsesdf
btScalar m_maxDisplacement
const btCollisionObject * m_colObj
btScalar Evaluate(const btVector3 &x, const btCollisionShape *shape, btVector3 &normal, btScalar margin)