PxSceneDesc Class Reference

Descriptor class for scenes. See PxScene. More...

#include <PxSceneDesc.h>

Collaboration diagram for PxSceneDesc:

Public Member Functions

PX_INLINE PxSceneDesc (const PxTolerancesScale &scale)
 constructor sets to default. More...
 
PX_INLINE void setToDefault (const PxTolerancesScale &scale)
 (re)sets the structure to the default. More...
 
PX_INLINE bool isValid () const
 Returns true if the descriptor is valid. More...
 

Public Attributes

PxVec3 gravity
 Gravity vector. More...
 
PxSimulationEventCallbacksimulationEventCallback
 Possible notification callback. More...
 
PxContactModifyCallbackcontactModifyCallback
 Possible asynchronous callback for contact modification. More...
 
PxCCDContactModifyCallbackccdContactModifyCallback
 Possible asynchronous callback for contact modification. More...
 
const void * filterShaderData
 Shared global filter data which will get passed into the filter shader. More...
 
PxU32 filterShaderDataSize
 Size (in bytes) of the shared global filter data filterShaderData. More...
 
PxSimulationFilterShader filterShader
 The custom filter shader to use for collision filtering. More...
 
PxSimulationFilterCallbackfilterCallback
 A custom collision filter callback which can be used to implement more complex filtering operations which need access to the simulation state, for example. More...
 
PxPairFilteringMode::Enum kineKineFilteringMode
 Filtering mode for kinematic-kinematic pairs in the broadphase. More...
 
PxPairFilteringMode::Enum staticKineFilteringMode
 Filtering mode for static-kinematic pairs in the broadphase. More...
 
PxBroadPhaseType::Enum broadPhaseType
 Selects the broad-phase algorithm to use. More...
 
PxBroadPhaseCallbackbroadPhaseCallback
 Broad-phase callback. More...
 
PxSceneLimits limits
 Expected scene limits. More...
 
PxFrictionType::Enum frictionType
 Selects the friction algorithm to use for simulation. More...
 
PxSolverType::Enum solverType
 Selects the solver algorithm to use. More...
 
PxReal bounceThresholdVelocity
 A contact with a relative velocity below this will not bounce. A typical value for simulation. stability is about 0.2 * gravity. More...
 
PxReal frictionOffsetThreshold
 A threshold of contact separation distance used to decide if a contact point will experience friction forces. More...
 
PxReal ccdMaxSeparation
 A threshold for speculative CCD. Used to control whether bias, restitution or a combination of the two are used to resolve the contacts. More...
 
PxReal solverOffsetSlop
 A slop value used to zero contact offsets from the body's COM on an axis if the offset along that axis is smaller than this threshold. Can be used to compensate for small numerical errors in contact generation. More...
 
PxSceneFlags flags
 Flags used to select scene options. More...
 
PxCpuDispatcher * cpuDispatcher
 The CPU task dispatcher for the scene. More...
 
PxCudaContextManager * cudaContextManager
 The CUDA context manager for the scene. More...
 
PxPruningStructureType::Enum staticStructure
 Defines the structure used to store static objects. More...
 
PxPruningStructureType::Enum dynamicStructure
 Defines the structure used to store dynamic objects. More...
 
PxU32 dynamicTreeRebuildRateHint
 Hint for how much work should be done per simulation frame to rebuild the pruning structure. More...
 
PxSceneQueryUpdateMode::Enum sceneQueryUpdateMode
 Defines the scene query update mode. Default: PxSceneQueryUpdateMode::eBUILD_ENABLED_COMMIT_ENABLED. More...
 
void * userData
 Will be copied to PxScene::userData. More...
 
PxU32 solverBatchSize
 Defines the number of actors required to spawn a separate rigid body solver island task chain. More...
 
PxU32 solverArticulationBatchSize
 Defines the number of articulations required to spawn a separate rigid body solver island task chain. More...
 
PxU32 nbContactDataBlocks
 Setting to define the number of 16K blocks that will be initially reserved to store contact, friction, and contact cache data. This is the number of 16K memory blocks that will be automatically allocated from the user allocator when the scene is instantiated. Further 16k memory blocks may be allocated during the simulation up to maxNbContactDataBlocks. More...
 
PxU32 maxNbContactDataBlocks
 Setting to define the maximum number of 16K blocks that can be allocated to store contact, friction, and contact cache data. As the complexity of a scene increases, the SDK may require to allocate new 16k blocks in addition to the blocks it has already allocated. This variable controls the maximum number of blocks that the SDK can allocate. More...
 
PxReal maxBiasCoefficient
 The maximum bias coefficient used in the constraint solver. More...
 
PxU32 contactReportStreamBufferSize
 Size of the contact report stream (in bytes). More...
 
PxU32 ccdMaxPasses
 Maximum number of CCD passes. More...
 
PxReal ccdThreshold
 CCD threshold. More...
 
PxReal wakeCounterResetValue
 The wake counter reset value. More...
 
PxBounds3 sanityBounds
 The bounds used to sanity check user-set positions of actors and articulation links. More...
 
PxgDynamicsMemoryConfig gpuDynamicsConfig
 The pre-allocations performed in the GPU dynamics pipeline. More...
 
PxU32 gpuMaxNumPartitions
 Limitation for the partitions in the GPU dynamics pipeline. This variable must be power of 2. A value greater than 32 is currently not supported. Range: (1, 32)
More...
 
PxU32 gpuComputeVersion
 Defines which compute version the GPU dynamics should target. DO NOT MODIFY. More...
 

Detailed Description

Descriptor class for scenes. See PxScene.

This struct must be initialized with the same PxTolerancesScale values used to initialize PxPhysics.

See also
PxScene PxPhysics.createScene PxTolerancesScale

Member Data Documentation

◆ bounceThresholdVelocity

PxReal PxSceneDesc::bounceThresholdVelocity

A contact with a relative velocity below this will not bounce. A typical value for simulation. stability is about 0.2 * gravity.

Range: [0, PX_MAX_F32)
Default: 0.2 * PxTolerancesScale::speed

See also
PxMaterial PxScene.setBounceThresholdVelocity() PxScene.getBounceThresholdVelocity()

Referenced by isValid().

◆ broadPhaseCallback

PxBroadPhaseCallback* PxSceneDesc::broadPhaseCallback

Broad-phase callback.

Default: NULL

See also
PxBroadPhaseCallback

◆ broadPhaseType

PxBroadPhaseType::Enum PxSceneDesc::broadPhaseType

Selects the broad-phase algorithm to use.

Default: PxBroadPhaseType::eABP

See also
PxBroadPhaseType

◆ ccdContactModifyCallback

PxCCDContactModifyCallback* PxSceneDesc::ccdContactModifyCallback

Possible asynchronous callback for contact modification.

Default: NULL

See also
PxContactModifyCallback PxScene.setContactModifyCallback() PxScene.getContactModifyCallback()

◆ ccdMaxPasses

PxU32 PxSceneDesc::ccdMaxPasses

Maximum number of CCD passes.

The CCD performs multiple passes, where each pass every object advances to its time of first impact. This value defines how many passes the CCD system should perform.

Note
The CCD system is a multi-pass best-effort conservative advancement approach. After the defined number of passes has been completed, any remaining time is dropped.
This defines the maximum number of passes the CCD can perform. It may perform fewer if additional passes are not necessary.

Default: 1 Range: [1, PX_MAX_U32]

◆ ccdMaxSeparation

PxReal PxSceneDesc::ccdMaxSeparation

A threshold for speculative CCD. Used to control whether bias, restitution or a combination of the two are used to resolve the contacts.

Note
This only has any effect on contacting pairs where one of the bodies has PxRigidBodyFlag::eENABLE_SPECULATIVE_CCD raised.

Range: [0, PX_MAX_F32)
Default: 0.04 * PxTolerancesScale::length

Referenced by isValid().

◆ ccdThreshold

PxReal PxSceneDesc::ccdThreshold

CCD threshold.

CCD performs sweeps against shapes if and only if the relative motion of the shapes is fast-enough that a collision would be missed by the discrete contact generation. However, in some circumstances, e.g. when the environment is constructed from large convex shapes, this approach may produce undesired simulation artefacts. This parameter defines the minimum relative motion that would be required to force CCD between shapes. The smaller of this value and the sum of the thresholds calculated for the shapes involved will be used.

Note
It is not advisable to set this to a very small value as this may lead to CCD "jamming" and detrimentally effect performance. This value should be at least larger than the translation caused by a single frame's gravitational effect

Default: PX_MAX_F32 Range: [Eps, PX_MAX_F32]

Referenced by isValid().

◆ contactModifyCallback

PxContactModifyCallback* PxSceneDesc::contactModifyCallback

Possible asynchronous callback for contact modification.

Default: NULL

See also
PxContactModifyCallback PxScene.setContactModifyCallback() PxScene.getContactModifyCallback()

◆ contactReportStreamBufferSize

PxU32 PxSceneDesc::contactReportStreamBufferSize

Size of the contact report stream (in bytes).

The contact report stream buffer is used during the simulation to store all the contact reports. If the size is not sufficient, the buffer will grow by a factor of two. It is possible to disable the buffer growth by setting the flag PxSceneFlag::eDISABLE_CONTACT_REPORT_BUFFER_RESIZE. In that case the buffer will not grow but contact reports not stored in the buffer will not get sent in the contact report callbacks.

Default: 8192

Range: (0, PX_MAX_U32]

Referenced by isValid().

◆ cpuDispatcher

PxCpuDispatcher* PxSceneDesc::cpuDispatcher

The CPU task dispatcher for the scene.

See PxCpuDispatcher, PxScene::getCpuDispatcher

Referenced by isValid().

◆ cudaContextManager

PxCudaContextManager* PxSceneDesc::cudaContextManager

The CUDA context manager for the scene.

Platform specific: Applies to PC GPU only.

See PxCudaContextManager, PxScene::getCudaContextManager

◆ dynamicStructure

PxPruningStructureType::Enum PxSceneDesc::dynamicStructure

Defines the structure used to store dynamic objects.

◆ dynamicTreeRebuildRateHint

PxU32 PxSceneDesc::dynamicTreeRebuildRateHint

Hint for how much work should be done per simulation frame to rebuild the pruning structure.

This parameter gives a hint on the distribution of the workload for rebuilding the dynamic AABB tree pruning structure PxPruningStructureType::eDYNAMIC_AABB_TREE. It specifies the desired number of simulation frames the rebuild process should take. Higher values will decrease the workload per frame but the pruning structure will get more and more outdated the longer the rebuild takes (which can make scene queries less efficient).

Note
Only used for PxPruningStructureType::eDYNAMIC_AABB_TREE pruning structure.
This parameter gives only a hint. The rebuild process might still take more or less time depending on the number of objects involved.

Range: [4, PX_MAX_U32)
Default: 100

Referenced by isValid().

◆ filterCallback

PxSimulationFilterCallback* PxSceneDesc::filterCallback

A custom collision filter callback which can be used to implement more complex filtering operations which need access to the simulation state, for example.

Default: NULL

See also
PxSimulationFilterCallback

◆ filterShader

PxSimulationFilterShader PxSceneDesc::filterShader

The custom filter shader to use for collision filtering.

Note
This parameter is compulsory. If you don't want to define your own filter shader you can use the default shader PxDefaultSimulationFilterShader which can be found in the PhysX extensions library.
See also
PxSimulationFilterShader

Referenced by isValid().

◆ filterShaderData

const void* PxSceneDesc::filterShaderData

Shared global filter data which will get passed into the filter shader.

Note
The provided data will get copied to internal buffers and this copy will be used for filtering calls.

Default: NULL

See also
PxSimulationFilterShader PxScene::setFilterShaderData()

Referenced by isValid().

◆ filterShaderDataSize

PxU32 PxSceneDesc::filterShaderDataSize

Size (in bytes) of the shared global filter data filterShaderData.

Default: 0

See also
PxSimulationFilterShader filterShaderData

Referenced by isValid().

◆ flags

PxSceneFlags PxSceneDesc::flags

Flags used to select scene options.

See also
PxSceneFlag PxSceneFlags

Referenced by isValid().

◆ frictionOffsetThreshold

PxReal PxSceneDesc::frictionOffsetThreshold

A threshold of contact separation distance used to decide if a contact point will experience friction forces.

Note
If the separation distance of a contact point is greater than the threshold then the contact point will not experience friction forces.
If the aggregated contact offset of a pair of shapes is large it might be desirable to neglect friction for contact points whose separation distance is sufficiently large that the shape surfaces are clearly separated.
This parameter can be used to tune the separation distance of contact points at which friction starts to have an effect.

Range: [0, PX_MAX_F32)
Default: 0.04 * PxTolerancesScale::length

Referenced by isValid().

◆ frictionType

PxFrictionType::Enum PxSceneDesc::frictionType

Selects the friction algorithm to use for simulation.

Note
frictionType cannot be modified after the first call to any of PxScene::simulate, PxScene::solve and PxScene::collide
See also
PxFrictionType Default: PxFrictionType::ePATCH
PxScene::setFrictionType, PxScene::getFrictionType

◆ gpuComputeVersion

PxU32 PxSceneDesc::gpuComputeVersion

Defines which compute version the GPU dynamics should target. DO NOT MODIFY.

◆ gpuDynamicsConfig

PxgDynamicsMemoryConfig PxSceneDesc::gpuDynamicsConfig

The pre-allocations performed in the GPU dynamics pipeline.

◆ gpuMaxNumPartitions

PxU32 PxSceneDesc::gpuMaxNumPartitions

Limitation for the partitions in the GPU dynamics pipeline. This variable must be power of 2. A value greater than 32 is currently not supported. Range: (1, 32)

Referenced by isValid().

◆ gravity

PxVec3 PxSceneDesc::gravity

Gravity vector.

Range: force vector
Default: Zero

See also
PxScene.setGravity() PxScene.getGravity()

When setting gravity, you should probably also set bounce threshold.

◆ kineKineFilteringMode

PxPairFilteringMode::Enum PxSceneDesc::kineKineFilteringMode

Filtering mode for kinematic-kinematic pairs in the broadphase.

Default: PxPairFilteringMode::eDEFAULT

See also
PxPairFilteringMode

◆ limits

PxSceneLimits PxSceneDesc::limits

Expected scene limits.

See also
PxSceneLimits

Referenced by isValid().

◆ maxBiasCoefficient

PxReal PxSceneDesc::maxBiasCoefficient

The maximum bias coefficient used in the constraint solver.

When geometric errors are found in the constraint solver, either as a result of shapes penetrating or joints becoming separated or violating limits, a bias is introduced in the solver position iterations to correct these errors. This bias is proportional to 1/dt, meaning that the bias becomes increasingly strong as the time-step passed to PxScene::simulate(...) becomes smaller. This coefficient allows the application to restrict how large the bias coefficient is, to reduce how violent error corrections are. This can improve simulation quality in cases where either variable time-steps or extremely small time-steps are used.

Default: PX_MAX_F32

Range [0, PX_MAX_F32]

◆ maxNbContactDataBlocks

PxU32 PxSceneDesc::maxNbContactDataBlocks

Setting to define the maximum number of 16K blocks that can be allocated to store contact, friction, and contact cache data. As the complexity of a scene increases, the SDK may require to allocate new 16k blocks in addition to the blocks it has already allocated. This variable controls the maximum number of blocks that the SDK can allocate.

In the case that the scene is sufficiently complex that all the permitted 16K blocks are used, contacts will be dropped and a warning passed to the error stream.

If a warning is reported to the error stream to indicate the number of 16K blocks is insufficient for the scene complexity then the choices are either (i) re-tune the number of 16K data blocks until a number is found that is sufficient for the scene complexity, (ii) to simplify the scene or (iii) to opt to not increase the memory requirements of physx and accept some dropped contacts.

Default: 65536

Range: [0, PX_MAX_U32]

See also
nbContactDataBlocks PxScene::setNbContactDataBlocks

Referenced by isValid().

◆ nbContactDataBlocks

PxU32 PxSceneDesc::nbContactDataBlocks

Setting to define the number of 16K blocks that will be initially reserved to store contact, friction, and contact cache data. This is the number of 16K memory blocks that will be automatically allocated from the user allocator when the scene is instantiated. Further 16k memory blocks may be allocated during the simulation up to maxNbContactDataBlocks.

Note
This value cannot be larger than maxNbContactDataBlocks because that defines the maximum number of 16k blocks that can be allocated by the SDK.

Default: 0

Range: [0, PX_MAX_U32]

See also
PxPhysics::createScene PxScene::setNbContactDataBlocks

Referenced by isValid().

◆ sanityBounds

PxBounds3 PxSceneDesc::sanityBounds

The bounds used to sanity check user-set positions of actors and articulation links.

These bounds are used to check the position values of rigid actors inserted into the scene, and positions set for rigid actors already within the scene.

Range: any valid PxBounds3
Default: (-PX_MAX_BOUNDS_EXTENTS, PX_MAX_BOUNDS_EXTENTS) on each axis

Referenced by isValid().

◆ sceneQueryUpdateMode

PxSceneQueryUpdateMode::Enum PxSceneDesc::sceneQueryUpdateMode

Defines the scene query update mode. Default: PxSceneQueryUpdateMode::eBUILD_ENABLED_COMMIT_ENABLED.

◆ simulationEventCallback

PxSimulationEventCallback* PxSceneDesc::simulationEventCallback

◆ solverArticulationBatchSize

PxU32 PxSceneDesc::solverArticulationBatchSize

Defines the number of articulations required to spawn a separate rigid body solver island task chain.

This parameter defines the minimum number of articulations required to spawn a separate rigid body solver task chain. Setting a low value will potentially cause more task chains to be generated. This may result in the overhead of spawning tasks can become a limiting performance factor. Setting a high value will potentially cause fewer islands to be generated. This may reduce thread scaling (fewer task chains spawned) and may detrimentally affect performance if some bodies in the scene have large solver iteration counts because all constraints in a given island are solved by the maximum number of solver iterations requested by any body in the island.

Note that a rigid body solver task chain is spawned as soon as either a sufficient number of rigid bodies or articulations are batched together.

Default: 128

See also
PxScene.setSolverArticulationBatchSize() PxScene.getSolverArticulationBatchSize()

◆ solverBatchSize

PxU32 PxSceneDesc::solverBatchSize

Defines the number of actors required to spawn a separate rigid body solver island task chain.

This parameter defines the minimum number of actors required to spawn a separate rigid body solver task chain. Setting a low value will potentially cause more task chains to be generated. This may result in the overhead of spawning tasks can become a limiting performance factor. Setting a high value will potentially cause fewer islands to be generated. This may reduce thread scaling (fewer task chains spawned) and may detrimentally affect performance if some bodies in the scene have large solver iteration counts because all constraints in a given island are solved by the maximum number of solver iterations requested by any body in the island.

Note that a rigid body solver task chain is spawned as soon as either a sufficient number of rigid bodies or articulations are batched together.

Default: 128

See also
PxScene.setSolverBatchSize() PxScene.getSolverBatchSize()

◆ solverOffsetSlop

PxReal PxSceneDesc::solverOffsetSlop

A slop value used to zero contact offsets from the body's COM on an axis if the offset along that axis is smaller than this threshold. Can be used to compensate for small numerical errors in contact generation.

Range: [0, PX_MAX_F32)
Default: 0.0

Referenced by isValid().

◆ solverType

PxSolverType::Enum PxSceneDesc::solverType

Selects the solver algorithm to use.

Default: PxSolverType::ePGS

See also
PxSolverType

◆ staticKineFilteringMode

PxPairFilteringMode::Enum PxSceneDesc::staticKineFilteringMode

Filtering mode for static-kinematic pairs in the broadphase.

Default: PxPairFilteringMode::eDEFAULT

See also
PxPairFilteringMode

◆ staticStructure

PxPruningStructureType::Enum PxSceneDesc::staticStructure

Defines the structure used to store static objects.

Note
Only PxPruningStructureType::eSTATIC_AABB_TREE and PxPruningStructureType::eDYNAMIC_AABB_TREE are allowed here.

Referenced by isValid().

◆ userData

void* PxSceneDesc::userData

Will be copied to PxScene::userData.

Default: NULL

◆ wakeCounterResetValue

PxReal PxSceneDesc::wakeCounterResetValue

The wake counter reset value.

Calling wakeUp() on objects which support sleeping will set their wake counter value to the specified reset value.

Range: (0, PX_MAX_F32)
Default: 0.4 (which corresponds to 20 frames for a time step of 0.02)

See also
PxRigidDynamic::wakeUp() PxArticulationBase::wakeUp()

Referenced by isValid().


The documentation for this class was generated from the following file: