Struct vrp_core::solver::population::Greedy[][src]

pub struct Greedy { /* fields omitted */ }
Expand description

A population which keeps track of the best known individuals only. If solutions are equal, prefers to keep first discovered.

Implementations

impl Greedy[src]

pub fn new(
    problem: Arc<Problem>,
    selection_size: usize,
    best_known: Option<Individual>
) -> Self
[src]

Creates a new instance of Greedy.

Trait Implementations

impl Display for Greedy[src]

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

Formats the value using the given formatter. Read more

impl Population for Greedy[src]

fn add_all(&mut self, individuals: Vec<Individual>) -> bool[src]

Adds all individuals into the population, then sorts and shrinks population if necessary. Returns true if any of newly added individuals is considered as best known. Read more

fn add(&mut self, individual: Individual) -> bool[src]

Adds an individual into the population. Returns true if newly added individual is considered as best known. Read more

fn on_generation(&mut self, _: &Statistics)[src]

Informs population about new generation event. This is time for the population to decide whether selection phase has to be changed. Read more

fn cmp(&self, a: &Individual, b: &Individual) -> Ordering[src]

Compares two solutions the same way as population does.

fn select<'a>(&'a self) -> Box<dyn Iterator<Item = &Individual> + 'a>[src]

Selects parents from the population based on current selection phase.

fn ranked<'a>(&'a self) -> Box<dyn Iterator<Item = (&Individual, usize)> + 'a>[src]

Returns subset of individuals within their rank sorted according their quality.

fn size(&self) -> usize[src]

Returns population size.

fn selection_phase(&self) -> SelectionPhase[src]

Returns a current selection phase.

Auto Trait Implementations

impl !RefUnwindSafe for Greedy

impl Send for Greedy

impl Sync for Greedy

impl Unpin for Greedy

impl !UnwindSafe for Greedy

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T> Pointable for T

pub const ALIGN: usize

The alignment of pointer.

type Init = T

The type for initializers.

pub unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more

pub unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more

pub unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more

pub unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more

impl<T> ToString for T where
    T: Display + ?Sized
[src]

pub default fn to_string(&self) -> String[src]

Converts the given value to a String. Read more

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]

Performs the conversion.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>, 

pub fn vzip(self) -> V