Apakah ada cara untuk menambahkan batasan belokan di A * dan Dijkstra?


11

Kami saat ini bekerja dengan pgRouting dan menemukan bahwa tidak ada cara menerapkan pembatasan belokan (misalnya belokan kanan atau kiri yang diblokir). Meskipun dimungkinkan untuk menetapkan "to_cost" dan "rule" dalam algoritma Shooting * ... Saya tidak dapat menemukan cara untuk menerapkan pembatasan ini menggunakan algoritme bintang A dan Dijktra.

Apakah ada cara menerapkan pembatasan belokan khusus dalam metode Bintang dan Dijkstra?

Jawaban:


3

Ya, kami baru saja mengimplementasikan lintasan terpendek putaran terbatas (trsp). Saya pikir itu sudah diperiksa ke cabang git di origin / trsp. Itu belum didokumentasikan. Jika Anda memiliki pertanyaan atau butuh bantuan, tanyakan pada daftar pgrouting, karena di situlah saya hangout.

-Steve


1

Apakah Anda mencari ini?

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.

Ini bagian dari bengkel.

Dengan menggunakan situs kami, Anda mengakui telah membaca dan memahami Kebijakan Cookie dan Kebijakan Privasi kami.
Licensed under cc by-sa 3.0 with attribution required.