Gibt es eine Möglichkeit, Turn-Einschränkungen in A * und Dijkstra hinzuzufügen?

11

Wir arbeiten derzeit mit pgRouting und haben festgestellt, dass es keine Möglichkeit gibt, Abbiegebeschränkungen zu implementieren (z. B. verbotene Rechts- oder Linkskurven). Während es möglich ist, "to_cost" und "rule" im Shooting * -Algorithmus zuzuweisen ... konnte ich keine Möglichkeit finden, diese Einschränkungen mithilfe von A-Star- und Dijktra-Algorithmen zu implementieren.

Gibt es eine Möglichkeit, spezielle Turn-Einschränkungen in A-Star- und Dijkstra-Methoden zu implementieren?

nka
quelle

Antworten:

3

Ja, wir haben gerade einen Turn Restricted Shortest Path (trsp) implementiert. Ich denke, es wurde in einen Git-Zweig bei origin / trsp eingecheckt. Es ist noch nicht dokumentiert. Wenn Sie Fragen haben oder Hilfe benötigen, stellen Sie diese auf der Pgrouting-Liste, denn hier treffe ich mich.

-Steve

Stephen Woodbridge
quelle
1

Suchst du das nach?

7.2. Restricted access

Another possibility is to restrict access to roads of a certain type by either setting a very high cost for road links with a certain attribute or by not selecting certain road links at all:

UPDATE classes SET cost=100000 WHERE name LIKE 'motorway%';

Through subqueries you can mix your costs as you like and this will change the results of your routing request immediately. Cost changes will affect the next shortest path search, and there is no need to rebuild your network.

Of course certain road classes can be excluded in the WHERE clause of the query as well, for example exclude living_street class:

SELECT * FROM shortest_path_shooting_star(
        'SELECT gid as id, class_id, source, target, length*c.cost as cost,
                x1, y1, x2, y2, rule, to_cost, reverse_cost*c.cost as reverse_cost
        FROM ways w, classes c
        WHERE class_id=c.id AND class_id != 111', 6585, 8247, true, true);

Of course pgRouting allows you all kind of SQL that is possible with PostgreSQL/PostGIS.

Es ist ein Fragment aus der Werkstatt.

Angelcervera
quelle