pub struct FeasibilityRule {
pub feasibility_tol: f64,
}Expand description
Deb’s feasibility tournament rule for comparing candidate solutions.
The rule defines a total order on solutions:
- A feasible solution always beats an infeasible one.
- Among two feasible solutions, the one with the better objective wins.
- Among two infeasible solutions, the one with the smaller total constraint violation wins.
§References
Deb, K. (2000). An efficient constraint handling method for genetic algorithms. Computer Methods in Applied Mechanics and Engineering, 186.
Fields§
§feasibility_tol: f64Feasibility tolerance: violations smaller than this are treated as zero.
Implementations§
Source§impl FeasibilityRule
impl FeasibilityRule
Sourcepub fn compare(
&self,
f_a: f64,
viol_a: &ViolationSummary,
f_b: f64,
viol_b: &ViolationSummary,
) -> Ordering
pub fn compare( &self, f_a: f64, viol_a: &ViolationSummary, f_b: f64, viol_b: &ViolationSummary, ) -> Ordering
Compare two solutions a and b according to Deb’s tournament rule.
Returns std::cmp::Ordering::Less if a is preferred,
Equal if they are equivalent, and Greater if b is preferred.
§Arguments
f_a,f_b— Objective values (minimisation).viol_a,viol_b— Constraint violations.
Sourcepub fn sort_population(
&self,
population: &[(f64, ViolationSummary)],
) -> Vec<usize>
pub fn sort_population( &self, population: &[(f64, ViolationSummary)], ) -> Vec<usize>
Sort a list of (objective, violation) pairs in-place using the
feasibility rule (best first).
Returns the sorted indices into the original slice.
Trait Implementations§
Source§impl Clone for FeasibilityRule
impl Clone for FeasibilityRule
Source§fn clone(&self) -> FeasibilityRule
fn clone(&self) -> FeasibilityRule
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for FeasibilityRule
impl Debug for FeasibilityRule
Source§impl Default for FeasibilityRule
impl Default for FeasibilityRule
Source§fn default() -> FeasibilityRule
fn default() -> FeasibilityRule
Returns the “default value” for a type. Read more
impl Copy for FeasibilityRule
Auto Trait Implementations§
impl Freeze for FeasibilityRule
impl RefUnwindSafe for FeasibilityRule
impl Send for FeasibilityRule
impl Sync for FeasibilityRule
impl Unpin for FeasibilityRule
impl UnsafeUnpin for FeasibilityRule
impl UnwindSafe for FeasibilityRule
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§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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 moreSource§impl<T> Pointable for T
impl<T> Pointable for T
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.