Помогите выбрать подходящий движок маршрутизации


16

Я строю систему планирования маршрута, но мне еще предстоит решить, какой базовый механизм маршрутизации я буду использовать. До сих пор я нашел pgrouting и neo4j.

У меня есть сеть маршрутов в базе данных postgresql / postgis (импортирована из шейп-файла). Я сделал запросы, чтобы извлечь узлы (конечные точки, где вы должны принять решение, в каком направлении идти или тупики) и извлечь края (часто составленные несколькими последовательными способами). Все мои ребра двунаправлены.

Моя главная цель - рассчитать маршруты в этой сети, используя алгоритм A-star, где расстояние = стоимость.

Мои ощущения подсказывают мне, что база данных графов, такая как neo4j, является подходящим способом (как кажется, она создана именно для этой цели), но они, по-видимому, не поддерживают A-star по умолчанию, а также не имеют реального смысла геометрии. , Кажется, лучше подходит для социальных сетей вместо карт.

  • Будет ли pgrouting удовлетворить мои потребности?
  • Это достаточно быстро для запросов на лету (+ -2000 узлов, + -4000 ребер)? Обычно это будет несколько мс для A-star, но я не уверен насчет реализации в sql.
  • Дает ли pgrouting A-star список узлов и ребер?
  • В большинстве примеров, которые я вижу о pgrouting, я замечаю, что обычно есть список команд после расчета маршрута (например, «При повороте влево и т. Д.»). Производит ли pgrouting это или это из другой системы?

Надеюсь, кто-нибудь может дать мне некоторую информацию о том, какую систему выбрать. Neo4j, pgrouting или какая-то другая система.


3
Я думаю, что большинство алгоритмов маршрутизации не работают с «чувством геометрии», вместо этого геометрический атрибут вычисляется и используется как стоимость (то есть мера расстояния полилинии). Я никогда не использовал Neo4j, но он выглядит действительно способным, и я, возможно, скоро его использую. Я только что взглянул на документацию, и кажется возможным использовать A-Star: docs.neo4j.org/chunked/stable/graph-algo.html docs.neo4j.org/chunked/stable/… pgRouting также способен, и Я большой поклонник этого. Было бы интересно сравнить производительность этих двух решений.
Аллан Адэйр

Во-первых, я бы предложил взглянуть на urbansim модель использования земли с открытым исходным кодом. Что касается вашего вопроса маршрутизации: если это приложение планирования, то я бы посоветовал сначала взглянуть на программное обеспечение, такое как TransCAD, CUBE, PLANAR или EMME / 2, для функциональности и пользовательского интерфейса. Они обычно выдают 1 или 2 часа демонстрации своего программного обеспечения (программное обеспечение, которое вы можете запустить в течение часа или двух, чтобы почувствовать его). Если вы хотите создать что-то для использования в Интернете или для настольного компьютера, посмотрите на pgRouting; однако, исходя из опыта, иногда это не так просто, как на семинаре / учебнике.
Дассуки

Я получил pgrouting с звездой, работающей, и это здорово! Он отвечает да на мои первые 3 вопроса. Тем не менее, мне интересно, знает ли кто-нибудь здесь о создании подробных навигационных указаний. Существует ли какой-либо инструмент, который взаимодействует с pgrouting, который генерирует подробные указания («после 200 м поворота налево и т. Д.») Из вывода рассчитанного маршрута?
MRG

Ответы:


8

В настоящее время я изучаю ту же проблему, что и вы, с целью исследования. До того, как я начал тестировать эти две базы данных, у меня была такая же презумпция, как и у вас. Эта графическая база данных Neo4j была бы идеальным решением для такого рода проблем. И отчасти это так, но с множеством проблем.

Первая проблема заключается в том, что A-Star реализуется, только если вы используете встроенную базу данных, а не через REST API (сервер). Если вы хотите использовать Neo4j с REST API, то поддерживается только алгоритм Dijkstra. Вторая проблема - требования к аппаратной памяти для Neo4j. Для маршрутизации (Dijkstra) в «больших» сетях вам нужно много оперативной памяти. Для большой сети я имею в виду размер дорожной базы данных OSM в Германии . Я выполнил свои тесты на сервере ОЗУ 6 ГБ (это все, что у меня есть в настоящее время), и только небольшие сети могли маршрутизироваться без ошибок исключения OutOfMemory. «Маленькие» сети в моих тестовых случаях - это, например, дорожная база данных OSM для Австрии или Хорватии. Параллельные запросы, которые я до сих пор не проверял с Neo4j.

Все эти проблемы не существуют в pgRouting. Память не такая проблема, но параллельные запросы увеличивают необходимый объем памяти. Например, если у вас есть два одновременных запроса, необходим двойной объем памяти. Это не было проблемой даже для немецкого набора данных OSM, pgRouting без проблем маршрутизировал все одновременные запросы.

Производительность: в большинстве случаев Neo4j превосходит pgRouting. Но только если достаточно памяти для данного набора данных и если все узлы и отношения находятся в памяти (горячий старт). Увеличение / уменьшение производительности зависит от множества факторов, но в основном от размера сети и расстояния (прыжков) между исходным и целевым узлом.

Размер вашей сети довольно мал, поэтому у вас не должно быть проблем с памятью. Вероятно, Neo4j - неплохой выбор, но вам нужно адаптироваться к «немного» другой модели данных, чем в стандартных реляционных базах данных.

Чтобы ответить на ваши вопросы:

  • В pgRouting вам не нужно беспокоиться о реализации AStar в sql, которая уже реализована.
  • Да, pgRouting может дать вам список узлов и ребер
  • Я не думаю, что pgRouting может дать вам такую ​​информацию без какой-либо специальной работы с запросами. Но, возможно, я ошибаюсь, может, кто-то сделал это и может помочь вам больше об этом вопросе.

Я не знаю, поможет ли это вам напрямую, но одним из самых быстрых серверов маршрутизации, который я нашел, является osm2po . Он работает с набором данных OSM и работает довольно быстро. В настоящее время внедряется только dijkstra, но разработчик также объявил AStar. Я надеюсь, что это поможет вам. :)


Приятно слышать от кого-то, кто действительно протестировал обе системы. Между тем, у меня гораздо больше опыта работы с pgrouting. Я заметил, что pgrouting строит весь график для каждого запроса, и это делает его довольно медленным для больших сетей (размер Германии), поэтому я не понимаю, почему pgrouting потребует меньше памяти, чем Neo4j. Моя следующая попытка будет заключаться в том, чтобы получить весь статический граф в ram и маршрутизировать по нему (с помощью neo4j, nx_spatial и т. Д.), Чтобы обеспечить более быструю реакцию для маршрутизации в реальном времени.
MRG

Да, чем больше график, тем больше различие между pgrouting и neo4j. Вероятно, если вы поместите весь график в память, то это будет самое быстрое решение, без сомнений. Neo4j довольно быстрый, когда весь график загружен в память. Не знаю насчет nx_spatial, я не проверял его, но, может быть, узнаю. Я считаю, что он может выиграть даже у Neo4j. Но это решение хорошо, если оно приемлемо для вашего приложения.
Марио Милер

1
@mrg не уверен, что это все еще проблема для вас, но есть OSRM (C ++) и GraphHopper (Java). Оба масштабируются до глобальных графиков, и, например, для GraphHopper требуется меньше 1 ГБ для Германии (где я являюсь автором)
Karussell

Карусселл, спасибо за информацию! Я уже нашел OSRM, но GraphHopper является новым для меня.
mrg

0

Вы также можете ознакомиться с нашим пакетом RW Net 4 (www.routeware.dk). Он может выполнять такие вычисления кратчайшего пути, используя A * прямо из файла SHP. Базовый пакет на 500 евро кажется достаточным для ваших нужд.


Спасибо за ваш быстрый ответ, но мой проект все еще находится в фазе, в которой я не уверен, стоит ли тратить деньги прямо сейчас. Также я получил pgrouting, работающий с моими данными, так что пока неизвестно, что было решено.
MRG
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.