summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorfonsinchen <fonsinchen@openttd.org>2016-07-10 11:53:43 +0000
committerfonsinchen <fonsinchen@openttd.org>2016-07-10 11:53:43 +0000
commitbcdae9a093cf14a6eea0eab97d464f17688596ea (patch)
tree10c1c21447ffededbeaf6b22bf963c4c7b350de5 /src
parent14533f073b29801cc596379d3301f69aea07ee61 (diff)
downloadopenttd-bcdae9a093cf14a6eea0eab97d464f17688596ea.tar.xz
(svn r27611) -Codechange: Cache the calculated value of CapacityAnnotation
Diffstat (limited to 'src')
-rw-r--r--src/linkgraph/mcf.cpp19
1 files changed, 18 insertions, 1 deletions
diff --git a/src/linkgraph/mcf.cpp b/src/linkgraph/mcf.cpp
index 6fed7adea..10296575c 100644
--- a/src/linkgraph/mcf.cpp
+++ b/src/linkgraph/mcf.cpp
@@ -33,6 +33,11 @@ public:
inline uint GetAnnotation() const { return this->distance; }
/**
+ * Update the cached annotation value
+ */
+ inline void UpdateAnnotation() { }
+
+ /**
* Comparator for std containers.
*/
struct Comparator {
@@ -47,6 +52,8 @@ public:
* can only decrease or stay the same if you add more edges.
*/
class CapacityAnnotation : public Path {
+ int cached_annotation;
+
public:
/**
@@ -62,7 +69,15 @@ public:
* Return the actual value of the annotation, in this case the capacity.
* @return Capacity.
*/
- inline int GetAnnotation() const { return this->GetCapacityRatio(); }
+ inline int GetAnnotation() const { return this->cached_annotation; }
+
+ /**
+ * Update the cached annotation value
+ */
+ inline void UpdateAnnotation()
+ {
+ this->cached_annotation = this->GetCapacityRatio();
+ }
/**
* Comparator for std containers.
@@ -246,6 +261,7 @@ void MultiCommodityFlow::Dijkstra(NodeID source_node, PathVector &paths)
paths.resize(size, NULL);
for (NodeID node = 0; node < size; ++node) {
Tannotation *anno = new Tannotation(node, node == source_node);
+ anno->UpdateAnnotation();
annos.insert(anno);
paths[node] = anno;
}
@@ -270,6 +286,7 @@ void MultiCommodityFlow::Dijkstra(NodeID source_node, PathVector &paths)
if (dest->IsBetter(source, capacity, capacity - edge.Flow(), distance)) {
annos.erase(dest);
dest->Fork(source, capacity, capacity - edge.Flow(), distance);
+ dest->UpdateAnnotation();
annos.insert(dest);
}
}