pub struct EllipsoidMethod {
pub max_iter: usize,
pub initial_radius: f64,
pub tol: f64,
}Expand description
Ellipsoid method for convex feasibility problems.
Given a list of constraint functions g_i(x) ≤ 0 and a starting ellipsoid
E(x0, R²I), iteratively cuts the ellipsoid using the most-violated
constraint until a feasible point is found or max_iter is exhausted.
Fields§
§max_iter: usizeMaximum number of iterations.
initial_radius: f64Initial radius of the starting ball.
tol: f64Tolerance for constraint satisfaction.
Implementations§
Source§impl EllipsoidMethod
impl EllipsoidMethod
Sourcepub fn new(max_iter: usize, initial_radius: f64, tol: f64) -> Self
pub fn new(max_iter: usize, initial_radius: f64, tol: f64) -> Self
Create a new ellipsoid method solver.
Sourcepub fn find_feasible(
&self,
x0: Vec<f64>,
constraints: &[(Box<dyn Fn(&[f64]) -> f64>, Box<dyn Fn(&[f64]) -> Vec<f64>>)],
) -> EllipsoidResult
pub fn find_feasible( &self, x0: Vec<f64>, constraints: &[(Box<dyn Fn(&[f64]) -> f64>, Box<dyn Fn(&[f64]) -> Vec<f64>>)], ) -> EllipsoidResult
Find a feasible point satisfying all constraints.
Each element of constraints is a pair (g, subgrad) where g(x)
returns the constraint value and subgrad(x) returns a subgradient.
Auto Trait Implementations§
impl Freeze for EllipsoidMethod
impl RefUnwindSafe for EllipsoidMethod
impl Send for EllipsoidMethod
impl Sync for EllipsoidMethod
impl Unpin for EllipsoidMethod
impl UnsafeUnpin for EllipsoidMethod
impl UnwindSafe for EllipsoidMethod
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<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
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
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
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.