X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouteplanner.h;h=85f5f6501321e328b2db36a70a0a79c9c18b59e4;hb=d6516b0d9faa26fe6c64000c34f8d820f91ac479;hp=153eda0532dfc369d48f34aabc77fff068a3ec51;hpb=997e14793d8e58d3cb14a495970b36b1e0cad39b;p=r2c2.git diff --git a/source/libr2c2/trainrouteplanner.h b/source/libr2c2/trainrouteplanner.h index 153eda0..85f5f65 100644 --- a/source/libr2c2/trainrouteplanner.h +++ b/source/libr2c2/trainrouteplanner.h @@ -31,8 +31,13 @@ private: struct TrainRoutingInfo { Train *train; + float length; float speed; + Block *first_noncritical; TrainRouter *router; + std::vector waypoints; + std::vector metrics; + bool has_duration; std::list routes; Track *track_history[2]; std::list sequence; @@ -65,16 +70,20 @@ private: { TrainRoutingInfo *info; TrackIter track; - unsigned path; + unsigned char path; + bool critical; OccupiedTrack *occupied_tracks; float offset; float back_offset; TrainState state; Msp::Time::TimeDelta delay; - int waypoint; + Msp::Time::TimeDelta duration; + unsigned waypoint; + float travel_multiplier; float distance_traveled; float remaining_estimate; Msp::Time::TimeDelta wait_time; + Msp::Time::TimeDelta estimated_wait; int blocked_by; TrainRoutingState(TrainRoutingInfo &); @@ -82,18 +91,22 @@ private: ~TrainRoutingState(); Msp::Time::TimeDelta get_time_to_next_track() const; + Msp::Time::TimeDelta get_time_to_pass(Track &) const; bool is_occupying(Track &) const; bool check_arrival(); void advance(float); void advance(const Msp::Time::TimeDelta &); void advance_track(unsigned); + void set_path(unsigned); void update_estimate(); + bool is_viable() const; }; struct RoutingStep { Msp::Time::TimeDelta time; Msp::Time::TimeDelta cost_estimate; + bool preferred; std::vector trains; const RoutingStep *prev; @@ -101,6 +114,7 @@ private: RoutingStep(const RoutingStep *); void create_successors(std::list &) const; + static void create_successor(RoutingStep &, unsigned, unsigned, std::list &); bool update_states(); bool check_deadlocks() const; int get_occupant(Track &) const; @@ -129,6 +143,8 @@ private: std::list steps; std::list queue; const RoutingStep *goal; + Msp::Time::TimeDelta path_switch_bias; + Msp::Time::TimeDelta timeout; Result result; PlanningThread *thread; @@ -136,10 +152,11 @@ public: TrainRoutePlanner(Layout &); ~TrainRoutePlanner(); + void set_timeout(const Msp::Time::TimeDelta &); Result plan(); void plan_async(); Result check(); - Result get_result() { return result; } + Result get_result() const { return result; } const std::list &get_routes_for(const Train &) const; const std::list &get_sequence_for(const Train &) const; private: