pub struct RKF45 {
pub tol: f64,
pub safety_factor: f64,
pub min_step_size: f64,
pub max_step_size: f64,
pub max_step_iter: usize,
}
Expand description
Runge-Kutta-Fehlberg 4/5th order integrator.
This integrator uses the Runge-Kutta-Fehlberg method, which is an adaptive step size integrator. It calculates six intermediate values (k1, k2, k3, k4, k5, k6) to estimate the next step solution and the error. The step size is automatically adjusted based on the estimated error to maintain the desired tolerance.
§Member variables
tol
: The tolerance for the estimated error.safety_factor
: The safety factor for the step size adjustment.min_step_size
: The minimum step size.max_step_size
: The maximum step size.max_step_iter
: The maximum number of iterations per step.
Fields§
§tol: f64
§safety_factor: f64
§min_step_size: f64
§max_step_size: f64
§max_step_iter: usize
Implementations§
Trait Implementations§
source§impl ButcherTableau for RKF45
impl ButcherTableau for RKF45
const C: &'static [f64] = _
const A: &'static [&'static [f64]] = _
const BU: &'static [f64] = _
const BE: &'static [f64] = _
fn tol(&self) -> f64
fn safety_factor(&self) -> f64
fn min_step_size(&self) -> f64
fn max_step_size(&self) -> f64
fn max_step_iter(&self) -> usize
source§impl<'de> Deserialize<'de> for RKF45
impl<'de> Deserialize<'de> for RKF45
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
impl Copy for RKF45
Auto Trait Implementations§
impl Freeze for RKF45
impl RefUnwindSafe for RKF45
impl Send for RKF45
impl Sync for RKF45
impl Unpin for RKF45
impl UnwindSafe for RKF45
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more