一覧に戻る

HERE-APIを使ってQGISでルートマッチングができるプラグインを開発しました

#Python#GIS#Here#QGIS#QiitaEngineerFesta2022

はじめに

GIS技術においては、GPS測定値をはじめとした一連の経緯度情報を、道路などに「フィットさせる」処理というものがあり、map matchingだとかroute matchingなどと呼ばれます。

最も単純には、ある点があったとしてその最近傍の地物に寄せるという処理になります。しかし下図のとおり、これだけでは「適切な経路」にはなり得ません。一連の点の順序や誤差を考慮したマッチングが必要です。

この問題に対応するには経路検索技術が必要です。調べると自前で経路検索サーバーを立てる方法が出てきたりしますが、これは一般のGISユーザーにとって(あるいは技術者であっても)容易ではありません。一方この処理は「一連の点を入力として、もっともらしい線分を返す処理」と言い換えることができ、これをWebAPIで提供しているサービスは複数あります。

今回、QGISプラグイン開発を得意とする弊社で、こういったサービスを用いてQGIS上でルートマッチングを実現するプラグインを開発しました。その際もちいるサービスは、経路検索に最も強いと思われる(後述)HEREのAPIを採用しました。本記事ではAPIの技術情報やプラグインの使い方を紹介します。

HEREのAPIについて

HEREは位置情報に関する一般的なAPI、たとえば背景地図配信・ジオコーディング・経路検索など…これら全てを取り揃えています。また、経路検索(Routing)という括りだけでも以下の5つのAPIが存在します(2022年7月現在、deprecatedの2つを除く)。

  • HERE Routing API v8 (経路検索)
  • HERE Isoline Routing API v8 (到達圏)
  • HERE Matrix Routing API v8 (多数の出発地・目的地からなる行列の経路検索)
  • HERE Route Matching v8
  • HERE Waypoints Sequence v8 (多数の地点に対し最適な訪問順を求める、巡回セールスマン問題)

種類だけでいえば、Mapboxも同等のAPI群を提供しています。しかしHEREの経路検索は、リアルタイムの信号の状況や、トラックが通行できるルートに限定した検索、はたまたEV(電気自動車)向けに充電状況を考慮するなど、極めて高機能といえます(なおMapboxもEV対応は進んでいる模様)。とりわけ運送業、いわゆるロジスティクス向けにフォーカスした機能が多いように見受けられます。

今回開発したプラグインにはHERE Route Matching v8との連携機能が実装されています。他のAPIもニーズがあったら追加していく方針です。

HERE Route API Plugin

https://github.com/MIERUNE/qgis-here-api-plugin

プラグインの使用には、事前にQGISをインストールしておく必要があります。3.x系であれば特にバージョンの指定などはありませんが、よっぽど古いと動作しないことがあり得ますので、直近のLTRを推奨します。

使い方

インストール

  1. プラグインの管理とインストールを開く
  2. 一覧からHERE Route API Pluginを選択し、インストール
  3. メニューバーの「プラグイン」にHERE Route API Pluginが追加されていることを確認

APIキーの設定

  1. HERE PlatformでAPIキーを発行
  2. メニューバーから「プラグイン」「HERE Route API Plugin」「Config」を開き、APIキーを入力し「OK」をクリック

Route Matching

本プラグインのルートマッチングは「任意の点レイヤーを入力とし、もっともらしい線分を線レイヤーとして出力」という処理を行います。したがって、何らかの点レイヤーが存在することを前提とします(なお地物数は1万未満とします)。以下の説明では上記の画像のポイントレイヤーを用います。また、APIが一度に受け取れるポイントの数が概ね400個程度なので、これを上回るレイヤーの場合はリクエストを分割します。具体的には、一度リクエストで400個ずつルートを計算し、すべての処理結果をひとつに結合します。メニューバーから「プラグイン」「HERE Route API Plugin」「Route Matching」を開きます。

  1. Layerで処理対象の点レイヤーを選択する
  2. Sort Fieldで順序を示す属性を選択する(オプション項目、空欄の場合はfid(地物の登録順)が用いられる)
  3. Modeで、車(car)バス(bus)自転車(bicycle)歩き(pedestrian)からいずれかを選択
  4. OKをクリックし処理を実行する
  5. 完了後、処理結果が表示される

ある程度の誤差を許容しながら、最もそれらしいルートが表示されていることがわかります。

おわりに

実はRoute Matching APIにはプラグインでは扱いきれていない非常に多くの計算パラメータが存在し、その中から汎用的な引数のみを採用しています。すべてを使いこなすのは難しいですが、それだけ高機能で多様なユースケースをサポートしていると言えます。今回のプラグインでカバーしているのはそのほんの一部ですが、ぜひ使ってみてください!