Struct vrp_core::algorithms::gsom::Topology[][src]

pub struct Topology<I: Input, S: Storage<Item = I>> {
    pub dimension: usize,
    pub right: Option<NodeLink<I, S>>,
    pub left: Option<NodeLink<I, S>>,
    pub up: Option<NodeLink<I, S>>,
    pub down: Option<NodeLink<I, S>>,
}

Represents a node neighbourhood.

Fields

dimension: usize

An input dimension.

right: Option<NodeLink<I, S>>

A link to right neighbour.

left: Option<NodeLink<I, S>>

A link to left neighbour.

up: Option<NodeLink<I, S>>

A link to up neighbour.

down: Option<NodeLink<I, S>>

A link to down neighbour.

Implementations

impl<I: Input, S: Storage<Item = I>> Topology<I, S>[src]

pub fn empty(dimension: usize) -> Self[src]

Creates an empty cell at given coordinate.

pub fn neighbours(&self) -> impl Iterator<Item = &NodeLink<I, S>>[src]

Gets neighbors.

pub fn is_boundary(&self) -> bool[src]

Checks if the cell is at the boundary of the network.

Trait Implementations

impl<I: Input, S: Storage<Item = I>> Clone for Topology<I, S>[src]

Auto Trait Implementations

impl<I, S> RefUnwindSafe for Topology<I, S>

impl<I, S> Send for Topology<I, S>

impl<I, S> Sync for Topology<I, S>

impl<I, S> Unpin for Topology<I, S>

impl<I, S> UnwindSafe for Topology<I, S>

Blanket Implementations

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

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

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

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

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

impl<T> Pointable for T

type Init = T

The type for initializers.

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

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.

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.

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