Struct sim::analytics::Analytics

source ·
pub struct Analytics {
Show 16 fields pub road_thruput: TimeSeriesCount<RoadID>, pub intersection_thruput: TimeSeriesCount<IntersectionID>, pub traffic_signal_thruput: TimeSeriesCount<CompressedMovementID>, pub demand: BTreeMap<MovementID, usize>, pub bus_arrivals: Vec<(Time, CarID, TransitRouteID, TransitStopID)>, pub passengers_boarding: BTreeMap<TransitStopID, Vec<(Time, TransitRouteID, Duration)>>, pub passengers_alighting: BTreeMap<TransitStopID, Vec<(Time, TransitRouteID)>>, pub started_trips: BTreeMap<TripID, Time>, pub finished_trips: Vec<(Time, TripID, TripMode, Option<Duration>)>, pub problems_per_trip: BTreeMap<TripID, Vec<(Time, Problem)>>, pub trip_log: Vec<(Time, TripID, Option<PathRequest>, TripPhaseType)>, pub intersection_delays: BTreeMap<IntersectionID, Vec<(u8, Time, Duration, AgentType)>>, pub parking_lane_changes: BTreeMap<LaneID, Vec<(Time, bool)>>, pub parking_lot_changes: BTreeMap<ParkingLotID, Vec<(Time, bool)>>, pub(crate) alerts: Vec<(Time, AlertLocation, String)>, record_anything: bool,
}
Expand description

As a simulation runs, different pieces emit Events. The Analytics object listens to these, organizing and storing some information from them. The UI queries Analytics to draw time-series and display statistics.

For all maps whose weekday scenario fully runs, the game’s release includes some “prebaked results.” These are just serialized Analytics after running the simulation on a map without any edits for the full day. This is the basis of A/B testing – the player can edit the map, start running the simulation, and compare the live Analytics to the prebaked baseline Analytics.

Fields§

§road_thruput: TimeSeriesCount<RoadID>§intersection_thruput: TimeSeriesCount<IntersectionID>§traffic_signal_thruput: TimeSeriesCount<CompressedMovementID>§demand: BTreeMap<MovementID, usize>

Most fields in Analytics are cumulative over time, but this is just for the current moment in time.

§bus_arrivals: Vec<(Time, CarID, TransitRouteID, TransitStopID)>§passengers_boarding: BTreeMap<TransitStopID, Vec<(Time, TransitRouteID, Duration)>>

For each passenger boarding, how long did they wait at the stop?

§passengers_alighting: BTreeMap<TransitStopID, Vec<(Time, TransitRouteID)>>§started_trips: BTreeMap<TripID, Time>§finished_trips: Vec<(Time, TripID, TripMode, Option<Duration>)>

Finish time, ID, mode, trip duration if successful (or None if cancelled)

§problems_per_trip: BTreeMap<TripID, Vec<(Time, Problem)>>

Record different problems that each trip encounters.

§trip_log: Vec<(Time, TripID, Option<PathRequest>, TripPhaseType)>§intersection_delays: BTreeMap<IntersectionID, Vec<(u8, Time, Duration, AgentType)>>

Only for traffic signals. The u8 is the movement index from a CompressedMovementID.

§parking_lane_changes: BTreeMap<LaneID, Vec<(Time, bool)>>

Per parking lane or lot, when does a spot become filled (true) or free (false)

§parking_lot_changes: BTreeMap<ParkingLotID, Vec<(Time, bool)>>§alerts: Vec<(Time, AlertLocation, String)>§record_anything: bool

For benchmarking, we may want to disable collecting data.

Implementations§

source§

impl Analytics

source

pub fn new(record_anything: bool) -> Analytics

source

pub fn event(&mut self, ev: Event, time: Time, map: &Map)

source

pub fn record_demand(&mut self, path: &Path, map: &Map)

source

pub fn finished_trip_time(&self, trip: TripID) -> Option<Duration>

Ignores the current time. Returns None for cancelled trips.

source

pub fn both_finished_trips( &self, now: Time, before: &Analytics ) -> Vec<(TripID, Duration, Duration, TripMode)>

Returns pairs of trip times for finished trips in both worlds. (ID, before, after, mode)

source

pub fn get_trip_phases(&self, trip: TripID, map: &Map) -> Vec<TripPhase>

If calling on prebaked Analytics, be careful to pass in an unedited map, to match how the simulation was originally run. Otherwise the paths may be nonsense.

source

pub fn get_all_trip_phases(&self) -> BTreeMap<TripID, Vec<TripPhase>>

source

pub fn active_agents(&self, now: Time) -> Vec<(Time, usize)>

source

pub fn parking_lane_availability( &self, now: Time, l: LaneID, capacity: usize ) -> Vec<(Time, usize)>

Returns the free spots over time

source

pub fn parking_lot_availability( &self, now: Time, pl: ParkingLotID, capacity: usize ) -> Vec<(Time, usize)>

source

fn parking_spot_availability( now: Time, changes: &[(Time, bool)], capacity: usize ) -> Vec<(Time, usize)>

source

pub fn problems_per_intersection( &self, now: Time, id: IntersectionID ) -> Vec<(ProblemType, Vec<(Time, usize)>)>

source

pub fn problems_per_lane( &self, now: Time, id: LaneID ) -> Vec<(ProblemType, Vec<(Time, usize)>)>

Trait Implementations§

source§

impl Clone for Analytics

source§

fn clone(&self) -> Analytics

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Default for Analytics

source§

fn default() -> Analytics

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

impl<'de> Deserialize<'de> for Analytics

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl Serialize for Analytics

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. 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
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn 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.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

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.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

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

Initializes a with the given initializer. Read more
§

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

Dereferences the given pointer. Read more
§

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

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

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

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

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

§

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>,

§

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.
§

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

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<G1, G2> Within<G2> for G1
where G2: Contains<G1>,

§

fn is_within(&self, b: &G2) -> bool

source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,