Struct rapier3d::dynamics::IntegrationParameters [−][src]
pub struct IntegrationParameters {}Show fields
pub dt: Real, pub min_ccd_dt: Real, pub erp: Real, pub joint_erp: Real, pub warmstart_coeff: Real, pub warmstart_correction_slope: Real, pub velocity_solve_fraction: Real, pub velocity_based_erp: Real, pub allowed_linear_error: Real, pub prediction_distance: Real, pub allowed_angular_error: Real, pub max_linear_correction: Real, pub max_angular_correction: Real, pub max_velocity_iterations: usize, pub max_position_iterations: usize, pub min_island_size: usize, pub max_ccd_substeps: usize,
Expand description
Parameters for a time-step of the physics engine.
Fields
dt: Real
The timestep length (default: 1.0 / 60.0
)
min_ccd_dt: Real
Minimum timestep size when using CCD with multiple substeps (default 1.0 / 60.0 / 100.0
)
When CCD with multiple substeps is enabled, the timestep is subdivided
into smaller pieces. This timestep subdivision won’t generate timestep
lengths smaller than min_ccd_dt
.
Setting this to a large value will reduce the opportunity to performing CCD substepping, resulting in potentially more time dropped by the motion-clamping mechanism. Setting this to an very small value may lead to numerical instabilities.
erp: Real
The Error Reduction Parameter in [0, 1]
is the proportion of
the positional error to be corrected at each time step (default: 0.2
).
joint_erp: Real
The Error Reduction Parameter for joints in [0, 1]
is the proportion of
the positional error to be corrected at each time step (default: 0.2
).
warmstart_coeff: Real
Each cached impulse are multiplied by this coefficient in [0, 1]
when they are re-used to initialize the solver (default 1.0
).
warmstart_correction_slope: Real
Correction factor to avoid large warmstart impulse after a strong impact (default 10.0
).
velocity_solve_fraction: Real
0-1: how much of the velocity to dampen out in the constraint solver?
(default 1.0
).
velocity_based_erp: Real
0-1: multiplier for how much of the constraint violation (e.g. contact penetration)
will be compensated for during the velocity solve.
If zero, you need to enable the positional solver.
If non-zero, you do not need the positional solver.
A good non-zero value is around 0.2
.
(default 0.0
).
allowed_linear_error: Real
Amount of penetration the engine wont attempt to correct (default: 0.005m
).
prediction_distance: Real
The maximal distance separating two objects that will generate predictive contacts (default: 0.002
).
allowed_angular_error: Real
Amount of angular drift of joint limits the engine wont
attempt to correct (default: 0.001rad
).
max_linear_correction: Real
Maximum linear correction during one step of the non-linear position solver (default: 0.2
).
max_angular_correction: Real
Maximum angular correction during one step of the non-linear position solver (default: 0.2
).
max_velocity_iterations: usize
Maximum number of iterations performed by the velocity constraints solver (default: 4
).
max_position_iterations: usize
Maximum number of iterations performed by the position-based constraints solver (default: 1
).
min_island_size: usize
Minimum number of dynamic bodies in each active island (default: 128
).
max_ccd_substeps: usize
Maximum number of substeps performed by the solver (default: 1
).
Implementations
impl IntegrationParameters
[src]
impl IntegrationParameters
[src]pub fn new(
dt: Real,
erp: Real,
joint_erp: Real,
warmstart_coeff: Real,
allowed_linear_error: Real,
allowed_angular_error: Real,
max_linear_correction: Real,
max_angular_correction: Real,
prediction_distance: Real,
max_velocity_iterations: usize,
max_position_iterations: usize,
max_ccd_substeps: usize
) -> Self
[src]
👎 Deprecated: Use IntegrationParameters { dt: 60.0, ..Default::default() }
instead
pub fn new(
dt: Real,
erp: Real,
joint_erp: Real,
warmstart_coeff: Real,
allowed_linear_error: Real,
allowed_angular_error: Real,
max_linear_correction: Real,
max_angular_correction: Real,
prediction_distance: Real,
max_velocity_iterations: usize,
max_position_iterations: usize,
max_ccd_substeps: usize
) -> Self
[src]Use IntegrationParameters { dt: 60.0, ..Default::default() }
instead
Creates a set of integration parameters with the given values.
pub fn dt(&self) -> Real
[src]
👎 Deprecated: You can just read the IntegrationParams::dt
value directly
pub fn dt(&self) -> Real
[src]You can just read the IntegrationParams::dt
value directly
The current time-stepping length.
pub fn inv_dt(&self) -> Real
[src]
pub fn inv_dt(&self) -> Real
[src]The inverse of the time-stepping length, i.e. the steps per seconds (Hz).
This is zero if self.dt
is zero.
pub fn set_dt(&mut self, dt: Real)
[src]
👎 Deprecated: You can just set the IntegrationParams::dt
value directly
pub fn set_dt(&mut self, dt: Real)
[src]You can just set the IntegrationParams::dt
value directly
Sets the time-stepping length.
pub fn set_inv_dt(&mut self, inv_dt: Real)
[src]
pub fn set_inv_dt(&mut self, inv_dt: Real)
[src]Sets the inverse time-stepping length (i.e. the frequency).
This automatically recompute self.dt
.
Trait Implementations
impl Clone for IntegrationParameters
[src]
impl Clone for IntegrationParameters
[src]fn clone(&self) -> IntegrationParameters
[src]
fn clone(&self) -> IntegrationParameters
[src]Returns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)
1.0.0[src]
fn clone_from(&mut self, source: &Self)
1.0.0[src]Performs copy-assignment from source
. Read more
impl Default for IntegrationParameters
[src]
impl Default for IntegrationParameters
[src]impl Copy for IntegrationParameters
[src]
Auto Trait Implementations
impl RefUnwindSafe for IntegrationParameters
impl Send for IntegrationParameters
impl Sync for IntegrationParameters
impl Unpin for IntegrationParameters
impl UnwindSafe for IntegrationParameters
Blanket Implementations
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]pub fn borrow_mut(&mut self) -> &mut T
[src]
pub fn borrow_mut(&mut self) -> &mut T
[src]Mutably borrows from an owned value. Read more
impl<T> Downcast for T where
T: Any,
[src]
impl<T> Downcast for T where
T: Any,
[src]pub fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
[src]
pub fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
[src]Convert Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
. Read more
pub fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
[src]
pub fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
[src]Convert Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
. Read more
pub fn as_any(&self) -> &(dyn Any + 'static)
[src]
pub fn as_any(&self) -> &(dyn Any + 'static)
[src]Convert &Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s. Read more
pub fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
[src]
pub fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
[src]Convert &mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s. Read more
impl<T> DowncastSync for T where
T: Any + Send + Sync,
[src]
impl<T> DowncastSync for T where
T: Any + Send + Sync,
[src]impl<T> Pointable for T
impl<T> Pointable for T
impl<T> Same<T> for T
impl<T> Same<T> for T
type Output = T
type Output = T
Should always be Self
impl<SS, SP> SupersetOf<SS> for SP where
SS: SubsetOf<SP>,
[src]
impl<SS, SP> SupersetOf<SS> for SP where
SS: SubsetOf<SP>,
[src]pub fn to_subset(&self) -> Option<SS>
[src]
pub fn to_subset(&self) -> Option<SS>
[src]The inverse inclusion map: attempts to construct self
from the equivalent element of its
superset. Read more
pub fn is_in_subset(&self) -> bool
[src]
pub fn is_in_subset(&self) -> bool
[src]Checks if self
is actually part of its subset T
(and can be converted to it).
pub fn to_subset_unchecked(&self) -> SS
[src]
pub fn to_subset_unchecked(&self) -> SS
[src]Use with care! Same as self.to_subset
but without any property checks. Always succeeds.
pub fn from_subset(element: &SS) -> SP
[src]
pub fn from_subset(element: &SS) -> SP
[src]The inclusion map: converts self
to the equivalent element of its superset.
impl<T> ToOwned for T where
T: Clone,
[src]
impl<T> ToOwned for T where
T: Clone,
[src]type Owned = T
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn to_owned(&self) -> T
[src]Creates owned data from borrowed data, usually by cloning. Read more
pub fn clone_into(&self, target: &mut T)
[src]
pub fn clone_into(&self, target: &mut T)
[src]🔬 This is a nightly-only experimental API. (toowned_clone_into
)
recently added
Uses borrowed data to replace owned data, usually by cloning. Read more