X-Git-Url: http://git.tdb.fi/?p=r2c2.git;a=blobdiff_plain;f=source%2Flibr2c2%2Ftrainrouteplanner.h;h=3076c3978efa5ed0b27edae5cec7b4130e72afa7;hp=2ae7dc4ef6e502d6f27f263cb67c24a453321a8d;hb=528c4f8760ac54fb2d1f3002248ecf6774956030;hpb=055d7e80b68c8f77ebf226ffd48c37a7e504940c diff --git a/source/libr2c2/trainrouteplanner.h b/source/libr2c2/trainrouteplanner.h index 2ae7dc4..3076c39 100644 --- a/source/libr2c2/trainrouteplanner.h +++ b/source/libr2c2/trainrouteplanner.h @@ -3,8 +3,10 @@ #include #include +#include #include #include "trackiter.h" +#include "trainrouter.h" namespace R2C2 { @@ -12,10 +14,17 @@ class Layout; class Route; class Track; class Train; -class TrainRouter; class TrainRoutePlanner { +public: + enum Result + { + PENDING, + COMPLETE, + FAILED + }; + private: struct TrainRoutingState; @@ -23,9 +32,14 @@ private: { Train *train; float speed; + Block *first_noncritical; TrainRouter *router; - Route *route; - std::list waits; + std::vector waypoints; + std::vector metrics; + bool has_duration; + std::list routes; + Track *track_history[2]; + std::list sequence; TrainRoutingInfo(Train &); }; @@ -55,53 +69,97 @@ 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 distance_traveled; + float remaining_estimate; + Msp::Time::TimeDelta wait_time; + int blocked_by; TrainRoutingState(TrainRoutingInfo &); TrainRoutingState(const TrainRoutingState &); ~TrainRoutingState(); Msp::Time::TimeDelta get_time_to_next_track() const; - bool is_occupied(Track &) const; + bool is_occupying(Track &) const; + bool check_arrival(); void advance(float); + void advance(const Msp::Time::TimeDelta &); void advance_track(unsigned); + void update_estimate(); + bool is_viable() const; }; struct RoutingStep { Msp::Time::TimeDelta time; + Msp::Time::TimeDelta penalty; + Msp::Time::TimeDelta cost_estimate; std::vector trains; - RoutingStep *prev; + const RoutingStep *prev; RoutingStep(); - RoutingStep(RoutingStep *); - + 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; + int find_next_train() const; void advance(const Msp::Time::TimeDelta &); + void update_estimate(); + bool is_viable() const; bool is_goal() const; bool operator<(const RoutingStep &) const; }; + class PlanningThread: public Msp::Thread + { + private: + TrainRoutePlanner &planner; + + public: + PlanningThread(TrainRoutePlanner &); + + private: + virtual void main(); + }; + std::vector routed_trains; std::list steps; + std::list queue; + const RoutingStep *goal; + Msp::Time::TimeDelta timeout; + Result result; + PlanningThread *thread; public: TrainRoutePlanner(Layout &); - - void plan(); + ~TrainRoutePlanner(); + + void set_timeout(const Msp::Time::TimeDelta &); + Result plan(); + void plan_async(); + Result check(); + 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: - bool update_states(RoutingStep &); - int find_next_train(RoutingStep &); - void add_steps(RoutingStep &, unsigned); - void add_waiting_step(RoutingStep &, unsigned); - void add_steps(RoutingStep &, TrainRoutingState &train); - void create_routes(RoutingStep &); + const TrainRoutingInfo &get_train_info(const Train &) const; + const RoutingStep &get_step(); + void prepare_plan(); + void create_plan(); + void add_steps(const RoutingStep &); + void finalize_plan(); }; } // namespace R2C2