Version: Unity 6 (6000.0)
Language : English
Package Manager
Physics 2D reference

Physics

To apply global settings for 3D physics, use the Physics settings (main menu: Edit > Project Settings, then select the Physics category).

Note: To manage global settings for 2D physics, use the Physics 2D settings instead.

The Physics settings define limits on the accuracy of the 3D physical simulation. In most cases, a more accurate simulation requires more processing overhead, so these settings offer a way to trade off accuracy against performance.

The Physics panel contains settings to define which Physics SDKs you want to use in your project.

Physics Inspector settings
Physics Inspector settings
Setting Description
GameObjectThe fundamental object in Unity scenes, which can represent characters, props, scenery, cameras, waypoints, and more. A GameObject’s functionality is defined by the Components attached to it. More info
See in Glossary
SDK
Define the SDK you want to use to manage physics simulation on GameObjects in your project. The default setting is PhysX. Set to None to disable physics simulation for GameObjects in your project.

The Physics settings also contains a panel called Settings.

Settings

The Settings panel contain settings for all Physics SDKs. The following tabs are available:

  • Shared: Settings that apply to all Physics SDKs.
  • GameObject: Settings that apply to all GameObject physics in your project.
  • Cloth: Settings that apply to all ClothA component that works with the Skinned Mesh Renderer to provide a physics-based solution for simulating fabrics. More info
    See in Glossary
    physics.

Shared settings

The Shared tab contains global settings that apply to all physics SDKs.

Property Function
Gravity Use the x, y and z axes to set the amount of gravity applied to all Rigidbody components. For realistic gravity settings, apply a negative number to the y axis. Gravity is defined in world units per seconds squared.
Note: If you increase the gravity, you might need to also increase the Default Solver Iterations value to maintain stable contacts.
Layer Collision Matrix Define how the layer-based collision detection system behaves. To select which layers on the Collision Matrix interact with the other layers, check their respective checkboxes.

GameObject settings

The GameObject tab contains global physics settings that apply to all GameObjects in your project.

Property Function
Default Material Set a reference to the default Physics MaterialA physics asset for adjusting the friction and bouncing effects of colliding objects. More info
See in Glossary
to use if none has been assigned to an individual ColliderAn invisible shape that is used to handle physical collisions for an object. A collider doesn’t need to be exactly the same shape as the object’s mesh - a rough approximation is often more efficient and indistinguishable in gameplay. More info
See in Glossary
.
Bounce Threshold Set a velocity value. If two colliding objects have a relative velocity below this value, they do not bounce off each other. This value also reduces jitter, so it is not recommended to set it to a very low value.
Default Max Depenetration Velocity Define the default value for the maximum depenetration velocity (the velocity that the solver can set to a body while trying to pull it out of overlap with the other bodies).
Sleep Threshold Set a global energy threshold, below which a non-kinematic RigidbodyA component that allows a GameObject to be affected by simulated gravity and other forces. More info
See in Glossary
(that is, one that is not controlled by the physics system) may go to sleep. When a Rigidbody is sleeping, it is not updated every frame, making it less resource-intensive. If a Rigidbody’s kinetic energy divided by its mass is below this threshold, it is a candidate for sleeping.
Default Contact Offset Set the distance the collision detectionAn automatic process performed by Unity which determines whether a moving GameObject with a Rigidbody and collider component has come into contact with any other colliders. More info
See in Glossary
system uses to generate collision contacts. The value must be positive, and if set too close to zero, it can cause jitter. This is set to 0.01 by default. Colliders only generate collision contacts if their distance is less than the sum of their contact offset values.
Default Solver Iterations Define how many solver processes Unity runs on every physics frame. Solvers are small physics engine tasks which determine a number of physics interactions, such as the movements of joints or managing contact between overlapping Rigidbody components.
This affects the quality of the solver output, and it is advisable to change the property in case non-default Time.fixedDeltaTime is used, or the configuration is extra demanding. Typically, it is used to reduce the jitter resulting from joints or contacts.
Default Solver Velocity Iterations Set how many velocity processes a solver performs in each physics frame. The more processes the solver performs, the higher the accuracy of the resulting exit velocity after a Rigidbody bounce. If you experience problems with jointed Rigidbody components or Ragdolls moving too much after collisions, try increasing this value.
Queries Hit Backfaces Enable this option if you want physics queries (such as Physics.Raycast) to detect hits with the backface triangles of MeshColliders. By default, this setting is disabled.
Queries Hit Triggers Enable this option if you want physics hit tests (such as Raycasts, SphereCasts and SphereTests) to return a hit when they intersect with a Collider marked as a Trigger. Individual raycasts can override this behavior. By default, this setting is enabled.
Enable Adaptive Force Enable this option to enable the adaptive force. The adaptive force affects the way forces are transmitted through a pile or stack of objects, to give more realistic behaviour. By default, this setting is disabled.
Contacts Generation Choose a contact generation method.
Legacy Contacts Generation Before Unity 5.5, Unity used a contacts generation method based on the separating axis theorem (SAT).

PCM is more efficient, but for older projects, you might find it easier to continue using SAT, to avoid needing to retweak physics slightly. PCM can result in a slightly different bounce, and fewer useless contacts end up in the contacts buffers (that is, the arrays you get in the CollisionA collision occurs when the physics engine detects that the colliders of two GameObjects make contact or overlap, when at least one has a Rigidbody component and is in motion. More info
See in Glossary
instance passed to OnCollisionEnter, OnCollisionStay, and OnCollisionExit).

Upgrade advice: To migrate a Project made with Unity 2018.2 or lower, you might need to update your scripts to work with the code that merges patches in the manifold, and selects contacts.
Persistent Contacts Manifold (PCM) Generates fewer contacts every physics frame, and more contact data is shared across frames. The PCM contacts generation path is also more accurate, and usually produces better collision feedback in most of the cases. For more information, see Nvidia documentation on Persistent Contact Manifold.
This is the default value.
Simulation Mode Choose when Unity executes the physics simulation. The default value is Fixed Update.
Fixed Update Execute the physics simulation immediately after MonoBehaviour.FixedUpdate.
Update Execute the physics simulation immediately after MonoBehaviour.Update.
Script Execute the physics simulation when a script calls Physics.Simulate.
Auto Sync Transforms Enable this option to automatically sync transform changes with the physics system whenever a Transform componentA Transform component determines the Position, Rotation, and Scale of each object in the scene. Every GameObject has a Transform. More info
See in Glossary
changes. By default, this setting is disabled.
Reuse Collision Callbacks Enable to re-use collision callbacks. The physics system only creates a single instance of the Collision type, and reuses it for each individual callback. This reduces waste for the garbage collector to handle, and improves performance. This property is enabled by default.
Invoke Collision Callbacks Send MonoBehaviour collision messages for OnCollisionEnter, OnCollisionStay, and OnCollisionExit to the corresponding scriptsA piece of code that allows you to create your own Components, trigger game events, modify Component properties over time and respond to user input in any way you like. More info
See in Glossary
that implement the OnCollision methods. This property is enabled by default.
Contact Pairs Mode Choose the type of contact pair generation to use.
Default Contact Pairs Receive collision and trigger events from all contact pairs except kinematic-kinematic and kinematic-static pairs.
Enable Kinematic Kinematic Pairs Receive collision and trigger events from kinematic-kinematic contact pairs.
Enable Kinematic Static Pairs Receive collision and trigger events from kinematic-static contact pairs.
Enable All Contact Pairs Receive collision and trigger events from all contact pairs.
Broadphase Type Choose which broad-phase algorithm to use in the physics simulation. See NVIDIA’s documentation on PhysX SDK and Rigid Body Collision.
Sweep and Prune Broadphase Use the sweep-and-prune broad phase collision method (that is, sorting objects along a single axis to rule out having to check pairs that are far apart).
Multibox Pruning Broadphase Multi-box pruning uses a grid, and each grid cell performs sweep-and-prune. This usually helps improve performance if, for example, there are many GameObjects in a flat world.
Automatic Box Pruning This algorithm is similar to the Multibox Pruning one, except that it can also automatically compute the world boundaries and number of subdivisions. It maintains the set of grid cells and uses the regular sweep-and-prune approach to work out potentially overlapping pairs of colliders. It usually helps with big scenesA Scene contains the environments and menus of your game. Think of each unique Scene file as a unique level. In each Scene, you place your environments, obstacles, and decorations, essentially designing and building your game in pieces. More info
See in Glossary
where a single Sweep and Prune would produce lots of extra false positives.
World Bounds Define the 2D grid that encloses the world to prevent far away objects from affecting each other when using the Multibox Pruning Broadphase algorithm.
This option is only used when you set Broadphase Type to Multibox Pruning Broadphase.
World Subdivisions The number of cells along the x and z axis in the 2D grid algorithm.
This option is only used when you set Broadphase Type to Multibox Pruning Broadphase.
Friction Type Choose the friction algorithm used for simulation.
Patch Friction Type A basic strong friction algorithm which typically leads to the most stable results at low solver iteration counts. This method uses only up to four scalar solver constraints per pair of touching objects.
One Directional Friction Type A simplification of the Coulomb friction model, in which the friction for a given point of contact is applied in the alternating tangent directions of the contact’s normal. This requires more solver iterations than patch friction but is not as accurate as the two-directional model. For Articulation bodies to work with this friction type, set the Solver Type to Temporal Gauss Seidel.
Two Directional Friction Type Like the one-directional model, but applies friction in both tangent directions simultaneously. This requires more solver iterations but is more accurate. More expensive than patch friction for scenarios with many contact points because it is applied at every contact point. For Articulation bodies to work with this friction type, set the Solver Type to Temporal Gauss Seidel.
Enable Enhanced Determinism Simulation in the scene is consistent regardless the actors present, provided that the game inserts the actors in a deterministic order. This mode sacrifices some performance to ensure this additional determinism.
Enable Unified HeightmapsA greyscale Texture that stores height data for an object. Each pixel stores the height difference perpendicular to the face that pixel represents.
See in Glossary
Enable this option to process TerrainThe landscape in your scene. A Terrain GameObject adds a large flat plane to your scene and you can use the Terrain’s Inspector window to create a detailed landscape. More info
See in Glossary
collisions in the same way as MeshThe main graphics primitive of Unity. Meshes make up a large part of your 3D worlds. Unity supports triangulated or Quadrangulated polygon meshes. Nurbs, Nurms, Subdiv surfaces must be converted to polygons. More info
See in Glossary
collisions.
Improved Patch Friction Optimize patch friction so that static and dynamic frictionA Physics Material property that defines the friction for a Rigidbody when it’s in motion. Lower values mean less friction, so a setting of zero represents slipping on ice. More info
See in Glossary
do not exceed analytical results. This property is deactivated by default.
Solver Type Choose the PhysX solver type to use for the simulation.
Projected Gauss Seidel The default PhysX solver.
Temporal Gauss Seidel This solver offers a better convergence and a better handling of high-mass ratios, minimizes energy introduced when correcting penetrations and improves the resistance of jointsA physics component allowing a dynamic connection between Rigidbody components, usually allowing some degree of movement such as a hinge. More info
See in Glossary
to overstretch. It usually helps when you experience some erratic behavior during simulation with the default solver.
Default Max Angular Speed Set the project-wide default maximum angular speed of all dynamic Rigidbody GameObjects, in radian. The default value is 50.
Scratch Buffer Chunk Count The number of 16KB memory chunks to allocate to the physics system for temporary allocations. The default value is 4, which provides a 64KB buffer.
Fast Motion Threshold The linear motion threshold that sweep-based CCD algorithms use to determine whether a fast-moving body moved this frame or not. Must be greater than zero. The default value is infinity, represented by the value 3.402823e+38.

Cloth settings

The settings in the Cloth tab apply to Cloth physics only.

Property Function
Cloth Gravity Set the gravity value on each axis for Cloth components. By default, X is set to 0, Y is set to -9.81, and Z is set to 0.
Enable Cloth Inter-Collision Enable the ability for Cloth particles to collide with each other. Refer to Cloth: Self collision and intercollision for details.
Distance Define the diameter of a sphere around each intercolliding Cloth particle, in world units. Unity ensures that these spheres do not overlap during simulations. The distance should be smaller than the smallest distance between two particles in the configuration. If the distance is larger, cloth collision can violate distance constraints and result in jittering. This value is set to 0.1 by default.
Stiffness Define the strength of the separating force between intercolliding Cloth particles when they are closer than the Distance value. The value is the factor by which PhysX multiplies the separation force; the cloth solver then calculates the stiffness based on the value you provide. This value is set to 0.2 by default.

PhysicsManager

Package Manager
Physics 2D reference