pub struct CxCrossover;Expand description
Cycle Crossover (CX) for permutation genomes
CX produces offspring where each element’s position comes from one parent, preserving the absolute position of elements. It identifies cycles in the parent mappings and alternates which parent contributes each cycle.
Reference: Oliver, I. M., Smith, D. J., & Holland, J. R. (1987). A Study of Permutation Crossover Operators on the Traveling Salesman Problem.
Implementations§
Source§impl CxCrossover
impl CxCrossover
Trait Implementations§
Source§impl Clone for CxCrossover
impl Clone for CxCrossover
Source§fn clone(&self) -> CxCrossover
fn clone(&self) -> CxCrossover
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl CrossoverOperator<Permutation> for CxCrossover
impl CrossoverOperator<Permutation> for CxCrossover
Source§fn crossover<R: Rng>(
&self,
parent1: &Permutation,
parent2: &Permutation,
_rng: &mut R,
) -> OperatorResult<(Permutation, Permutation)>
fn crossover<R: Rng>( &self, parent1: &Permutation, parent2: &Permutation, _rng: &mut R, ) -> OperatorResult<(Permutation, Permutation)>
Apply crossover to two parents and produce two offspring
Source§fn crossover_probability(&self) -> f64
fn crossover_probability(&self) -> f64
Get the probability of crossover being applied
Source§impl Debug for CxCrossover
impl Debug for CxCrossover
Source§impl Default for CxCrossover
impl Default for CxCrossover
Source§fn default() -> CxCrossover
fn default() -> CxCrossover
Returns the “default value” for a type. Read more
Auto Trait Implementations§
impl Freeze for CxCrossover
impl RefUnwindSafe for CxCrossover
impl Send for CxCrossover
impl Sync for CxCrossover
impl Unpin for CxCrossover
impl UnsafeUnpin for CxCrossover
impl UnwindSafe for CxCrossover
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> 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 more§impl<T> Pointable for T
impl<T> Pointable for T
§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§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 more§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).§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.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.