Skip to main content

ScanDispatch

Struct ScanDispatch 

Source
pub struct ScanDispatch { /* private fields */ }
Expand description

Elevator dispatch using the SCAN (elevator) algorithm.

Each car tracks a sweep direction; stops demanded in that direction receive a positional cost while stops behind are excluded. When nothing remains ahead, the sweep reverses and the car considers the reverse side. Direction and mode are resolved once per pass in DispatchStrategy::prepare_car so ranking is independent of the iteration order over stops.

Implementations§

Source§

impl ScanDispatch

Source

pub fn new() -> Self

Create a new ScanDispatch with no initial direction state.

Trait Implementations§

Source§

impl Default for ScanDispatch

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl DispatchStrategy for ScanDispatch

Source§

fn prepare_car( &mut self, car: EntityId, car_position: f64, group: &ElevatorGroup, manifest: &DispatchManifest, world: &World, )

Optional hook called once per candidate car, before any rank calls for that car in the current pass. Read more
Source§

fn rank(&mut self, ctx: &RankContext<'_>) -> Option<f64>

Score the cost of sending car to stop. Lower is better. Read more
Source§

fn notify_removed(&mut self, elevator: EntityId)

Notify the strategy that an elevator has been removed. Read more
Source§

fn pre_dispatch( &mut self, _group: &ElevatorGroup, _manifest: &DispatchManifest, _world: &mut World, )

Optional hook called once per group before the assignment pass. Read more
Source§

fn fallback( &mut self, _car: EntityId, _car_position: f64, _group: &ElevatorGroup, _manifest: &DispatchManifest, _world: &World, ) -> DispatchDecision

Decide what an idle car should do when no stop was assigned to it. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.