Поиск кратчайшего маршрута c помощью Road graph для QGIS: различия между версиями

Материал из GIS-Lab
Перейти к навигации Перейти к поиску
м (Чуть вверх первый скриншот)
(Уточнена версия QGIS, скриншоты по центру)
Строка 1: Строка 1:
Road graph — расширение QGIS, позволяющее осуществлять поиск кратчейшего маршрута на заданном графе дорог. Входит в состав QGIS, начиная с r15068 ([http://hub.qgis.org/projects/quantum-gis/repository/revisions/0a76ab4212ab5c5ef63c98f8a978034e2c0c42d2 0a76ab4212]), автор модуля — Сергей Якушев ([http://gis-lab.info/forum/memberlist.php?mode=viewprofile&u=7751 stopa85]).
Road graph — расширение QGIS, позволяющее осуществлять поиск кратчейшего маршрута на заданном графе дорог. Входит в состав QGIS, начиная с r15068 ([http://hub.qgis.org/projects/quantum-gis/repository/revisions/0a76ab4212ab5c5ef63c98f8a978034e2c0c42d2 0a76ab4212]), автор модуля — Сергей Якушев ([http://gis-lab.info/forum/memberlist.php?mode=viewprofile&u=7751 stopa85]).


[[Файл:roadgraph2.png|400px|thumb|center|<center>Внешний вид Road graph</center>]]
Активировав модуль и загрузив в QGIS линейный векторный слой можно легко найти путь от одной заданной точки к другой, оптимизировав его по расстоянию (самый короткий) или по времени (самый быстрый).
[[Файл:roadgraph2.png|700px|center|<center>QGIS c активированным Road graph. Загружены слои OSM на Тюменскую область, красным цветом отображается проложенный маршрут.</center>]]
 


=== Установка ===
=== Установка ===


[[Файл:roadgraph-01.png|thumb|Активация Road graph в Менеджере модулей]]
При использовании более-менее актуальной версии QGIS (>=1.6.0) никаких дополнительных действий по установке модуля выполнять не нужно, так как Road graph является расширением ядра QGIS. Достаточно установить QGIS со всеми зависимостями ([http://gis-lab.info/qa/qgis-osgeo4w.html подробнее]) и в Менеджере модулей («Модули — Управление модулями») активировать модуль Road graph.


При использовании более-менее актуальной версии QGIS никаких дополнительных действий по установке модуля выполнять не нужно, так как Road graph является расширением ядра QGIS. Достаточно установить QGIS со всеми зависимостями ([http://gis-lab.info/qa/qgis-osgeo4w.html подробнее]) и в Менеджере модулей («Модули — Управление модулями») активировать модуль Road graph.
[[Файл:roadgraph-01.png|center|<center>Активация Road graph в Менеджере модулей</center>]]


[[Файл:roadgraph-02.png|thumb|Панель модуля Road graph]]
После активации модуль добавляет свою панель в левой части окна QGIS и создает вложенный элемент в меню «Вектор».


После активации модуль добавляет свою панель в левой части окна QGIS и создает вложенный элемент в меню «Вектор».
[[Файл:roadgraph-02.png|center|<center>Панель модуля Road graph</center>]]


Исходный код модуля интегрирован в дерево исходных кодов QGIS, получить его можно из [https://github.com/qgis/Quantum-GIS основного репозитория].
Исходный код модуля интегрирован в дерево исходных кодов QGIS, получить его можно из [https://github.com/qgis/Quantum-GIS основного репозитория].
Строка 24: Строка 26:
В версиях QGIS 1.6, 1.7 присутствует возможность подсветки направления движения дорог (работает медленно, чаще всего используется в целях проверки настроек). В QGIS 1.8 и старше данная возможность удалена. Эффекта подсветки направления можно легко добиться настраивая стиль отображения слоя.
В версиях QGIS 1.6, 1.7 присутствует возможность подсветки направления движения дорог (работает медленно, чаще всего используется в целях проверки настроек). В QGIS 1.8 и старше данная возможность удалена. Эффекта подсветки направления можно легко добиться настраивая стиль отображения слоя.


[[Изображение:Road direction.png|thumb|QGIS c подсветкой направления дорог, реализованной при помощи стилей]]
[[Изображение:Road direction.png|center|700px|<center>QGIS c подсветкой направления дорог, реализованной при помощи стилей</center>]]


В качестве слоя дорог можно использовать любой линейный векторный слой в формате, поддерживаемом QGIS. Две линии, имеющие общую точку
В качестве слоя дорог можно использовать любой линейный векторный слой в формате, поддерживаемом QGIS. Две линии, имеющие общую точку
Строка 45: Строка 47:
Перед использованием рекомендуется выполнить настроку модуля. Для этого вызовите диалог настройки из меню «Вектор — Road graph — Параметры модуля Road graph».
Перед использованием рекомендуется выполнить настроку модуля. Для этого вызовите диалог настройки из меню «Вектор — Road graph — Параметры модуля Road graph».


[[Файл:roadgraph-03.png|thumb|Диалог настройки Road graph]]
[[Файл:roadgraph-03.png|center|<center>Диалог настройки Road graph</center>]]


Здесь задаются предпочитаемые единицы измерения времени и расстояния, топологический порог и настраивается распознавание характера движения по дорогам. Если первые два параметра не требуют дополнительных пояснений, то остальные мы рассмотрим подробнее.
Здесь задаются предпочитаемые единицы измерения времени и расстояния, топологический порог и настраивается распознавание характера движения по дорогам. Если первые два параметра не требуют дополнительных пояснений, то остальные мы рассмотрим подробнее.


[[Изображение:RoadGraph_without_TT.png|thumb|Поиск пути с нулевой топологической толерантностью (в слой дорог введен искусственный артефакт)]]
При использовании слоя дорог, в котором присутствуют артефакты в виде небольших разрывов между вершинами полилиний, необходимо установить «топологический порог». Топологический порог (или топологическая толерантность) — это расстояние между двумя соседними вершинами, при котором они интерпретируются как одна и та же вершина графа. Эта величина должна быть как можно меньше (чем меньше — тем лучше). Не стоит полагаться на параметр топологической толерантности как на панацею, лучше если Ваши данные будут приведены к «правильному» виду.
[[Изображение:RoadGraph_with_TT.png|thumb|Поиск пути с ненулевой (0.00005) топологической толерантностью (в слой дорог введен искусственный артефакт)]]
 
При использовании слоя дорог, в котором присутствуют артефакты в виде небольших разрывов между вершинами полилиний, необходимо установить «топологический порог». Топологический порог (или топологическая толерантность) — это расстояние между двумя соседними вершинами, при котором они интерпретируются как одна и та же вершина графа. Эта величина должна быть как можно меньше (чем меньше — тем лучше). Не стоит полагаться на параметр топологической толерантности как на панацею, лучше если Ваши данные будут приведены к "правильному" виду.
[[Изображение:RoadGraph_without_TT.png|center|700px|<center>Поиск пути с нулевой топологической толерантностью (в слой дорог введен искусственный артефакт)</center>]]
 
 
[[Изображение:RoadGraph_with_TT.png|center|700px|<center>Поиск пути с ненулевой (0.00005) топологической толерантностью (в слой дорог введен искусственный артефакт)</center>]]


Модуль может правильно обрабатывать дороги с разным характером движения: одностроннее или двустороннее. Для этого необходимо, чтобы в атрибутивной таблице слоя присутствовало поле с указанием типа дороги. Его нужно выбрать в выпадающем списке «Поле направления» с настройках модуля и задать значения для прямого, обратного и двустроннего движения. Под прямым направлением понимается движение в порядке создания точек линии, от первой точки к последней. Соответственно, обратное направление это движение от последней точки линии к первой. Эти два варианта задают односторонние дороги.
Модуль может правильно обрабатывать дороги с разным характером движения: одностроннее или двустороннее. Для этого необходимо, чтобы в атрибутивной таблице слоя присутствовало поле с указанием типа дороги. Его нужно выбрать в выпадающем списке «Поле направления» с настройках модуля и задать значения для прямого, обратного и двустроннего движения. Под прямым направлением понимается движение в порядке создания точек линии, от первой точки к последней. Соответственно, обратное направление это движение от последней точки линии к первой. Эти два варианта задают односторонние дороги.


Рассмотрим настройку на примере данных [http://gis-lab.info/projects/osm_shp.html OpenStreetMap]. В качестве поля направления выбираем "oneway", тогда двусторонней дороге будет соответствовать значение "no", прямому направлению односторонней дороги будет соответствовать значение "yes", a обратному — какое-либо другое значение, например "123". На вкладке «По умолчанию» для поля «Направление» выбираем «Двустороннее направление», чтобы дороги, не подпадающие под описанную выше схему трактовались как двусторонние. Все, теперь модуль будет различать дороги и строить маршруты с учетом характера движения по дорогам.
Рассмотрим настройку на примере данных [http://gis-lab.info/projects/osm_shp.html OpenStreetMap]. В качестве поля направления выбираем «oneway», тогда двусторонней дороге будет соответствовать значение «no», прямому направлению односторонней дороги будет соответствовать значение «yes», a обратному — какое-либо другое значение, например «123». На вкладке «По умолчанию» для поля «Направление» выбираем «Двустороннее направление», чтобы дороги, не подпадающие под описанную выше схему трактовались как двусторонние. Все, теперь модуль будет различать дороги и строить маршруты с учетом характера движения по дорогам.


Здесь же можно указать в каком поле находится информация о скорости движения по данному участку дороги. Если такое поле присутствует, то становится возможной оптимизация маршрута не только по рассточнию, но и по времени движения.
Здесь же можно указать в каком поле находится информация о скорости движения по данному участку дороги. Если такое поле присутствует, то становится возможной оптимизация маршрута не только по рассточнию, но и по времени движения.

Версия от 10:34, 11 января 2012

Road graph — расширение QGIS, позволяющее осуществлять поиск кратчейшего маршрута на заданном графе дорог. Входит в состав QGIS, начиная с r15068 (0a76ab4212), автор модуля — Сергей Якушев (stopa85).

Активировав модуль и загрузив в QGIS линейный векторный слой можно легко найти путь от одной заданной точки к другой, оптимизировав его по расстоянию (самый короткий) или по времени (самый быстрый).

QGIS c активированным Road graph. Загружены слои OSM на Тюменскую область, красным цветом отображается проложенный маршрут.


Установка

При использовании более-менее актуальной версии QGIS (>=1.6.0) никаких дополнительных действий по установке модуля выполнять не нужно, так как Road graph является расширением ядра QGIS. Достаточно установить QGIS со всеми зависимостями (подробнее) и в Менеджере модулей («Модули — Управление модулями») активировать модуль Road graph.

Активация Road graph в Менеджере модулей

После активации модуль добавляет свою панель в левой части окна QGIS и создает вложенный элемент в меню «Вектор».

Панель модуля Road graph

Исходный код модуля интегрирован в дерево исходных кодов QGIS, получить его можно из основного репозитория.

Работа с расширением

Основные возможности расширения:

  • расчет маршрута, его протяженности и времени пути
  • оптимизация по критерию расстояния или времени
  • экспорт маршрута в векторный слой

В версиях QGIS 1.6, 1.7 присутствует возможность подсветки направления движения дорог (работает медленно, чаще всего используется в целях проверки настроек). В QGIS 1.8 и старше данная возможность удалена. Эффекта подсветки направления можно легко добиться настраивая стиль отображения слоя.

QGIS c подсветкой направления дорог, реализованной при помощи стилей

В качестве слоя дорог можно использовать любой линейный векторный слой в формате, поддерживаемом QGIS. Две линии, имеющие общую точку считаются связанными между собой. ВНИМАНИЕ: при редактировании слоя дорог в качестве СК проекта необходимо использовать СК слоя. Это вызвано тем, что при пересчете координат между разными СК возникают погрешности, что может приводить к появлению разрывов даже при включенном «прилипании».

В атрибутивной таблице слоя могут присутствовать и задействоваться следующие поля:

  • скорость движения по участку дороги — числовое поле
  • направление движения — любой тип, приводимый к строке. Прямое и обратное направления соответствуют односторонней дороге, оба направления — двусторонней.

Если значение какого-либо поля не задано, или поле отсутствует — используется значение по умолчанию, изменить которое можно в настройках расширения.

Выбор начальной и конечной точек маршрута выполняется при помощи соответствующих кнопок возле полей ввода. Координаты выбранных точек будут отображены в полях ввода.

Нажатие на кнопку «Рассчитать» запустит поиск кратчайшего маршрута с использованием критерия оптимизации, заданного выпадающим списком «Критерий». Кнопка «Экспорт» служит для экспорта построенного маршрута в новый векторный слой, а при помощи кнопки «Очистить» выполняется очистка полей с координатами начальной и конечной точек, а также из области карты удаляются сами точки и построенный маршрут. Краткую справку по работе с модулем можно получить нажав кнопку «Справка».

Настройки модуля

Перед использованием рекомендуется выполнить настроку модуля. Для этого вызовите диалог настройки из меню «Вектор — Road graph — Параметры модуля Road graph».

Диалог настройки Road graph

Здесь задаются предпочитаемые единицы измерения времени и расстояния, топологический порог и настраивается распознавание характера движения по дорогам. Если первые два параметра не требуют дополнительных пояснений, то остальные мы рассмотрим подробнее.

При использовании слоя дорог, в котором присутствуют артефакты в виде небольших разрывов между вершинами полилиний, необходимо установить «топологический порог». Топологический порог (или топологическая толерантность) — это расстояние между двумя соседними вершинами, при котором они интерпретируются как одна и та же вершина графа. Эта величина должна быть как можно меньше (чем меньше — тем лучше). Не стоит полагаться на параметр топологической толерантности как на панацею, лучше если Ваши данные будут приведены к «правильному» виду.

Поиск пути с нулевой топологической толерантностью (в слой дорог введен искусственный артефакт)


Поиск пути с ненулевой (0.00005) топологической толерантностью (в слой дорог введен искусственный артефакт)

Модуль может правильно обрабатывать дороги с разным характером движения: одностроннее или двустороннее. Для этого необходимо, чтобы в атрибутивной таблице слоя присутствовало поле с указанием типа дороги. Его нужно выбрать в выпадающем списке «Поле направления» с настройках модуля и задать значения для прямого, обратного и двустроннего движения. Под прямым направлением понимается движение в порядке создания точек линии, от первой точки к последней. Соответственно, обратное направление это движение от последней точки линии к первой. Эти два варианта задают односторонние дороги.

Рассмотрим настройку на примере данных OpenStreetMap. В качестве поля направления выбираем «oneway», тогда двусторонней дороге будет соответствовать значение «no», прямому направлению односторонней дороги будет соответствовать значение «yes», a обратному — какое-либо другое значение, например «123». На вкладке «По умолчанию» для поля «Направление» выбираем «Двустороннее направление», чтобы дороги, не подпадающие под описанную выше схему трактовались как двусторонние. Все, теперь модуль будет различать дороги и строить маршруты с учетом характера движения по дорогам.

Здесь же можно указать в каком поле находится информация о скорости движения по данному участку дороги. Если такое поле присутствует, то становится возможной оптимизация маршрута не только по рассточнию, но и по времени движения.

На вкладке «По умолчанию» задаются значения параметров по умолчанию, которые будут использоваться, если модуль не сможет извлечь информацию из указанных полей или если эти поля отсутствуют.

Библиотека QGIS network-analysis

В настоящее время, в экспериментальных версиях QGIS базовый функционал плагина вынесен в отдельную библиотеку network-analysis, что делает возможным использование алгоритмов сетевого анализа реализованных в модуле из Консоли Python QGIS, а также в своих расширениях.