diff options
Diffstat (limited to 'thirdparty/bullet/BulletDynamics/ConstraintSolver')
7 files changed, 22 insertions, 8 deletions
| diff --git a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btBatchedConstraints.cpp b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btBatchedConstraints.cpp index 27f76b8425..0f5ed1c2ce 100644 --- a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btBatchedConstraints.cpp +++ b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btBatchedConstraints.cpp @@ -852,7 +852,7 @@ static void setupSpatialGridBatchesMt(  		memHelper.addChunk((void**)&constraintRowBatchIds, sizeof(int) * numConstraintRows);  		size_t scratchSize = memHelper.getSizeToAllocate();  		// if we need to reallocate -		if (scratchMemory->capacity() < scratchSize) +		if (static_cast<size_t>(scratchMemory->capacity()) < scratchSize)  		{  			// allocate 6.25% extra to avoid repeated reallocs  			scratchMemory->reserve(scratchSize + scratchSize / 16); diff --git a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btContactSolverInfo.h b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btContactSolverInfo.h index e82d1b139e..3316403a87 100644 --- a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btContactSolverInfo.h +++ b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btContactSolverInfo.h @@ -46,7 +46,9 @@ struct btContactSolverInfoData  	btScalar m_sor;          //successive over-relaxation term  	btScalar m_erp;          //error reduction for non-contact constraints  	btScalar m_erp2;         //error reduction for contact constraints -    btScalar m_deformable_erp;          //error reduction for deformable constraints +	btScalar m_deformable_erp;          //error reduction for deformable constraints +	btScalar m_deformable_cfm;          //constraint force mixing for deformable constraints +	btScalar m_deformable_maxErrorReduction; // maxErrorReduction for deformable contact  	btScalar m_globalCfm;    //constraint force mixing for contacts and non-contacts  	btScalar m_frictionERP;  //error reduction for friction constraints  	btScalar m_frictionCFM;  //constraint force mixing for friction constraints @@ -67,6 +69,7 @@ struct btContactSolverInfoData  	bool m_jointFeedbackInWorldSpace;  	bool m_jointFeedbackInJointFrame;  	int m_reportSolverAnalytics; +	int m_numNonContactInnerIterations;  };  struct btContactSolverInfo : public btContactSolverInfoData @@ -82,7 +85,9 @@ struct btContactSolverInfo : public btContactSolverInfoData  		m_numIterations = 10;  		m_erp = btScalar(0.2);  		m_erp2 = btScalar(0.2); -        m_deformable_erp = btScalar(0.); +		m_deformable_erp = btScalar(0.06); +		m_deformable_cfm = btScalar(0.01); +		m_deformable_maxErrorReduction = btScalar(0.1);  		m_globalCfm = btScalar(0.);  		m_frictionERP = btScalar(0.2);  //positional friction 'anchors' are disabled by default  		m_frictionCFM = btScalar(0.); @@ -104,6 +109,7 @@ struct btContactSolverInfo : public btContactSolverInfoData  		m_jointFeedbackInWorldSpace = false;  		m_jointFeedbackInJointFrame = false;  		m_reportSolverAnalytics = 0; +		m_numNonContactInnerIterations = 1;   // the number of inner iterations for solving motor constraint in a single iteration of the constraint solve  	}  }; diff --git a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btGeneric6DofSpring2Constraint.cpp b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btGeneric6DofSpring2Constraint.cpp index 93626f18ff..74a13c6249 100644 --- a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btGeneric6DofSpring2Constraint.cpp +++ b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btGeneric6DofSpring2Constraint.cpp @@ -876,7 +876,10 @@ int btGeneric6DofSpring2Constraint::get_limit_motor_info2(  		// will we not request a velocity with the wrong direction ?  		// and the answer is not, because in practice during the solving the current velocity is subtracted from the m_constraintError  		// so the sign of the force that is really matters -		info->m_constraintError[srow] = (rotational ? -1 : 1) * (f < 0 ? -SIMD_INFINITY : SIMD_INFINITY); +		if (m_flags & BT_6DOF_FLAGS_USE_INFINITE_ERROR) +			info->m_constraintError[srow] = (rotational ? -1 : 1) * (f < 0 ? -SIMD_INFINITY : SIMD_INFINITY); +		else +			info->m_constraintError[srow] = vel + f / m * (rotational ? -1 : 1);  		btScalar minf = f < fd ? f : fd;  		btScalar maxf = f < fd ? fd : f; diff --git a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btGeneric6DofSpring2Constraint.h b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btGeneric6DofSpring2Constraint.h index 00e24364e0..c86dc373da 100644 --- a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btGeneric6DofSpring2Constraint.h +++ b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btGeneric6DofSpring2Constraint.h @@ -265,6 +265,7 @@ enum bt6DofFlags2  	BT_6DOF_FLAGS_ERP_STOP2 = 2,  	BT_6DOF_FLAGS_CFM_MOTO2 = 4,  	BT_6DOF_FLAGS_ERP_MOTO2 = 8, +	BT_6DOF_FLAGS_USE_INFINITE_ERROR = (1<<16)  };  #define BT_6DOF_FLAGS_AXIS_SHIFT2 4  // bits per axis diff --git a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btSequentialImpulseConstraintSolver.cpp b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btSequentialImpulseConstraintSolver.cpp index e4da468299..d2641c582f 100644 --- a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btSequentialImpulseConstraintSolver.cpp +++ b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btSequentialImpulseConstraintSolver.cpp @@ -14,7 +14,9 @@ subject to the following restrictions:  */  //#define COMPUTE_IMPULSE_DENOM 1 -//#define BT_ADDITIONAL_DEBUG +#ifdef BT_DEBUG +#	define BT_ADDITIONAL_DEBUG +#endif  //It is not necessary (redundant) to refresh contact manifolds, this refresh has been moved to the collision algorithms. @@ -690,8 +692,10 @@ int btSequentialImpulseConstraintSolver::getOrInitSolverBody(btCollisionObject&  {  #if BT_THREADSAFE  	int solverBodyId = -1; -	bool isRigidBodyType = btRigidBody::upcast(&body) != NULL; -	if (isRigidBodyType && !body.isStaticOrKinematicObject()) +	const bool isRigidBodyType = btRigidBody::upcast(&body) != NULL; +	const bool isStaticOrKinematic = body.isStaticOrKinematicObject(); +	const bool isKinematic = body.isKinematicObject(); +	if (isRigidBodyType && !isStaticOrKinematic)  	{  		// dynamic body  		// Dynamic bodies can only be in one island, so it's safe to write to the companionId @@ -704,7 +708,7 @@ int btSequentialImpulseConstraintSolver::getOrInitSolverBody(btCollisionObject&  			body.setCompanionId(solverBodyId);  		}  	} -	else if (isRigidBodyType && body.isKinematicObject()) +	else if (isRigidBodyType && isKinematic)  	{  		//  		// NOTE: must test for kinematic before static because some kinematic objects also diff --git a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btSliderConstraint.cpp b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btSliderConstraint.cpp index cac5302a73..cac5302a73 100755..100644 --- a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btSliderConstraint.cpp +++ b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btSliderConstraint.cpp diff --git a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btSliderConstraint.h b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btSliderConstraint.h index 75ca34e978..75ca34e978 100755..100644 --- a/thirdparty/bullet/BulletDynamics/ConstraintSolver/btSliderConstraint.h +++ b/thirdparty/bullet/BulletDynamics/ConstraintSolver/btSliderConstraint.h |