mirror of
https://github.com/bulletphysics/bullet3
synced 2025-01-05 15:21:06 +00:00
Replace all hardcoded 1e30(f) by BT_LARGE_FLOAT, defined in btScalar.h as 1e18(f) so that its square still fits in FLT_MAX
Thanks to Ole K. for reporting! http://code.google.com/p/bullet/issues/detail?id=206
This commit is contained in:
parent
1e11223f6b
commit
badf723257
@ -92,7 +92,6 @@ struct ClipVertex
|
|||||||
#define b2Dot(a,b) (a).dot(b)
|
#define b2Dot(a,b) (a).dot(b)
|
||||||
#define b2Mul(a,b) (a)*(b)
|
#define b2Mul(a,b) (a)*(b)
|
||||||
#define b2MulT(a,b) (a).transpose()*(b)
|
#define b2MulT(a,b) (a).transpose()*(b)
|
||||||
#define BT_FLT_MAX 1e30f
|
|
||||||
#define b2Cross(a,b) (a).cross(b)
|
#define b2Cross(a,b) (a).cross(b)
|
||||||
#define btCrossS(a,s) btVector3(s * a.getY(), -s * a.getX(),0.f)
|
#define btCrossS(a,s) btVector3(s * a.getY(), -s * a.getX(),0.f)
|
||||||
|
|
||||||
@ -151,7 +150,7 @@ static btScalar EdgeSeparation(const btBox2dShape* poly1, const btTransform& xf1
|
|||||||
|
|
||||||
// Find support vertex on poly2 for -normal.
|
// Find support vertex on poly2 for -normal.
|
||||||
int index = 0;
|
int index = 0;
|
||||||
btScalar minDot = BT_FLT_MAX;
|
btScalar minDot = BT_LARGE_FLOAT;
|
||||||
|
|
||||||
for (int i = 0; i < count2; ++i)
|
for (int i = 0; i < count2; ++i)
|
||||||
{
|
{
|
||||||
@ -183,7 +182,7 @@ static btScalar FindMaxSeparation(int* edgeIndex,
|
|||||||
|
|
||||||
// Find edge normal on poly1 that has the largest projection onto d.
|
// Find edge normal on poly1 that has the largest projection onto d.
|
||||||
int edge = 0;
|
int edge = 0;
|
||||||
btScalar maxDot = -BT_FLT_MAX;
|
btScalar maxDot = -BT_LARGE_FLOAT;
|
||||||
for (int i = 0; i < count1; ++i)
|
for (int i = 0; i < count1; ++i)
|
||||||
{
|
{
|
||||||
btScalar dot = b2Dot(normals1[i], dLocal1);
|
btScalar dot = b2Dot(normals1[i], dLocal1);
|
||||||
@ -286,7 +285,7 @@ static void FindIncidentEdge(ClipVertex c[2],
|
|||||||
|
|
||||||
// Find the incident edge on poly2.
|
// Find the incident edge on poly2.
|
||||||
int index = 0;
|
int index = 0;
|
||||||
btScalar minDot = BT_FLT_MAX;
|
btScalar minDot = BT_LARGE_FLOAT;
|
||||||
for (int i = 0; i < count2; ++i)
|
for (int i = 0; i < count2; ++i)
|
||||||
{
|
{
|
||||||
btScalar dot = b2Dot(normal1, normals2[i]);
|
btScalar dot = b2Dot(normal1, normals2[i]);
|
||||||
|
@ -217,8 +217,8 @@ void CollisionDemo::displayCallback(void) {
|
|||||||
}
|
}
|
||||||
debugDrawer.drawTransform(input.m_transformA,10.0);
|
debugDrawer.drawTransform(input.m_transformA,10.0);
|
||||||
btGjkPairDetector convexConvex(shapePtr[0],shapePtr[1],&sGjkSimplexSolver,&epaSolver);
|
btGjkPairDetector convexConvex(shapePtr[0],shapePtr[1],&sGjkSimplexSolver,&epaSolver);
|
||||||
input.m_maximumDistanceSquared = 1e30;
|
input.m_maximumDistanceSquared = BT_LARGE_FLOAT;
|
||||||
gjkOutput.m_distance = 1e30f;
|
gjkOutput.m_distance = BT_LARGE_FLOAT;
|
||||||
convexConvex.getClosestPoints(input, gjkOutput, 0);
|
convexConvex.getClosestPoints(input, gjkOutput, 0);
|
||||||
|
|
||||||
|
|
||||||
|
@ -406,8 +406,8 @@ void ConcaveConvexcastDemo::clientMoveAndDisplay()
|
|||||||
|
|
||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
btVector3 aabbMin(1e30,1e30,1e30);
|
btVector3 aabbMin(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT);
|
||||||
btVector3 aabbMax(-1e30,-1e30,-1e30);
|
btVector3 aabbMax(-BT_LARGE_FLOAT,-BT_LARGE_FLOAT,-BT_LARGE_FLOAT);
|
||||||
|
|
||||||
for ( i=NUM_VERTS_X/2-3;i<NUM_VERTS_X/2+2;i++)
|
for ( i=NUM_VERTS_X/2-3;i<NUM_VERTS_X/2+2;i++)
|
||||||
{
|
{
|
||||||
|
@ -340,8 +340,8 @@ void ConcaveDemo::clientMoveAndDisplay()
|
|||||||
|
|
||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
btVector3 aabbMin(1e30,1e30,1e30);
|
btVector3 aabbMin(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT);
|
||||||
btVector3 aabbMax(-1e30,-1e30,-1e30);
|
btVector3 aabbMax(-BT_LARGE_FLOAT,-BT_LARGE_FLOAT,-BT_LARGE_FLOAT);
|
||||||
|
|
||||||
for ( i=NUM_VERTS_X/2-3;i<NUM_VERTS_X/2+2;i++)
|
for ( i=NUM_VERTS_X/2-3;i<NUM_VERTS_X/2+2;i++)
|
||||||
{
|
{
|
||||||
|
@ -83,7 +83,7 @@ float steeringIncrement = 0.04f;
|
|||||||
float steeringClamp = 0.3f;
|
float steeringClamp = 0.3f;
|
||||||
float wheelRadius = 0.5f;
|
float wheelRadius = 0.5f;
|
||||||
float wheelWidth = 0.4f;
|
float wheelWidth = 0.4f;
|
||||||
float wheelFriction = 1000;//1e30f;
|
float wheelFriction = 1000;//BT_LARGE_FLOAT;
|
||||||
float suspensionStiffness = 20.f;
|
float suspensionStiffness = 20.f;
|
||||||
float suspensionDamping = 2.3f;
|
float suspensionDamping = 2.3f;
|
||||||
float suspensionCompression = 4.4f;
|
float suspensionCompression = 4.4f;
|
||||||
|
@ -487,8 +487,8 @@ if (shape->getShapeType() == CONVEX_TRIANGLEMESH_SHAPE_PROXYTYPE)
|
|||||||
btConvexTriangleMeshShape* convexMesh = (btConvexTriangleMeshShape*) shape;
|
btConvexTriangleMeshShape* convexMesh = (btConvexTriangleMeshShape*) shape;
|
||||||
|
|
||||||
//todo: pass camera for some culling
|
//todo: pass camera for some culling
|
||||||
btVector3 aabbMax(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
btVector3 aabbMax(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
btVector3 aabbMin(-btScalar(1e30),-btScalar(1e30),-btScalar(1e30));
|
btVector3 aabbMin(-btScalar(BT_LARGE_FLOAT),-btScalar(BT_LARGE_FLOAT),-btScalar(BT_LARGE_FLOAT));
|
||||||
TriangleGlDrawcallback drawCallback;
|
TriangleGlDrawcallback drawCallback;
|
||||||
convexMesh->getMeshInterface()->InternalProcessAllTriangles(&drawCallback,aabbMin,aabbMax);
|
convexMesh->getMeshInterface()->InternalProcessAllTriangles(&drawCallback,aabbMin,aabbMax);
|
||||||
|
|
||||||
|
@ -275,8 +275,8 @@ void MultiMaterialDemo::clientMoveAndDisplay()
|
|||||||
|
|
||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
btVector3 aabbMin(1e30,1e30,1e30);
|
btVector3 aabbMin(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT);
|
||||||
btVector3 aabbMax(-1e30,-1e30,-1e30);
|
btVector3 aabbMax(-BT_LARGE_FLOAT,-BT_LARGE_FLOAT,-BT_LARGE_FLOAT);
|
||||||
|
|
||||||
for ( i=NUM_VERTS_X/2-3;i<NUM_VERTS_X/2+2;i++)
|
for ( i=NUM_VERTS_X/2-3;i<NUM_VERTS_X/2+2;i++)
|
||||||
{
|
{
|
||||||
|
@ -1098,8 +1098,8 @@ void DemoApplication::renderscene(int pass)
|
|||||||
btVector3 aabbMin,aabbMax;
|
btVector3 aabbMin,aabbMax;
|
||||||
m_dynamicsWorld->getBroadphase()->getBroadphaseAabb(aabbMin,aabbMax);
|
m_dynamicsWorld->getBroadphase()->getBroadphaseAabb(aabbMin,aabbMax);
|
||||||
|
|
||||||
aabbMin-=btVector3(1e30,1e30,1e30);
|
aabbMin-=btVector3(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT);
|
||||||
aabbMax+=btVector3(1e30,1e30,1e30);
|
aabbMax+=btVector3(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT);
|
||||||
// printf("aabbMin=(%f,%f,%f)\n",aabbMin.getX(),aabbMin.getY(),aabbMin.getZ());
|
// printf("aabbMin=(%f,%f,%f)\n",aabbMin.getX(),aabbMin.getY(),aabbMin.getZ());
|
||||||
// printf("aabbMax=(%f,%f,%f)\n",aabbMax.getX(),aabbMax.getY(),aabbMax.getZ());
|
// printf("aabbMax=(%f,%f,%f)\n",aabbMax.getX(),aabbMax.getY(),aabbMax.getZ());
|
||||||
// m_dynamicsWorld->getDebugDrawer()->drawAabb(aabbMin,aabbMax,btVector3(1,1,1));
|
// m_dynamicsWorld->getDebugDrawer()->drawAabb(aabbMin,aabbMax,btVector3(1,1,1));
|
||||||
|
@ -149,8 +149,8 @@ void OGL_displaylist_clean()
|
|||||||
|
|
||||||
void OGL_displaylist_register_shape(btCollisionShape * shape)
|
void OGL_displaylist_register_shape(btCollisionShape * shape)
|
||||||
{
|
{
|
||||||
btVector3 aabbMax(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
btVector3 aabbMax(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
btVector3 aabbMin(-btScalar(1e30),-btScalar(1e30),-btScalar(1e30));
|
btVector3 aabbMin(-btScalar(BT_LARGE_FLOAT),-btScalar(BT_LARGE_FLOAT),-btScalar(BT_LARGE_FLOAT));
|
||||||
GlDisplaylistDrawcallback drawCallback;
|
GlDisplaylistDrawcallback drawCallback;
|
||||||
TRIMESH_KEY dlist;
|
TRIMESH_KEY dlist;
|
||||||
|
|
||||||
|
@ -66,7 +66,7 @@ float steeringIncrement = 0.04f;
|
|||||||
float steeringClamp = 0.3f;
|
float steeringClamp = 0.3f;
|
||||||
float wheelRadius = 0.5f;
|
float wheelRadius = 0.5f;
|
||||||
float wheelWidth = 0.4f;
|
float wheelWidth = 0.4f;
|
||||||
float wheelFriction = 1000;//1e30f;
|
float wheelFriction = 1000;//BT_LARGE_FLOAT;
|
||||||
float suspensionStiffness = 20.f;
|
float suspensionStiffness = 20.f;
|
||||||
float suspensionDamping = 2.3f;
|
float suspensionDamping = 2.3f;
|
||||||
float suspensionCompression = 4.4f;
|
float suspensionCompression = 4.4f;
|
||||||
|
@ -155,7 +155,7 @@ void btOdeContactJoint::GetInfo2(Info2 *info)
|
|||||||
|
|
||||||
// set LCP limits for normal
|
// set LCP limits for normal
|
||||||
info->m_lowerLimit[0] = 0;
|
info->m_lowerLimit[0] = 0;
|
||||||
info->m_higherLimit[0] = 1e30f;//dInfinity;
|
info->m_higherLimit[0] = BT_LARGE_FLOAT;//dInfinity;
|
||||||
info->m_lowerLimit[1] = 0;
|
info->m_lowerLimit[1] = 0;
|
||||||
info->m_higherLimit[1] = 0.f;
|
info->m_higherLimit[1] = 0.f;
|
||||||
info->m_lowerLimit[2] = 0.f;
|
info->m_lowerLimit[2] = 0.f;
|
||||||
@ -208,7 +208,7 @@ void btOdeContactJoint::GetInfo2(Info2 *info)
|
|||||||
// }
|
// }
|
||||||
// set LCP bounds and friction index. this depends on the approximation
|
// set LCP bounds and friction index. this depends on the approximation
|
||||||
// mode
|
// mode
|
||||||
//1e30f
|
//BT_LARGE_FLOAT
|
||||||
|
|
||||||
|
|
||||||
info->m_lowerLimit[1] = -friction;//-j->contact.surface.mu;
|
info->m_lowerLimit[1] = -friction;//-j->contact.surface.mu;
|
||||||
|
@ -1000,11 +1000,11 @@ inline void btDbvt::rayTest( const btDbvtNode* root,
|
|||||||
btVector3 rayDir = (rayTo-rayFrom);
|
btVector3 rayDir = (rayTo-rayFrom);
|
||||||
rayDir.normalize ();
|
rayDir.normalize ();
|
||||||
|
|
||||||
///what about division by zero? --> just set rayDirection[i] to INF/1e30
|
///what about division by zero? --> just set rayDirection[i] to INF/BT_LARGE_FLOAT
|
||||||
btVector3 rayDirectionInverse;
|
btVector3 rayDirectionInverse;
|
||||||
rayDirectionInverse[0] = rayDir[0] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDir[0];
|
rayDirectionInverse[0] = rayDir[0] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDir[0];
|
||||||
rayDirectionInverse[1] = rayDir[1] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDir[1];
|
rayDirectionInverse[1] = rayDir[1] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDir[1];
|
||||||
rayDirectionInverse[2] = rayDir[2] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDir[2];
|
rayDirectionInverse[2] = rayDir[2] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDir[2];
|
||||||
unsigned int signs[3] = { rayDirectionInverse[0] < 0.0, rayDirectionInverse[1] < 0.0, rayDirectionInverse[2] < 0.0};
|
unsigned int signs[3] = { rayDirectionInverse[0] < 0.0, rayDirectionInverse[1] < 0.0, rayDirectionInverse[2] < 0.0};
|
||||||
|
|
||||||
btScalar lambda_max = rayDir.dot(rayTo-rayFrom);
|
btScalar lambda_max = rayDir.dot(rayTo-rayFrom);
|
||||||
|
@ -133,8 +133,8 @@ public:
|
|||||||
///will add some transform later
|
///will add some transform later
|
||||||
virtual void getBroadphaseAabb(btVector3& aabbMin,btVector3& aabbMax) const
|
virtual void getBroadphaseAabb(btVector3& aabbMin,btVector3& aabbMax) const
|
||||||
{
|
{
|
||||||
aabbMin.setValue(-1e30f,-1e30f,-1e30f);
|
aabbMin.setValue(-BT_LARGE_FLOAT,-BT_LARGE_FLOAT,-BT_LARGE_FLOAT);
|
||||||
aabbMax.setValue(1e30f,1e30f,1e30f);
|
aabbMax.setValue(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT);
|
||||||
}
|
}
|
||||||
|
|
||||||
void buildTree(const btVector3& bvhAabbMin,const btVector3& bvhAabbMax);
|
void buildTree(const btVector3& bvhAabbMin,const btVector3& bvhAabbMax);
|
||||||
|
@ -474,9 +474,9 @@ void btQuantizedBvh::walkStacklessTreeAgainstRay(btNodeOverlapCallback* nodeCall
|
|||||||
lambda_max = rayDir.dot(rayTarget-raySource);
|
lambda_max = rayDir.dot(rayTarget-raySource);
|
||||||
///what about division by zero? --> just set rayDirection[i] to 1.0
|
///what about division by zero? --> just set rayDirection[i] to 1.0
|
||||||
btVector3 rayDirectionInverse;
|
btVector3 rayDirectionInverse;
|
||||||
rayDirectionInverse[0] = rayDir[0] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDir[0];
|
rayDirectionInverse[0] = rayDir[0] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDir[0];
|
||||||
rayDirectionInverse[1] = rayDir[1] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDir[1];
|
rayDirectionInverse[1] = rayDir[1] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDir[1];
|
||||||
rayDirectionInverse[2] = rayDir[2] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDir[2];
|
rayDirectionInverse[2] = rayDir[2] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDir[2];
|
||||||
unsigned int sign[3] = { rayDirectionInverse[0] < 0.0, rayDirectionInverse[1] < 0.0, rayDirectionInverse[2] < 0.0};
|
unsigned int sign[3] = { rayDirectionInverse[0] < 0.0, rayDirectionInverse[1] < 0.0, rayDirectionInverse[2] < 0.0};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -561,9 +561,9 @@ void btQuantizedBvh::walkStacklessQuantizedTreeAgainstRay(btNodeOverlapCallback*
|
|||||||
rayDirection.normalize ();
|
rayDirection.normalize ();
|
||||||
lambda_max = rayDirection.dot(rayTarget-raySource);
|
lambda_max = rayDirection.dot(rayTarget-raySource);
|
||||||
///what about division by zero? --> just set rayDirection[i] to 1.0
|
///what about division by zero? --> just set rayDirection[i] to 1.0
|
||||||
rayDirection[0] = rayDirection[0] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDirection[0];
|
rayDirection[0] = rayDirection[0] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDirection[0];
|
||||||
rayDirection[1] = rayDirection[1] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDirection[1];
|
rayDirection[1] = rayDirection[1] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDirection[1];
|
||||||
rayDirection[2] = rayDirection[2] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDirection[2];
|
rayDirection[2] = rayDirection[2] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDirection[2];
|
||||||
unsigned int sign[3] = { rayDirection[0] < 0.0, rayDirection[1] < 0.0, rayDirection[2] < 0.0};
|
unsigned int sign[3] = { rayDirection[0] < 0.0, rayDirection[1] < 0.0, rayDirection[2] < 0.0};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -153,8 +153,8 @@ public:
|
|||||||
///will add some transform later
|
///will add some transform later
|
||||||
virtual void getBroadphaseAabb(btVector3& aabbMin,btVector3& aabbMax) const
|
virtual void getBroadphaseAabb(btVector3& aabbMin,btVector3& aabbMax) const
|
||||||
{
|
{
|
||||||
aabbMin.setValue(-1e30f,-1e30f,-1e30f);
|
aabbMin.setValue(-BT_LARGE_FLOAT,-BT_LARGE_FLOAT,-BT_LARGE_FLOAT);
|
||||||
aabbMax.setValue(1e30f,1e30f,1e30f);
|
aabbMax.setValue(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void printStats()
|
virtual void printStats()
|
||||||
|
@ -37,7 +37,7 @@ void SphereTriangleDetector::getClosestPoints(const ClosestPointInput& input,Res
|
|||||||
btVector3 point,normal;
|
btVector3 point,normal;
|
||||||
btScalar timeOfImpact = btScalar(1.);
|
btScalar timeOfImpact = btScalar(1.);
|
||||||
btScalar depth = btScalar(0.);
|
btScalar depth = btScalar(0.);
|
||||||
// output.m_distance = btScalar(1e30);
|
// output.m_distance = btScalar(BT_LARGE_FLOAT);
|
||||||
//move sphere into triangle space
|
//move sphere into triangle space
|
||||||
btTransform sphereInTr = transformB.inverseTimes(transformA);
|
btTransform sphereInTr = transformB.inverseTimes(transformA);
|
||||||
|
|
||||||
|
@ -61,7 +61,7 @@ void btBoxBoxCollisionAlgorithm::processCollision (btCollisionObject* body0,btCo
|
|||||||
#endif //USE_PERSISTENT_CONTACTS
|
#endif //USE_PERSISTENT_CONTACTS
|
||||||
|
|
||||||
btDiscreteCollisionDetectorInterface::ClosestPointInput input;
|
btDiscreteCollisionDetectorInterface::ClosestPointInput input;
|
||||||
input.m_maximumDistanceSquared = 1e30f;
|
input.m_maximumDistanceSquared = BT_LARGE_FLOAT;
|
||||||
input.m_transformA = body0->getWorldTransform();
|
input.m_transformA = body0->getWorldTransform();
|
||||||
input.m_transformB = body1->getWorldTransform();
|
input.m_transformB = body1->getWorldTransform();
|
||||||
|
|
||||||
|
@ -212,7 +212,7 @@ void cullPoints2 (int n, btScalar p[], int m, int i0, int iret[])
|
|||||||
a = 1.f/(btScalar(3.0)*(a+q));
|
a = 1.f/(btScalar(3.0)*(a+q));
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
a=1e30f;
|
a=BT_LARGE_FLOAT;
|
||||||
}
|
}
|
||||||
cx = a*(cx + q*(p[n*2-2]+p[0]));
|
cx = a*(cx + q*(p[n*2-2]+p[0]));
|
||||||
cy = a*(cy + q*(p[n*2-1]+p[1]));
|
cy = a*(cy + q*(p[n*2-1]+p[1]));
|
||||||
|
@ -19,7 +19,7 @@ subject to the following restrictions:
|
|||||||
btCollisionObject::btCollisionObject()
|
btCollisionObject::btCollisionObject()
|
||||||
: m_anisotropicFriction(1.f,1.f,1.f),
|
: m_anisotropicFriction(1.f,1.f,1.f),
|
||||||
m_hasAnisotropicFriction(false),
|
m_hasAnisotropicFriction(false),
|
||||||
m_contactProcessingThreshold(1e30f),
|
m_contactProcessingThreshold(BT_LARGE_FLOAT),
|
||||||
m_broadphaseHandle(0),
|
m_broadphaseHandle(0),
|
||||||
m_collisionShape(0),
|
m_collisionShape(0),
|
||||||
m_rootCollisionShape(0),
|
m_rootCollisionShape(0),
|
||||||
|
@ -643,10 +643,10 @@ struct btSingleRayCallback : public btBroadphaseRayCallback
|
|||||||
btVector3 rayDir = (rayToWorld-rayFromWorld);
|
btVector3 rayDir = (rayToWorld-rayFromWorld);
|
||||||
|
|
||||||
rayDir.normalize ();
|
rayDir.normalize ();
|
||||||
///what about division by zero? --> just set rayDirection[i] to INF/1e30
|
///what about division by zero? --> just set rayDirection[i] to INF/BT_LARGE_FLOAT
|
||||||
m_rayDirectionInverse[0] = rayDir[0] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDir[0];
|
m_rayDirectionInverse[0] = rayDir[0] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDir[0];
|
||||||
m_rayDirectionInverse[1] = rayDir[1] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDir[1];
|
m_rayDirectionInverse[1] = rayDir[1] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDir[1];
|
||||||
m_rayDirectionInverse[2] = rayDir[2] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDir[2];
|
m_rayDirectionInverse[2] = rayDir[2] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDir[2];
|
||||||
m_signs[0] = m_rayDirectionInverse[0] < 0.0;
|
m_signs[0] = m_rayDirectionInverse[0] < 0.0;
|
||||||
m_signs[1] = m_rayDirectionInverse[1] < 0.0;
|
m_signs[1] = m_rayDirectionInverse[1] < 0.0;
|
||||||
m_signs[2] = m_rayDirectionInverse[2] < 0.0;
|
m_signs[2] = m_rayDirectionInverse[2] < 0.0;
|
||||||
@ -736,10 +736,10 @@ struct btSingleSweepCallback : public btBroadphaseRayCallback
|
|||||||
{
|
{
|
||||||
btVector3 unnormalizedRayDir = (m_convexToTrans.getOrigin()-m_convexFromTrans.getOrigin());
|
btVector3 unnormalizedRayDir = (m_convexToTrans.getOrigin()-m_convexFromTrans.getOrigin());
|
||||||
btVector3 rayDir = unnormalizedRayDir.normalized();
|
btVector3 rayDir = unnormalizedRayDir.normalized();
|
||||||
///what about division by zero? --> just set rayDirection[i] to INF/1e30
|
///what about division by zero? --> just set rayDirection[i] to INF/BT_LARGE_FLOAT
|
||||||
m_rayDirectionInverse[0] = rayDir[0] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDir[0];
|
m_rayDirectionInverse[0] = rayDir[0] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDir[0];
|
||||||
m_rayDirectionInverse[1] = rayDir[1] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDir[1];
|
m_rayDirectionInverse[1] = rayDir[1] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDir[1];
|
||||||
m_rayDirectionInverse[2] = rayDir[2] == btScalar(0.0) ? btScalar(1e30) : btScalar(1.0) / rayDir[2];
|
m_rayDirectionInverse[2] = rayDir[2] == btScalar(0.0) ? btScalar(BT_LARGE_FLOAT) : btScalar(1.0) / rayDir[2];
|
||||||
m_signs[0] = m_rayDirectionInverse[0] < 0.0;
|
m_signs[0] = m_rayDirectionInverse[0] < 0.0;
|
||||||
m_signs[1] = m_rayDirectionInverse[1] < 0.0;
|
m_signs[1] = m_rayDirectionInverse[1] < 0.0;
|
||||||
m_signs[2] = m_rayDirectionInverse[2] < 0.0;
|
m_signs[2] = m_rayDirectionInverse[2] < 0.0;
|
||||||
|
@ -194,7 +194,7 @@ void btConvexConvexAlgorithm ::processCollision (btCollisionObject* body0,btColl
|
|||||||
#ifdef USE_SEPDISTANCE_UTIL2
|
#ifdef USE_SEPDISTANCE_UTIL2
|
||||||
if (dispatchInfo.m_useConvexConservativeDistanceUtil)
|
if (dispatchInfo.m_useConvexConservativeDistanceUtil)
|
||||||
{
|
{
|
||||||
input.m_maximumDistanceSquared = 1e30f;
|
input.m_maximumDistanceSquared = BT_LARGE_FLOAT;
|
||||||
} else
|
} else
|
||||||
#endif //USE_SEPDISTANCE_UTIL2
|
#endif //USE_SEPDISTANCE_UTIL2
|
||||||
{
|
{
|
||||||
|
@ -59,7 +59,7 @@ void btSphereTriangleCollisionAlgorithm::processCollision (btCollisionObject* co
|
|||||||
SphereTriangleDetector detector(sphere,triangle, m_manifoldPtr->getContactBreakingThreshold());
|
SphereTriangleDetector detector(sphere,triangle, m_manifoldPtr->getContactBreakingThreshold());
|
||||||
|
|
||||||
btDiscreteCollisionDetectorInterface::ClosestPointInput input;
|
btDiscreteCollisionDetectorInterface::ClosestPointInput input;
|
||||||
input.m_maximumDistanceSquared = btScalar(1e30);///@todo: tighter bounds
|
input.m_maximumDistanceSquared = btScalar(BT_LARGE_FLOAT);///@todo: tighter bounds
|
||||||
input.m_transformA = sphereObj->getWorldTransform();
|
input.m_transformA = sphereObj->getWorldTransform();
|
||||||
input.m_transformB = triObj->getWorldTransform();
|
input.m_transformB = triObj->getWorldTransform();
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ btCapsuleShape::btCapsuleShape(btScalar radius, btScalar height) : btConvexInter
|
|||||||
|
|
||||||
btVector3 supVec(0,0,0);
|
btVector3 supVec(0,0,0);
|
||||||
|
|
||||||
btScalar maxDot(btScalar(-1e30));
|
btScalar maxDot(btScalar(-BT_LARGE_FLOAT));
|
||||||
|
|
||||||
btVector3 vec = vec0;
|
btVector3 vec = vec0;
|
||||||
btScalar lenSqr = vec.length2();
|
btScalar lenSqr = vec.length2();
|
||||||
@ -88,7 +88,7 @@ btCapsuleShape::btCapsuleShape(btScalar radius, btScalar height) : btConvexInter
|
|||||||
|
|
||||||
for (int j=0;j<numVectors;j++)
|
for (int j=0;j<numVectors;j++)
|
||||||
{
|
{
|
||||||
btScalar maxDot(btScalar(-1e30));
|
btScalar maxDot(btScalar(-BT_LARGE_FLOAT));
|
||||||
const btVector3& vec = vectors[j];
|
const btVector3& vec = vectors[j];
|
||||||
|
|
||||||
btVector3 vtx;
|
btVector3 vtx;
|
||||||
|
@ -18,8 +18,8 @@ subject to the following restrictions:
|
|||||||
#include "BulletCollision/BroadphaseCollision/btDbvt.h"
|
#include "BulletCollision/BroadphaseCollision/btDbvt.h"
|
||||||
|
|
||||||
btCompoundShape::btCompoundShape(bool enableDynamicAabbTree)
|
btCompoundShape::btCompoundShape(bool enableDynamicAabbTree)
|
||||||
: m_localAabbMin(btScalar(1e30),btScalar(1e30),btScalar(1e30)),
|
: m_localAabbMin(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT)),
|
||||||
m_localAabbMax(btScalar(-1e30),btScalar(-1e30),btScalar(-1e30)),
|
m_localAabbMax(btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT)),
|
||||||
m_collisionMargin(btScalar(0.)),
|
m_collisionMargin(btScalar(0.)),
|
||||||
m_localScaling(btScalar(1.),btScalar(1.),btScalar(1.)),
|
m_localScaling(btScalar(1.),btScalar(1.),btScalar(1.)),
|
||||||
m_dynamicAabbTree(0),
|
m_dynamicAabbTree(0),
|
||||||
@ -138,8 +138,8 @@ void btCompoundShape::recalculateLocalAabb()
|
|||||||
// Recalculate the local aabb
|
// Recalculate the local aabb
|
||||||
// Brute force, it iterates over all the shapes left.
|
// Brute force, it iterates over all the shapes left.
|
||||||
|
|
||||||
m_localAabbMin = btVector3(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
m_localAabbMin = btVector3(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
m_localAabbMax = btVector3(btScalar(-1e30),btScalar(-1e30),btScalar(-1e30));
|
m_localAabbMax = btVector3(btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT));
|
||||||
|
|
||||||
//extend the local aabbMin/aabbMax
|
//extend the local aabbMin/aabbMax
|
||||||
for (int j = 0; j < m_children.size(); j++)
|
for (int j = 0; j < m_children.size(); j++)
|
||||||
|
@ -55,7 +55,7 @@ void btConvexHullShape::addPoint(const btVector3& point)
|
|||||||
btVector3 btConvexHullShape::localGetSupportingVertexWithoutMargin(const btVector3& vec0)const
|
btVector3 btConvexHullShape::localGetSupportingVertexWithoutMargin(const btVector3& vec0)const
|
||||||
{
|
{
|
||||||
btVector3 supVec(btScalar(0.),btScalar(0.),btScalar(0.));
|
btVector3 supVec(btScalar(0.),btScalar(0.),btScalar(0.));
|
||||||
btScalar newDot,maxDot = btScalar(-1e30);
|
btScalar newDot,maxDot = btScalar(-BT_LARGE_FLOAT);
|
||||||
|
|
||||||
btVector3 vec = vec0;
|
btVector3 vec = vec0;
|
||||||
btScalar lenSqr = vec.length2();
|
btScalar lenSqr = vec.length2();
|
||||||
@ -90,7 +90,7 @@ void btConvexHullShape::batchedUnitVectorGetSupportingVertexWithoutMargin(const
|
|||||||
{
|
{
|
||||||
for (int i=0;i<numVectors;i++)
|
for (int i=0;i<numVectors;i++)
|
||||||
{
|
{
|
||||||
supportVerticesOut[i][3] = btScalar(-1e30);
|
supportVerticesOut[i][3] = btScalar(-BT_LARGE_FLOAT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (int i=0;i<m_unscaledPoints.size();i++)
|
for (int i=0;i<m_unscaledPoints.size();i++)
|
||||||
|
@ -28,7 +28,7 @@ void btConvexPointCloudShape::setLocalScaling(const btVector3& scaling)
|
|||||||
btVector3 btConvexPointCloudShape::localGetSupportingVertexWithoutMargin(const btVector3& vec0)const
|
btVector3 btConvexPointCloudShape::localGetSupportingVertexWithoutMargin(const btVector3& vec0)const
|
||||||
{
|
{
|
||||||
btVector3 supVec(btScalar(0.),btScalar(0.),btScalar(0.));
|
btVector3 supVec(btScalar(0.),btScalar(0.),btScalar(0.));
|
||||||
btScalar newDot,maxDot = btScalar(-1e30);
|
btScalar newDot,maxDot = btScalar(-BT_LARGE_FLOAT);
|
||||||
|
|
||||||
btVector3 vec = vec0;
|
btVector3 vec = vec0;
|
||||||
btScalar lenSqr = vec.length2();
|
btScalar lenSqr = vec.length2();
|
||||||
@ -63,7 +63,7 @@ void btConvexPointCloudShape::batchedUnitVectorGetSupportingVertexWithoutMargin(
|
|||||||
{
|
{
|
||||||
for (int i=0;i<numVectors;i++)
|
for (int i=0;i<numVectors;i++)
|
||||||
{
|
{
|
||||||
supportVerticesOut[i][3] = btScalar(-1e30);
|
supportVerticesOut[i][3] = btScalar(-BT_LARGE_FLOAT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (int i=0;i<m_numPoints;i++)
|
for (int i=0;i<m_numPoints;i++)
|
||||||
|
@ -35,7 +35,7 @@ btConvexShape::~btConvexShape()
|
|||||||
static btVector3 convexHullSupport (const btVector3& localDir, const btVector3* points, int numPoints, const btVector3& localScaling)
|
static btVector3 convexHullSupport (const btVector3& localDir, const btVector3* points, int numPoints, const btVector3& localScaling)
|
||||||
{
|
{
|
||||||
btVector3 supVec(btScalar(0.),btScalar(0.),btScalar(0.));
|
btVector3 supVec(btScalar(0.),btScalar(0.),btScalar(0.));
|
||||||
btScalar newDot,maxDot = btScalar(-1e30);
|
btScalar newDot,maxDot = btScalar(-BT_LARGE_FLOAT);
|
||||||
|
|
||||||
btVector3 vec0(localDir.getX(),localDir.getY(),localDir.getZ());
|
btVector3 vec0(localDir.getX(),localDir.getY(),localDir.getZ());
|
||||||
btVector3 vec = vec0;
|
btVector3 vec = vec0;
|
||||||
@ -160,7 +160,7 @@ btVector3 btConvexShape::localGetSupportVertexWithoutMarginNonVirtual (const btV
|
|||||||
btScalar radius = capsuleShape->getRadius();
|
btScalar radius = capsuleShape->getRadius();
|
||||||
btVector3 supVec(0,0,0);
|
btVector3 supVec(0,0,0);
|
||||||
|
|
||||||
btScalar maxDot(btScalar(-1e30));
|
btScalar maxDot(btScalar(-BT_LARGE_FLOAT));
|
||||||
|
|
||||||
btVector3 vec = vec0;
|
btVector3 vec = vec0;
|
||||||
btScalar lenSqr = vec.length2();
|
btScalar lenSqr = vec.length2();
|
||||||
|
@ -44,7 +44,7 @@ public:
|
|||||||
|
|
||||||
LocalSupportVertexCallback(const btVector3& supportVecLocal)
|
LocalSupportVertexCallback(const btVector3& supportVecLocal)
|
||||||
: m_supportVertexLocal(btScalar(0.),btScalar(0.),btScalar(0.)),
|
: m_supportVertexLocal(btScalar(0.),btScalar(0.),btScalar(0.)),
|
||||||
m_maxDot(btScalar(-1e30)),
|
m_maxDot(btScalar(-BT_LARGE_FLOAT)),
|
||||||
m_supportVecLocal(supportVecLocal)
|
m_supportVecLocal(supportVecLocal)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
@ -92,7 +92,7 @@ btVector3 btConvexTriangleMeshShape::localGetSupportingVertexWithoutMargin(const
|
|||||||
}
|
}
|
||||||
|
|
||||||
LocalSupportVertexCallback supportCallback(vec);
|
LocalSupportVertexCallback supportCallback(vec);
|
||||||
btVector3 aabbMax(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
btVector3 aabbMax(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
m_stridingMesh->InternalProcessAllTriangles(&supportCallback,-aabbMax,aabbMax);
|
m_stridingMesh->InternalProcessAllTriangles(&supportCallback,-aabbMax,aabbMax);
|
||||||
supVec = supportCallback.GetSupportVertexLocal();
|
supVec = supportCallback.GetSupportVertexLocal();
|
||||||
|
|
||||||
@ -105,7 +105,7 @@ void btConvexTriangleMeshShape::batchedUnitVectorGetSupportingVertexWithoutMargi
|
|||||||
{
|
{
|
||||||
for (int i=0;i<numVectors;i++)
|
for (int i=0;i<numVectors;i++)
|
||||||
{
|
{
|
||||||
supportVerticesOut[i][3] = btScalar(-1e30);
|
supportVerticesOut[i][3] = btScalar(-BT_LARGE_FLOAT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -116,7 +116,7 @@ void btConvexTriangleMeshShape::batchedUnitVectorGetSupportingVertexWithoutMargi
|
|||||||
{
|
{
|
||||||
const btVector3& vec = vectors[j];
|
const btVector3& vec = vectors[j];
|
||||||
LocalSupportVertexCallback supportCallback(vec);
|
LocalSupportVertexCallback supportCallback(vec);
|
||||||
btVector3 aabbMax(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
btVector3 aabbMax(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
m_stridingMesh->InternalProcessAllTriangles(&supportCallback,-aabbMax,aabbMax);
|
m_stridingMesh->InternalProcessAllTriangles(&supportCallback,-aabbMax,aabbMax);
|
||||||
supportVerticesOut[j] = supportCallback.GetSupportVertexLocal();
|
supportVerticesOut[j] = supportCallback.GetSupportVertexLocal();
|
||||||
}
|
}
|
||||||
@ -298,7 +298,7 @@ void btConvexTriangleMeshShape::calculatePrincipalAxisTransform(btTransform& pri
|
|||||||
};
|
};
|
||||||
|
|
||||||
CenterCallback centerCallback;
|
CenterCallback centerCallback;
|
||||||
btVector3 aabbMax(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
btVector3 aabbMax(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
m_stridingMesh->InternalProcessAllTriangles(¢erCallback, -aabbMax, aabbMax);
|
m_stridingMesh->InternalProcessAllTriangles(¢erCallback, -aabbMax, aabbMax);
|
||||||
btVector3 center = centerCallback.getCenter();
|
btVector3 center = centerCallback.getCenter();
|
||||||
principal.setOrigin(center);
|
principal.setOrigin(center);
|
||||||
|
@ -23,7 +23,7 @@ btMultiSphereShape::btMultiSphereShape (const btVector3& inertiaHalfExtents,cons
|
|||||||
:btConvexInternalAabbCachingShape (), m_inertiaHalfExtents(inertiaHalfExtents)
|
:btConvexInternalAabbCachingShape (), m_inertiaHalfExtents(inertiaHalfExtents)
|
||||||
{
|
{
|
||||||
m_shapeType = MULTI_SPHERE_SHAPE_PROXYTYPE;
|
m_shapeType = MULTI_SPHERE_SHAPE_PROXYTYPE;
|
||||||
btScalar startMargin = btScalar(1e30);
|
btScalar startMargin = btScalar(BT_LARGE_FLOAT);
|
||||||
|
|
||||||
m_localPositionArray.resize(numSpheres);
|
m_localPositionArray.resize(numSpheres);
|
||||||
m_radiArray.resize(numSpheres);
|
m_radiArray.resize(numSpheres);
|
||||||
@ -46,7 +46,7 @@ btMultiSphereShape::btMultiSphereShape (const btVector3& inertiaHalfExtents,cons
|
|||||||
int i;
|
int i;
|
||||||
btVector3 supVec(0,0,0);
|
btVector3 supVec(0,0,0);
|
||||||
|
|
||||||
btScalar maxDot(btScalar(-1e30));
|
btScalar maxDot(btScalar(-BT_LARGE_FLOAT));
|
||||||
|
|
||||||
|
|
||||||
btVector3 vec = vec0;
|
btVector3 vec = vec0;
|
||||||
@ -89,7 +89,7 @@ btMultiSphereShape::btMultiSphereShape (const btVector3& inertiaHalfExtents,cons
|
|||||||
|
|
||||||
for (int j=0;j<numVectors;j++)
|
for (int j=0;j<numVectors;j++)
|
||||||
{
|
{
|
||||||
btScalar maxDot(btScalar(-1e30));
|
btScalar maxDot(btScalar(-BT_LARGE_FLOAT));
|
||||||
|
|
||||||
const btVector3& vec = vectors[j];
|
const btVector3& vec = vectors[j];
|
||||||
|
|
||||||
|
@ -56,8 +56,8 @@ void btOptimizedBvh::build(btStridingMeshInterface* triangles, bool useQuantized
|
|||||||
{
|
{
|
||||||
btOptimizedBvhNode node;
|
btOptimizedBvhNode node;
|
||||||
btVector3 aabbMin,aabbMax;
|
btVector3 aabbMin,aabbMax;
|
||||||
aabbMin.setValue(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
aabbMin.setValue(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
aabbMax.setValue(btScalar(-1e30),btScalar(-1e30),btScalar(-1e30));
|
aabbMax.setValue(btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT));
|
||||||
aabbMin.setMin(triangle[0]);
|
aabbMin.setMin(triangle[0]);
|
||||||
aabbMax.setMax(triangle[0]);
|
aabbMax.setMax(triangle[0]);
|
||||||
aabbMin.setMin(triangle[1]);
|
aabbMin.setMin(triangle[1]);
|
||||||
@ -104,8 +104,8 @@ void btOptimizedBvh::build(btStridingMeshInterface* triangles, bool useQuantized
|
|||||||
|
|
||||||
btQuantizedBvhNode node;
|
btQuantizedBvhNode node;
|
||||||
btVector3 aabbMin,aabbMax;
|
btVector3 aabbMin,aabbMax;
|
||||||
aabbMin.setValue(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
aabbMin.setValue(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
aabbMax.setValue(btScalar(-1e30),btScalar(-1e30),btScalar(-1e30));
|
aabbMax.setValue(btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT));
|
||||||
aabbMin.setMin(triangle[0]);
|
aabbMin.setMin(triangle[0]);
|
||||||
aabbMax.setMax(triangle[0]);
|
aabbMax.setMax(triangle[0]);
|
||||||
aabbMin.setMin(triangle[1]);
|
aabbMin.setMin(triangle[1]);
|
||||||
@ -168,8 +168,8 @@ void btOptimizedBvh::build(btStridingMeshInterface* triangles, bool useQuantized
|
|||||||
{
|
{
|
||||||
NodeTriangleCallback callback(m_leafNodes);
|
NodeTriangleCallback callback(m_leafNodes);
|
||||||
|
|
||||||
btVector3 aabbMin(btScalar(-1e30),btScalar(-1e30),btScalar(-1e30));
|
btVector3 aabbMin(btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT));
|
||||||
btVector3 aabbMax(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
btVector3 aabbMax(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
|
|
||||||
triangles->InternalProcessAllTriangles(&callback,aabbMin,aabbMax);
|
triangles->InternalProcessAllTriangles(&callback,aabbMin,aabbMax);
|
||||||
|
|
||||||
@ -337,8 +337,8 @@ void btOptimizedBvh::updateBvhNodes(btStridingMeshInterface* meshInterface,int f
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
aabbMin.setValue(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
aabbMin.setValue(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
aabbMax.setValue(btScalar(-1e30),btScalar(-1e30),btScalar(-1e30));
|
aabbMax.setValue(btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT));
|
||||||
aabbMin.setMin(triangleVerts[0]);
|
aabbMin.setMin(triangleVerts[0]);
|
||||||
aabbMax.setMax(triangleVerts[0]);
|
aabbMax.setMax(triangleVerts[0]);
|
||||||
aabbMin.setMin(triangleVerts[1]);
|
aabbMin.setMin(triangleVerts[1]);
|
||||||
|
@ -26,7 +26,7 @@ btVector3 btPolyhedralConvexShape::localGetSupportingVertexWithoutMargin(const b
|
|||||||
int i;
|
int i;
|
||||||
btVector3 supVec(0,0,0);
|
btVector3 supVec(0,0,0);
|
||||||
|
|
||||||
btScalar maxDot(btScalar(-1e30));
|
btScalar maxDot(btScalar(-BT_LARGE_FLOAT));
|
||||||
|
|
||||||
btVector3 vec = vec0;
|
btVector3 vec = vec0;
|
||||||
btScalar lenSqr = vec.length2();
|
btScalar lenSqr = vec.length2();
|
||||||
@ -66,7 +66,7 @@ void btPolyhedralConvexShape::batchedUnitVectorGetSupportingVertexWithoutMargin(
|
|||||||
|
|
||||||
for (i=0;i<numVectors;i++)
|
for (i=0;i<numVectors;i++)
|
||||||
{
|
{
|
||||||
supportVerticesOut[i][3] = btScalar(-1e30);
|
supportVerticesOut[i][3] = btScalar(-BT_LARGE_FLOAT);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int j=0;j<numVectors;j++)
|
for (int j=0;j<numVectors;j++)
|
||||||
|
@ -38,7 +38,7 @@ void btStaticPlaneShape::getAabb(const btTransform& t,btVector3& aabbMin,btVecto
|
|||||||
{
|
{
|
||||||
(void)t;
|
(void)t;
|
||||||
/*
|
/*
|
||||||
btVector3 infvec (btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
btVector3 infvec (btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
|
|
||||||
btVector3 center = m_planeNormal*m_planeConstant;
|
btVector3 center = m_planeNormal*m_planeConstant;
|
||||||
aabbMin = center + infvec*m_planeNormal;
|
aabbMin = center + infvec*m_planeNormal;
|
||||||
@ -47,8 +47,8 @@ void btStaticPlaneShape::getAabb(const btTransform& t,btVector3& aabbMin,btVecto
|
|||||||
aabbMax.setMax(center - infvec*m_planeNormal);
|
aabbMax.setMax(center - infvec*m_planeNormal);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
aabbMin.setValue(btScalar(-1e30),btScalar(-1e30),btScalar(-1e30));
|
aabbMin.setValue(btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT));
|
||||||
aabbMax.setValue(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
aabbMax.setValue(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -156,8 +156,8 @@ void btStridingMeshInterface::calculateAabbBruteForce(btVector3& aabbMin,btVecto
|
|||||||
|
|
||||||
AabbCalculationCallback()
|
AabbCalculationCallback()
|
||||||
{
|
{
|
||||||
m_aabbMin.setValue(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
m_aabbMin.setValue(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
m_aabbMax.setValue(btScalar(-1e30),btScalar(-1e30),btScalar(-1e30));
|
m_aabbMax.setValue(btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT));
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void internalProcessTriangleIndex(btVector3* triangle,int partId,int triangleIndex)
|
virtual void internalProcessTriangleIndex(btVector3* triangle,int partId,int triangleIndex)
|
||||||
@ -176,8 +176,8 @@ void btStridingMeshInterface::calculateAabbBruteForce(btVector3& aabbMin,btVecto
|
|||||||
|
|
||||||
//first calculate the total aabb for all triangles
|
//first calculate the total aabb for all triangles
|
||||||
AabbCalculationCallback aabbCallback;
|
AabbCalculationCallback aabbCallback;
|
||||||
aabbMin.setValue(btScalar(-1e30),btScalar(-1e30),btScalar(-1e30));
|
aabbMin.setValue(btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT));
|
||||||
aabbMax.setValue(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
aabbMax.setValue(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
InternalProcessAllTriangles(&aabbCallback,aabbMin,aabbMax);
|
InternalProcessAllTriangles(&aabbCallback,aabbMin,aabbMax);
|
||||||
|
|
||||||
aabbMin = aabbCallback.m_aabbMin;
|
aabbMin = aabbCallback.m_aabbMin;
|
||||||
|
@ -62,8 +62,8 @@ void btBU_Simplex1to4::getAabb(const btTransform& t,btVector3& aabbMin,btVector3
|
|||||||
#if 1
|
#if 1
|
||||||
btPolyhedralConvexAabbCachingShape::getAabb(t,aabbMin,aabbMax);
|
btPolyhedralConvexAabbCachingShape::getAabb(t,aabbMin,aabbMax);
|
||||||
#else
|
#else
|
||||||
aabbMin.setValue(1e30f,1e30f,1e30f);
|
aabbMin.setValue(BT_LARGE_FLOAT,BT_LARGE_FLOAT,BT_LARGE_FLOAT);
|
||||||
aabbMax.setValue(-1e30f,-1e30f,-1e30f);
|
aabbMax.setValue(-BT_LARGE_FLOAT,-BT_LARGE_FLOAT,-BT_LARGE_FLOAT);
|
||||||
|
|
||||||
//just transform the vertices in worldspace, and take their AABB
|
//just transform the vertices in worldspace, and take their AABB
|
||||||
for (int i=0;i<m_numVertices;i++)
|
for (int i=0;i<m_numVertices;i++)
|
||||||
|
@ -91,7 +91,7 @@ public:
|
|||||||
btVector3 m_supportVecLocal;
|
btVector3 m_supportVecLocal;
|
||||||
|
|
||||||
SupportVertexCallback(const btVector3& supportVecWorld,const btTransform& trans)
|
SupportVertexCallback(const btVector3& supportVecWorld,const btTransform& trans)
|
||||||
: m_supportVertexLocal(btScalar(0.),btScalar(0.),btScalar(0.)), m_worldTrans(trans) ,m_maxDot(btScalar(-1e30))
|
: m_supportVertexLocal(btScalar(0.),btScalar(0.),btScalar(0.)), m_worldTrans(trans) ,m_maxDot(btScalar(-BT_LARGE_FLOAT))
|
||||||
|
|
||||||
{
|
{
|
||||||
m_supportVecLocal = supportVecWorld * m_worldTrans.getBasis();
|
m_supportVecLocal = supportVecWorld * m_worldTrans.getBasis();
|
||||||
@ -199,7 +199,7 @@ btVector3 btTriangleMeshShape::localGetSupportingVertex(const btVector3& vec) co
|
|||||||
|
|
||||||
SupportVertexCallback supportCallback(vec,ident);
|
SupportVertexCallback supportCallback(vec,ident);
|
||||||
|
|
||||||
btVector3 aabbMax(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
btVector3 aabbMax(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
|
|
||||||
processAllTriangles(&supportCallback,-aabbMax,aabbMax);
|
processAllTriangles(&supportCallback,-aabbMax,aabbMax);
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ public:
|
|||||||
virtual void drawCoordSystem(const btTransform& trans) {(void)trans;}
|
virtual void drawCoordSystem(const btTransform& trans) {(void)trans;}
|
||||||
|
|
||||||
CastResult()
|
CastResult()
|
||||||
:m_fraction(btScalar(1e30)),
|
:m_fraction(btScalar(BT_LARGE_FLOAT)),
|
||||||
m_debugDrawer(0),
|
m_debugDrawer(0),
|
||||||
m_allowedPenetration(btScalar(0))
|
m_allowedPenetration(btScalar(0))
|
||||||
{
|
{
|
||||||
|
@ -41,7 +41,7 @@ struct btDiscreteCollisionDetectorInterface
|
|||||||
struct ClosestPointInput
|
struct ClosestPointInput
|
||||||
{
|
{
|
||||||
ClosestPointInput()
|
ClosestPointInput()
|
||||||
:m_maximumDistanceSquared(btScalar(1e30)),
|
:m_maximumDistanceSquared(btScalar(BT_LARGE_FLOAT)),
|
||||||
m_stackAlloc(0)
|
m_stackAlloc(0)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
@ -68,7 +68,7 @@ struct btStorageResult : public btDiscreteCollisionDetectorInterface::Result
|
|||||||
btVector3 m_closestPointInB;
|
btVector3 m_closestPointInB;
|
||||||
btScalar m_distance; //negative means penetration !
|
btScalar m_distance; //negative means penetration !
|
||||||
|
|
||||||
btStorageResult() : m_distance(btScalar(1e30))
|
btStorageResult() : m_distance(btScalar(BT_LARGE_FLOAT))
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -108,7 +108,7 @@ bool btMinkowskiPenetrationDepthSolver::calcPenDepth(btSimplexSolverInterface& s
|
|||||||
};
|
};
|
||||||
|
|
||||||
//just take fixed number of orientation, and sample the penetration depth in that direction
|
//just take fixed number of orientation, and sample the penetration depth in that direction
|
||||||
btScalar minProj = btScalar(1e30);
|
btScalar minProj = btScalar(BT_LARGE_FLOAT);
|
||||||
btVector3 minNorm(btScalar(0.), btScalar(0.), btScalar(0.));
|
btVector3 minNorm(btScalar(0.), btScalar(0.), btScalar(0.));
|
||||||
btVector3 minA,minB;
|
btVector3 minA,minB;
|
||||||
btVector3 seperatingAxisInA,seperatingAxisInB;
|
btVector3 seperatingAxisInA,seperatingAxisInB;
|
||||||
@ -299,7 +299,7 @@ bool btMinkowskiPenetrationDepthSolver::calcPenDepth(btSimplexSolverInterface& s
|
|||||||
|
|
||||||
input.m_transformA = displacedTrans;
|
input.m_transformA = displacedTrans;
|
||||||
input.m_transformB = transB;
|
input.m_transformB = transB;
|
||||||
input.m_maximumDistanceSquared = btScalar(1e30);//minProj;
|
input.m_maximumDistanceSquared = btScalar(BT_LARGE_FLOAT);//minProj;
|
||||||
|
|
||||||
btIntermediateResult res;
|
btIntermediateResult res;
|
||||||
gjkdet.getClosestPoints(input,res,debugDraw);
|
gjkdet.getClosestPoints(input,res,debugDraw);
|
||||||
|
@ -31,7 +31,7 @@ struct btPointCollector : public btDiscreteCollisionDetectorInterface::Result
|
|||||||
bool m_hasResult;
|
bool m_hasResult;
|
||||||
|
|
||||||
btPointCollector ()
|
btPointCollector ()
|
||||||
: m_distance(btScalar(1e30)),m_hasResult(false)
|
: m_distance(btScalar(BT_LARGE_FLOAT)),m_hasResult(false)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,7 +68,7 @@ void btVoronoiSimplexSolver::reset()
|
|||||||
m_cachedValidClosest = false;
|
m_cachedValidClosest = false;
|
||||||
m_numVertices = 0;
|
m_numVertices = 0;
|
||||||
m_needsUpdate = true;
|
m_needsUpdate = true;
|
||||||
m_lastW = btVector3(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
m_lastW = btVector3(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
m_cachedBC.reset();
|
m_cachedBC.reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -64,7 +64,7 @@ void btConeTwistConstraint::init()
|
|||||||
m_bMotorEnabled = false;
|
m_bMotorEnabled = false;
|
||||||
m_maxMotorImpulse = btScalar(-1);
|
m_maxMotorImpulse = btScalar(-1);
|
||||||
|
|
||||||
setLimit(btScalar(1e30), btScalar(1e30), btScalar(1e30));
|
setLimit(btScalar(BT_LARGE_FLOAT), btScalar(BT_LARGE_FLOAT), btScalar(BT_LARGE_FLOAT));
|
||||||
m_damping = btScalar(0.01);
|
m_damping = btScalar(0.01);
|
||||||
m_fixThresh = CONETWIST_DEF_FIX_THRESH;
|
m_fixThresh = CONETWIST_DEF_FIX_THRESH;
|
||||||
}
|
}
|
||||||
|
@ -191,8 +191,8 @@ btScalar btRotationalLimitMotor::solveAngularLimits(
|
|||||||
|
|
||||||
|
|
||||||
// sort with accumulated impulses
|
// sort with accumulated impulses
|
||||||
btScalar lo = btScalar(-1e30);
|
btScalar lo = btScalar(-BT_LARGE_FLOAT);
|
||||||
btScalar hi = btScalar(1e30);
|
btScalar hi = btScalar(BT_LARGE_FLOAT);
|
||||||
|
|
||||||
btScalar oldaccumImpulse = m_accumulatedImpulse;
|
btScalar oldaccumImpulse = m_accumulatedImpulse;
|
||||||
btScalar sum = oldaccumImpulse + clippedMotorImpulse;
|
btScalar sum = oldaccumImpulse + clippedMotorImpulse;
|
||||||
@ -283,8 +283,8 @@ btScalar btTranslationalLimitMotor::solveLinearAxis(
|
|||||||
|
|
||||||
//positional error (zeroth order error)
|
//positional error (zeroth order error)
|
||||||
btScalar depth = -(pointInA - pointInB).dot(axis_normal_on_a);
|
btScalar depth = -(pointInA - pointInB).dot(axis_normal_on_a);
|
||||||
btScalar lo = btScalar(-1e30);
|
btScalar lo = btScalar(-BT_LARGE_FLOAT);
|
||||||
btScalar hi = btScalar(1e30);
|
btScalar hi = btScalar(BT_LARGE_FLOAT);
|
||||||
|
|
||||||
btScalar minLimit = m_lowerLimit[limit_index];
|
btScalar minLimit = m_lowerLimit[limit_index];
|
||||||
btScalar maxLimit = m_upperLimit[limit_index];
|
btScalar maxLimit = m_upperLimit[limit_index];
|
||||||
|
@ -79,8 +79,8 @@ btHingeConstraint::btHingeConstraint(btRigidBody& rbA,btRigidBody& rbB, const bt
|
|||||||
rbAxisB1.getZ(),rbAxisB2.getZ(),axisInB.getZ() );
|
rbAxisB1.getZ(),rbAxisB2.getZ(),axisInB.getZ() );
|
||||||
|
|
||||||
//start with free
|
//start with free
|
||||||
m_lowerLimit = btScalar(1e30);
|
m_lowerLimit = btScalar(BT_LARGE_FLOAT);
|
||||||
m_upperLimit = btScalar(-1e30);
|
m_upperLimit = btScalar(-BT_LARGE_FLOAT);
|
||||||
m_biasFactor = 0.3f;
|
m_biasFactor = 0.3f;
|
||||||
m_relaxationFactor = 1.0f;
|
m_relaxationFactor = 1.0f;
|
||||||
m_limitSoftness = 0.9f;
|
m_limitSoftness = 0.9f;
|
||||||
@ -119,8 +119,8 @@ m_useReferenceFrameA(useReferenceFrameA)
|
|||||||
rbAxisB1.getZ(),rbAxisB2.getZ(),axisInB.getZ() );
|
rbAxisB1.getZ(),rbAxisB2.getZ(),axisInB.getZ() );
|
||||||
|
|
||||||
//start with free
|
//start with free
|
||||||
m_lowerLimit = btScalar(1e30);
|
m_lowerLimit = btScalar(BT_LARGE_FLOAT);
|
||||||
m_upperLimit = btScalar(-1e30);
|
m_upperLimit = btScalar(-BT_LARGE_FLOAT);
|
||||||
m_biasFactor = 0.3f;
|
m_biasFactor = 0.3f;
|
||||||
m_relaxationFactor = 1.0f;
|
m_relaxationFactor = 1.0f;
|
||||||
m_limitSoftness = 0.9f;
|
m_limitSoftness = 0.9f;
|
||||||
@ -139,8 +139,8 @@ m_useSolveConstraintObsolete(HINGE_USE_OBSOLETE_SOLVER),
|
|||||||
m_useReferenceFrameA(useReferenceFrameA)
|
m_useReferenceFrameA(useReferenceFrameA)
|
||||||
{
|
{
|
||||||
//start with free
|
//start with free
|
||||||
m_lowerLimit = btScalar(1e30);
|
m_lowerLimit = btScalar(BT_LARGE_FLOAT);
|
||||||
m_upperLimit = btScalar(-1e30);
|
m_upperLimit = btScalar(-BT_LARGE_FLOAT);
|
||||||
m_biasFactor = 0.3f;
|
m_biasFactor = 0.3f;
|
||||||
m_relaxationFactor = 1.0f;
|
m_relaxationFactor = 1.0f;
|
||||||
m_limitSoftness = 0.9f;
|
m_limitSoftness = 0.9f;
|
||||||
@ -162,8 +162,8 @@ m_useReferenceFrameA(useReferenceFrameA)
|
|||||||
m_rbBFrame.getOrigin() = m_rbA.getCenterOfMassTransform()(m_rbAFrame.getOrigin());
|
m_rbBFrame.getOrigin() = m_rbA.getCenterOfMassTransform()(m_rbAFrame.getOrigin());
|
||||||
|
|
||||||
//start with free
|
//start with free
|
||||||
m_lowerLimit = btScalar(1e30);
|
m_lowerLimit = btScalar(BT_LARGE_FLOAT);
|
||||||
m_upperLimit = btScalar(-1e30);
|
m_upperLimit = btScalar(-BT_LARGE_FLOAT);
|
||||||
m_biasFactor = 0.3f;
|
m_biasFactor = 0.3f;
|
||||||
m_relaxationFactor = 1.0f;
|
m_relaxationFactor = 1.0f;
|
||||||
m_limitSoftness = 0.9f;
|
m_limitSoftness = 0.9f;
|
||||||
|
@ -1147,8 +1147,8 @@ void btDiscreteDynamicsWorld::debugDrawObject(const btTransform& worldTransform,
|
|||||||
btConcaveShape* concaveMesh = (btConcaveShape*) shape;
|
btConcaveShape* concaveMesh = (btConcaveShape*) shape;
|
||||||
|
|
||||||
///@todo pass camera, for some culling? no -> we are not a graphics lib
|
///@todo pass camera, for some culling? no -> we are not a graphics lib
|
||||||
btVector3 aabbMax(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
btVector3 aabbMax(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
btVector3 aabbMin(btScalar(-1e30),btScalar(-1e30),btScalar(-1e30));
|
btVector3 aabbMin(btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT));
|
||||||
|
|
||||||
DebugDrawcallback drawCallback(getDebugDrawer(),worldTransform,color);
|
DebugDrawcallback drawCallback(getDebugDrawer(),worldTransform,color);
|
||||||
concaveMesh->processAllTriangles(&drawCallback,aabbMin,aabbMax);
|
concaveMesh->processAllTriangles(&drawCallback,aabbMin,aabbMax);
|
||||||
@ -1159,8 +1159,8 @@ void btDiscreteDynamicsWorld::debugDrawObject(const btTransform& worldTransform,
|
|||||||
{
|
{
|
||||||
btConvexTriangleMeshShape* convexMesh = (btConvexTriangleMeshShape*) shape;
|
btConvexTriangleMeshShape* convexMesh = (btConvexTriangleMeshShape*) shape;
|
||||||
//todo: pass camera for some culling
|
//todo: pass camera for some culling
|
||||||
btVector3 aabbMax(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
btVector3 aabbMax(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
btVector3 aabbMin(btScalar(-1e30),btScalar(-1e30),btScalar(-1e30));
|
btVector3 aabbMin(btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT),btScalar(-BT_LARGE_FLOAT));
|
||||||
//DebugDrawcallback drawCallback;
|
//DebugDrawcallback drawCallback;
|
||||||
DebugDrawcallback drawCallback(getDebugDrawer(),worldTransform,color);
|
DebugDrawcallback drawCallback(getDebugDrawer(),worldTransform,color);
|
||||||
convexMesh->getMeshInterface()->InternalProcessAllTriangles(&drawCallback,aabbMin,aabbMax);
|
convexMesh->getMeshInterface()->InternalProcessAllTriangles(&drawCallback,aabbMin,aabbMax);
|
||||||
|
@ -136,7 +136,7 @@ btVector3 localGetSupportingVertexWithoutMargin(int shapeType, void* shape, cons
|
|||||||
btScalar radius = capsuleShape->getRadius();
|
btScalar radius = capsuleShape->getRadius();
|
||||||
btVector3 supVec(0,0,0);
|
btVector3 supVec(0,0,0);
|
||||||
|
|
||||||
btScalar maxDot(btScalar(-1e30));
|
btScalar maxDot(btScalar(-BT_LARGE_FLOAT));
|
||||||
|
|
||||||
btVector3 vec = vec0;
|
btVector3 vec = vec0;
|
||||||
btScalar lenSqr = vec.length2();
|
btScalar lenSqr = vec.length2();
|
||||||
@ -230,7 +230,7 @@ btVector3 localGetSupportingVertexWithoutMargin(int shapeType, void* shape, cons
|
|||||||
// spu_printf("numPoints = %d\n",numPoints);
|
// spu_printf("numPoints = %d\n",numPoints);
|
||||||
|
|
||||||
int ptIndex = 0;
|
int ptIndex = 0;
|
||||||
btScalar newDot,maxDot = btScalar(-1e30);
|
btScalar newDot,maxDot = btScalar(-BT_LARGE_FLOAT);
|
||||||
|
|
||||||
btVector3 vec0(localDir.getX(),localDir.getY(),localDir.getZ());
|
btVector3 vec0(localDir.getX(),localDir.getY(),localDir.getZ());
|
||||||
btVector3 vec = vec0;
|
btVector3 vec = vec0;
|
||||||
|
@ -56,7 +56,7 @@ struct SpuCollisionPairInput
|
|||||||
struct SpuClosestPointInput
|
struct SpuClosestPointInput
|
||||||
{
|
{
|
||||||
SpuClosestPointInput()
|
SpuClosestPointInput()
|
||||||
:m_maximumDistanceSquared(float(1e30)),
|
:m_maximumDistanceSquared(float(BT_LARGE_FLOAT)),
|
||||||
m_stackAlloc(0)
|
m_stackAlloc(0)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -1081,7 +1081,7 @@ void processCollisionTask(void* userPtr, void* lsMemPtr)
|
|||||||
SpuBridgeContactCollector bridgeOutput(spuContacts);
|
SpuBridgeContactCollector bridgeOutput(spuContacts);
|
||||||
|
|
||||||
btDiscreteCollisionDetectorInterface::ClosestPointInput input;
|
btDiscreteCollisionDetectorInterface::ClosestPointInput input;
|
||||||
input.m_maximumDistanceSquared = 1e30f;
|
input.m_maximumDistanceSquared = BT_LARGE_FLOAT;
|
||||||
input.m_transformA = collisionPairInput.m_worldTransform0;
|
input.m_transformA = collisionPairInput.m_worldTransform0;
|
||||||
input.m_transformB = collisionPairInput.m_worldTransform1;
|
input.m_transformB = collisionPairInput.m_worldTransform1;
|
||||||
|
|
||||||
|
@ -112,7 +112,7 @@ bool SpuMinkowskiPenetrationDepthSolver::calcPenDepth( SpuVoronoiSimplexSolver&
|
|||||||
};
|
};
|
||||||
|
|
||||||
//just take fixed number of orientation, and sample the penetration depth in that direction
|
//just take fixed number of orientation, and sample the penetration depth in that direction
|
||||||
btScalar minProj = btScalar(1e30);
|
btScalar minProj = btScalar(BT_LARGE_FLOAT);
|
||||||
btVector3 minNorm;
|
btVector3 minNorm;
|
||||||
btVector3 minVertex;
|
btVector3 minVertex;
|
||||||
btVector3 minA,minB;
|
btVector3 minA,minB;
|
||||||
@ -309,7 +309,7 @@ bool SpuMinkowskiPenetrationDepthSolver::calcPenDepth( SpuVoronoiSimplexSolver&
|
|||||||
|
|
||||||
input.m_transformA = displacedTrans;
|
input.m_transformA = displacedTrans;
|
||||||
input.m_transformB = transB;
|
input.m_transformB = transB;
|
||||||
input.m_maximumDistanceSquared = btScalar(1e30);//minProj;
|
input.m_maximumDistanceSquared = btScalar(BT_LARGE_FLOAT);//minProj;
|
||||||
|
|
||||||
btIntermediateResult res;
|
btIntermediateResult res;
|
||||||
gjkdet.getClosestPoints(input,res);
|
gjkdet.getClosestPoints(input,res);
|
||||||
|
@ -69,7 +69,7 @@ void SpuVoronoiSimplexSolver::reset()
|
|||||||
m_cachedValidClosest = false;
|
m_cachedValidClosest = false;
|
||||||
m_numVertices = 0;
|
m_numVertices = 0;
|
||||||
m_needsUpdate = true;
|
m_needsUpdate = true;
|
||||||
m_lastW = btVector3(btScalar(1e30),btScalar(1e30),btScalar(1e30));
|
m_lastW = btVector3(btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT),btScalar(BT_LARGE_FLOAT));
|
||||||
m_cachedBC.reset();
|
m_cachedBC.reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -168,8 +168,12 @@ inline int btGetVersion()
|
|||||||
///The btScalar type abstracts floating point numbers, to easily switch between double and single floating point precision.
|
///The btScalar type abstracts floating point numbers, to easily switch between double and single floating point precision.
|
||||||
#if defined(BT_USE_DOUBLE_PRECISION)
|
#if defined(BT_USE_DOUBLE_PRECISION)
|
||||||
typedef double btScalar;
|
typedef double btScalar;
|
||||||
|
//this number could be bigger in double precision
|
||||||
|
#define BT_LARGE_FLOAT 1e30
|
||||||
#else
|
#else
|
||||||
typedef float btScalar;
|
typedef float btScalar;
|
||||||
|
//keep BT_LARGE_FLOAT*BT_LARGE_FLOAT < FLT_MAX
|
||||||
|
#define BT_LARGE_FLOAT 1e18f
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
@ -488,7 +488,7 @@ public:
|
|||||||
SIMD_FORCE_INLINE int maxAxis4() const
|
SIMD_FORCE_INLINE int maxAxis4() const
|
||||||
{
|
{
|
||||||
int maxIndex = -1;
|
int maxIndex = -1;
|
||||||
btScalar maxVal = btScalar(-1e30);
|
btScalar maxVal = btScalar(-BT_LARGE_FLOAT);
|
||||||
if (m_floats[0] > maxVal)
|
if (m_floats[0] > maxVal)
|
||||||
{
|
{
|
||||||
maxIndex = 0;
|
maxIndex = 0;
|
||||||
@ -521,7 +521,7 @@ public:
|
|||||||
SIMD_FORCE_INLINE int minAxis4() const
|
SIMD_FORCE_INLINE int minAxis4() const
|
||||||
{
|
{
|
||||||
int minIndex = -1;
|
int minIndex = -1;
|
||||||
btScalar minVal = btScalar(1e30);
|
btScalar minVal = btScalar(BT_LARGE_FLOAT);
|
||||||
if (m_floats[0] < minVal)
|
if (m_floats[0] < minVal)
|
||||||
{
|
{
|
||||||
minIndex = 0;
|
minIndex = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user