LBFGSB

Struct LBFGSB 

Source
pub struct LBFGSB { /* private fields */ }
Expand description

The L-BFGS-B (Limited memory, bounded Broyden-Fletcher-Goldfarb-Shanno) algorithm.

This minimization Algorithm is a quasi-Newton minimizer which approximates the inverse of the Hessian matrix using the L-BFGS update step with a modification to ensure boundary constraints are satisfied. The L-BFGS-B algorithm is described in detail in 1.

Trait Implementations§

Source§

impl<P, U, E> Algorithm<P, GradientStatus, U, E> for LBFGSB
where P: Gradient<U, E>,

Source§

type Summary = MinimizationSummary

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

type Config = LBFGSBConfig

The configuration struct for the algorithm.
Source§

fn initialize( &mut self, problem: &P, status: &mut GradientStatus, 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 GradientStatus, 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 postprocessing( &mut self, problem: &P, status: &mut GradientStatus, 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 summarize( &self, _current_step: usize, _problem: &P, status: &GradientStatus, _args: &U, config: &Self::Config, ) -> Result<Self::Summary, E>

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

fn reset(&mut self)

Reset the algorithm to its initial state.
Source§

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

Provides a set of reasonable default callbacks specific to this Algorithm.
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 LBFGSB

Source§

fn clone(&self) -> LBFGSB

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 Default for LBFGSB

Source§

fn default() -> Self

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

impl<P, U, E> Terminator<LBFGSB, P, GradientStatus, U, E, LBFGSBConfig> for LBFGSBFTerminator
where P: Gradient<U, E>,

Source§

fn check_for_termination( &mut self, _current_step: usize, algorithm: &mut LBFGSB, _problem: &P, status: &mut GradientStatus, _args: &U, _config: &LBFGSBConfig, ) -> ControlFlow<()>

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

impl<P, U, E> Terminator<LBFGSB, P, GradientStatus, U, E, LBFGSBConfig> for LBFGSBGTerminator
where P: Gradient<U, E>,

Source§

fn check_for_termination( &mut self, _current_step: usize, algorithm: &mut LBFGSB, _problem: &P, status: &mut GradientStatus, _args: &U, _config: &LBFGSBConfig, ) -> ControlFlow<()>

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

impl<P, U, E> Terminator<LBFGSB, P, GradientStatus, U, E, LBFGSBConfig> for LBFGSBInfNormGTerminator
where P: Gradient<U, E>,

Source§

fn check_for_termination( &mut self, _current_step: usize, algorithm: &mut LBFGSB, _problem: &P, status: &mut GradientStatus, _args: &U, _config: &LBFGSBConfig, ) -> ControlFlow<()>

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

Auto Trait Implementations§

§

impl Freeze for LBFGSB

§

impl RefUnwindSafe for LBFGSB

§

impl Send for LBFGSB

§

impl Sync for LBFGSB

§

impl Unpin for LBFGSB

§

impl UnwindSafe for LBFGSB

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<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.