Struct sim::mechanics::parking::InfiniteParkingSimState [−][src]
pub struct InfiniteParkingSimState {
parked_cars: BTreeMap<CarID, ParkedCar>,
occupants: BTreeMap<ParkingSpot, CarID>,
reserved_spots: BTreeMap<ParkingSpot, CarID>,
driving_to_offstreet: MultiMap<LaneID, (BuildingID, Distance)>,
blackholed_building_redirects: BTreeMap<BuildingID, BuildingID>,
num_occupants_per_offstreet: BTreeMap<BuildingID, usize>,
events: Vec<Event>,
}
Expand description
This assigns infinite private parking to all buildings and none anywhere else. This effectively disables the simulation of parking entirely, making driving trips just go directly between buildings. Useful for maps without good parking data (which is currently all of them) and experiments where parking contention skews results and just gets in the way.
Fields
parked_cars: BTreeMap<CarID, ParkedCar>
occupants: BTreeMap<ParkingSpot, CarID>
reserved_spots: BTreeMap<ParkingSpot, CarID>
driving_to_offstreet: MultiMap<LaneID, (BuildingID, Distance)>
blackholed_building_redirects: BTreeMap<BuildingID, BuildingID>
num_occupants_per_offstreet: BTreeMap<BuildingID, usize>
events: Vec<Event>
Implementations
Trait Implementations
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Performs the conversion.
Returns any cars that got very abruptly evicted from existence, and also cars actively moving into a deleted spot. Read more
fn get_free_onstreet_spots(&self, _: LaneID) -> Vec<ParkingSpot>ⓘ
fn get_free_offstreet_spots(&self, b: BuildingID) -> Vec<ParkingSpot>ⓘ
fn get_free_lot_spots(&self, _: ParkingLotID) -> Vec<ParkingSpot>ⓘ
Needed when abruptly deleting a car, in case they’re being deleted during their last step.
fn get_draw_cars(&self, _: LaneID, _: &Map) -> Vec<DrawCarInput>ⓘ
fn get_draw_cars_in_lots(&self, _: LaneID, _: &Map) -> Vec<DrawCarInput>ⓘ
There’s no DrawCarInput for cars parked offstreet, so we need this.
fn get_all_draw_cars(&self, _: &Map) -> Vec<DrawCarInput>ⓘ
The vehicle’s front is currently at the given driving_pos. Returns all valid spots and their driving position. Read more
(Filled, available)
fn path_to_free_parking_spot(
&self,
start: LaneID,
vehicle: &Vehicle,
target: BuildingID,
map: &Map
) -> Option<(Vec<PathStep>, ParkingSpot, Position)>
fn path_to_free_parking_spot(
&self,
start: LaneID,
vehicle: &Vehicle,
target: BuildingID,
map: &Map
) -> Option<(Vec<PathStep>, ParkingSpot, Position)>
Unrealistically assumes the driver has knowledge of currently free parking spots, even if they’re far away. Since they don’t reserve the spot in advance, somebody else can still beat them there, producing some nice, realistic churn if there’s too much contention. But the implementation has some internal jitter between different vehicles, to discourage everybody near one spot from all competing for it. Note the first PathStep is the turn after start, NOT PathStep::Lane(start). Read more
fn collect_events(&mut self) -> Vec<Event>ⓘ
fn try_into(
self
) -> Result<InfiniteParkingSimState, <Self as TryInto<InfiniteParkingSimState>>::Error>
fn try_into(
self
) -> Result<InfiniteParkingSimState, <Self as TryInto<InfiniteParkingSimState>>::Error>
Performs the conversion.
Auto Trait Implementations
impl RefUnwindSafe for InfiniteParkingSimState
impl Send for InfiniteParkingSimState
impl Sync for InfiniteParkingSimState
impl Unpin for InfiniteParkingSimState
impl UnwindSafe for InfiniteParkingSimState
Blanket Implementations
Mutably borrows from an owned value. Read more
impl<T> Downcast for T where
T: Any,
impl<T> Downcast for T where
T: Any,
Convert Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
. Read more
pub fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
pub fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
Convert Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
. Read more
Convert &Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s. Read more
pub fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
pub fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert &mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s. Read more
Instruments this type with the provided Span
, returning an
Instrumented
wrapper. Read more
type Output = T
type Output = T
Should always be Self