Skip to main content

Spring

Struct Spring 

Source
pub struct Spring {
    pub mass: f32,
    pub stiffness: f32,
    pub damping: f32,
}
Expand description

A damped-harmonic-oscillator spring, solved in closed form.

Parameters follow the common “physical” convention: mass, stiffness (k) and damping (c). The angular frequency is ω₀ = √(k/m) and the damping ratio is ζ = c / (2√(k·m)).

Fields§

§mass: f32

Oscillator mass (> 0).

§stiffness: f32

Spring stiffness k (> 0).

§damping: f32

Damping coefficient c (>= 0).

Implementations§

Source§

impl Spring

Source

pub fn new(mass: f32, stiffness: f32, damping: f32) -> Self

Construct a spring from physical parameters.

Source

pub fn from_frequency(omega0: f32, zeta: f32) -> Self

Build a spring with the given natural frequency ω₀ (rad/s) and damping ratio ζ (unit mass). ζ = 1 is critically damped.

Source

pub fn natural_frequency(&self) -> f32

The undamped natural angular frequency ω₀ = √(k/m).

Source

pub fn damping_ratio(&self) -> f32

The damping ratio ζ. < 1 under-, == 1 critically-, > 1 over-damped.

Source

pub fn position(&self, from: f32, to: f32, v0: f32, t: f32) -> f32

Position at time t (seconds) for a spring released from displacement from - to with initial velocity v0, settling towards to.

Returns the absolute position (already offset by to). The solution is the exact analytic response of m·x'' + c·x' + k·x = 0, so it is numerically stable at any t and frame rate.

Source

pub fn is_settled( &self, from: f32, to: f32, v0: f32, t: f32, tolerance: f32, ) -> bool

Whether the spring has effectively settled at to by time t, within tolerance of the rest position.

Trait Implementations§

Source§

impl Clone for Spring

Source§

fn clone(&self) -> Spring

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Spring

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for Spring

Source§

fn default() -> Self

A snappy, slightly-underdamped UI spring.

Source§

impl PartialEq for Spring

Source§

fn eq(&self, other: &Spring) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Copy for Spring

Source§

impl StructuralPartialEq for Spring

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.