43 :
btMultiBodyDynamicsWorld(dispatcher, pairCache, (btMultiBodyConstraintSolver*)constraintSolver, collisionConfiguration),
44 m_deformableBodySolver(deformableBodySolver),
48 m_drawNodeTree =
true;
49 m_drawFaceTree =
false;
50 m_drawClusterTree =
false;
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++)
277 btVector3 zero(0, 0, 0);
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;
319 node.m_x = node.m_x + timeStep * (node.m_v + node.m_splitv);
321 node.m_vn = node.m_v;
328 n->
m_x = a.m_cti.m_colObj->getWorldTransform() * a.m_local;
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),
344 a.m_cti.m_normal = wtr.getBasis() * nrm;
345 btVector3 normal = a.m_cti.m_normal;
347 btVector3 t2 =
btCross(normal, t1);
349 findJacobian(multibodyLinkCol, jacobianData_normal, a.m_node->m_x, normal);
350 findJacobian(multibodyLinkCol, jacobianData_t1, a.m_node->m_x, t1);
351 findJacobian(multibodyLinkCol, jacobianData_t2, a.m_node->m_x, t2);
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;
367 a.jacobianData_normal = jacobianData_normal;
368 a.jacobianData_t1 = jacobianData_t1;
369 a.jacobianData_t2 = jacobianData_t2;
381 BT_PROFILE(
"btDeformableMultiBodyDynamicsWorld::solveConstraints");
417 btTypedConstraint** constraintsPtr =
getNumConstraints() ? &m_sortedConstraints[0] : 0;
418 m_solverDeformableBodyIslandCallback->
setup(&m_solverInfo, constraintsPtr, m_sortedConstraints.size(), sortedMultiBodyConstraints,
m_sortedMultiBodyConstraints.
size(), getDebugDrawer());
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();
510 collisionFilterGroup,
511 collisionFilterMask);
523 m_internalTime += timeStep;
526 m_deformableBodySolver->
reinitialize(m_softBodies, timeStep);
527 btDispatcherInfo& dispatchInfo = btMultiBodyDynamicsWorld::getDispatchInfo();
530 dispatchInfo.
m_debugDraw = btMultiBodyDynamicsWorld::getDebugDrawer();
531 btMultiBodyDynamicsWorld::getSolverInfo().m_timeStep = timeStep;
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);
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);
745 btDiscreteDynamicsWorld::removeCollisionObject(collisionObject);
752 int numSimulationSubSteps = 0;
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 inverse() const
Return the inverse of the matrix.
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)
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)
void remove(const T &key)
SIMD_FORCE_INLINE void resize(int newsize, const T &fillData=T())
void quickSort(const L &CompareFunc)
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)
virtual void allSolved(const btContactSolverInfo &, class btIDebugDraw *)
virtual void solveDeformableConstraints(btScalar solverdt)
void setConstraints(const btContactSolverInfo &infoGlobal)
btDeformableBackwardEulerObjective * m_objective
void reinitialize(const btAlignedObjectArray< btSoftBody * > &softBodies, btScalar dt)
void setupDeformableSolve(bool implicit)
void setLineSearch(bool lineSearch)
virtual void predictMotion(btScalar solverdt)
void setImplicit(bool implicit)
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
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
void processIslands(btDispatcher *dispatcher, btCollisionWorld *collisionWorld, IslandCallback *callback)
void buildIslands(btDispatcher *dispatcher, btCollisionWorld *colWorld)
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)
local_group_size(16, 16) .push_constant(Type b
draw_view push_constant(Type::INT, "radiance_src") .push_constant(Type capture_info_buf storage_buf(1, Qualifier::READ, "ObjectBounds", "bounds_buf[]") .push_constant(Type draw_view int
ccl_device_inline float cross(const float2 a, const float2 b)
virtual void processConstraints(int islandId=-1)
virtual SIMD_FORCE_INLINE void setup(btContactSolverInfo *solverInfo, btTypedConstraint **sortedConstraints, int numConstraints, btMultiBodyConstraint **sortedMultiBodyConstraints, int numMultiBodyConstraints, btIDebugDraw *debugDrawer)
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)
btDispatcher * m_dispatcher
btSparseSdf< 3 > m_sparsesdf
btScalar m_maxDisplacement
btBroadphaseInterface * m_broadphase
btScalar Evaluate(const btVector3 &x, const btCollisionShape *shape, btVector3 &normal, btScalar margin)
void setDefaultVoxelsz(btScalar sz)
void Initialize(int hashsize=2383, int clampCells=256 *1024)