OpenTTD
|
Class for calculation jobs to be run on link graphs. More...
#include <linkgraphjob.h>
Data Structures | |
class | Edge |
A job edge. More... | |
struct | EdgeAnnotation |
Annotation for a link graph edge. More... | |
class | EdgeIterator |
Iterator for job edges. More... | |
class | Node |
Link graph job node. More... | |
struct | NodeAnnotation |
Annotation for a link graph node. More... |
Public Member Functions | |
LinkGraphJob () | |
Bare constructor, only for save/load. | |
LinkGraphJob (const LinkGraph &orig) | |
Create a link graph job from a link graph. | |
~LinkGraphJob () | |
Join the link graph job and destroy it. | |
void | Init () |
Initialize the link graph job: Resize nodes and edges and populate them. | |
bool | IsFinished () const |
Check if job is supposed to be finished. | |
Date | JoinDate () const |
Get the date when the job should be finished. | |
void | ShiftJoinDate (int interval) |
Change the join date on date cheating. | |
const LinkGraphSettings & | Settings () const |
Get the link graph settings for this component. | |
Node | operator[] (NodeID num) |
Get a node abstraction with the specified id. | |
uint | Size () const |
Get the size of the underlying link graph. | |
CargoID | Cargo () const |
Get the cargo of the underlying link graph. | |
Date | LastCompression () const |
Get the date when the underlying link graph was last compressed. | |
LinkGraphID | LinkGraphIndex () const |
Get the ID of the underlying link graph. | |
const LinkGraph & | Graph () const |
Get a reference to the underlying link graph. | |
![]() | |
void * | operator new (size_t size) |
Allocates space for new Titem. | |
void * | operator new (size_t size, size_t index) |
Allocates space for new Titem with given index. | |
void * | operator new (size_t size, void *ptr) |
Allocates space for new Titem at given memory address. | |
void | operator delete (void *p) |
Marks Titem as free. |
Protected Member Functions | |
void | EraseFlows (NodeID from) |
Erase all flows originating at a specific node. | |
void | JoinThread () |
Join the calling thread with this job's thread if threading is enabled. | |
void | SpawnThread () |
Spawn a thread if possible and run the link graph job in the thread. |
Protected Attributes | |
const LinkGraph | link_graph |
Link graph to by analyzed. Is copied when job is started and mustn't be modified later. | |
const LinkGraphSettings | settings |
Copy of _settings_game.linkgraph at spawn time. | |
ThreadObject * | thread |
Thread the job is running in or NULL if it's running in the main thread. | |
Date | join_date |
Date when the job is to be joined. | |
NodeAnnotationVector | nodes |
Extra node data necessary for link graph calculation. | |
EdgeAnnotationMatrix | edges |
Extra edge data necessary for link graph calculation. |
Private Types | |
typedef SmallVector < NodeAnnotation, 16 > | NodeAnnotationVector |
typedef SmallMatrix < EdgeAnnotation > | EdgeAnnotationMatrix |
Friends | |
class | LinkGraphSchedule |
const SaveLoad * | GetLinkGraphJobDesc () |
Get a SaveLoad array for a link graph job. |
Additional Inherited Members | |
![]() | |
static bool | CanAllocateItem (size_t n=1) |
Helper functions so we can use PoolItem::Function() instead of _poolitem_pool.Function() | |
static bool | CleaningPool () |
Returns current state of pool cleaning - yes or no. | |
static bool | IsValidID (size_t index) |
Tests whether given index can be used to get valid (non-NULL) Titem. | |
static Titem * | Get (size_t index) |
Returns Titem with given index. | |
static Titem * | GetIfValid (size_t index) |
Returns Titem with given index. | |
static size_t | GetPoolSize () |
Returns first unused index. | |
static size_t | GetNumItems () |
Returns number of valid items in the pool. | |
static void | PostDestructor (size_t index) |
Dummy function called after destructor of each member. | |
![]() | |
Tindex | index |
Index of this pool item. |
Class for calculation jobs to be run on link graphs.
Definition at line 31 of file linkgraphjob.h.
|
inline |
Bare constructor, only for save/load.
link_graph, join_date and actually settings have to be brutally const-casted in order to populate them.
Definition at line 269 of file linkgraphjob.h.
LinkGraphJob::LinkGraphJob | ( | const LinkGraph & | orig | ) |
Create a link graph job from a link graph.
The link graph will be copied so that the calculations don't interfer with the normal operations on the original. The job is immediately started.
orig | Original LinkGraph to be copied. |
Definition at line 37 of file linkgraphjob.cpp.
|
inline |
Get the cargo of the underlying link graph.
Definition at line 318 of file linkgraphjob.h.
References LinkGraph::Cargo(), and link_graph.
Referenced by DemandCalculator::DemandCalculator(), and ~LinkGraphJob().
|
protected |
Erase all flows originating at a specific node.
from | Node to erase flows for. |
Definition at line 51 of file linkgraphjob.cpp.
References Size().
Referenced by ~LinkGraphJob().
|
inline |
Get a reference to the underlying link graph.
Only use this for save/load.
Definition at line 336 of file linkgraphjob.h.
References link_graph.
Referenced by AfterLoadLinkGraphs(), DoSave_LGRJ(), and Load_LGRJ().
void LinkGraphJob::Init | ( | ) |
Initialize the link graph job: Resize nodes and edges and populate them.
This is done after the constructor so that we can do it in the calculation thread without delaying the main game.
Definition at line 179 of file linkgraphjob.cpp.
References edges, LinkGraphJob::EdgeAnnotation::Init(), link_graph, nodes, SmallVector< T, S >::Resize(), SmallMatrix< T >::Resize(), and Size().
Referenced by InitHandler::Run().
|
inline |
Check if job is supposed to be finished.
Definition at line 281 of file linkgraphjob.h.
References _date, and join_date.
Referenced by LinkGraphSchedule::JoinNext().
|
inline |
Get the date when the job should be finished.
Definition at line 287 of file linkgraphjob.h.
References join_date.
Referenced by FlowMapper::Run().
|
inline |
Get the date when the underlying link graph was last compressed.
Definition at line 324 of file linkgraphjob.h.
References LinkGraph::LastCompression(), and link_graph.
Referenced by FlowMapper::Run().
|
inline |
Get the ID of the underlying link graph.
Definition at line 330 of file linkgraphjob.h.
References Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, and link_graph.
Referenced by LinkGraphSchedule::JoinNext().
|
inline |
Get a node abstraction with the specified id.
num | ID of the node. |
Definition at line 306 of file linkgraphjob.h.
|
inline |
Get the link graph settings for this component.
Definition at line 299 of file linkgraphjob.h.
References settings.
Referenced by DemandCalculator::DemandCalculator(), MCF1stPass::MCF1stPass(), MCF2ndPass::MCF2ndPass(), and FlowMapper::Run().
|
inline |
Change the join date on date cheating.
interval | Number of days to add. |
Definition at line 293 of file linkgraphjob.h.
References join_date.
Referenced by LinkGraphSchedule::ShiftDates().
|
inline |
Get the size of the underlying link graph.
Definition at line 312 of file linkgraphjob.h.
References link_graph, and LinkGraph::Size().
Referenced by DemandCalculator::CalcDemand(), MultiCommodityFlow::Dijkstra(), DoSave_LGRJ(), MCF1stPass::EliminateCycles(), EraseFlows(), FlowEdgeIterator::FlowEdgeIterator(), Init(), MCF1stPass::MCF1stPass(), MCF2ndPass::MCF2ndPass(), FlowMapper::Run(), and ~LinkGraphJob().
|
protected |
Spawn a thread if possible and run the link graph job in the thread.
If that's not possible run the job right now in the current thread.
Definition at line 62 of file linkgraphjob.cpp.
References ThreadObject::New(), LinkGraphSchedule::Run(), and thread.
Referenced by LinkGraphSchedule::SpawnNext().
|
friend |
Get a SaveLoad array for a link graph job.
The settings struct is derived from the global settings saveload array. The exact entries are calculated when the function is called the first time. It's necessary to keep a copy of the settings for each link graph job so that you can change the settings while in-game and still not mess with current link graph runs. Of course the settings have to be saved and loaded, too, to avoid desyncs.
Definition at line 52 of file linkgraph_sl.cpp.