pub trait ExplicitDaeVariableStep<Y, Z, U, V>where
Self: VariableStepExplicit<Y, U>,
Y: Tensor,
Z: Tensor,
U: TensorVec<Item = Y>,
V: TensorVec<Item = Z>,
for<'a> &'a Y: Mul<Scalar, Output = Y> + Sub<&'a Y, Output = Y>,{
// Required method
fn slopes_solve(
evolution: impl FnMut(Scalar, &Y, &Z) -> Result<Y, String>,
solution: impl FnMut(Scalar, &Y, &Z) -> Result<Z, String>,
y: &Y,
z: &Z,
t: Scalar,
dt: Scalar,
k: &mut [Y],
y_trial: &mut Y,
z_trial: &mut Z,
) -> Result<(), String>;
// Provided methods
fn integrate_explicit_dae_variable_step(
&self,
evolution: impl FnMut(Scalar, &Y, &Z) -> Result<Y, String>,
solution: impl FnMut(Scalar, &Y, &Z) -> Result<Z, String>,
time: &[Scalar],
initial_condition: (Y, Z),
) -> Result<(Vector, U, U, V), IntegrationError> { ... }
fn interpolate_explicit_dae_variable_step(
&self,
evolution: impl FnMut(Scalar, &Y, &Z) -> Result<Y, String>,
solution: impl FnMut(Scalar, &Y, &Z) -> Result<Z, String>,
time: &Vector,
tp: &Vector,
yp: &U,
zp: &V,
) -> Result<(U, U, V), IntegrationError> { ... }
fn slopes_solve_and_error(
&self,
evolution: impl FnMut(Scalar, &Y, &Z) -> Result<Y, String>,
solution: impl FnMut(Scalar, &Y, &Z) -> Result<Z, String>,
y: &Y,
z: &Z,
t: Scalar,
dt: Scalar,
k: &mut [Y],
y_trial: &mut Y,
z_trial: &mut Z,
) -> Result<Scalar, String> { ... }
fn step_solve(
&self,
evolution: impl FnMut(Scalar, &Y, &Z) -> Result<Y, String>,
y: &mut Y,
z: &mut Z,
t: &mut Scalar,
y_sol: &mut U,
z_sol: &mut V,
t_sol: &mut Vector,
dydt_sol: &mut U,
dt: &mut Scalar,
_k: &mut [Y],
y_trial: &Y,
z_trial: &Z,
e: Scalar,
) -> Result<(), String> { ... }
}Required Methods§
fn slopes_solve( evolution: impl FnMut(Scalar, &Y, &Z) -> Result<Y, String>, solution: impl FnMut(Scalar, &Y, &Z) -> Result<Z, String>, y: &Y, z: &Z, t: Scalar, dt: Scalar, k: &mut [Y], y_trial: &mut Y, z_trial: &mut Z, ) -> Result<(), String>
Provided Methods§
fn integrate_explicit_dae_variable_step( &self, evolution: impl FnMut(Scalar, &Y, &Z) -> Result<Y, String>, solution: impl FnMut(Scalar, &Y, &Z) -> Result<Z, String>, time: &[Scalar], initial_condition: (Y, Z), ) -> Result<(Vector, U, U, V), IntegrationError>
fn interpolate_explicit_dae_variable_step( &self, evolution: impl FnMut(Scalar, &Y, &Z) -> Result<Y, String>, solution: impl FnMut(Scalar, &Y, &Z) -> Result<Z, String>, time: &Vector, tp: &Vector, yp: &U, zp: &V, ) -> Result<(U, U, V), IntegrationError>
fn slopes_solve_and_error( &self, evolution: impl FnMut(Scalar, &Y, &Z) -> Result<Y, String>, solution: impl FnMut(Scalar, &Y, &Z) -> Result<Z, String>, y: &Y, z: &Z, t: Scalar, dt: Scalar, k: &mut [Y], y_trial: &mut Y, z_trial: &mut Z, ) -> Result<Scalar, String>
fn step_solve( &self, evolution: impl FnMut(Scalar, &Y, &Z) -> Result<Y, String>, y: &mut Y, z: &mut Z, t: &mut Scalar, y_sol: &mut U, z_sol: &mut V, t_sol: &mut Vector, dydt_sol: &mut U, dt: &mut Scalar, _k: &mut [Y], y_trial: &Y, z_trial: &Z, e: Scalar, ) -> Result<(), String>
Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.