reactphysics3d/src/configuration.h

94 lines
4.0 KiB
C
Raw Normal View History

/********************************************************************************
* ReactPhysics3D physics library, http://code.google.com/p/reactphysics3d/ *
* Copyright (c) 2010-2012 Daniel Chappuis *
*********************************************************************************
* *
* This software is provided 'as-is', without any express or implied warranty. *
* In no event will the authors be held liable for any damages arising from the *
* use of this software. *
* *
* Permission is granted to anyone to use this software for any purpose, *
* including commercial applications, and to alter it and redistribute it *
* freely, subject to the following restrictions: *
* *
* 1. The origin of this software must not be misrepresented; you must not claim *
* that you wrote the original software. If you use this software in a *
* product, an acknowledgment in the product documentation would be *
* appreciated but is not required. *
* *
* 2. Altered source versions must be plainly marked as such, and must not be *
* misrepresented as being the original software. *
* *
* 3. This notice may not be removed or altered from any source distribution. *
* *
********************************************************************************/
#ifndef CONFIGURATION_H
#define CONFIGURATION_H
// Libraries
#include <limits>
#include <cfloat>
2012-09-26 21:07:40 +00:00
#include <utility>
#include "decimal.h"
// Windows platform
#if defined(WIN32) ||defined(_WIN32) || defined(_WIN64) ||defined(__WIN32__) || defined(__WINDOWS__)
#define WINDOWS_OS
#elif defined(__APPLE__) // Apple platform
#define APPLE_OS
#elif defined(__linux__) || defined(linux) || defined(__linux) // Linux platform
#define LINUX_OS
#endif
// Namespace reactphysics3d
namespace reactphysics3d {
// ------------------- Type definitions ------------------- //
typedef unsigned int uint;
typedef long unsigned int luint;
typedef short unsigned int bodyindex;
2012-09-26 21:07:40 +00:00
typedef std::pair<bodyindex, bodyindex> bodyindexpair;
// ------------------- Constants ------------------- //
2013-02-19 22:16:20 +00:00
const decimal DECIMAL_SMALLEST = - std::numeric_limits<decimal>::max();
// Maximum decimal value
2013-02-19 22:16:20 +00:00
const decimal DECIMAL_LARGEST = std::numeric_limits<decimal>::max();
// Machine epsilon
2013-02-19 22:16:20 +00:00
const decimal MACHINE_EPSILON = std::numeric_limits<decimal>::epsilon();
// Pi constant
2013-02-19 22:16:20 +00:00
const decimal PI = decimal(3.14159265);
// Default internal constant timestep in seconds
2013-02-19 22:16:20 +00:00
const decimal DEFAULT_TIMESTEP = decimal(1.0 / 60.0);
// Default friction coefficient for a rigid body
const decimal DEFAULT_FRICTION_COEFFICIENT = decimal(0.3);
// True if the deactivation (sleeping) of inactive bodies is enabled
const bool DEACTIVATION_ENABLED = true;
// // Object margin for collision detection in cm (For GJK-EPA Algorithm)
2013-02-19 22:16:20 +00:00
const decimal OBJECT_MARGIN = decimal(0.04);
// Distance threshold for two contact points for a valid persistent contact (in meters)
2013-02-19 22:16:20 +00:00
const decimal PERSISTENT_CONTACT_DIST_THRESHOLD = decimal(0.03);
// Number of iterations when solving a LCP problem
2013-02-19 22:16:20 +00:00
const uint DEFAULT_CONSTRAINTS_SOLVER_NB_ITERATIONS = 15;
// Number of iterations when solving a LCP problem for error correction
const uint DEFAULT_LCP_ITERATIONS_ERROR_CORRECTION = 5;
// True if the error correction projection (first order world) is active in the constraint solver
const bool ERROR_CORRECTION_PROJECTION_ENABLED = true;
}
#endif