GradientFreeStatus

Struct GradientFreeStatus 

Source
pub struct GradientFreeStatus {
    pub message: String,
    pub x: DVector<Float>,
    pub fx: Float,
    pub n_f_evals: usize,
    pub converged: bool,
    pub hess: Option<DMatrix<Float>>,
    pub cov: Option<DMatrix<Float>>,
    pub err: Option<DVector<Float>>,
}
Expand description

A status message struct containing all information about a minimization result.

Fields§

§message: String

A String message that can be set by Algorithms.

§x: DVector<Float>

The current parameters of the minimization.

§fx: Float

The current value of the minimization problem function at GradientFreeStatus::x.

§n_f_evals: usize

The number of function evaluations (approximately, this is left up to individual Algorithms to correctly compute and may not be exact).

§converged: bool

Flag that says whether or not the fit is in a converged state.

§hess: Option<DMatrix<Float>>

The Hessian matrix at the end of the fit (None if not computed yet)

§cov: Option<DMatrix<Float>>

Covariance matrix at the end of the fit (None if not computed yet)

§err: Option<DVector<Float>>

Errors on parameters at the end of the fit (None if not computed yet)

Implementations§

Source§

impl GradientFreeStatus

Source

pub fn with_message(&mut self, message: &str)

Updates the GradientFreeStatus::message field.

Source

pub fn with_position(&mut self, pos: (DVector<Float>, Float))

Source

pub fn set_converged(&mut self)

Source

pub fn inc_n_f_evals(&mut self)

Source

pub fn with_cov(&mut self, covariance: Option<DMatrix<Float>>)

Updates the GradientFreeStatus::err field.

Source

pub fn with_hess(&mut self, hessian: &DMatrix<Float>)

Trait Implementations§

Source§

impl<P, U, E> Algorithm<P, GradientFreeStatus, U, E> for NelderMead
where P: CostFunction<U, E>,

Source§

type Summary = MinimizationSummary

A type which holds a summary of the algorithm’s ending state.
Source§

type Config = NelderMeadConfig

The configuration struct for the algorithm.
Source§

fn initialize( &mut self, problem: &P, status: &mut GradientFreeStatus, args: &U, config: &Self::Config, ) -> Result<(), E>

Any setup work done before the main steps of the algorithm should be done here. Read more
Source§

fn step( &mut self, _current_step: usize, problem: &P, status: &mut GradientFreeStatus, args: &U, config: &Self::Config, ) -> Result<(), E>

The main “step” of an algorithm, which is repeated until termination conditions are met or the max number of steps have been taken. Read more
Source§

fn summarize( &self, _current_step: usize, _func: &P, status: &GradientFreeStatus, _args: &U, config: &Self::Config, ) -> Result<MinimizationSummary, E>

Generates a new Algorithm::Summary from the current state of the Algorithm, which can be displayed or used elsewhere. Read more
Source§

fn default_callbacks() -> Callbacks<Self, P, GradientFreeStatus, U, E, Self::Config>
where Self: Sized,

Provides a set of reasonable default callbacks specific to this Algorithm.
Source§

fn postprocessing( &mut self, problem: &P, status: &mut S, args: &U, config: &Self::Config, ) -> Result<(), E>

Runs any steps needed by the Algorithm after termination or convergence. This will run regardless of whether the Algorithm converged. Read more
Source§

fn reset(&mut self)

Reset the algorithm to its initial state.
Source§

fn process<C>( &mut self, problem: &P, args: &U, config: Self::Config, callbacks: C, ) -> Result<Self::Summary, E>
where C: Into<Callbacks<Self, P, S, U, E, Self::Config>>, Self: Sized,

Process the given problem using this Algorithm. Read more
Source§

fn process_default( &mut self, problem: &P, user_data: &U, config: Self::Config, ) -> Result<Self::Summary, E>
where Self: Sized,

Process the given problem using this Algorithm. Read more
Source§

impl Clone for GradientFreeStatus

Source§

fn clone(&self) -> GradientFreeStatus

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for GradientFreeStatus

Source§

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

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

impl Default for GradientFreeStatus

Source§

fn default() -> GradientFreeStatus

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for GradientFreeStatus

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Serialize for GradientFreeStatus

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Status for GradientFreeStatus

Source§

fn reset(&mut self)

Resets the status to its default state. This is called at the beginning of every Algorithm::process run. Only members that are not persistent between runs should be reset. For example, the initial parameters of a minimization should not be reset.
Source§

fn converged(&self) -> bool

Returns the convergence flag of the minimization.
Source§

fn message(&self) -> &str

Returns the message of the minimization.
Source§

fn update_message(&mut self, message: &str)

Sets the message of the minimization.
Source§

impl<P, U, E> Terminator<NelderMead, P, GradientFreeStatus, U, E, NelderMeadConfig> for NelderMeadFTerminator
where P: CostFunction<U, E>,

Source§

fn check_for_termination( &mut self, _current_step: usize, algorithm: &mut NelderMead, _problem: &P, status: &mut GradientFreeStatus, _args: &U, _config: &NelderMeadConfig, ) -> ControlFlow<()>

A termination check which is called on each step of an Algorithm.
Source§

impl<P, U, E> Terminator<NelderMead, P, GradientFreeStatus, U, E, NelderMeadConfig> for NelderMeadXTerminator
where P: CostFunction<U, E>,

Source§

fn check_for_termination( &mut self, _current_step: usize, algorithm: &mut NelderMead, _problem: &P, status: &mut GradientFreeStatus, _args: &U, _config: &NelderMeadConfig, ) -> ControlFlow<()>

A termination check which is called on each step of an Algorithm.

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> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

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> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> Serialize for T
where T: Serialize + ?Sized,

Source§

fn erased_serialize(&self, serializer: &mut dyn Serializer) -> Result<(), Error>

Source§

fn do_erased_serialize( &self, serializer: &mut dyn Serializer, ) -> Result<(), ErrorImpl>

Source§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

Source§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
Source§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
Source§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
Source§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
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> TransformExt for T

Source§

fn compose<T2>(self, t2: T2) -> Compose<Self, T2>

Compose a transform with another. 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.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,