JP6129253B2 - 経路探索加速データとともに地図データを用いるナビゲーション装置 - Google Patents

経路探索加速データとともに地図データを用いるナビゲーション装置 Download PDF

Info

Publication number
JP6129253B2
JP6129253B2 JP2015160686A JP2015160686A JP6129253B2 JP 6129253 B2 JP6129253 B2 JP 6129253B2 JP 2015160686 A JP2015160686 A JP 2015160686A JP 2015160686 A JP2015160686 A JP 2015160686A JP 6129253 B2 JP6129253 B2 JP 6129253B2
Authority
JP
Japan
Prior art keywords
bit
navigable
level
region
bits
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
JP2015160686A
Other languages
English (en)
Other versions
JP2016020915A (ja
Inventor
ヘイコ シリング,
ヘイコ シリング,
ユージェニー ゴーリロー,
ユージェニー ゴーリロー,
モリッツ ヒルガー,
モリッツ ヒルガー,
アンドレアス プロフォス,
アンドレアス プロフォス,
ユルゲン ウェルバー,
ユルゲン ウェルバー,
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
TomTom Navigation BV
Original Assignee
TomTom Navigation BV
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by TomTom Navigation BV filed Critical TomTom Navigation BV
Publication of JP2016020915A publication Critical patent/JP2016020915A/ja
Application granted granted Critical
Publication of JP6129253B2 publication Critical patent/JP6129253B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G01MEASURING; TESTING
    • G01CMEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
    • G01C21/00Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00
    • G01C21/26Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00 specially adapted for navigation in a road network
    • G01C21/34Route searching; Route guidance
    • G01C21/3453Special cost functions, i.e. other than distance or default speed limit of road segments
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01CMEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
    • G01C21/00Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00
    • G01C21/26Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00 specially adapted for navigation in a road network
    • G01C21/34Route searching; Route guidance
    • G01C21/3446Details of route searching algorithms, e.g. Dijkstra, A*, arc-flags, using precalculated routes
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01CMEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
    • G01C21/00Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00
    • G01C21/26Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00 specially adapted for navigation in a road network
    • G01C21/34Route searching; Route guidance
    • G01C21/3453Special cost functions, i.e. other than distance or default speed limit of road segments
    • G01C21/3492Special cost functions, i.e. other than distance or default speed limit of road segments employing speed data or traffic data, e.g. real-time or historical
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01CMEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
    • G01C21/00Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00
    • G01C21/26Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00 specially adapted for navigation in a road network
    • G01C21/34Route searching; Route guidance
    • G01C21/36Input/output arrangements for on-board computers
    • G01C21/3664Details of the user input interface, e.g. buttons, knobs or sliders, including those provided on a touch screen; remote controllers; input using gestures
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01CMEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
    • G01C21/00Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00
    • G01C21/26Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00 specially adapted for navigation in a road network
    • G01C21/34Route searching; Route guidance
    • G01C21/36Input/output arrangements for on-board computers
    • G01C21/3667Display of a road map
    • G01C21/367Details, e.g. road map scale, orientation, zooming, illumination, level of detail, scrolling of road map or positioning of current position marker
    • GPHYSICS
    • G08SIGNALLING
    • G08GTRAFFIC CONTROL SYSTEMS
    • G08G1/00Traffic control systems for road vehicles
    • G08G1/09Arrangements for giving variable traffic instructions
    • G08G1/0962Arrangements for giving variable traffic instructions having an indicator mounted inside the vehicle, e.g. giving voice messages
    • G08G1/0968Systems involving transmission of navigation instructions to the vehicle
    • G08G1/096805Systems involving transmission of navigation instructions to the vehicle where the transmitted instructions are used to compute a route
    • G08G1/096827Systems involving transmission of navigation instructions to the vehicle where the transmitted instructions are used to compute a route where the route is computed onboard
    • GPHYSICS
    • G08SIGNALLING
    • G08GTRAFFIC CONTROL SYSTEMS
    • G08G1/00Traffic control systems for road vehicles
    • G08G1/09Arrangements for giving variable traffic instructions
    • G08G1/0962Arrangements for giving variable traffic instructions having an indicator mounted inside the vehicle, e.g. giving voice messages
    • G08G1/0968Systems involving transmission of navigation instructions to the vehicle
    • G08G1/096833Systems involving transmission of navigation instructions to the vehicle where different aspects are considered when computing the route
    • G08G1/09685Systems involving transmission of navigation instructions to the vehicle where different aspects are considered when computing the route where the complete route is computed only once and not updated
    • GPHYSICS
    • G08SIGNALLING
    • G08GTRAFFIC CONTROL SYSTEMS
    • G08G1/00Traffic control systems for road vehicles
    • G08G1/09Arrangements for giving variable traffic instructions
    • G08G1/0962Arrangements for giving variable traffic instructions having an indicator mounted inside the vehicle, e.g. giving voice messages
    • G08G1/0968Systems involving transmission of navigation instructions to the vehicle
    • G08G1/096855Systems involving transmission of navigation instructions to the vehicle where the output is provided in a suitable form to the driver
    • G08G1/096866Systems involving transmission of navigation instructions to the vehicle where the output is provided in a suitable form to the driver where the complete route is shown to the driver
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M7/00Conversion of a code where information is represented by a given sequence or number of digits to a code where the same, similar or subset of information is represented by a different sequence or number of digits
    • H03M7/30Compression; Expansion; Suppression of unnecessary data, e.g. redundancy reduction
    • H03M7/40Conversion to or from variable length codes, e.g. Shannon-Fano code, Huffman code, Morse code
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M7/00Conversion of a code where information is represented by a given sequence or number of digits to a code where the same, similar or subset of information is represented by a different sequence or number of digits
    • H03M7/30Compression; Expansion; Suppression of unnecessary data, e.g. redundancy reduction
    • H03M7/70Type of the data to be coded, other than image and sound
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M7/00Conversion of a code where information is represented by a given sequence or number of digits to a code where the same, similar or subset of information is represented by a different sequence or number of digits
    • H03M7/30Compression; Expansion; Suppression of unnecessary data, e.g. redundancy reduction
    • H03M7/70Type of the data to be coded, other than image and sound
    • H03M7/705Unicode
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M7/00Conversion of a code where information is represented by a given sequence or number of digits to a code where the same, similar or subset of information is represented by a different sequence or number of digits
    • H03M7/30Compression; Expansion; Suppression of unnecessary data, e.g. redundancy reduction
    • H03M7/3068Precoding preceding compression, e.g. Burrows-Wheeler transformation
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M7/00Conversion of a code where information is represented by a given sequence or number of digits to a code where the same, similar or subset of information is represented by a different sequence or number of digits
    • H03M7/30Compression; Expansion; Suppression of unnecessary data, e.g. redundancy reduction
    • H03M7/40Conversion to or from variable length codes, e.g. Shannon-Fano code, Huffman code, Morse code
    • H03M7/4031Fixed length to variable length coding
    • H03M7/4037Prefix coding
    • H03M7/4043Adaptive prefix coding

Landscapes

  • Engineering & Computer Science (AREA)
  • Radar, Positioning & Navigation (AREA)
  • Remote Sensing (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Automation & Control Theory (AREA)
  • Theoretical Computer Science (AREA)
  • Mathematical Physics (AREA)
  • Human Computer Interaction (AREA)
  • Navigation (AREA)
  • Traffic Control Systems (AREA)
  • Instructional Devices (AREA)

Description

本発明は、地図データを生成するコンピュータを使用した方法及び関連するシステムに関するものである。特に、地図データを生成する方法は、所定のコスト関数に従って少なくとも2つの地点間の経路計画を容易にするために使用されるが、これに限定されない。本発明の実施形態は、経路計画で使用される時に経路を生成するのにかかる時間を短縮する探索加速データを生成する。
http://routes.tomtom.com/等のワールドワイドウェブ(WWW)でアクセス可能なウェブサイトと共に経路計画装置(衛星ナビゲーション又はポータブルナビゲーション装置(PND)等と呼ばれることが多い。)は既知であり、ユーザが2地点間の経路を計画することを可能にする。そのような技術は、一般に電子経路計画又は単に経路計画と呼ばれてもよい。
そのような電子経路計画のための地図データは、Tele Atlas NV等の地図専門メーカから得られる。そのような経路計画は、PNDで実行される場合、一般にGPSシステムからの場所データを使用する。しかし、他の応用例は、ユーザが経路計画の目的で自身の場所又は考慮される他の地点を入力することを可能にしてもよい。
そのような地図データは、線、すなわちベクトル又は道路区分(例えば、道路の始点、終点、方向であり、道路全体は、それぞれが始点/終点方向パラメータにより一意に規定される数百もの区分から構成される)として記述される複数の道路(及び他のナビゲート可能なパスを含む。地図は、そのような道路ベクトル、各ベクトルと関連付けられたデータ(制限速度、移動方向等)+地点情報(POI)+道路名+公園の境界や川の境界等の他の地理的特徴の集合であり、それらは全てベクトルに関して規定される。全ての地図の特徴(例えば、道路ベクトル、POI等)は、一般にGPS座標系に対応するか又は関連する座標系で規定され、GPSシステムを介して判定される装置の位置を地図に示された関連道路に配置することを可能にし、目的地までの最適な経路の計画を可能にする。
そのような地図データは広範囲にわたる可能性がある。地図が120,000,000個以上のベクトルを有するエリアを範囲に含むことが既知であり、そのような地図データの一例はヨーロッパ及びロシアのエリアを範囲に含む地図である。従って、そのような地図データを使用して経路を計画することは、複雑であり且つ時間もかかる。また、そのような経路計画は精度と時間との間にはトレードオフの関係があることが既知である。
経路指定が行われる速度を向上する時の概念を考慮した従来技術は特許文献1を含み、これは、西ヨーロッパの幹線道路ネットワーク(約400,000個のベクトルを有する)等の非常に小さい地図のサイズに適したA*最良優先探索戦略に対する改善点について説明している。
米国特許第6,636,800号明細書
本発明の第1の態様によると、それぞれが電子地図によってカバーされるエリアにおいてナビゲート可能な経路の区分を表す複数のナビゲート可能区分を含む電子地図にわたり経路を計画する際の速度を向上するように構成された探索加速データを含む地図データを作成する方法であって、
a)ナビゲート可能区分のコアネットワークを形成するナビゲート可能区分を除去することにより探索加速データの作成時に考慮されるナビゲート可能区分の数を減少するステップと、
b)各ナビゲート可能区分が階層の各レベルの少なくとも1つの領域に分類されるように電子地図を複数の階層領域の集合に分割するステップと、
c)ナビゲート可能区分が複数の領域の少なくとも1つまでの最小コストの経路の一部であるかを判定するためにコアネットワークの少なくともいくつかのナビゲート可能区分、一般には各ナビゲート可能区分と関連付けられた時変関数を使用し且つ当該判定を探索加速データに記録するステップと、
d)地図データを生成するステップと、
を備える方法が提供される。
そのような方法は、探索加速データが従来の方法より速く算出されるのを可能にするため有利であると考えられる。従って、探索加速データは、その地図データを使用する経路計画がより速く実行されるのを可能にするため有利であると考えられる。
一般に、探索加速データは複数のビットベクトルとして算出される。本発明のいくつかの実施形態は、探索加速データのビットを介して、道路区分が起点ナビゲート可能区分から行先領域までの最小コストの経路の一部であるかを算出し、示してもよい。
一般に地図データ内の各ナビゲート可能区分又はノードが時変関数と関連付けられていることは、当業者には理解されるだろう。例えば時変関数は、異なる時間間隔でのナビゲート可能区分における平均速度を含んでもよい。例えば平均速度は、5分間隔等で指定されてもよい。
コアネットワークは、探索加速データが後で回復可能なナビゲート可能区分を除去することにより生成される。そのような方法は、探索加速データが電子地図内のほぼ全てのナビゲート可能区分に対して判定されるのを可能にし、それにより地図内のいずれのナビゲート可能区分からの経路計画も加速されるため有利である。
本発明のいくつかの実施形態は、探索加速データの作成前に電子地図からナビゲート可能区分を除去するために以下の技術のうちのいずれか1つ以上を利用してもよい。
・道路プロパティに関連する所定の基準を満たすこと。
・ある所定の基準に従って十分に小さく且つ更なる所定の基準を満たすナビゲート可能区分の集合を除去することによりネットワークの残りの部分から切断されるネットワークの部分を形成するナビゲート可能区分をネットワークから除去すること。
・所定の状況においてナビゲート可能区分の間の分岐点に存在するノードを他方のノードにまとめること。
・ノードが2つ以下のナビゲート可能区分を接続させる場合にそれらノードを他方のノードにまとめること。
そのような技術は、探索加速データの生成中に考慮される必要があるナビゲート可能区分の数を減少させ、それにより探索加速データを作成する際の速度が可能性として非常に向上されるため有利であると考えられる。
更に又はあるいは、本発明の実施形態は、探索加速データが作成された後に探索加速データを圧縮する以下の技術のうちのいずれか1つ以上を利用してもよい。
・探索加速データ中のビット対の相関性を計算する。
・可逆的に符号化するビット数を減少するために探索加速データ中のほぼ相関されたビットを結合させる。
・不可逆的圧縮を実行するために探索加速データ中の相関されたビットを結合させる。
・相関性に従って結合された探索加速データ中のビットを再順序付けする。
・探索加速データをハフマン符号化する。
いくつかの実施形態において、ほぼ相関されたビットは他方とほぼ相関されたものと考えられてもよい。すなわち、圧縮される探索加速データに小さな差分が存在する。探索加速データが結合される際の探索加速データの密接度は所定の基準に従って調整可能であってもよい。従って、そのような不可逆的結合を実現する本発明の実施形態は、探索加速データを使用して経路計画を実行するのに必要な処理を増加するが、探索加速データにより占有されるメモリフットプリントを更に減少する。
探索加速データを再順序付けする実施形態は、ハフマン圧縮が探索加速データを圧縮する際の効率が向上されるため有利である。
本発明の第2の態様によると、電子地図にわたり経路が計画される際の速度を向上するように構成された探索加速データを含む地図データを作成する方法であり、電子地図によってカバーされるエリアにおけるナビゲート可能な経路の区分を表す複数のナビゲート可能区分を含む電子地図を処理するために少なくとも1つの処理装置を使用することを備える方法であって、処理装置が、
a.ナビゲート可能区分のコアネットワークを形成するナビゲート可能区分を除去することにより探索加速データの作成時に考慮されるナビゲート可能区分の数を減少させるためにナビゲート可能区分を処理し、
b.そのナビゲート可能区分が最小コストの経路の一部であるかを示す探索加速データをコアネットワークのナビゲート可能区分の少なくとも一部に対して、一般には各ナビゲート可能区分に対して生成するようにすることを備え、
ステップa.は、
・道路プロパティに関連した所定の基準を満たすステップと、
・ある所定の基準に従って十分に小さく且つ更なる所定の基準を満たすナビゲート可能区分の集合を除去することによりネットワークの残りの部分から切断されるネットワークの部分を形成するナビゲート可能区分をネットワークから除去するステップと、
・所定の状況においてナビゲート可能区分の間の分岐点に存在するノードを他方のノードにまとめるステップと、
・ノードが2つ以下のナビゲート可能区分を接続させる場合にそれらノードを他方のノードにまとめるステップと、
のうちいずれか1つ以上を含む方法が提供される。
本発明の第3の態様によると、電子地図にわたり経路が計画される際の速度を向上するように構成された探索加速データを含む地図データを作成する方法であり、それぞれが電子地図によってカバーされるエリアにおいてナビゲート可能な経路の区分を表し且つナビゲート可能な経路のパラメータを表す関連付けられた少なくとも1つの属性を有する複数の関連付けられたノードを有する複数のナビゲート可能区分を含む電子地図を処理するために少なくとも1つの処理装置を使用することを備える方法であって、
a)少なくとも1つの属性を評価するステップと、
b)ナビゲート可能区分と関連付けられたノードが電子地図の領域にわたり均衡されることを保証するためにステップa.の評価を使用して各ナビゲート可能区分を階層の各レベルの少なくとも1つの領域に分類するように、電子地図を階層領域の集合に分割するステップと、
c)地図データを生成するステップと、
を備える方法が提供される。
そのような方法の1つの利点は、各領域間で分布されるナビゲート可能区分の数を均衡させることを助長でき、その結果、探索加速データの有効性を向上することを助長できることである。
ステップa)及びb)は、領域にわたるノードの均衡を測定する所定の基準が満たされるまで繰り返し実行されてもよい。例えば、所定の領域に存在してもよいナビゲート可能区分の数に対する上限閾値がそのような基準であってもよい。そのような尺度は、探索加速データがより迅速に算出されることを保証するのを助長できる。領域がそこに含まれたナビゲート可能区分に関して不均衡を含む場合、探索加速データが算出される際の速度は損なわれる可能性がある。
属性は以下のうちのいずれかを含んでもよい。
・ナビゲート可能区分の種類
・ナビゲート可能区分に沿う平均速度
・ナビゲート可能区分の長さ
・他のナビゲート可能区分に対するその区分の接続性
方法は、移動時間が所定の閾値より遅い電子地図の領域を判定するように構成されてもよく、それら領域内の別個のナビゲート可能区分を電子地図の他の領域から更に分離してもよい。
方法は、島の一部であるナビゲート可能区分を電子地図の他の領域から分離するように構成されてもよく、これはナビゲート可能区分に対する属性がフェリー路線であると判定することにより実行されてもよい。そのような島までの移動が電子地図の他の領域までの移動より遅く、そのような島を含むことにより探索加速データの有効性を損ない且つ/又は探索加速データの算出を遅くする可能性あるため、そのような方法は有利である。
本発明の第4の態様によると、電子地図にわたり経路を計画する際の速度を向上するように構成された探索加速データを含む地図データを作成する方法であり、それぞれが電子地図によってカバーされるエリアにおいてナビゲート可能な経路の区分を表す複数のナビゲート可能区分を含む電子地図を処理するために少なくとも1つの処理装置を使用することを備える方法であって、
a)より粗なレベルのいずれか1つの領域がより精細なレベルの複数の領域を含む場合に、各ナビゲート可能区分がより粗なレベル及びより精細なレベルの各々の少なくとも1つの領域に分類されるように、地図を少なくともより粗なレベル及び近傍のより精細なレベルに属する複数の階層領域に分割するステップと、
b)行先領域を含むより粗なレベルの領域に近接する領域が可視エリアに追加されるべきかを評価し且つその評価が肯定的である場合にそれらの領域を追加することにより、行先領域を含むより粗なレベルの領域を少なくとも含む可視エリアの範囲を所定の行先領域に対して判定するステップと、
c)少なくともいくつかのナビゲート可能区分に対して行先領域までの少なくとも1つの最小コストの経路に関する情報を算出するステップと、
d)ナビゲート可能区分の処理が行先領域からナビゲート可能区分へ戻る逆探索の実行を含み、実質的に行先領域の可視エリアのナビゲート可能区分のみを含むステップと、
e)地図データを生成するステップと、
を備える方法が提供される。
そのような方法の1つの利点は、近傍のエリアの使用により、探索加速データを生成するのに使用される探索空間が制限されるため、探索加速データが作成される際の速度が向上されることである。
本発明の第5の態様によると、電子地図にわたり経路が計画される際の速度を向上するように構成された探索加速データを含む地図データを作成する方法であり、それぞれが電子地図によってカバーされるエリアにおいてナビゲート可能経路の区分を表す複数のナビゲート可能区分を含む電子地図を処理するために少なくとも1つの処理装置を使用することを備える方法であって、
a)より粗なレベルのいずれか1つの領域がより精細なレベルの複数の領域を含む場合に、各ナビゲート可能区分がより粗なレベル及びより精細なレベルの各々の少なくとも1つの領域に分類されるように、地図を少なくともより粗なレベル及び近傍のより精細なレベルに属する複数の階層領域に分割するステップと、
b)行先領域を含むより粗なレベルの領域に近接する領域が可視エリアに追加されるべきかを評価し且つその評価が肯定的である場合にそれらの領域を追加することにより、行先領域を含むより粗なレベルの領域を少なくとも含む可視エリアの範囲を所定の行先領域に対して判定するステップと、
c)少なくともいくつかのナビゲート可能区分に対して行先領域までの少なくとも1つの最小コストの経路に関する情報を算出するステップと、
d)可視エリアの少なくともいくつかのナビゲート可能区分に対して、一般には各ナビゲート可能区分に対して、行先領域までの少なくとも1つの最小コストの経路に関する情報を含むように探索加速データを構成するステップと、
e)地図データを生成するステップと、
を備える方法が提供される。
そのような方法の1つの利点は、探索加速データを使用する経路計画が実行される際の速度が向上されることである。探索加速データは、行先領域までの道路標識であると考えられてもよい。これにより近傍エリア内に含まれた領域までの探索加速データを含む領域の数を増加することにより、行先領域までの「道路標識」を含む領域の数が増加される。従って、探索加速データを使用する経路計画の性能が向上されるが、探索加速データを生成する時間が増加する可能性がある。
領域が行先領域を含むより粗なレベルの領域に近接するかに関する評価は、所定の基準に基づいてもよい。この所定の基準は、グラフ理論距離、地理的距離、移動時間、燃料消費及び/又はCO排出のうちのいずれか1つ又はそれらの組み合わせであってもよい。実際には、いくつかの実施形態において、行先領域を含むより粗なレベルの領域に隣接する領域はより近接すると判定されてもよい。
可視エリアに追加された領域は、より粗なレベルの1つ以上の領域及びより粗なレベルの1つ以上の領域の一部のうちの少なくとも一方を含んでもよい。
上記方法のいずれも、最小コストの経路に加えて少なくとも1つの追加の経路を探索加速データ内に含んでもよく、追加の経路は以下のいずれか1つ以上を反映してもよい。
・所定の出発地と目的地との間の異なる時間における種々の最小コストの経路
・種々の交通状況に対する所定の出発地と目的地との間の種々の最小コストの経路
・種々のコスト関数に従う所定の出発地と目的地との間の種々の最小コストの経路
・所定の道路ネットワークのあらゆる動的変化に対する所定の出発地と目的地との間の種々の最小コストの経路
・同一のコスト関数に従う所定の出発地と目的地との間の別の経路
・互いに類似する方向の種々の目的地
従って、探索加速データは、それぞれが一般に異なる基準に対して判断される複数の「最小コスト」の経路を含んでもよい。そのような方法の1つの利点は、最小コストのデータを使用する経路計画が種々の基準に対して最適な経路を生成できることである。
本発明の第6の態様によると、
a)地図を階層の1つ以上のレベルの複数の階層領域に分割するステップと、
b)レベル階層の順序で階層の特定のレベルに属する領域の少なくとも一部を処理し、最も精細なレベルから最も粗なレベルに向かって動作し、それら領域の少なくとも一部に対してその領域に入るナビゲート可能区分及び/又はその領域から出るナビゲート可能区分を判定するステップと、
c)地図内のナビゲート可能区分の少なくとも一部を処理してそのナビゲート可能区分から行先領域までの少なくとも1つの最小コストの経路を決定するステップと、
d)ナビゲート可能区分の処理が行先領域からナビゲート可能区分に戻る逆探索の実行を含むステップと、
e)結果として得られた探索グラフにおいて、次に精細なレベルの少なくとも1つの領域に対して、所定の領域からの最小コストの各パスが次に精細なレベルの領域の集合の少なくとも1つの領域を通過するようにその集合を特定し、結果として相関行列を得るステップと、
f)結果として得られた探索グラフにおいて、自身とは異なる領域から更なる行先領域までのいずれのパスにも含まれず且つ従って「非通過区分」と考えられるナビゲート可能区分を特定し、後続ステップにおいて考慮されるナビゲート可能区分の数を減少するために後続ステップのためにそれら非通過区分を除去するステップと、
g)探索加速データの作成が前の全てのステップにおいて除去された非通過区分に探索加速データを割り当てるために相関行列を使用することを含むステップと、
h)地図データを生成するステップと、
が提供される。
本発明の上記態様のうちのいずれも、少なくとも一連の位置により構成されている測位データを生成するために1つ以上のナビゲーション装置を使用してもよい。その後、方法は、測位データを処理して時間と共に変動する速度プロファイルを生成してもよく、生成された速度プロファイルは、速度プロファイルを生成する測位データが発生したナビゲート可能区分と関連付けられる。
本発明の第7の態様によると、プロセッサを使用して電子地図にわたり経路を生成するように構成されたナビゲーション装置であって、プロセッサは、
電子地図にわたり経路探索を実行し、
電子地図のナビゲート可能区分を表す探索中に処理されたノードにおけるコストの算出において、それらノードに接続されたナビゲート可能区分が最小コストの経路の一部として印をつけられるかの評価を実行し、
そのようなナビゲート可能区分が存在する場合にそれらのナビゲート可能区分のみを探索するように構成されるナビゲーション装置が提供される。
探索は、A*探索又は本明細書で説明される他のあらゆる探索方法等の木探索を含んでもよい。他の実施形態において、探索は有向非周期グラフ探索を含んでもよい。
本発明の第8の態様によると、電子地図内のナビゲート可能区分を表すグラフ木のノードで実行されるコストの算出においてA*探索を実行することと、ノードに接続されたナビゲート可能区分が最小コストの経路の一部として印をつけられるかを判定するために探索加速データを評価し且つそのようなナビゲート可能区分が存在する場合にそれらのナビゲート可能区分のみを探索することを含むこととを備える電子地図にわたり経路を生成する方法が提供される。
探索加速データは、再生成され且つ電子地図と共に又は電子地図と関連付けられて格納されるのが便利である。
そのような方法は、電子地図にわたり経路が生成される際の速度を非常に向上する可能性があるため有利であると考えられる。
本発明の第9の態様によると、地図データを解析するためにプロセッサを使用して目的地までの電子地図にわたる経路を生成するように構成されたナビゲーション装置であって、プロセッサは、
・地図データに保持された情報を使用して電子地図にわたり経路探索を実行し、
・電子地図のナビゲート可能区分を表す探索中に処理されたノードにおけるコストの算出において、それらノードに接続されたナビゲート可能区分が探索加速データ内で最小コストの経路の一部として印をつけられるかの評価を実行し、
・最小コストの経路に関する更なる情報を提供する追加の探索加速データがノードから目的地までに存在するかに関する指標を前記地図データが含み、
・そのような最小コストのデータが入手可能である場合にそのような探索加速データを有するそれらのナビゲート可能区分のみを探索するように構成されるナビゲーション装置が提供される。
地図データに提供された指標がナビゲーション装置により探索される経路の数を制限する情報を提供するのを助長するため、そのような装置は有利である。
指標は、目的地の可視エリアを含んでもよく、ナビゲーション装置は、最小コストの経路に関する更なる情報が可視領域内にある場合にそれを利用するように構成されてもよい。
本発明の更なる態様によると、上記方法のいずれかを実行するように構成された演算装置が提供されてもよい。
本発明の更なる態様によると、少なくとも1つの機械に読み込まれた時に上記方法のいずれかを提供する命令を含む機械可読媒体が提供される。
本発明の更なる態様によると、命令が読み込まれる各機械に本発明の上記態様のいずれかの演算装置として機能させる命令を含む機械可読媒体が提供される。
方法が並行に実行される実施形態において、命令は複数の機械に読み込まれてもよい。
本発明の上記態様の特徴のうちの多くは、必要な変更を加えて本発明の他の態様に適用されてもよいことが当業者には理解されるだろう。
本発明の上記態様のいずれかにおいて、機械可読媒体は、フロッピーディスク、CD ROM、DVD ROM/RAM(−R/−RW及び+R/+RWを含む)、ハードドライブ、メモリ(USBメモリキー、SDカード、Memorystick(登録商標)又はコンパクトフラッシュカード等)、テープ、他のあらゆる形態の光磁気記憶装置、送信信号(インターネットダウンロード、FTP転送等を含む)、ワイヤ又は他のあらゆる適切な媒体のうちのいずれを含んでもよい。
本明細書で説明される方法及び/又は装置の多くは、ソフトウェア、ハードウェア又はファームウェアで実行されてもよいことが当業者には理解されるだろう。実際には、それら3つの組み合わせが少なくとも一部の概念に適切であってもよい。
本発明の上記態様のいずれかにおける地図データの生成の参照は、実際にはオプションのステップであってもよく、そのようなステップが方法に対するオプションであってもよいことは当業者には理解されるだろう。
本発明の更なる1つの態様によると、探索加速データを生成するためにナビゲート可能区分を前処理することを含む探索加速データを生成する方法が提供される。
測位データから地図データを生成する方法であり、電子地図によってカバーされるエリアのナビゲート可能経路の区分を表す複数のナビゲート可能区分を含む電子地図を処理するために少なくとも1つの処理装置を使用することを備える方法であって、
1.少なくとも一連の位置により構成されている測位データを生成するために1つ以上のナビゲーション装置を使用するステップと、
2.測位データを処理して時間と共に変動する速度プロファイルを生成することであり、生成された速度プロファイルが速度プロファイルを生成する測位データが発生したナビゲート可能区分と関連付けられるステップと、
3.ナビゲート可能区分の少なくとも一部に対して、所定の基準に対する時変関数を使用して、ナビゲート可能区分が各領域まで移動するための所定の基準に対するコストを最小限にするために経路の一部を含むかを少なくとも1つの領域、一般には各領域に対して示す探索加速データを生成するステップと、
4.地図データを生成するステップと、
を備える方法が提供される。
本発明の態様において、ノード、線又は道路に対する参照はナビゲート可能区分に対する参照として利用されてもよく、ナビゲート可能区分に対する参照はノード、線又は道路に対する参照として利用されてもよい。必要な変更を行う方法は、当業者には理解されるだろう。
図1は、ナビゲーション装置により使用可能な全地球測位システム(GPS)の例示的な一部を示す概略図である。 図1aは、ポータブルナビゲーション装置(PND)又は他のあらゆる適切なナビゲーション装置の電子構成要素を示す概略図である。 図1bは、ナビゲーション装置を搭載及び/又はドッキングするための構成を示す概略図である。 図1cは、図1aのナビゲーション装置により採用されたアーキテクチャスタックの概略表現を示す図である。 図2は、本発明の実施形態により生成されるような地図の一例の一部を示す図である。 図3は、経路指定に使用されたノードが示される図2の地図を示す図である。 図4は、処理後の図2の地図を示す図である。 図5は、いくつかの実施形態においてノードが図3の地図に割り当てられる方法の一例を示す図である。 図6は、地図が複数のネストされた領域に区分される方法の一例を示す図である。 図6aは、図6の区分の高度化を示す図である。 図7は、本発明の実施形態により利用されたビットベクトルの集合の一例を示す図である。 図7aは、時間プロファイル化された情報がネットワークのダイクストラ探索中に利用される方法を示す図である。 図8は、本発明の一実施形態のファイルに対するファイル形式の一例を示す図である。 図9は、図8の領域再マッピングテーブル及び領域IDリストが符号化される方法の一実施形態を示す図である。 図10は、レベル0領域に対するファイル形式の一例を示す図である。 図11は、レベル0以外のレベル領域に対するファイル形式の一例を示す図である。 図12は、符号化方式内のビットの結合を例示的に示す図である。 図13は、ビットを結合する効果を例示的に示す図である。 図14は、ビットを結合する効果を例示的に更に示す図である。 図15は、従来の経路指定技術を使用して考えられた経路を強調表示する地図を示す図である。 図16は、本発明の実施形態により考えられた経路を強調表示する地図を示す図である。 図17は、A*探索方法(従来技術)の一例を示す図である。 図18は、本発明の少なくともいくつかの実施形態により使用された図17に対する変形例を示す図である。 図19は、方法のステップを概略的に示すフローチャートである。
以下の説明において、同一の図中符号は同様の部分を特定するために使用される。種々の実施形態の説明において、一連の19xxの図中符号を有する図19のフローチャートを参照する。
図1は、連続した位置、速度、時間及びいくつかの例においては無数のユーザに対する方向情報を判定するために利用されてもよい衛星無線を使用したナビゲーションシステムである全地球測位システム(GPS)を概略的に示す。以前はNAVSTARとして既知であったGPSは、極めて正確な軌道で地球を周回する複数の衛星を含む。これらの正確な軌道に基づいて、GPS衛星は自身の場所をGPSデータとしていかなる数の受信ユニットにも中継できる。しかし、GLOSNASS、欧州のGalileo測位システム、COMPASS測位システム又はIRNSS(Indian Regional Navigation Satellite System)等の全地球測位システムが使用可能であることが理解されるだろう。
特にGPSデータを受信できる装置がGPS衛星信号に対する無線周波数の走査を開始する場合、GPSシステムは実現される。GPS衛星から無線信号を受信すると、装置は、複数の異なる従来の方法のうちの1つを使用してその衛星の正確な場所を判定する。殆どの例において、装置は、少なくとも3つの異なる衛星信号を取得するまで信号の走査を継続する(尚、位置を判定する標準的な方法ではないが、2つの信号だけでも他の三角測量技術を使用して位置を判定できる)。幾何学的三角測量を実現すると、受信機は、3つの既知の位置を利用して、衛星に対する自身の2次元位置を判定する。これは、既知の方法で行われる。更に、第4の衛星信号を取得することにより、受信装置は、同一の幾何学計算によって既知の方法でその3次元位置を算出できる。位置及び速度データは、無数のユーザにより連続的にリアルタイムで更新可能である。
図1に示すように、GPSシステム100は、地球104の周囲の軌道上にある複数の衛星102を含む。GPS受信機106は、多くの衛星102からスペクトル拡散GPS衛星データ信号108としてGPSデータを受信する。スペクトル拡散データ信号108は、各衛星102から連続的に送信され、送信された各スペクトル拡散データ信号108は、データストリームの発信元である特定の衛星102を特定する情報を含むデータストリームを含む。一般にGPS受信機106は、2次元位置を算出できるように少なくとも3つの衛星102からスペクトル拡散データ信号108を必要とする。第4のスペクトル拡散データ信号を受信することにより、GPS受信機106は既知の技術を使用して3次元位置を算出できる。
従って、GPSシステムにより、GPS受信機106を有する装置のユーザは数メートル内で地球上の自身の位置を判定できる。この情報を使用するために、ユーザの位置を示すことを可能にする電子地図に依存することが一般的になっている。そのような地図は、TeleAtlas(http://www.teleatlas.com)等のプロバイダにより例示される。
そのような電子地図は、GPSシステム(又は他の手段)を使用してユーザの位置を示すことを可能にするだけでなく、ユーザが移動等(経路指定の目的)のための経路を計画することを可能にする。この経路計画を行うために、電子地図はナビゲーション装置により処理され、これは一般的な演算装置により提供されてもよい。
ナビゲーション装置の特定の例は、ポータブルナビゲーション装置(PND)と呼ぶ便利な衛星ナビゲーション装置(衛星ナビゲーション)を含む。しかし、本発明の教示はPNDに限定されず、一般に経路計画及びナビゲーション機能性を提供するために電子地図を処理するように構成されるいかなる種類の処理装置にも例外なく適用可能である。従って、本出願において、ナビゲーション装置は、PND、自動車等の乗り物、例えば経路計画及びナビゲーションソフトウェアを実行するポータブルパーソナルコンピュータ(PC)、移動電話又はパーソナルデジタルアシスタント(PDA)又はサーバであるポータブル計算リソース、あるいはネットワークを介してそのような機能性を提供する他の演算装置として実装されるか否かにかかわらず、どんな種類の経路計画及びナビゲーション装置も含むことを意図する(それらに限定されない)。
PNDの形態のそのようなナビゲーション装置の一例を図1aに示す。尚、ナビゲーション装置200のブロック図は、ナビゲーション装置の全ての構成要素を含んでいるわけではなく、多くの構成要素の例を示しているにすぎない。ナビゲーション装置200は筐体(不図示)内に配置される。ナビゲーション装置200は、例えば上述したプロセッサ202を含む処理回路網を含む。プロセッサ202は、入力装置204及び例えば表示画面206である表示装置に結合される。ここで、入力装置204は単数で示されるが、入力装置204がキーボード装置、音声入力装置、タッチパネル及び/又は情報を入力するのに利用される他のあらゆる既知の入力装置を含む任意の数の入力装置を表すことは、当業者には理解されるべきである。同様に、表示画面206は、例えば液晶ディスプレイ(LCD)等のあらゆる種類の表示画面を含むことができる。
ナビゲーション装置200において、プロセッサ202は、接続210を介して入力装置204に動作可能に接続されて入力装置204から入力情報を受信でき、各出力接続212を介して表示画面206及び出力装置208のうち少なくとも一方に動作可能に接続されて情報を出力する。ナビゲーション装置200は、例えば可聴出力装置(例えば、スピーカ)である出力装置208を含んでもよい。出力装置208がナビゲーション装置200のユーザに対して可聴情報を生成できるため、入力装置204は入力音声コマンドを受信するためのマイク及びソフトウェアを含むことができると同様に理解されるべきである。また、ナビゲーション装置200は、例えばオーディオ入出力装置等のあらゆる追加の入力装置204及び/又はあらゆる追加の出力装置を更に含むことができる。
プロセッサ202は、接続216を介してメモリ214に動作可能に接続され、更に接続220を介して入出力(I/O)ポート218に対して情報を送受信するように更に構成される。I/Oポート218は、ナビゲーション装置200の外部のI/O装置222に接続可能である。外部I/O装置222は、例えばイヤホン等の外部リスニングデバイスを含んでもよいがこれに限定されない。I/O装置222への接続は、イヤホン又はヘッドホンへの接続及び/又は例えば移動電話への接続のためのハンズフリー動作及び/又は音声起動動作を行うカーステレオユニット等の他のあらゆる外部装置への有線又は無線接続であってもよい。ここで、例えばナビゲーション装置200とインターネット又は他のあらゆるネットワークとの間のデータ接続を確立するため、並びに/あるいは例えばインターネット又は他の何らかのネットワークを介してサーバとの接続を確立するために移動電話接続が使用される。
ナビゲーション装置200のメモリ214は、不揮発性メモリ(例えば、プログラムコードを格納する)の一部及び揮発性メモリ(例えば、プログラムコードが実行された時にデータを格納する)の一部を含む。ナビゲーション装置は、接続230を介してプロセッサ202と通信するポート228を更に含み、取外し可能なメモリカード(一般に、カードと呼ばれる)が装置200に追加されるのを可能にする。説明している実施形態において、ポートは、SD(セキュアデジタル)カードが追加されるのを可能にするように構成される。他の実施形態において、ポートは他の形態のメモリが接続されるのを可能にしてもよい(コンパクトフラッシュ(CF)カード、Memory Stick(登録商標)、xDメモリカード、USB(Universal Serial Bus)フラッシュドライブ、MMC(マルチメディア)カード、SmartMediaカード又はマイクロドライブ等)。
図1aは、接続226を介するプロセッサ202とアンテナ/受信機224との間の動作可能接続を更に示す。ここで、アンテナ/受信機224は、例えばGPSアンテナ/受信機であってもよいため、図1のGPS受信機106として機能する。図中符号224で指定されたアンテナ及び受信機は図示するために概略的に組み合わされるが、アンテナ及び受信機は別個に配置された構成要素であってもよく、アンテナは例えばGPSパッチアンテナ又はヘリカルアンテナであってもよいことが理解されるべきである。
更に、図3のポータブル又はハンドヘルドナビゲーション装置200は、例えば自転車、オートバイ、自動車又は船等の乗り物に既知の方法で接続又は「ドッキング」される。そのようなナビゲーション装置200は、ポータブル又はハンドヘルドナビゲーションに使用するためにドッキングされた場所から取り外し可能である。実際には、他の実施形態において、装置200はユーザのナビゲーションを可能にするためにハンドヘルド装置となるように構成されてもよい。
図1bを参照すると、ナビゲーション装置200は、内蔵された入力及び表示装置206並びに図3の他の構成要素(内部GPS受信機224、プロセッサ202、電源(不図示)、メモリシステム214等を含むがこれらに限定されない)を含むユニットであってもよい。
ナビゲーション装置200は、吸着カップ254を使用して車両のダッシュボード/窓等に固定されてもよいアーム252上に位置してもよい。このアーム252は、ナビゲーション装置200がドッキングされるドッキングステーションの一例である。ナビゲーション装置200は、例えばナビゲーション装置200をアーム252に嵌合接続することによりドッキングステーションのアーム252にドッキングされるか又は接続される。ナビゲーション装置200は、アーム252を中心に回転可能であってもよい。ナビゲーション装置200とドッキングステーションとの間の接続を解放するために、例えばナビゲーション装置200上のボタン(不図示)が押下されてもよい。ドッキングステーションに対してナビゲーション装置200を結合及び分離する同様に適切な他の構成は当業者には既知である。
図1cを参照すると、プロセッサ202及びメモリ214は協働して、ナビゲーション装置200の機能ハードウェア構成要素280と装置により実行されるソフトウェアとの間のインタフェースとして機能するBIOS(基本入出力システム)282をサポートする。プロセッサ202は、メモリ214からオペレーティングシステム284をロードし、アプリケーションソフトウェア286(説明された経路計画及びナビゲーション機能性の一部又は全てを実現する)が実行可能な環境を提供する。アプリケーションソフトウェア286は、例えば地図閲覧、経路計画、ナビゲーション機能及び関連する他のあらゆる機能であるナビゲーション装置の中核機能をサポートするグラフィカルユーザインタフェース(GUI)を含む動作環境を提供する。この点に関して、アプリケーションソフトウェア286の一部はビュー生成モジュール288を含む。
説明している実施形態において、ナビゲーション装置のプロセッサ202は、アンテナ224により受信されたGPSデータを受信し且つGPSデータが受信された時のタイムスタンプと共にGPSデータを時々格納してナビゲーション装置の一連の位置を構築するようにプログラムされる。そのように格納された各データレコードはGPSのフィックス解と考えられてもよい。すなわち、ナビゲーション装置の場所のフィックス解であり、緯度、経度、タイムスタンプ及び精度レポートを含む。この一連の位置は測位データと考えられてもよい。
一実施形態において、データは、ほぼ周期的に、例えば5秒毎に格納される。他の周期も可能であり、データ解像度と記憶容量との間で均衡がとられることが当業者には理解されるだろう。すなわち、データの解像度がより多くのサンプルをとることにより向上されると、データを保持するのに必要なメモリはより多くなる。しかし、他の実施形態において、解像度は、ほぼ1秒毎、10秒毎、15秒毎、20秒毎、30秒毎、45秒毎、1分毎、2.5分毎(又は実際にはそれらの周期の間のあらゆる周期)であってもよい。従って、装置のメモリ内では、複数の時点における装置200の位置のレコードが構築される。
いくつかの実施形態において、取り込まれたデータの品質は、周期が長くなるほど低下し、劣化の程度はナビゲーション装置200の移動していた速度に少なくとも部分的に依存するが、約15秒の周期が適切な上限を与える可能性があることが分かるだろう。
更にプロセッサ202は、装置200の位置のレコード(すなわち、GPSデータ及びタイムスタンプ)をサーバに対して時々アップロードするように構成される。ナビゲーション装置200が自身をサーバに接続する永続的な又は少なくとも一般的に存在する通信チャネルを有するいくつかの実施形態において、データのアップロードは、24時間に1回等の周期的に行われる。他の周期も可能であり、ほぼ15分毎、30分毎、1時間毎、2時間毎、5時間毎、12時間毎、2日毎、1週間毎又はそれらの期間の間のあらゆる時間のいずれであってもよいことが当業者には理解されるだろう。実際には、そのような実施形態において、プロセッサ202は、ほぼリアルタイムに位置のレコードをアップロードするように構成されてもよい。しかし、これは、データが実際には送信の間に相対的に短い周期で時々送信されることを必然的に意味するため、より正確には擬似リアルタイムであると考えられる。そのような擬似リアルタイムの実施形態において、ナビゲーション装置は、メモリ214内及び/又はポート228に挿入されたカードにGPSのフィックス解をバッファリングし且つ所定の数だけ格納された時にそれらを送信するように構成されてもよい。この所定の数は、20、36、100、200又はそれらの間のどのような数であってもよい。所定の数は、メモリ214/ポート228内のカードのサイズにより部分的に管理されることが当業者には理解されるだろう。
一般的に存在する通信チャネルを有さない他の実施形態において、プロセッサは、通信チャネルが作成される時にレコードをサーバにアップロードするように構成されてもよい。例えばこれは、ナビゲーション装置200がユーザのコンピュータに接続される時であってもよい。ここでも、そのような実施形態において、ナビゲーション装置は、メモリ214内又はポート228に挿入されたカードにGPSのフィックス解をバッファリングするように構成されてもよい。メモリ214又はポート228に挿入されたカードがGPSのフィックス解で一杯になった場合、ナビゲーション装置は、最も古いGPSのフィックス解を削除するように構成されてもよいため、先入れ先出し(FIFO)バッファと考えられてもよい。
説明している実施形態において、位置のレコードは、それぞれが24時間以内のナビゲーション装置200の動きを表す1つ以上のトレースを含む。24時間の各期間はカレンダーの日付と一致するように構成されるが、他の実施形態においては一致する必要はない。
サーバは、装置の位置のレコードを受信し且つ処理するために大容量データ記憶装置内にそのレコードを格納するように構成される。従って、時間の経過と共に、大容量データ記憶装置はデータをアップロードした複数のナビゲーション装置200の位置のレコードを蓄積する。一般に、サーバは複数のナビゲーション装置200の位置を収集する。
サーバは、各装置の収集した位置から速度データを生成するように構成されてもよい。この速度データは、地図のナビゲート可能区分に沿う平均速度が計時変化する様子を示す時間で変動する速度プロファイルを含んでもよい。
図2は、説明している実施形態において、この例ではインターネットであるネットワークを介してナビゲーション装置において閲覧される電子地図の一例を示す。本明細書で説明している実施形態のいずれかにおける第1のステップは、そのような電子地図1900の生成である。地図は、http://routes.tomtom.com/で閲覧されてもよい。
図2の電子地図が行われる経路指定の目的で使用されるために、電子地図は一般に電子地図のユーザには見えない一連のノードを有する。従って、ノード等は一般に地図データと呼ばれてもよい。しかし、理解しやすいように、ノード300の一部が図3に示される。これらのノードは、交差点、道路の最終領域等に提供され、経路指定の目的で使用される。ユーザが自身のナビゲーション装置に2つ以上の地点間の経路を計画するように要求する場合、一般にナビゲーション装置は地図の関連するノード間の経路を計画する(ノードのグループまでの経路を計画することも可能であるが)。従って、地図データは、ナビゲーション装置のユーザにより設定された少なくとも1つの基準に従って経路を生成するために使用される。
電子地図は、道路区分の形状、建物への入り口の場所等を提供する更なるノードを更に含んでもよい。
従って、各ノード300は、ユーザが移動してもよいそのノードから出る道路区分を少なくとも1つ、一般には複数有する。例えばノード302は、4つのそのような道路区分304a、304b、304c、304dを有する。各道路区分は、歩道、自転車道路、運河、鉄道線路又は軌道等の道路ではない経路を参照する可能性があるため、ナビゲート可能区分と考えられてもよい。しかし、便宜上、道路区分を参照する。従って、図2に示すような地図は、それぞれが地図によってカバーされるエリアのナビゲート可能な経路の一部を表す複数の道路区分をユーザに対して示す。
経路計画方法(ダイクストラ法、A*方法又はMoore/Pape方法)は既知である。しかし、これらは、算出時間に関して非常に遅い。そのような経路計画の速度を向上する方法の一例は、米国特許第6,636,800号公報で示され、その教示は参考として本明細書に取り入れられている。
本明細書で説明している実施形態は、前処理ステップにおいて、電子地図を処理する時に経路の生成を加速するために使用される探索加速データを含むいわゆる副ファイルを生成してもよい。この情報は、ビットベクトルと呼ばれてもよい2値データ、すなわち0及び1の列(又はその圧縮符号化)として保持されてもよい。従って、副ファイルは地図データと考えられてもよいが、電子地図(例えば、図2に示すような)が供給されてもされなくてもよい。従って、本発明のいくつかの実施形態は、副ファイルから分離可能な地図として地図データを提供してもよいが、本発明の他の実施形態は、地図及び副ファイルデータを組み合わせてもよい。
しかし、副ファイルが使用される場合、副ファイルが生成された電子地図と共に使用されるべきであることは、当業者には理解されるだろう。これが行われない場合、不正確な経路(例えば、ユーザにより設定されたコスト関数を最小限にしない経路)が取得されると考えられる。
また、本発明の種々の実施形態は、探索加速データ(本実施形態においては、一連のビットベクトルであり、便宜上、以下においてビットベクトルと呼ぶ)の生成のための種々のパラメータを指定してもよい。従って、生成された地図データを使用する次の経路計画がビットベクトルを作成するのに使用されたパラメータとは異なるパラメータを使用する場合、ビットベクトルはその経路計画に有用ではないと考えられる。
例えばいくつかの実施形態は、自動車による地図上の移動に対してビットベクトルを生成してもよい。次の経路計画が徒歩のための経路を生成するために使用される場合、自動車用のビットベクトルは有用ではないと考えられる。別の例において、いくつかの実施形態は、ユーザが高速自動車道路、有料道路等を喜んで移動すると仮定してビットベクトルを生成してもよい。次の経路計画において、ユーザが高速自動車道路、有料道路等を利用しない経路を要求する場合、ビットベクトルは有用ではないと考えられる。
本発明のいくつかの実施形態は、それぞれが所定の基準の異なる集合を有する複数のビットベクトルの集合を生成してもよい。例えば本発明の実施形態は、2つ、3つ、4つ、5つ、6つ、10個、15個又はそれ以上のビットベクトルの集合のいずれを生成してもよい。
従って、いくつかの実施形態において、副ファイルを生成するために、地図前処理ステップにおいてノードは複数の領域に分割されるため、あらゆる地図は既知の数の領域、例えばN個の領域に分割される。これについては、図5を参照して以下に更に詳細に説明する。この前処理は、経路計画方法の速度を向上するために地図と共に利用可能なデータを生成する。
再帰的であってもよい反復処理において、地図データ内のノードは階層領域の集合に分割される。図5の点線で示すような領域が作成され、各領域は複数のノードを含む。方法は、より多くの又はより少ないノード(及び従ってナビゲート可能区分)を含むようにそれらの境界を移動し、それらの境界の移動の際にノードと関連付けられた道路区分のパラメータを考慮する。方法のいくつかの実施形態は、いずれか1つの領域内に含まれるノード数に関する上限を設定することを目的とする。方法は、ナビゲート可能区分の予想された移動時間に従って領域のメンバーシップを判定してもよい。例えばナビゲート可能区分が遅い平均移動時間を有する(例えば、フェリー路線)場合、ノードは別個の領域に移動されてもよい。
一般に前処理は、地図データがウェブサイト上で使用されるか又はPND等の装置上で使用されるかに関わらず、地図データが使用される前に実行される。従って、前処理ステップは、サーバ側処理と呼ばれることが多い。
一般的なあらゆる演算装置が前処理を実行するのに適しているが、装置の性能が高い程、前処理は迅速に実行されることが当業者には理解されるだろう。一般に、X86アーキテクチャ演算装置が前処理に利用される。一般にそのようなX86アーキテクチャ装置は、Microsoft(登録商標)Windows(登録商標)、UNIX、LINUX、OSX(登録商標)等のオペレーティングシステム(OS)を実行する。しかし、他の実施形態はRISCアーキテクチャ等の他の演算プラットフォームを使用してもよい。
また、他で説明するように、前処理は並列に実行されてもよいため、複数の演算装置又は少なくとも複数のプロセッサコア(仮想又は実プロセッサコアであってもよい)で実行されてもよい。
次の前処理ステップとして、領域内の各道路区分(例えば、304a〜304d)が処理され、それが地図内の領域数(N)の各々までの最小コスト経路の一部であるかを判定し、ビットベクトルが生成される(最小コスト評価)。従って、領域内の道路区分毎のビットベクトルは、領域内のナビゲート可能区分毎のビットを含む。すなわち、ビットベクトルは、経路がビットで表された領域までの最短経路の一部を形成するかに依存して0又は1に設定されるN−1ビット(当該領域を除いた各領域に対して1ビット)を含む。いくつかの実施形態は、ヘッダ及び可視エリア等の更なる情報を提供するために追加のビットを追加してもよい。これらの用語については以下に説明する。これについては、図5を参照して以下に更に詳細に説明する。
この意味で最小コスト経路が複数の種々のコスト基準に対して判定されることは、当業者には理解されるだろう。例えば最小コストは、最短距離、最短移動時間、最安(環境的な影響に関して)、最小の使用燃料、最小の生成CO等の基準のうちいずれかに対して判断されてもよい。本実施形態において、最小コストは最短移動時間に対して判断される。
従って、大きなエリアを範囲に含む地図の場合にNが大きい可能性が高いことは、当業者には理解されるだろう。そのため、前処理には多くの時間がかかる可能性がある。
例えばヨーロッパ及びロシアを範囲に含む地図の一例において、一般に120,000,000個の道路区分を有する50,000,000個のノードが存在する。地図内に100個の領域が存在すると仮定すると、Nは100であり、ビットベクトルに属する120,000,000x100(N)ビットが存在する。すなわち、12x10ビットは地図の道路区分毎に99(すなわち、N−1)ビットを格納する必要がある。以下に説明する本発明の実施形態を使用すると、そのような地図は約500Mbの追加の記憶容量を使用してもよい。
国際公開第WO2009/053410号は、時間の関数として地図の経路に沿う速度を与える速度プロファイルを割り当てる方法を説明する。この出願の内容は、参考として本明細書に取り入れられている。従って、経路指定の目的で、ある経路が別の領域までの最速経路の一部を構成するか否かは時間の関数として変動する。すなわち、例えばラッシュアワー等で、交通密度が増加すると経路を使用するのが望ましくなくなり、交通密度が減少すると経路を使用するのがより望ましくなる。
いくつかの実施形態は、道路区分毎に複数のビットベクトルを格納してもよい。速度が記録される際の解像度が高い程、必要とされるビットベクトル数は増加することが当業者には理解されるだろう。しかし、他の実施形態は、国際公開第WO2009/053410号で説明するように時変関数を多く利用して最速経路の評価を行ってもよい。
電子地図にわたる経路計画の時、約1/100秒の精度の時間粒度を使用してこれを行える必要があると考えられる。すなわち、最小コストの経路を正確に判定するために、0.01秒の精度でノードからの出発時間を指定できる必要があると考えられる。
従って、このレベルの精度を考慮する場合、上記で考慮された地図に対して、50,000,000個のノード及び120,000,000個の道路区分を有することは120,000,000個の可能な経路を有することが理解されるだろう。時間次元が更に考慮される場合、可能な経路の数は更に増加する。すなわち、7(すなわち、1週間の日数)x24(すなわち、1日の時間数)x3600(すなわち、1時間の秒数)x100(すなわち、1秒間の100分のいくつか)x120,000,000=870,912,000,000,000,000,000,000(1021)個の可能な経路がある。現在の処理レベルで、各区分が各時間間隔で探索される単純な方法を使用すると、約27,616,438,400,000,000年かかるだろう。ヨーロッパ及びロシアの地図は年々大きくなっているため、その時間は更に増加する。
従って、前処理段階でデータを格納及び処理するために多くのデータ量が必要とされることは理解されるだろう。
本発明の実施形態は、前処理の量を非常に低減するために技術を使用する。これらの技術について次に更に詳細に説明する。本発明のいくつかの実施形態はそれら技術の全てを利用してもよいが、他の実施形態は一部のみを利用してもよい。
本発明の種々の実施形態は、以下に概略を示す特徴の種々の組み合わせを使用してもよい。従って、いくつかの実施形態は、情報量を減少するために説明される技術の全てを利用してもよい。全く逆に、他の実施形態はデータを低減するためにそれら技術のいずれも利用しなくてもよい。
本発明のいくつかの実施形態は、ステップ1902(すなわち、道路区分が道路プロパティの所定の基準を満たさない)として示すように、所定の基準を満たさない道路区分に対するビットベクトルを算出しない。例えば、所定の種類の交通機関で道路区分を移動できない場合、道路区分は自身に対するビットベクトルを算出しなくてもよい。
従って、交通機関のモードの基準が自動車に設定される一例において、以下の道路区分は自身に対するビットベクトルを算出しなくてもよい。
・鉄道線路
・ナビゲート可能区分に対応しない地図データに存在する区分
・間違った(不法な)方向の一方通行道路
・交通機関の形態によりナビゲート不可能な道路区分(例えば、自動車による運転性を考慮した時、歩行用ゾーン、歩道)
・非決定地点の道路区分(すなわち、道路区分から方向転換できない)。
ネットワークの縮小
1つの技術は、道路区分が最小コストの経路の一部を形成するかに関する評価に対して考慮されるネットワークのサイズを縮小することである。すなわち、ステップ1904で示すように、道路区分数を減少することにより算出を行うのにかかる時間が短縮される。
この技術を図示するために、図2に示すような道路ネットワークを図4に示すが、図4では最小コスト評価に有用でない道路区分が削除されている。ネットワークの縮小の目的は、最小コスト評価が行われるべき最小のサブネットワークを提供することである。従って、ナビゲート可能区分はコアネットワークを形成する除去されていることが当業者には理解されるだろう。
数学的には、残されたネットワークは、図4に示すように、図2の道路ネットワークの最大の強連結成分の無向表現の最大の2連結成分として記述される。コアネットワークは、右左折制限及びローカルアクセス等の道路交通規制に適応した双方の強い接続性(2連結性としても既知である)に対して一般的な技術を適用することにより判定される。強い接続性は、2つのノード間で双方の方向に移動が可能であること(すなわち、A−>B及びB−>A)を示すことが当業者には理解されるだろう。
図2及び図4の双方を参照すると、袋小路250、冗長ループ252等の行き止まりの道が削除されていることが分かる。しかし、ノード(例えば、図4の400)は、除去された道路区分の起点に残っていることが分かる。これは以下に説明する理由による。
図2のネットワークを図4に示すネットワークに縮小する際、探索加速データが次に回復可能であるナビゲート可能区分は除去されている。すなわち、いくつかの所定の基準に従って十分に小さく且ついくつかの更なる所定の基準を満たすナビゲート可能区分の集合を除去することにより残りのネットワークから切断されてもよいネットワークの部分を形成するナビゲート可能区分は、ネットワークから除去されている。例えばノード302に対する探索加速データは、いずれの経路計画の性能にも殆ど影響を及ぼさずに、ナビゲート可能区分304aの行き止まりの領域のノードに対して容易に使用されてもよい。
コアネットワーク(例えば、図4に示す)に縮小後、コアネットワークは、上述した領域を提供するように区分される。説明している実施形態において、ネットワークは、多方向の円弧状の区切り記号に従って区分される。そのようなネットワークにおいて、領域境界により二等分される道路区分(すなわち、円弧)が除去される場合、いずれか一方の領域に残っている道路区分は他方の領域に接続されないことが当業者には理解されるだろう。
ネットワークの区分−ステップ1906
しかし、区分の実行前に以下のステップが行われる。
1.島が判定され、個々に区分される。島は、フェリーリンク等の手段によりネットワーク及びリンクの他の部分から物理的に分離される傾向がある。これらは一般的な道路区分とは異なる挙動をし(すなわち、平均速度が非常に遅い等)、そのようなリンクが区分に含まれる場合、方法は実行されず、予想されてもよい。
2.ネットワークにおいて2つ以上のノードで表される交差点、ロータリー及び他の分岐点は、同一の交差点等に属するノードが異なる領域で終了しないように短縮される。
3.全てのナビゲート可能区分が同一のプロパティの集合(例えば、フェリー区分、歩行用ゾーン又はゲート制御されたコミュニティに属する区分等)を共有する単純なパス(すなわち、方向転換の可能性のない2つのノード間の接続)は、区分システムに渡されるネットワークの入力サイズを縮小するために短縮される。例えば図3を見ると、ノード301は、そのすぐ下のノードにまとめられてもよい。すなわち、ノードは、2つ以下のナビゲート可能区分を接続させる場合に一方のノードにまとめられる。
更なる実施形態において、ナビゲート可能区分間の複雑な分岐点は複数のノードを含んでもよい。そのような複雑な分岐点は、単一のノードにまとめられてもよい(すなわち、ナビゲート可能区分間の分岐点にあるノードは、所定の状況において一方のノードにまとめられる)。
説明している本発明の実施形態は、http://labri.fr/perso/pelegrin/scotchで概略を示される分割統治法を採用する。そこで概略を示される方法は、地図のエリアに基づかず領域内に含まれたノード数に基づく多くの領域を含むように地図を分割する。そのように編成されるノードを有することは、同様のローカル探索の直径を有する領域を出力するのを助長するため、領域を使用する経路指定をより効率的にすることを助長できるという利点を有する。
各ノードは、領域IDを含む関連付けられた特定番号を有するため、同一領域のノードは同一の領域ID番号を有する。ノードは、L個の階層レベルの領域に属する。レベル0は、慣例によって、最も粗なレベル(長い距離の経路指定に使用される)である。レベルL−1は最も精細なレベルである。
いずれか1つの領域内に含まれるノードの絶対数を設定するのではなく、本発明のいくつかの実施形態はノードの最大数の上限を設定し、これを下回る自由度を可能にしてもよい。例えば方法は、領域毎に最大100個のノードを指定してもよく、その結果、一般に60〜100個のノードの領域毎のノードの広がりが得られる。設定されたノードの数が結果として不自然な形状の領域を与え、それら領域を使用する場合に次善の経路指定が得られるため、上限は設定された数より有利であると考えられる。
複数レベル
説明している実施形態において、複数のレベルのネストされた領域を提供するように区分が行われる。これについては、図6に例示的に示す。最も粗なレベル(0)がレベル1を提供するように細分され、レベル1が最も精細なレベルであるレベル2に細分される階層性が存在することは図6から明らかである。
各領域のノード数はレベル間で異なり、より粗なレベル(より広い地理的エリアを範囲に含む傾向がある)はより低いレベルより多くのノードを有する。従って、説明している実施形態におけるより粗なレベル(例えば、レベル0)は一般に長い範囲の経路指定の目的で使用され、より精細なレベル(例えば、レベル2)は短い範囲の経路指定に使用される。
道路区分毎のビットベクトルの一部分はレベル毎にビットを含む。ビット数は、各レベルにおける領域数である。
符号化するデータ量の概念を与えるために(一般的な一実施形態において、一般にレベル数はL=3である)、以下を示す。
・一般に、グローバルレベル=0は100個の領域を有する
・一般に、中間レベル=1はレベル0の領域毎に10個の領域を有する(すなわち、100x10)
・一般に、最も詳細なレベル=2は、レベル1の領域毎に5つの領域を有する(すなわち、100x10x5)
階層レベルを使用することは、必要とされる処理量を可能性として非常に減少させるため有利である。説明している本実施形態において、100x10x5個の領域(すなわち、5000個の領域)である。従って、平坦な構造において、同数の領域を有することは5000個の領域を参照するために本明細書で概略を示された方法を必要とする。しかし、本明細書で説明される実施形態において、これは適切なレベルのノードを参照することにより減少される。
一般に、種々の因子が地図に対して分かると、レベル数及びレベル毎の領域数は変更される。例えば、地図に割り当て可能な記憶容量及び経路指定が実行されるべき速度である。前処理量が増加すると、データを保持するために地図のサイズが大きくなるが、より速い経路はその地図を使用して算出されるという調和があることが当業者には理解されるだろう。
一実施形態において、3つのレベルの領域が存在する。しかし、他の実施形態において、レベルがいくつ存在してもよい。例えば、1つ、2つ、4つ、5つ、6つ、7つ、8つ、9つ又は10個のレベルが存在してもよい。
従って、上記例を使用して、一般に50,000,000個のノード及び120,000,000個の道路区分を有するヨーロッパ及びロシアの地図において、最も単純な符号化は、各レベルの全てのノードの領域IDに対する固定サイズの符号化及び各レベルの各道路区分に対する固定サイズのビットベクトルを使用する。従って、そのような基本的な符号化のサイズは以下のように容易に算出される。
・レベル0の各ノード領域IDはlog_2(100)ビット=7ビットを使用する
・レベル1の各ノード領域IDはlog_2(10)ビット=4ビットを使用する
・レベル2の各ノード領域IDはlog_2(5)ビット=3ビットを使用する
・レベル0の各ビットベクトルは100ビット(100個の領域−現在の領域である1つの領域)を使用する
・レベル1の各ビットベクトルは10ビット(10個の領域−現在の領域である1つの領域)を使用する
・レベル2の各ビットベクトルは5ビット(5個の領域−現在の領域である1つの領域)を使用する
図6は、最も粗なレベルの領域600を示す。図中、領域600は6つの領域1〜6を提供する。これらの領域の各々は、領域600の粗なレベル内の破線により表されるように、更なる領域、本実施形態では9つのサブ領域に細分される。6つの粗なレベルの領域はより粗なレベルの領域と考えられてもよく、9つのサブ領域は、より粗なレベルに対する近傍領域にあるより精細なレベルの領域と考えられてもよい。説明している実施形態において、破線で提供された各領域が更に細分される更なる細分のレベルが使用され、これにより3つのレベルの区分を提供するが、これについては参照を分かりやすくするため図6には示さない(しかし、図6aに示す)。当然、他の実施形態はより多くのレベル(例えば、4つ、5つ、6つ、7つ又はそれ以上のレベル)又はより少ないレベル(例えば、1つ又は2つのレベル)を使用してもよい。
従って、本発明の実施形態は、ステップ1908において、より精細なレベルの領域に対していわゆる可視エリアを導入する。k領域の可視エリアは、(k−1)領域の集合であり、領域はフラグセットの自身のビットで区別可能である。当然、可視エリアは所定のk領域が属する(k−1)領域を常に含む。更に可視エリアは、近傍の(k−1)領域を含んでもよい。可視エリアは、前処理中に計算され、ビットベクトルと関連付けられて格納される。ここで、k領域はより精細な領域と考えられてもよく、(k−1)領域はより粗な領域と考えられてもよい。
k領域とそれらの(k−1)レベルの可視エリアとの関係は反対側から見られる。各(k−1)領域は近傍にあるkレベルの領域から構成される限界を認識している。このように考えると、道路区分のフラグセットは地図全体にわたり固定長ではない。その代り、各1領域のビットベクトルは、特定の長さA+B+C+Noutskirts0+Noutskirts1を有する。Aは最も粗なレベルの領域を示し、Bは中程度の粒度を示し、Cは最も精細な粒度の領域を示す(3つのレベルが存在する一実施形態において)。
次の前処理は、ビットベクトルを生成するための最短パスの算出前に可視エリアを計算する。可視エリアを見つける方法は以下のように説明される。
一番上の各レベルの各領域Rに対して、近傍グラフは、以下の計測値が選択された閾値を超えるまで領域隣接グラフで幅優先探索を使用してk領域毎に探索される。
・Rから現在の領域のノードまでのグラフ理論距離
・現在の領域とRの中点との間のユークリッド距離
・本明細書の他の場所で説明される他のいずれかの距離
その後、開始領域に十分に近接する訪問先k領域毎に、含んでいる(k−1)領域を可視エリアに追加する。
「密接度」の関係は、地理的計測値(例えば、領域中点間の距離)及びグラフ理論距離を考慮に入れるべきである。(従って、領域は、地理的に遠いが高速接続により現在の領域とリンクされる場合に「近い」だろう。同様に、領域は、地理的に近くても領域間を移動するのが困難である場合は「遠い」と考えられるだろう。)
厳密な閾値は、前処理の増加等の上述した悪影響を最も受けやすい首都圏の平均直径のような地図固有のプロパティに依存するため実験的調整を行われてもよい。非常に長い移動時間がかかるナビゲート可能区分(フェリー又は歩行用ゾーンに属する道路区分等)は隣接グラフの横断中隠蔽される。このように、可視エリアは同一領域に属する小さな列島又は単独の島に常に制限される。
従って、幅優先探索中に訪問される領域はRの近傍領域を構成する。近傍領域を完全に範囲に含む次に粗なレベルの領域の操作対象最小集合は、Rの可視エリアと呼ばれる。逆の関係は近傍と呼ばれる。領域Q(レベルLの)の近傍リストは、可視エリアにQを有するレベルL+1の全ての領域から成る。
特定の例を与えるため、図6を参照すると、可視エリアの例は以下の通りである。
各1領域とその可視エリアの境界との間の最短距離が少なくとも1であるべきであると判断した場合、いくつかの選択した1領域に対する可視エリアは以下の0領域(自身の0領域は常に存在するため省略される)から成る。
・15:
(すなわち、自身の0レベル領域が常に存在するために省略されるため、レベル1領域no.15は可視エリアを示さない)
・28:5
(すなわち、レベル1領域no.28の可視エリアはレベル0領域no.5を含む)
・37:2、5、6
(すなわち、レベル1領域no.37は自身の可視エリアに3つの領域、すなわちレベル0領域no.2、5及び6を有する)。
レベル1領域のレベル0近傍領域を考慮することに加えて、レベル1近傍領域がレベル0領域毎に判定される。一例として以下を示す。
・1:21、24、27、28、41、42、43、51
(すなわち、レベル0領域no.1に対して、レベル1領域は21、24、27、41、42、43、51である)
従って、この例において、領域28が領域2の最も左側の列にないにも関わらず一覧表示されていることが分かる。例えばこれは、領域28が領域1への迅速なリンクを有しているために距離ではなく時間に関して考慮された時に近いからである。密接度は、環境性(最少のCO等)等の他の計測値に対して判断されてもよい。
いくつかの実施形態は、探索加速データの算出を制約することにより探索加速データを生成するのに必要とされる前処理量を低減するために可視エリアを使用してもよい。例えば実施形態は、行先領域(例えば、図6の領域24)から起点ナビゲート可能区分(例えば、図6の領域27)までの逆探索を使用してもよい。この逆探索は、行先領域の可視エリアの全てのナビゲート可能区分に最短経路で到達した時に停止するように制約されてもよい。例えば領域24の可視エリアが領域2であると仮定すると、逆探索は、領域2の全てのナビゲート可能区分に最短経路で到達すると停止する。領域2内の最短経路は、領域24の可視エリアに含まれていない領域を通過してもよいことが当業者には理解されるだろう。例えば、領域2の2つの場所の間の最短経路は領域1を通過してもよい。
更に詳細には、これは、領域27の起点ナビゲート可能区分と領域24の目的地との間の最短経路に対して真であってもよい。この経路は、領域24に対して正確な探索加速データを生成するために考慮される必要がある。上述した制約された探索は、領域1を通過する経路に対する正確な探索加速データを生成することが当業者には理解されるだろう。すなわち、領域2内で、特に領域27において、探索加速データを使用する探索は領域24に対する探索加速データを使用する。領域1に進むと、粗な領域2に対する探索加速を使用する。領域1が領域24の可視エリアにないため、領域1のナビゲート可能区分は、より精細な領域24ではなく粗な領域2に対する探索加速データを有する。
更なる実施形態又は別の実施形態は、所定のナビゲート可能区分に対して格納された探索加速データを増加するために可視エリアを更に使用してもよい。これは必要とされる前処理量を増加するが、そのような探索加速データを含む地図データを使用して経路計画が実行される際の速度を向上できる。領域51の可視エリアが領域5及び領域4の双方を含むと仮定すると、領域51の目的地までの加速された探索は、領域4に存在する領域51固有の加速データを既に使用する。すなわち、領域4内の道路区分は追加の探索情報を追加され、それらが領域51に対する更なる最小コストデータを含むことを示す。この追加の情報は関連ビットと呼ばれてもよい。これは、領域4のレベル5にのみ加速データを適用することにより領域51に近接するより広い探索面から悪影響を受ける従来技術にとって利点であると考えられる。
近傍リストの符号化
図6aは、図6と比較して採用されてもよいレベルの更なる詳細を示す。レベル0は、最も粗なレベルであり、レベルk−1と考えられてもよい。簡潔にするために、図6aにおいて、領域1〜4のみが示される(すなわち、602、604、606、608)。k−1領域の各々は、kレベル領域すなわちレベル1領域と呼ばれてもよい9つの領域(1〜9)に更に分割される。また、これらのレベル1領域の各々は4つのk+1レベル領域(すなわち、レベル2領域)に分割される。
ビットベクトルの生成
ネットワークが領域の階層レベル(説明している実施形態においては3)に区分されると、ステップ1910において、それら領域の各々までの最小コストの経路を決定するために処理され、ビットベクトルは領域内の道路区分毎に作成される。従って、上述したように、いずれか1つの領域内の各道路区分は、他の各領域までの最小コストの経路の一部であるかを判定するためにコスト関数に関して解析される。ビットベクトルは、図7に示すように領域の全ての道路区分に対して生成される。図7は、理解しやすくするために簡素化されたビットベクトルを示す。
最小コストの経路は、単一の期間で判定されるのではなく、以下に説明するように複数の期間に対して算出されることが理解されるべきである。
この算出は、図4に示したネットワーク(すなわち、縮小されたネットワーク)に対して行われる。除去された図3のネットワークの部分は、起点となるノードに効果的にまとめられる。例えば図3に示した道路区分304aの終端ノードは、図3のノード302にまとめられる。
各ビットベクトルは3列含むことが分かる。最も左側の列700は、考慮中の道路区分の開始のノードの特定番号を含む。第2の列702は、考慮中の道路区分の終了のノードの特定番号を含む。第3の列704はその道路区分のビットベクトルを含む。従って、各道路区分は、それぞれが道路区分の端部である2つのノードにより特定されることが分かるだろう。
道路区分が最小コスト経路の一部であるかを判定するためにどのような適切な経路指定方法が使用されてもよい。特定の本実施形態において、既知のダイクストラ法がネットワーク全体を探索するために使用される。
しかし、処理時間は種々の戦略を採用することにより短縮されてもよい。上述したネットワークを縮小する技術は、処理時間も短縮することが当業者には理解されるだろう。本発明の実施形態は、以下のうちいずれか1つ以上を採用してもよい。
・領域に対応する全てのビットベクトルエントリを1度に算出する。最短のパス木は、境界上にあるナビゲート可能区分毎に逆グラフにおいて算出される。そのような方法は、各領域が並行に処理されることにより処理時間を短縮するため有利である。
・同様の最短のパス部分木の再計算を減少する。
・既に生成されたビットベクトルを再計算しない。
従って、要約すると、一実施形態はビットベクトルを生成するために以下を実行してもよい。
準備ステップ
1.当業者には理解されるように、電子地図にわたる探索は有向非周期グラフ(DAG)により表される。このグラフ及び隣接するデータ構造(方向転換コスト及び長い範囲テーブル)が逆にされる。
2.最も精細なレベルに対する単純な道路区分は短縮される(すなわち、他で説明するように、終端ノードは一方にまとめられる)。道路区分(すなわち、パス)は、所定のレベルの同一の領域にある程度=2の1つ以上のノードから構成される場合に単純であると言われ、ナビゲート可能区分は同一の属性を有する。例えば、「フェリーである」、「NoThroughである」及び「NoDrivingである」である。
3.道路ネットワークの道路区分は、領域毎に、先端(すなわち、from_node)及び/又は末端(すなわち、to_node)のノードがその領域に属するかに依存して、退出道路区分、進入道路区分及び内部道路区分の3つのグループにソートされる。すなわち、先端及び末端の双方が同一の領域内にある場合、道路区分は内部道路区分と呼ばれる。先端が領域内にあるが末端が領域内にない場合、道路区分は退出道路区分と呼ばれる。末端が領域内にあるが先端が領域内にない場合、道路区分は進入道路区分と呼ばれる。
4.特別な右左折制限は、NoThrough及びNoDrivingエリアを出る全ての道路区分に設けられる。
前処理ルーチンは、最も精細な区分レベル、すなわち説明している実施形態においてはレベル2から開始してボトムアップ方式で進む。領域の各レベルにおいて、以下のステップが領域R毎に繰り返される。
1.Rの探索エリアを判定する。最上位レベル(例えば、説明している実施形態においては領域0)においてはグラフ全体であり、より精細なレベルにおいてはRの可視エリアにより制限された部分グラフである(上述したように)。
従って、中間レベル(すなわち、レベル1)において、以下のステップはレベル1領域が含まれるレベル0領域の可視エリアに対してのみ実行される。レベル0において、長い範囲の経路指定に対して使用されることを注意すべきであり、グラフ全体の道路区分が考慮される。
可視エリアの進入道路区分、すなわちエリア外のノードからエリア内に至る道路区分を収集する。その後、境界付近の道路区分、すなわち進入道路区分に続く道路区分を収集する。先端(L1)=末端(L2)でありL1からL2への方向転換が禁止されていない場合、道路区分L2はL1に続くと言われる(且つL1はL2に先行する)。複雑な交差点は、境界付近の道路区分を見つける目的で単一のノードに短縮される。フェリー路線及び「NoDriving」属性を有する道路区分は境界付近の道路区分と考えられない。
このように進入道路区分を収集することにより、後述する探索ステップで必要とされる処理量を可能性として非常に減少できる。探索ステップは、進入経路を含む所定の領域までの経路を考慮するためにグラフの探索を減少できる。
2.Rの退出道路区分毎に、ルート道路区分及び探索ステップ数を見つける。退出道路区分がR内にある先行道路区分の少なくとも1つの唯一の後続道路区分である場合、この退出道路区分は唯一のルート道路区分であり、単一の探索ステップが実行される。あるいは、退出道路区分が双方向である場合(すなわち、双方向に運転可能である場合)、道路区分自体及びその反対の(進入)道路区分は単一の探索ステップのルート道路区分として利用される。あるいは、退出道路区分が一方向である場合、先行する各内部道路区分(及び存在する場合はその反対の道路区分)は別個の探索ステップのルート道路区分として利用される。最後に、退出道路区分の種類に関係なく、退出道路区分を通る交通範囲パス毎に、範囲の開始道路区分(R内にある場合)は別個の探索ステップのルート道路区分として利用される。
より精細なレベル(すなわち、レベル0以外の全てのレベル)において、退出フェリー路線は特別に処理される。上述したように、フェリー路線は、領域の近傍領域を判定する時に無視される。フェリー路線の先端領域がRの可視エリアに属さない場合、フェリー路線が唯一のルート道路区分であり且つ探索エリアが先端領域自体に制限された状態で単一の探索ステップが実行される。
3.スケジュールされた探索ステップを実行する(以下に説明する)。
4.探索エリア内の道路区分からルート道路区分までの最短パスを辿る。最上位(すなわち、レベル0)以外の全てのレベルにおいて、辿ることを開始する道路区分の順序は結果に影響を及ぼす。RがレベルL領域(L>0)であるとすると、レベル(L−1)領域の退出道路区分は最初に処理され、その後、レベルLの残りの退出道路区分等、最も精細なレベルに向かって処理される。すなわち、最も精細なレベルに関して内部にあり(且つまだ除去されていない)道路区分が最後に処理される。先に辿った時に既に訪れた道路区分に遭遇した場合、2度目にそのパスに従う必要はない。辿っている間、適切な目標ビットベクトルが訪れた道路区分毎に設定される。最上位レベル(すなわち、レベル0)以外の全てのレベルにおいて、以下の追加の動作が行われる。
パスがあるレベルL領域の境界を初めて横切った後、その境界線及びルート道路区分までの途中にある全ての更なる道路区分は通過線フラグにより印がつけられる。
最短パスがUターンをするノードは、Uターンフラグで印がつけられる。
最後に、最も精細なレベル以外の全てのレベルにおいて、相関行列エントリが満たされる。
そのレベルの全ての領域が処理された後、グラフは次のレベルに対して簡素化される。最初に、通過線として印をつけられなかった全ての道路区分が除去される。その後、増加する新しい単純なパスは短縮される。Uターンノードとして印をつけられたノードは保存される。
最後に、ビットベクトルは、相関行列に従って、このレベルを処理する前に除去された道路区分に伝播される。
相関行列
本発明のいくつかの実施形態は、道路区分上にビットベクトルを設定するのに必要な目標領域の間の関係を格納する相関行列を使用する。最も精細なレベル以外の各レベルLにおいて、新しい相関行列が作成され且つ使用される。レベルLにおいて、行列の行は、レベル(L+1)領域により指標をつけられ、列はレベルL領域により指標をつけられ、各行列エントリは0個以上のレベル(L+1)領域の集合である。より低いレベルにおいて、殆どの行列エントリが空の集合と等しい。すなわち、行列は疎である。
相関行列の目的は、早い段階で削除された道路区分にビットベクトルを設定することを助長することである。これらの道路区分は、レベルLの探索ステップの結果として得られた有向非周期グラフに含まれないが、削除されなかった場合は含まれる。より詳細には、相関行列は、あるレベル>Lの算出中に削除されたSの探索エリアの道路区分のあるレベルL領域S(Lは最も精細なレベルではない)にビットベクトルを設定するために使用される。Sの探索エリアに含まれたレベル(L+1)領域Rの場合、行列成分M[R,S]は、SからRまでの全ての最短パス(逆グラフにおける)が1つの領域を通過するように、最終的にRの可視エリアの境界にあるレベル(L+1)領域の集合となる。
行列が作成される場合、全てのエントリは空の集合に初期化される。その後、全てのレベルL領域Sに対して、以下の2つの動作が行われる。
1.行列の構築:Sのルート道路区分l及び結果として得られる有向非周期グラフDを使用する各探索ステップに対して、Sの探索エリアに含まれた各レベル(L+1)領域Rに対して、並びにRの各進入道路区分l’に対して、行列成分M[R,S]が以下のように更新される。
Rの探索領域をAで示す(レベルL+1に対して早い段階で算出されたように)。l’からlまでのDにおけるパスを辿り、Aを出たかを検査する。すなわち、Tが依然としてAに含まれるがT’は含まれない状態で、このパス上の道路区分がレベル(L+1)領域Tからレベル(L+1)領域T’まで通っている場合、Tは集合M[R,S]に追加され、次のl’が処理される。
2.行列を読み出す:レベルL算出が開始する前に削除されたSの探索エリアの各道路区分に対して、Rを道路区分が終了する(ここでも、逆グラフに対して)レベル(L+1)領域とする。ここで、その線上の領域Sに対するビットベクトルのビットは領域Tのビットベクトルの論理和に設定される。尚、TはM[R,S]の全ての要素に及ぶ。
尚、T毎のビットベクトルのビットは、ある有向非周期グラフから直接又はより低いあるレベルにおいて相関行列を含む同様の手順で、より早いレベルで設定される。
探索
探索ステップは、所定の道路区分(対)を根とする最短パスの有向非周期グラフを構築することから成る。これは、最短パス(すなわち、最小コスト)の計算に対して既知のダイクストラ法の一変形例を使用することにより達成される。従来、「最短」という用語が選択される。実際には、最小にされる目的関数が、例えば移動時間又は推定された燃料消費又は他で説明される他の因子のいずれかとして自由に選択される。
一実施形態は、移動時間、パスの長さ、並びに望ましくない方向転換及び操作を抑制する他のペナルティ条件の加重和を使用する。
以下の変形が従来の(ダイクストラ)方法に行われる。
1.道路区分グラフに対して動作する。すなわち、訪れた項目、緩和された項目等がノードではなく道路区分である。これは、方法が右左折制限及び/又は交通範囲を考慮することを可能にするのに有用である。
2.ラベルの目的関数は、ルート道路区分における到着タイムスロットの固定の集合に対する対(移動時間、コスト)のベクトルである。タイムスロットは、全ての関連交通モードが範囲に含まれるように(自由流れ、平日の朝のラッシュアワー、夕方のラッシュアワー等)選択される。これについては、複数の期間におけるコスト関数の評価に関する説明において以下に更に詳述する。
3.2つ以上のラベルが所定の道路区分に対して格納される。2つのラベルにおける保留中(未完了)の交通範囲の集合が等しくない場合、ラベル自体は独立していると言われ、後続する道路区分にわたり伝播し続ける。あるいは、種々の到着タイムスロットに対するコスト関数値の間の関係は交互にならない。すなわち、一方のラベルが他方のラベルより良いのは明確であり、悪い方のラベルは廃棄される。そうでなければ、新しいラベルがタイムスロット毎の良い方の値をマージすることにより作成され、これは元のラベルの代わりに伝播される。先行するマージされたラベルの集合は、先行する元のラベルの集合の結合である。
4.特別なUターンラベルは、双方向の各道路区分において作成される。それらラベルは、双方向の実際の(逆にされていない)経路を開始する可能性を符号化する。Uターンラベルは伝播されず、通常のラベルとマージされなくてもよい。しかし、それらラベルは、ビットベクトルが設定される時に追跡段階に影響を及ぼす。すなわち、開始ラベルが同一道路区分上のUターンラベルより悪くない場合のみ、最短パスはフラグを立てられる。
5.探索エリアが領域の集合に制限されるより精細なレベルにおいて、上記で規定したような境界付近の道路区分は永続的に監視される。全ての境界付近道路区分に探索面が到達するとすぐに、監視コームはタイムスロット毎の最大(=最悪)のコスト関数値から構築される。その後、コスト関数値が少なくとも1つのタイムスロットにおいて現在の監視コームを下回る場合にのみ、探索エリア外の道路区分のラベルはヒープを出た時に伝播される。探索エリアがいくつかの島に及ぶ場合、別個の監視コームが島毎に維持される。
時変関数
本発明のいくつかの実施形態は、単一の時間ではなく複数の期間においてネットワークにわたる最小コストの経路を示すビットベクトルを算出してもよい。道路ネットワークにわたる最小コストの経路は、交通密度の影響等により計時変化する可能性があることが当業者には理解されるだろう。従って、あらゆる1つのノードに対して、それぞれが異なる時間に対するものである2つ以上の最小コストパスが存在してもよい。本実施形態において、ビットベクトルは、最小コストパスが適用可能である場合に対して時間参照により符号化されない。ビットベクトルは、最小コストパスの一部であるとして又は一部でないとしてナビゲート可能区分を特定するために単純に設定される。従って、最小コストデータを使用して経路指定する場合、経路指定アルゴリズムはノードからの可能な全ての最小コストパスを考慮する必要がある。この処理については、図7aを使用して次に簡単に説明する。
ネットワークの一般的なダイクストラ探索において、ネットワークが探索されると、方法はネットワークのその地点に到達するために現在までに発生した合計コスト+まだ発生していない予想されるコストを使用する。
従って、いくつかの実施形態は、各ノードにおいてコスト評価を行うために別個の値とは対照的に関数を利用する。図7aにおいて、探索されているグラフ751の各ノード(例えば、750)はコスト関数と関連付けられ、これは、探索されているパラメータ(例えば、時間又は消費燃料等)が計時変化する様子を特定する。ノード750は、起点ノードとして考えられてもよい。いくつかの実施形態において、起点ノードは起点ナビゲート可能区分と同義語であってもよい。
コスト関数は、ノードとは対照的に道路区分と関連付けられてもよい。
方法は費やしたコストを処理し、新しい関数を生成するために現在までに蓄積したコストを有する現在のノードにおいて関数を合計することにより推定されたコストを加算する。図7aの752で示した例は、探索方法によりノード750で生成されたコスト関数を示し、移動時間(y軸)が出発時間(x軸)に伴って変化する様子を示す。朝及び夕方のラッシュアワーのために移動時間がポイント754及び756において増加していることが分かる。
特定の一実施形態において、コスト関数(例えば、道路区分の平均速度)は5分間隔で格納される。すなわち、これは5分間に変化し続ける関数ではなく量子化関数である。
道路区分に対するビットベクトルは、その道路区分がどの期間においても最小コスト経路の一部である場合に設定される。
完全なネットワークへのコアデータの投影
区分方法により考慮される必要があるノード及び道路区分の数を減少するために地図に含まれたネットワークを縮小する方法について上述した。しかし、経路指定方法が削除された道路区分及びノードに対する経路を依然として生成できるようにするためには、縮小ステップで削除されたノードも更に考慮されるべきである。
従って、削除されたノード及び道路区分は、それらがコアネットワークにおいて接続されるノードと同一の領域に割り当てられる。
圧縮
上述したように、生成されたビットベクトルはサイズが大きいため、情報を圧縮するのが望ましい。本発明の実施形態は、これを種々の方法で実行してもよい。しかし、一実施形態は、ビットベクトルを圧縮、結合及び/又は相関し、その後ビットベクトルのハフマン符号化を行う種々の技術を利用する。
いくつかの実施形態は、ビットベクトルの不均一な分布があることを保証しようとしてもよい。これは、そのような分布がない場合よりハフマン符号化が効率的であることを保証するのを助長できるからである。
例えばビットベクトルが以下のように分布される場合、
0000....(時間の49%)
1111....(時間の49%)
????....(時間の2%)
以下のようなより不均一な分布を有するようにハフマン符号化前のビットベクトルを操作するのが望ましい。
0000....(時間の79%)
1111....(時間の19%)
????....(時間の2%)。
生成されたビットベクトルの縮小
生成される必要があるビットベクトルの量を減少するために、本発明の実施形態は、以下の戦略のうちいずれか1つ以上を使用してもよい。
・領域IDは、全てのノードに対して使用されるわけではなく、ナビゲート可能ノードに対してのみ生成される(例えば、鉄道線路に対応するノードは無視される)。
・ビットベクトルは、全ての道路区分に対して必要とされるわけではなく、決定ノードの周囲の決定道路区分に対して使用されてもよい。決定ノード&決定道路区分は道路区分データを見ることにより判定される(本明細書で説明されるように)。
・可能なビットベクトルが多く存在するが、その一部はその他のビットベクトルよりはるかに頻繁に発生するため、特定の符号化は最も頻度の高いビットベクトル(例えば、000...000及び111...111)に対して使用される。
・多くの場合、000...000でも111...111でもないビットベクトルは、それらの殆どのビットが1に設定されているか又は0に設定されている。従って、部分ブロックのハフマン符号は、それらを非常に効率的に符号化すべきである。
・ビットベクトルは、多くの場合に互いに近接するノードにおいて同一であるため、デルタ符号化がそれらを効率的に符号化できる。
・種々の領域は、ソース領域毎に行先領域IDを再順序付けすることにより、より類似するビットベクトルパターンを有するようにされてもよい(概念は本明細書において説明する)。
・ノードの道路区分の周囲の全てのビットベクトルは、常に111...111を与えるべきである。これはビットベクトルを更に効率的に符号化するために適切に使用される。
これらのうちの一部について、以下に更に詳細に説明する。
尚、この時点では、本明細書で説明される技術の目的はビットベクトルのサイズを縮小することである。しかし、経路指定の目的で地図データを使用する装置によりデータへのランダムアクセスが必要とされる。しかし、一般に、データの効率的な符号化にはデータへのランダムアクセスを防止する可変サイズが必要とされる。
従って、本発明の実施形態は、データが指標をつけられる一連のページとして符号化され且つそれらのページ内で可変符号化を利用するというトレードオフの関係を使用してもよい。そのような実施形態において、ランダムアクセスは各ページに対して達成可能である(指標をつけることにより)。ページがアクセスされると、実施形態はページ全体を復号化してもよい。これにより、効率と地図のサイズとの間にはトレードオフの関係が提供される。ページ毎のノード数を増加すると地図のサイズは減少するが、データアクセスは遅くなる。本発明の特定の一実施形態は、ページ毎に16個のノードを使用する。いずれか1つのノードは、そのノードを出る異なる数の道路区分を有してもよいことが理解されるだろう。従って、同数のノードが存在してもよいが、ページ毎の道路区分の量は可変であってもよい。更に、各ページに格納されたビットベクトルの各々に対して異なる圧縮が適切に行われてもよい。
そのような構造により、図8に示す地図形式が得られる。ここで、数字「n」は、ヘッダ内に格納され、その地図に対して性能を最適化するために種々の地図に対して変更されてもよい。
「n」を調整することは、地図データを復号化する時のアクセス速度と地図のサイズにはトレードオフの関係がある。
・大きな値のnは多くのノードをグループ化する。これは、地図の圧縮には適切であるが、データへのランダムアクセスの速度には不適切である。
・小さな値のnは殆どのノードをグループ化しない。これは、データのランダムアクセスの速度には適切であるが、地図の圧縮には不適切である。
・「n」は例えば4に設定されてもよい。すなわち、16個の出発ノード(出発ノードは道路区分の開始点あり、すなわち図7の列700である)から成るページであるが、各出発ノードはいくつかの到着道路区分を有する。平均で3つの到着道路区分を有すると仮定すると、各ページが〜48個の道路区分を格納することを意味する。
この形式において、符号化される領域のレベルに依存してデータに対する異なる形式が存在する。図9は、レベル0(すなわち、最も粗な領域)に対する形式の一例を示し、図9は、領域の他のレベルに対する形式の一例を示す。
ビットベクトル及び関連情報はデータ構造に格納され、その形式を図8に示す。図8は、ヘッダ800、後述するハフマン符号化で使用されるハフマン木802、各階層における領域数804(レベル毎の領域数が一定の場合は空)、近傍領域806(近傍領域がない場合は空)、領域ID再マッピングテーブル808、ビットベクトルページ指標(2n個のノード)810、並びに領域ID及びビットベクトル812を含む。ビットベクトルを保持するデータ構造は、単一のファイル内に保持されてもよく、あるいは複数のファイル内に保持されてもよい。
いくつかの実施形態において、地図ヘッダ800は、以下を示す更なる情報を含むように構成される。
・レベルの最大数
・最短近傍リストの長さ
・最長近傍リストの長さ
・全ての近傍リストを含むセクションのバイトオフセット。
情報を保持する各ファイルは、近傍リストを符号化するためにセクションを有してもよい。全てのリストのサイズがまず符号化される。リストの各長さは、最短リストの長さに対して、BitsRequired(longestListLength−shortestListLength)により判定された固定のビット数に符号化される。尚、全てのリストが同一の長さを有する場合、長さを符号化するのにビットは必要ない。
その後、全てのリストの内容に従う。各リストは、近傍領域IDのいくつかのタプル、すなわちレベル0ではいくつかの対、レベル2では3つの要素のいくつかのタプルから成る。
尚、出発領域タプル(ASCIIファイルの「:」の前の部分)は符号化されない。これらは、リストが全ての領域に対して昇順に格納されるため黙示的である。例えば地図が100x10x5(レベル0の100個の領域、レベル1の10個の領域、レベル2の5つの領域)を有する3つのレベルを有する場合、以下の通りである。
・レベル0において、リストは出発領域1、2、3、...100(この順序で100個のリスト)に対して格納される。これらリスト各々は対を含む。
・レベル1において、リストは出発領域1.1、1.2、1.3、...1.10、2.1、2.2、...2.10、3.1、...100.9、100.10(この順序で1000個のリスト)に対して格納される。これらのリストの各々は、3つの要素のタプルを含む。
・レベル2において、これは最後のレベルであり近傍領域が存在しないため、何も格納されない。
タプルの各成分はnビットとして格納される。レベル毎のビット数は、対応するレベルの領域数から判定される。従って、リストにランダムにアクセスできる。3つのレベルの100x10x5の場合、タプルa.b.cを符号化するには、aに対しては7ビット(レベル0の領域が100個存在するため)、bに対しては4ビット(レベル1の領域が10個存在するため)及びcに対しては3ビット(レベル2の領域が5つ存在するため)を使用する。
例:100x10x5個の領域、すなわち粗レベル0の100個の領域、中間レベル1の10個の領域及び詳細レベル2の5つの領域の区分を仮定する。
レベル0のファイルにおいて、近傍リストを含むセクションは以下を含む。
・レベル0の100個の領域に対するリストの長さを示す100個の番号。ビット数は、BitsRequired(longestListLength−shortestListLength)から算出される。各番号は、そのレベルの最短リストに相対的である(最短リストはヘッダに格納される)。
・その後、100個のリスト(100対)の内容に従う。各対の第1の要素は7ビット(レベル0の領域が100個存在するため)に符号化され、各対の第2の要素は4ビット(レベル1の領域が10個存在するため)に符号化される。
レベル1のファイルにおいて、近傍リストを含むセクションは以下を含む。
・・レベル1の1000個の領域に対するリストの長さを示す100*10=1000個の数字。
・・1000個のリスト(1000個の3つの要素のタプル)の内容に従う。各タプルの第1の要素は7ビット(レベル0の領域が100個存在するため)に符号化され、各タプルの第2の要素は4ビット(各レベル0領域においてレベル1の領域が10個存在するため)に符号化され、各タプルの第3の要素は3ビット(各レベル1領域においてレベル2の領域が5つ存在するため)に符号化される。
レベル2のファイルにおいて、これは最後のレベルであるため、何も格納する必要がない。
ヘッダ800
一般に、本発明の実施形態で使用されるヘッダは小さく、従ってそのサイズを縮小するためにサイズを最適化する必要はない。一般に、全てが便宜上位置合わせされたバイト又は単語である。
・(4バイト)符号化バージョン(地図形式が変更される度に増加する)
・(4バイト)地図フラグ(機能をON又はOFFする。最初は0であるが、オプションの機能を追加する必要がある場合に後で使用される)
・(4バイト)地図中のノードの合計数
・(4バイト)地図中の道路区分の合計数
・(4バイト)ハフマン木セクションのバイトオフセット
・(4バイト)領域ブロブセクションのバイトオフセット
・(4バイト)領域ページ情報セクションのバイトオフセット
・(4バイト)ビットベクトルページ情報セクションのバイトオフセット
・(4バイト)可変サイズレコードセクションのバイトオフセット
・(4バイト)ビットベクトルページの最大ビット数(起動時にビットストリーム復号器に対して悪い例を事前に割り当てるために経路計画方法により使用される)
・(4バイト)平均ビットベクトルページサイズのビット数(ビットベクトルページ位置を補間するために使用される)
・(4バイト)最小ビットベクトルページデルタ(全てのデルタを>=0にするために使用され、ビットサインを格納することを回避する)
・(2バイト)ビットベクトル履歴の最大サイズ(起動時に履歴バッファを事前に割り当てるために経路計画方法により使用される)
・(2バイト)ページ毎の道路区分の最大数(現在使用されていない)
・(1バイト)このファイルのアポロレベル
・(1バイト)ビットベクトル毎のビット
・(1バイト)ビットベクトルページデルタ毎のビット(ビットベクトルページの固定サイズレコードのフィールド)
・(1バイト)ブロブ指標毎のビット(領域ページ情報の固定サイズレコードのフィールド)
・(1バイト)領域数毎のビット(領域ページ情報の固定サイズレコードのフィールド)
・(1バイト)非自明なビットベクトルブロック毎のビット
・(1バイト)領域ノードページサイズのlog_2()
・(1バイト)ビットベクトルページサイズのlog_2()
・(1バイト)ローカル領域IDを符号化するためのハフマン木の数
・(1バイト)ビットベクトル履歴符号を符号化するためのハフマン木の数。
ハフマン木802
・各ノードの周囲の道路区分数を符号化するためのハフマン木。小さく、10個ほどの符号がレベル0のファイルにのみ存在する)
・非自明なビットベクトルのブロックを格納するためのハフマン木。最大のハフマン木であり、大きい程、圧縮に適切であるが、経路計画方法で必要とされるメモリは多くなる(経路計画方法でのメモリの使用量と地図圧縮との間のトレードオフの関係)。
・履歴サイズが0である場合のビットベクトルデルタ符号のハフマン木。小さく、符号を3つだけ含む。
・履歴サイズが1である場合のビットベクトルデルタ符号のハフマン木。小さく、符号を4つだけ含む。
・履歴サイズが>=nである場合のビットベクトルデルタ符号のハフマン木。小さい(ヘッダに格納されたハフマン木の数)。
・領域ページに3つの領域が存在する場合の領域IDに対するハフマン木。小さく、符号を3つだけ含む。
・領域ページに4つの領域が存在する場合の領域IDに対するハフマン木。小さく、符号を4つだけ含む。
・領域ページに>=n個の領域が存在する場合の領域ID対するハフマン木。小さい(ヘッダに格納されたハフマン木の数)。
領域再マップテーブル804及び領域IDリスト806
図8のファイル形式の他の部分より小さいが、領域ID806は、図11に例示するように圧縮されてもよい。ここで、使用されるデータ量を減少するために、地理的相関が使用されてもよい。
各領域ページは、その領域ページの別個の領域のリストを格納する。このリストは、殆どの場合に小さいと予想される(実際には、多くのページは少なくともレベル0の領域を1つだけ含む可能性が高い)。領域のリストは可変サイズを有する。ページ内のデータは、ランダムにアクセス可能であるべきであり(すなわち、ランダムアクセス)、固定テーブルサイズはこれを可能にするために使用される。
別個の領域の各リストは、各領域のノードの頻度により順序付けされる。リストの第1の要素は、ページ中の最大数のノードを含む領域に対応し、リストの再度の要素は、ページ中の最小数のノードを含む領域である。
領域ページの各ノードにおいて、ローカル領域ID(ページにローカルな)を使用してその領域IDを符号化できる。このローカルIDは、ページ中の領域の指標である(これは小さい整数であり、0は領域ページの最も一般的な領域に対応するため、多くの場合は0である)。
ノードの領域IDは以下のように格納される。
・領域ID’を含む領域配列はページ中の領域の可能な重複リストを全て格納する。領域のリストは、その配列において連続した領域IDである。リストは、重複してもよい(重複する)。配列は各リストの開始及び終了を格納しない(これは、領域ページ情報テーブルにより行われる)。
・領域ページ情報テーブルは固定サイズレコードテーブルであり(従って、ランダムにアクセス可能である)、各レコードはリストの開始の配列における指標+リスト中の項目数を含む。
・各ノードはローカルノードID(そのページにローカルな)を含む。
これらの概念の各々については、以下に更に規定する。
領域配列
領域配列は、ページの全ての可能な領域リストを符号化する。領域IDのリストが重複してもよい領域IDの単純な配列である。そのサイズは、リストが重複するため小さい。領域配列については、領域ページ情報の節で更に説明される。
領域ページ情報
領域ページテーブルの領域IDのリストを指定するには、領域ページ情報テーブルの固定サイズレコードの2つのフィールドを使用する。
・領域数(このページの領域数であり、小さいと予想される)
・領域リストの配列へのオフセット(ここで領域のリストが開始する)
一実施形態において、これについては図9で説明する通りである。
オフセットフィールドは領域配列を示す。領域ID毎に1バイトの固定サイズレコードで十分である。例えば、各レベルには256個未満の領域が常に存在すると仮定する。これは妥当な仮定である(しかし、レベル毎に最大256個の領域というのは制限しすぎであると考えられる場合、8ビットより大きくすることは容易に可能である)。領域ページテーブルレコードの領域数は、指定されたオフセットで配列にあると考えられる領域数を示す。
いくつかの領域が同一リストを有する場合、それらは同一の場所を示せる。これは、多くのページが同一リストを共有するか又は同一リストの部分を共有することが予想できるためコンパクトであるべきである。
これについては、図9を参照して更に詳細に説明する。図9は、2^nr個のノード(例えば、512個のノードをグループ化するためにnr=9)のページを有する一実施形態を示す。
尚、いくつかのページが配列において同一の場所又は重複する場所(図中、領域ブロブとラベル付された)を示せるため、領域IDの配列900は非常にコンパクトである。実際には、各ページがより少ない領域と重複し、組み合わせの可能性が低減されるため、ページ数を増加することにより配列のサイズは増加されない。従って、この配列は、生成された地図データがロードされる装置において多くの地図空間も多くのメモリも必要とせずに多くのページを作成することを可能にすべきである。
方法の目的は、領域IDのリストを含む配列900を可能な限り小さく維持することである。方法の目的は、領域IDの同一のリストを配列において可能な限り多く再利用することである。方法は、リストの最後の2つの要素がハフマン符号のサイズに影響を及ぼさないためそれらの要素を自由に再順序付けできる。
例えばリストが2つの領域10及び34を含む場合、2つのノードが存在する全ての例においてハフマン木が1ビットのみを使用するため、これはリスト10、34又は34、10を格納すること(頻度に関係なく)と同等である。換言すると、頻度により再順序付けすることは、最後の2つの領域に対して緩和される。同様に、第1の符号10(頻度が最も高い)のみが1ビットを使用し、他の符号40及び34の双方が2ビットを使用する(順序に関係なく)ため、3つの要素10、34、40のリストは10、40、34として格納されてもよい。
図9を参照すると、配列900が2つの値、すなわち長さ及び領域データの開始からのオフセットを格納することが分かる。第1の行(3:0)を考慮すると、これはファイルの開始から0だけオフセットして3つのデータを参照する(すなわち、10、34、40)。更なる例を考慮すると、配列エントリ(1:2)は、ファイルの開始から2だけオフセットした単一の領域(すなわち、長さ1)を参照する(すなわち、領域40)。
別の実施形態において、領域ページ情報は、以下の方法に従って符号化される。
このセクションは、各領域のサブ領域数を符号化する。サブ領域の数はレベル毎に可変であってもよい。しかし、サブ領域数がレベル毎に一定であることが多い。サブ領域数は、log_2(max_number_of_regions−min_number_of_region)ビットを使用して、各レベルの最小領域数に対して相対的に符号化される。従って、領域数が一定である場合、領域数を符号化するために0ビットが使用され、このセクションは空である。最小領域数及び最大領域数は、副ファイルのヘッダに格納される。
近傍領域セクションの符号化(近傍領域についは、図6及び図6aに関連して説明する)
このセクションは、所定のレベルLの領域階層毎に、より詳細なレベルL+1の近傍領域のリストを符号化する。例えば、レベルL=1の領域3.9は、レベルL=2において近傍領域のリスト、3.5.4、3.6.3、3.6.4、4.7.1、4.7.3を有してもよい。他で説明するように、近傍領域のリストは、各副ファイルを生成するのに使用される前処理の速度を向上するために使用されてもよい。
このセクションは2つのサブセクションに分割される。
・全ての近傍リスト(所定のレベルにある領域と同数)の長さを符号化するサブセクション。長さは、最短リストに対して相対的に符号化され、ビット数はlog_2(length_longest_list−length_shortest_list)で計算される。全てのリストが同一の長さを有する場合、長さを符号化するのに0ビットが使用される(従って、セクションは空である)。
・全ての近傍リスト(所定のレベルにある領域と同数)を符号化するサブセクション。
領域ID再マッピングテーブルの符号化
このセクションは、レベル0の副ファイルでのみ符号化される。これは、レベル0の各領域のビットを再順序付けし且つ結合するのに使用される2次元テーブルを符号化する(ビットベクトルを効率的に符号化するために、結合及びビット再順序付けについて本文献において以下に更に説明する)。ビットベクトルのビットの再順序付け及び結合は、ビットベクトルのハフマン符号化を最適化するために行われる。このテーブルは、以下が分かっている場合に復号化するビットベクトルにおけるビット位置を見つけるために経路計画方法により使用される。
・現在のノードの出発領域ID
・元の到着ビット指標(すなわち、ビットベクトルのビットを分離した後のビット指標)
2次元テーブルの2つの指標は以下の通りである。
・出発領域ID
・行先ビット指標(目的地の領域)
このセクションは2つのサブセクションから成る。
・レベル0の領域毎に結合ビット数を符号化するセクション。各数を符号化するために使用されるビット数は、log_2(max_number_of_coalesced_bits)である。
・ビット再マッピングテーブルを符号化するセクション。経路指定する場合、行先ビットは変化しないが(経路指定の間、目的地は同一のままである)、出発領域IDは行先ビットの行により格納された行列を変更する(経路指定中に探索されるノードに依存して)。各行において、ビット再順序付け番号は、出発領域毎に格納される。一般に、経路計画方法は、経路指定中、所定の経路指定目的地に対応するメモリの1行のみをロードする。経路計画方法は、2次元行列全体をメモリに格納する必要はない。経路計画方法は、その行にランダムにアクセスできる。各再マッピングエントリを符号化するのに使用されるビット数は、log_2(最大結合ビット数)で計算される。
図10は、レベル0領域(図6を参照)に対する図8に示したファイルのビットベクトルセクション812を展開する。各ページが道路区分数、領域ID及びビットベクトルを含むことが分かる。
図11は、レベル0以外のレベルに対する図8に示したファイルのビットベクトルセクション812を展開する。他の領域に対して、ビットベクトルのみが格納され、レベル0に対して格納される道路区分数又は領域IDは格納されない。
これは、より精細なレベルにおいて、各ノードがレベル0の副ファイルに格納された全てのレベルに対する領域番号を有するためである。そのように格納する理由は、副ファイルを使用するいずれかの経路計画の間にアクセスされる必要のあるファイル数を減少するためである。
ビットベクトル810、812の符号化
テーブル810は固定サイズレコードを含む。出発ノードIDは2nのページにグループ化される。
ビットベクトルが同一の近傍領域のいくつかの道路区分に対して同様のパターンを有すると予想されるため、複数の連続したノードのページにデータをグループ化するのが便利である。ページを使用することにより、いくつかの道路区分をデルタに符号化でき、適切な圧縮を達成できる。同様に、ページにおいてデルタにノードの領域IDを符号化できる。一方、これは、1つの道路区分のデータにアクセスすることがいくつかの道路区分のデータをアンパックすることを必要とすること(直接ランダムアクセスではない)を意味する。1つの道路区分又はノードのデータにアクセスするのにいくつかのノード又は道路区分をアンパックする必要があることは、以下の理由により受け入れ可能であると考えられる。
・データは、1つの道路区分にアクセスする時に読み出された追加のデータが無用でないことが多いためキャッシュされる。この追加のデータはすぐ後で有用となるだろう(これは、ディスクキャッシングの先読みパラメータに類似する)。
・ビットベクトルを使用する経路指定は、ダイクストラA*経路指定と比較した時に拡張探索のサイズをある桁だけ減少する。ページ毎にデータをグループ化することにより、地図の小さな部分が依然として復号化される必要がある(実際のパスに沿うページ)。
・領域ID&ビットベクトルのデルタ圧縮のために符号化データサイズが非常に縮小される。
・上述したようにデータが副ファイルに格納されるため、ページは指標付けのサイズを縮小する。
テーブル810内の各レコードは、「デルタ」フィールドを含み、これは、各ページの可変サイズの開始位置(補間位置に対するデルタ)を見つけるために使用される。デルタ毎のビット数はヘッダに格納される。
領域ID及びビットベクトル812にアクセスするために、復号器は線形補間を行うことにより開始ページの推定されたオフセットを計算してもよい。
interpolated_offset = from_node_id * avg_page_size
式中、avg_page_sizeはヘッダに格納された平均ページサイズのビット数である(精度を向上するために可能性として固定点における)。データのオフセットは、以下のように計算される。
オフセット = interpolated_offset + min_delta + デルタ
式中、min_deltaは全てのページ(ヘッダに格納された)に対する全てのデルタフィールドの最小値であり、デルタは、ページに格納された符号なしフィールドである。min_delta値は、全てのデルタフィールドが正の値であること(格納するビット符号はない)を保証する。
可変サイズレコードは、上述したビットベクトルページ情報の「デルタ」フィールドを介してアクセスされる。
各レコードは、2個のノードのデータ(全てのレベルにおける出発ノードの領域ID及びそれらの連結道路区分のビットベクトル)を含む。従って、同一の指標付け方式が全てのレベルに対して使用される。
可変サイズレコードは以下を格納する。
・ページ符号−そのページ内のノードが同一領域の一部であるか否かを示すページ全体に対する符号。
・ビットベクトルページの各ノードの周囲の道路区分数(全てのレベルに対して同一であるため、レベル0でのみ格納される)。
・ページの出発ノードの領域ID。レベル毎に1つのIDがある(レベル0でファイルに格納された全てのレベルに対する情報)。
・レベルiのみのページのノードの周囲(>2個の連結道路区分を有するノードの周囲のみ)の道路区分のビットベクトル。これはデータの最大の部分である。
・各ノードの周囲の道路区分数の符号化。
ビットベクトルページの2個のノードの各々に対して、ハフマン符号はノードの周囲の道路区分数を符号化する。この情報は、全てのレベルに固有のものではなく、レベル0のファイル(ap_0_*.dat)にのみ格納される。
ノードの周囲の道路区分数を認識することは、ビットベクトルを復号化するのに使用される(図10の1000を参照)。この情報は、他のファイルに既に存在する情報と冗長するが、他の場所にある情報をルックアップする必要なくページ中のビットベクトルを復号化するのを容易に且つ迅速にする。これにより、サイズの小さな増加が性能を向上する。
可変サイズレコードの領域IDの符号化
ノードの領域ID1002は、各ノードの周囲の道路区分数1000の符号化の直後に可変サイズレコードに符号化される。前処理において生成されたビットベクトルを使用して経路指定を行うために、一般に所定のノードに対する全てのレベルの領域ID1002にアクセスする必要があり、全てのレベルの領域IDは、レベル毎に異なるファイルに分割されるのではなく互いに近接して同一ファイルに格納される。
3つのアポロレベルを有する2n(例えば、n=4)個のノードのビットベクトルページは以下のようにノードIDを格納する。
ノード#0:local_region_id_level_0 local_region_id_level_1 local_region_id_level_2
ノード#1:local_region_id_level_0 local_region_id_level_1 local_region_id_level_2
ノード#2:local_region_id_level_0 local_region_id_level_1 local_region_id_level_2
...
ノード#15:local_region_id_level_0 local_region_id_level_1 local_region_id_level_2
更に、以下の通りである。
・1つ又は2つの連結道路区分を有するノードの周囲で符号化されるものはない(すなわち、連結道路区分数として0を格納するノードに対して)。
・ページ符号のビットが所定のレベルで設定される場合、全てのノードはそのレベルの同一領域IDにあり、そのレベルの領域IDは1度だけ符号化される(>=3個の連結道路区分を有する第1のノードに対して)。領域IDを符号化するビット数はlog_2(regionCount−1)である。
・領域IDが符号化されるページの第1のノード以外は、各領域IDを符号化する前にビットが符号化される。このビットは、領域IDが同一レベルの先に符号化されたノードIDと同一であるかを示す。このビットが設定される場合、そのレベルの先に符号化されたものと同一であるため、領域IDを符号化する必要はない。このビットが0である場合、log_2(regionCount−1)ビットで領域IDを符号化する。多くの連続したノードが同一の領域にあるため、領域IDを符号化するのに1ビットだけ必要とすることが多い。
以下の理由のために、ローカル領域指標のハフマン符号化は効率的である。
・領域は各領域ページにおける頻度によりソートされる(従って、ローカル指標0はローカル指標1、...より頻度が高い)。
・ページの領域数毎に別個の専用のハフマン木が存在する(3つの領域がページにある場合に1つのハフマン、4つの領域がページにある場合に1つのハフマン木等)。ハフマン木は小さいため、メモリを多く使用せずにいくつか格納できる。
・少なくともレベル0において、3つ以上の領域を有することは極めて珍しい(しかし、他のレベルでは珍しくない)。
可変サイズレコードのビットベクトルの符号化
各可変サイズレコードは、ページのノードの周囲の全ての道路区分に対するビットベクトルを含む。ビットベクトルは、3つ以上の連結された線(道路区分)を有するノードの周囲でのみ符号化される。1つ又は2つの連結道路区分を有するノードの場合、経路指定方法は、それらのノードにビットベクトル値111...111を黙示的に与えられる。
到着ノードは符号化されない。
図7を参照すると、道路区分は、それぞれが道路区分の端部にある2つのノードにより指定されてもよい。従って、方向が考慮される場合、方向の開始にあるノードはfrom_nodeと呼ばれてもよく、方向の終了にあるノードはto_nodeと呼ばれてもよい。
ビットベクトルに関する種々のプロパティは、効率的にするために符号化内で使用される。
・ビットベクトルの多くは000...000又は111...111である。
・ビットベクトルの他の値(すなわち、000...000でも111...111でもない)に対しては、繰り返しになる可能性が高く、同一の値が繰り返される可能性が高い。
ビットベクトルは、第1のハフマン符号及びオプションの更なるハフマン符号として符号化される。第1のハフマン符号は、ビットベクトルが以下のいずれであるかを示す。
・自明なビットベクトル000...000に対する符号0
・自明なビットベクトル111...111に対する符号1
・符号2、すなわちページでまだ遭遇していない非自明なビットベクトルを示す符号。この場合のみ、新たに遭遇したビットベクトルを符号化するために他のハフマン符号が後続する。
・ビットベクトルが現在のページの先に遭遇したビットベクトルと同一である場合(自明なビットベクトル000...000及び111...111は無視する)、>=2の符号。この符号化は、ページの先に遭遇した符号の履歴を使用する。符号は、実際には先に遭遇した全ての符号の履歴中の指標を与える。
このハフマン符号以外は、履歴中で見つけられなかった非自明なビットベクトルの場合(符号=2)にのみ、更なる情報が符号化される必要がある。この場合、ハフマン符号==2の直後に以下が符号化される。
・否定ビット
・Nビットのブロックによりn個の領域に対するビットベクトルを符号化するためのいくつかのハフマン符号(N及びnは地図ヘッダで与えられる)。例えば、100個の領域(99ビットのビットベクトル)を11ビットのブロックを使用して符号化することは、9個のハフマン符号(9x11=99)を符号化することを必要とする。
殆どのビットベクトルは殆どが0又は殆どが1のベクトルを含むため、否定ビットは、ビットベクトルが否定されて格納されるか否かを示す。これにより、殆どが0のベクトルを多く含むハフマン木への符号の格納を可能にする(これにより、ブロックのハフマン符号化を向上する)。ブロックのサイズが領域数より小さい場合にのみ否定ビットは存在し、これは、実際にはレベル0において当てはまるが、レベル1又は2において、ビットベクトル全体は1つのブロックにのみ符号化されるため否定ビットは必要ない。
100個の領域が存在する場合、すなわちN=100(従って、99ビットのビットベクトル)の場合、第1のブロックは行先領域1〜11に対するビットを符号化し、第2のブロックは領域12〜22を符号化する。第1のブロックにおいて、LSB(0x1)は行先領域1に対応し、次のビット(0x2)は領域2に対応し、次のビット(0x4)は領域3に対応する。
履歴を使用するビットベクトルの場合、履歴配列の深さはページ中の先に遭遇した別個のビットベクトルの数である(自明なビットベクトル000...000及び111...111を考慮に入れない)。異なるハフマン木は、履歴ベクトルが0個の要素、1つの要素、2つの要素、3つの要素等を含むかに関わらず使用される。全てのハフマン木が小さいために大きな記憶容量が必要とされないため、ハフマン木を増加することは受け入れられる。
・履歴が0個の要素を有する場合、ハフマン木は3つの符号、すなわち000...000に対する0、111...111に対する1、新しいビットベクトルに対する2を有する。
・履歴が1つの要素を有する場合、ハフマン木は4つの符号、すなわち000...000に対する0、111...111に対する1、新しいビットベクトルに対する2、履歴の要素#0と同一のベクトルに対する3を有する。
・履歴が2つの要素を有する場合、ハフマン木は5つの符号、すなわち000...000に対する0、111...111に対する1、新しいビットベクトルに対する2、履歴の要素#0と同一のベクトルに対する3、履歴の要素#1と同一のベクトルに対する4を有する。
・その他。
ビットベクトルページのサイズが小さい(例えば、2n個の出発ノード)と予想されると、ハフマン木の数も小さいと予想される。
しかし、ハフマン木のサイズを最大値に制限できる。例えば履歴がH個より多くの要素を含む場合は必ず、単一のハフマン木が使用される(値Hは地図ヘッダに格納される)。
この符号化は、各ページ中の別個のビットベクトル+いくつかの符号のみを符号化する。
経路指定の目的でビットベクトル(ページ中の復号化するより多くのビットベクトル)を使用するために、符号化は、復号化を遅くする代わりに大きな指標のページに対してサイズに関してより効率的である。
統計
ベネルクスを254個の領域(1つのレベル)に符号化する場合のファイル形式に対する詳細な統計を示す。以下の入力パラメータを使用した。
ビットベクトルブロック毎のビット数:11
ビットベクトルページ毎のノード数:2^4=16
領域ページ毎のノード数:2^9=512
統計は、地図のサイズに関して地図形式の概念を与え且つ実データに関する地図形式の記述を示すために提供される。
−−−グローバル統計カウンタ:
ノード数.......................1598632
線の数........................ 1598632(100.000%)
1つの線を有するノードの周囲の線をスキップする... 220180( 13.773%)
2つの線を有するノードの周囲の線をスキップする... 727138( 45.485%)
−−−レベル=[0]の統計:
地図カウンタ......................87437736(100.000%)
符号化された自明なarpフラグ000...000... 1310914( 31.651%)
符号化された自明なarpフラグ111...111... 913348( 22.052%)
履歴中の符号化されたarpフラグ........... 362432( 8.751%)
履歴中にない符号化されたarpフラグ......... 607717( 14.673%)
否定ブロック.................... 235171( 5.678%)
地図のサイズ(ビット).................87437736(100.000%)
グローバルヘッダ................... 496( 0.001%)
ハフマン木...................... 28808( 0.033%)
領域ブロブ...................... 52664( 0.060%)
領域ページ情報.................... 56216( 0.064%)
arpフラグページ情報................ 2497880( 2.857%)
可変サイズレコード..................84801672( 96.985%)
ノードの周囲の線の数................ 2847844( 3.257%)
ノード領域ID................... 2112451( 2.416%)
arpフラグ....................79841370( 91.312%)
自明な符号000...000........... 1689322( 1.932%)
自明な符号111...111........... 1826696( 2.089%)
履歴中で見つけられた符号............. 1668053( 1.908%)
履歴中で見つけられない..............74657299( 85.383%)
履歴中で見つけられない符号........... 1463183( 1.673%)
否定ビット................... 607717( 0.695%)
ブロック....................72586399( 83.015%)
全てのサイズはビット単位である。地図の合計サイズは、87,437,736ビット(10,929,717バイト)である。
インデントは階層を反映している。可変サイズレコード情報は、圧倒的に大きい情報(地図のサイズの96.975%)である。可変サイズレコードにおいて、サブ項目(インデントされた)はより詳細を与える。ビットベクトルは、可変サイズレコードに格納する圧倒的に大きな情報(91.312%)である。ビットベクトルにおいて、履歴においてまだ遭遇していない非自明なビットベクトルを格納することは地図の最大部分を構成する(83.015%)。
ハフマン木に関する統計
このセクションは、ベネルクスを255個の領域に符号化する(すなわち、上記で示した地図データに対して)場合のハフマン木に対する統計を与える。
各ノードの周囲の道路区分数のハフマン木
−−−[ハフマン木:Nr本の線]−−−
ビット: 1 値: 3 符号 0
ビット: 2 値: 2 符号 10
ビット: 3 値: 1 符号 110
ビット: 4 値: 4 符号 1110
ビット: 5 値: 5 符号 11110
ビット: 6 値: 6 符号 111110
ビット: 7 値: 7 符号 1111110
ビット: 7 値: 8 符号 1111111
殆どのノードは3つの連結道路区分を有するが、ハフマン木の第2及び第3の位置において、2つ又は1つの連結道路区分を有するノード(決定ノードではない)を見つける。
非自明なビットベクトルブロックのハフマン木
自明なビットベクトルのブロックを格納することが圧倒的に大きな地図のサイズを占める(ベネルクスの255個の領域の例において83.015%)ため、これは最大のハフマン木である。
−−−[ハフマン木:NonTrivialArpFlagBlock]−−−
ビット: 1 値: 0 符号 0
ビット: 6 値: 1 符号 100000
ビット: 6 値: 2 符号 100001
ビット: 6 値: 4 符号 100010
ビット: 6 値: 8 符号 100011
ビット: 6 値: 16 符号 100100
ビット: 6 値: 32 符号 100101
ビット: 6 値: 64 符号 100110
ビット: 6 値: 512 符号 100111
ビット: 6 値:1024 符号 101000
ビット: 7 値: 128 符号 1010010
ビット: 7 値: 256 符号 1010011
ビット: 7 値: 384 符号 1010100
ビット: 8 値: 5 符号 10101010
...大きすぎるため中略...
ビット: 24 値:1534 符号 111111111111111111111011
ビット: 24 値:1717 符号 111111111111111111111100
ビット: 24 値:1741 符号 111111111111111111111101
ビット: 24 値:1830 符号 111111111111111111111110
ビット: 24 値:1973 符号 111111111111111111111111
全て0から成るブロックを格納することは、頻度が最も高いパターンであり、上記ハフマン木に従って1ビットのみに符号化される(これは、自明なビットベクトル000...000がブロックにより符号化されないが、ブロックの50%以上が値0を符号化することを意味する)。これは、殆どの非自明なビットベクトルが以下のいずれかを含むためである。
・殆どが0(及びいくつかの1)
・殆どが1(及びいくつかの0)
符号化方式は、殆どが1であるビットベクトルに否定演算(〜)をし、最終的にビットベクトルのブロックを符号化することは、主に、000...000を含むブロックを1ビットにのみ符号化する。次に頻度の高いブロックは、1ビットのみが設定されるブロックである(1、2、4、8、16、32、64...)。これらのブロックは同程度の頻度を有するため、同一(又はほぼ同一)のビット数を有する。
ローカル領域IDのハフマン木
領域のリストが頻度により各ページに格納されるため、ローカル領域ID0を格納することは他の場所の領域IDより少ないビット数(実際には1ビットのみ)を利用する。種々のハフマン木は、3つの領域、4つの領域、5つの領域等を含むページに対応する。
−−−[ハフマン木:Regions_0]−−−
ビット: 1 値: 0 符号 0
ビット: 2 値: 1 符号 10
ビット: 2 値: 2 符号 11
−−−[ハフマン木:Regions_1]−−−
ビット: 1 値: 0 符号 0
ビット: 2 値: 1 符号 10
ビット: 3 値: 2 符号 110
ビット: 3 値: 3 符号 111
−−−[ハフマン木:Regions_2]−−−
ビット: 1 値: 0 符号 0
ビット: 2 値: 1 符号 10
ビット: 3 値: 2 符号 110
ビット: 4 値: 3 符号 1110
ビット: 4 値: 4 符号 1111
−−−[ハフマン木:Regions_3]−−−
ビット: 1 値: 0 符号 0
ビット: 2 値: 1 符号 10
ビット: 3 値: 2 符号 110
ビット: 4 値: 3 符号 1110
ビット: 5 値: 4 符号 11110
ビット: 5 値: 5 符号 11111
...以下略...。
ビットベクトル履歴符号のハフマン木
符号0(自明なビットベクトル000...000を意味する)は、頻度が最も高い(且つ殆どの場合、1ビットにのみ符号化される)。符号1(自明なビットベクトル111...111は、次に頻度が高い(且つ1ビットにのみ符号化される)。次に頻度が高い符号(2)は、ブロックにより符号化された非自明なビットベクトルに対するものである。他のコード(>2)は履歴中に見つけられるビットベクトルに対するものである。
−−−[ハフマン木:ArpFlag_0]−−−
ビット: 1 値: 0 符号 0
ビット: 2 値: 1 符号 10
ビット: 2 値: 2 符号 11
−−−[ハフマン木:ArpFlag_1]−−−
ビット: 1 値: 0 符号 0
ビット: 2 値: 1 符号 10
ビット: 3 値: 2 符号 110
ビット: 3 値: 3 符号 111
−−−[ハフマン木:ArpFlag_2]−−−
ビット: 1 値: 0 符号 0
ビット: 2 値: 1 符号 10
ビット: 3 値: 2 符号 110
ビット: 4 値: 3 符号 1110
ビット: 4 値: 4 符号 1111
−−−[ハフマン木:ArpFlag_3]−−−
ビット: 1 値: 0 符号 0
ビット: 2 値: 1 符号 10
ビット: 3 値: 2 符号 110
ビット: 4 値: 3 符号 1110
ビット: 5 値: 4 符号 11110
ビット: 5 値: 5 符号 11111
−−−[ハフマン木:ArpFlag_4]−−−
ビット: 1 値: 0 符号 0
ビット: 2 値: 1 符号 10
ビット: 3 値: 2 符号 110
ビット: 4 値: 3 符号 1110
ビット: 5 値: 4 符号 11110
ビット: 6 値: 5 符号 111110
ビット: 6 値: 6 符号 111111
−−−[ハフマン木:ArpFlag_5]−−−
ビット: 2 値: 0 符号 0
ビット: 2 値: 1 符号 01
ビット: 2 値: 2 符号 10
ビット: 4 値: 3 符号 1100
ビット: 4 値: 4 符号 1101
ビット: 4 値: 5 符号 1110
ビット: 5 値: 6 符号 11110
ビット: 5 値: 7 符号 11111
...以下略...。
地図のサイズに対する入力パラメータの影響
図8に示したファイル形式を制御し且つ地図のサイズに影響を及ぼす入力パラメータが多く存在する。パラメータを微調整することは、パラメータに依存する伸張の速度又はメモリ使用量と地図のサイズとの間のトレードオフの関係となる。
本発明の実施形態は、以下の入力パラメータを使用してもよい。
・領域ページサイズ
・ビットベクトルページサイズ
・ビットベクトルブロックサイズ
・ビットベクトルハフマンコーデック数
・領域ハフマンコーデック数。
ビットベクトルブロックサイズの影響
値 地図のサイズ(ビット)
4 35548192
5 33648792
6 32290344
7 30853616
8 31103200
9 30436696(デフォルト)
10 30051792
11 29266784
12 28934696。
ビットベクトルに対するハフマンブロックサイズを増加することにより、地図圧縮は向上される。ブロックサイズが大きい程、圧縮はより適切になる。しかし、ブロックサイズを増加することは、2^n個の値のより大きなハフマン木を格納するのにより大きなメモリが必要となる。上記テーブルはこのことを示す。
ソース領域毎に領域IDを再マッピングするために最適化を導入する場合、このパラメータの影響はより大きくなると予想される。この最適化の結果、大きいビットベクトルブロックサイズを使用する場合に地図のサイズが非常に減少されるのが望ましい。
ビットベクトルページサイズの影響
値 地図のサイズ(ビット)
2^1 55563944
2^2 42502936
2^3 34898840
2^4 30436696(デフォルト)
2^5 27389952
2^6 25165032
2^7 23635936
ページサイズを増加することは、地図をより適切に圧縮するのを助長する。しかし、ランダムな道路区分のビットベクトルにアクセスするにはページ中の全ての道路区分を復号化する必要があるため、大きなページは経路指定方法によりデータをファイル形式に伸張することを遅くする。上記テーブルはこのことを示す。
ビットベクトルハフマンコーデック数の影響
値 地図のサイズ(ビット)
1 30866920
2 30748024
3 30634168
5 30504504
7 30467944
9 30436696(デフォルト)
11 30423688
ビットベクトルハフマンコーデックの数を増加することは、圧縮を僅かに向上させるのを助長し、これを上記テーブルに示す。ハフマン木はいずれの場合も小さいため、値を増加することに対する欠点はほぼない。9個(デフォルト値)を上回ってハフマン木を増加しても大きな改善は得られない。このパラメータを増加することは、ビットベクトルページが大きいほど効果的である可能性がある。
ビットベクトルのビットの結合&再順序付け
ビットベクトルはパターンを有する。これらのパターンはソース領域(すなわち、ビットベクトルが格納されるノードの領域)毎に大きく異なる。Nビットのビットベクトルを格納するためのビット数は、ソース領域毎に小さな変換テーブルを格納することにより減少される。これらのテーブルは、この節で更に説明される2つの関数を実行する。
・ビットの結合
・ビットの再順序付け
概念は、以下のように直感的に理解される。スペインの場合、スウェーデン(行先領域スウェーデンに対してビット=1)に通じている道路区分は、ノルウェー(すなわち、目的地ノルウェーに対するビットも1)に通じている可能性が高いことは明らかである。別の道路区分がスウェーデン(ビット=0)に通じていない場合、その道路区分は殆どの場合においてノルウェーにも通じていない。従って、スペインの場合、行先領域スウェーデン及びノルウェーに対するビットベクトルのビットの値はほぼ常に等しい。実際には、ビットの値は多くの行先領域に対して常に厳密に等しい。どのビットがどのビットに相関しているかは、出発領域に大きく依存する。
例えばフィンランドの場合、行先領域ノルウェー及びスウェーデンに対するビットは殆ど相関しない。一方、フィンランドにおいて、行先領域スペイン及びポルトガルに対するビットは100%(又は少なくともほぼ100%)相関する可能性が高い。
ビットの結合は、いくつかのビットが常に等しい(完全に相関される)というプロパティを利用する。これらのビットは単一ビットに結合される。ビットを結合することにより、各領域で符号化するビット数が減少される。
ビットの再順序付けは、ビットベクトルのハフマン符号化を最適化するように(且つ/又はハフマン木のサイズを縮小するように)ビットをシャッフルするために、いくつかのビットが十分適切に相関される(しかし、100%相関されるわけではない)というプロパティを利用する。
Figure 0006129253
ビットを結合し且つ再順序付けするためのテーブルを計算する前に、全ての出発領域の全てのビット対の相関が算出される。別個の対の数は以下の通りである。
C(N, 2) = N!/(2! * (N − 2)!) = N * (N − 1)/2
式中、Nは領域数である。この数は、領域数が多い場合に大きくなる。全てのビット相関を計算することは、図8に示したファイル形式を生成する方法の最も遅い部分である。方法の複雑さはn*N*Nであり、nはビットベクトル数であり、Nは領域数である。各領域のビット対(すなわち、ビットベクトルの個別の列の対)毎に3次元テーブルを計算する。
bitCorrelation[fromRegionId][bitI][bitJ]
テーブルの各エントリは、以下をカウントする4つのフィールドから成る構造を含む。
・fromRegionIdの全てのビットベクトルにおけるbitI=0及びbitJ=0の回数
・fromRegionIdの全てのビットベクトルにおけるbitI=0及びbitJ=1の回数
・fromRegionIdの全てのビットベクトルにおけるbitI=1及びbitJ=0の回数
・fromRegionIdの全てのビットベクトルにおけるbitI=1及びbitJ=1の回数
計算するためのプロセッサの時間に関して高価である(且つ従って遅い)が、出発領域毎にビット相関を計算することは他の出発領域から完全に独立しているため、この処理は容易に並列化できる。
本発明の実施形態は、マルチスレッディングを使用して、SMP(対称型マルチプロセッシング)マシンを効率的に使用するための全てのビットの相関の計算を加速する。1つのシステムにおいて、300個の領域を含むベネルクスのビット相関を計算する1CPUのマシンは約8分かかる。しかし、並行処理が適切に釣り合い、スレッドを可能にし且つビット相関を計算する4つのCPUを使用する場合は2分(1/4の時間)かかる。
ビットの結合
いくつかのビットが完全に相関される場合(すなわち、常に全て0又は全て1)、どの情報も損失することなくそれらのビットを1ビットのみに結合できる。所定の領域において「グループ」として完全に相関されるビットの集合を参照すると、所定の領域のビットベクトルはいくつかのグループから成る。Nビットのビットベクトルがn個のグループから成る場合、Nビットのビットベクトルを符号化することはnビット+各領域において等しいビットを示す小さなテーブルを使用する。
そのようなビットの結合は、結果として得られるファイルのサイズが可逆的に縮小されるという利点を有する。領域数が増加すると、より多くのビットが結合される可能性があるため、領域数の増加に伴いこの利点も大きくなる可能性が高い。従って、地図のサイズは領域数に伴いほぼ線形的に増加する。
一実施形態において、以下のデータが得られた。
最小グループ数 平均グループ数 最大グループ数
255個の領域のベネルクス 12 84 152
300個の領域のベネルクス 13 90.017 163
従って、255個の領域を有するベネルクスの例において、12個のグループのみを有する少なくとも1つの領域が存在する(すなわち、ハフマン符号化の前であっても(及びハフマン符号化の後であっても)255ビットのビットベクトル(すなわち、ビットベクトルが領域数と同一の長さである)を符号化するのに12ビットだけ必要とされる)。
平均して、領域は255個の領域のベネルクスに対して84ビット必要とする。この例において、ハフマン符号化の前、最悪な領域でも152ビット(152個のグループ)を必要とする。
別の例として、符号化データから得られるような以下の18個のグループを有する上記255個の領域のベネルクスにおいてregionId=3を利用する。
regionId=[3]は[18]個のグループを有する。
Figure 0006129253
各行は1つのグループ(regionId=3に対する18個のグループ)を表す。小括弧内の数字は、各グループで結合されたビット指標である。#の後の数字は各グループのビット数である。
この例において、1つのグループは非常に大きく、141個もの領域を含む。これは異例ではない。一般に、地図の境界上の領域は、地図の中央の領域より多くのビットを結合する。
この例において、ビット数は平均で〜3(〜=255/84)に減少されている。当然、これは、符号化する残りのビットが元のビットより高いエントロピーを有する(従って、ハフマンブロックにより符号化するのはより困難である)ため、地図のサイズが1/3に縮小されることを意味しない。しかし、ビットの結合により、地図のサイズは可能性として非常に縮小される可能性がある。
各領域のビットを結合させる場合、各領域のビットベクトルは、図12に示すように結果として異なるビット数を有する(しかし、所定の出発領域のビットベクトルに対しては同一のビット数を有する)。陰影は、各ビットベクトルの出発領域IDを示す。y軸は区分の順序を表す。例えば、最上部のブロックは1043本の線を表してもよく、次のブロックは507本の線を表してもよい。
テーブルbitCorrelationが計算されると、完全に相関したビットのグループを特定することは非常に容易で且つ迅速である。01又は10パターンが見つからない全てのビット対は完全に相関され、1ビットに結合される。
ビットの結合の更なる一例を与えるために、以下のテーブルは、それぞれが15ビットから成る6つのビットベクトルの一例を与える。これらは結合されていない。
Figure 0006129253
これらの15ビットのビットベクトルは、4つのグループ、すなわちハフマン符号化の前のビットベクトル毎に4ビットに結合される。
Figure 0006129253
テーブルの右側部分の見出しは、テーブルの左側部分の4ビットの結合ベクトルのビットを示す。明示するために、4ビットの結合ベクトルの第1のビットは、左側部分の第1列、第3列及び第9列を表す。従って、左側部分(すなわち、15ビットの元のベクトル)の第1のビット、第3のビット及び第9のビットが上記例において常に同一であるため、それらのビットは上記テーブルの右側部分の第1列により表されてもよい。
従って、要約すると、左側と右側との間の索引のテーブルは以下の通りである。
元のビット 結合されたビット
0 0
1 1
2 1
3 0
4 0
5 3
6 2
7 1
8 2
9 2
10 3
11 0
12 3
13 1
14 1
ビットを効果的に結合することは、近傍の行先領域及び図13に示すように出発領域から同一角度の扇形内にある行先領域をグループ化することである。
図13の陰影は、結合される領域のグループを示す。2つの図面(すなわち、図13a及び図13b)は、2つの異なる出発領域の観点から結合された同一領域を示す。結合される領域は、図示するように出発ノードの領域IDに依存する。図中、8つの領域が4つのグループに結合される。ビットの結合は、これらの図の出発領域A又は出発領域Bの観点から異なる。尚、垂直の縞模様の領域(1300)は、出発領域Aから見た場合に同一方向のあるため結合される。
これは、図14において更に例示される。図14は、ビットの結合が各出発領域の観点から近傍の行先領域及び+/−の同一角度の扇形内にある行先領域をグループ化することを示す。
ビットを結合した後、ビットベクトルに対して符号化するビット数は領域毎に異なる。例えば255個の領域のベネルクスの場合、領域毎のビットベクトルのビット数は以下の通りである。
出発領域 −> 結合されたビット
1 −> 57
2 −> 93
3 −> 18
4 −> 12
5 −> 63
6 −> 75
...中略...
251 −> 21
252 −> 46
253 −> 117
254 −> 80
方法は正確である(ヒューリスティックではない)。従って、理想的なビットのグループ数が分かる。
いくつかの実施形態において、ビットの結合は可逆的に実現される。すなわち、領域は常に同一ビットを有する場合に結合される。しかし、他の実施形態において、これは不可逆にするように、すなわち元のデータの完全な回復が不可能であるように拡張されてもよい。そのような不可逆の実施形態は閾値(すなわち、密接度の尺度)を導入してもよい。すなわち、ビット対がX倍未満だけ異なる場合、一部のビットベクトルの1つ以上の0を1で置換することによりビットベクトルを結合できる場合にビットを結合できる。従って、いくつかの実施形態において、そのような結合はほぼ相関されるビットに対して行われる。
そのような不可逆結合の一例は、0000001100を0000001110と結合することである。そのような方法の利点は、データの圧縮がより適切であることであるが、欠点は、道路区分が最速経路の一部であることを追加の1が示すため、更なる道路区分がビットベクトルを使用して経路指定方法により評価されることである。
可逆的結合の場合、閾値は0である。閾値を増加することにより更なる領域を結合することが可能になるが、いくつかのビット1をビットベクトルに導入する。しかし、閾値が小さく維持される場合、閾値は、経路指定がデータ形式を使用して実行される際の速度にほぼ何も影響を及ぼさない。例えば2ビットが1ビットのベクトル以外の数千個のビットベクトルにおいてほぼ常に同一である場合、これは、より多くのビットを結合することを可能にするために異なるものであるこの一意のビットベクトルを変更するために受け入れ可能であってもよい。閾値が大きい程、より高い地図圧縮を期待できる。
ビットの再順序付け
いくつかの実施形態において、上述したようにビットが結合されると、ビットは再順序付けされてもよい。ビットの再順序付けは、符号化するビット数(ハフマン符号化前の)を減少しないが、ハフマン符号化をより効率的にすることを助長し、従って地図のサイズを縮小する。ビットの再順序付けは、ビットベクトルハフマン符号における別個の符号の数を減少することを更に助長し、従ってハフマン木に要求されるメモリを減少する。
ビットの結合とは異なり、ビットの再順序付けはヒューリスティック法であるため、適切な再順序付けを見つけるが、最善の再順序付けを見つけない可能性がある。
ビットベクトルはブロックにより符号化される。ブロックサイズは、カスタマイズ可能であり、地図ヘッダ800に格納される。以下の説明において、一例として、ブロックサイズは11ビットに設定される。ビットベクトルのビット数は11で割り切れない可能性があるため、最後のブロックは11ビットより小さい可能性がある。最後のブロックは、11ビットの完全なブロックに対するハフマン木とは異なるハフマン木を使用する。各ビットベクトルを符号化することにより、以下を符号化する。
・11ビットのブロック(この例において)に対するハフマン符号を使用するいくつかの完全なブロック
・11ビット未満が残っている時に別のハウマン符号を使用する最後の1つのブロック
以下の図は、2つの領域(結合後、異なるビット数を有する)のビットベクトルを有するブロックによりハフマン符号化するビットを示す。
Figure 0006129253
領域毎にハフマン木を有することはメモリに関して高価すぎる可能性がある。従って、いくつかの実施形態において、同一のハフマン木が全ての領域に対して共有される。相関したビットが各領域において異なるため、各領域のビットを再順序付けでき、その結果、相関したビットは全ての領域の同一位置に体系的に置かれる。従って、全ての領域にわたりハフマン木を共有することは更に効率的になる。
領域毎にビットを再順序付けするテーブルは地図データに格納される。尚、ビットを結合するための別個のテーブル及びビットを再順序付けするための別個のテーブルを符号化する必要はなく、その代わりに双方の変換(結合+再順序付け)の合成である1つのテーブルのみを符号化できる。
完全なブロックのビットを再順序付けする方法は以下のように進む。領域毎に、最も相関したビット対を見つける。完全に相関したビットが既に結合されているため、残りのビットで完全に相関されたものは存在しない。しかし、いくつかのビット対は他のビット対より相関される。最も相関したビット対(a,b)は第1の完全なブロックのビット#0及び#1に再マッピングされる。
Figure 0006129253
最も相関したビット対をグループ化した結果、完全なブロックのハフマン木はより少ない別個の符号(データを格納するのにより少ないメモリを使用するという利点を有する)を有し、統計はより偏る(これにより、ハフマン符号化がより効率的になる)。ランダムなビットシーケンスを含むのではなく、例えば最初の2ビットは殆どの場合が00又は11を含み、10又は01を含むものはほぼない(他のビットについても同一である)。ビットを再順序付けせずに、最初の2ビットは全ての種類のパターン00、01、10、11を含む。
最初の2ビットを再マッピングした後、方法は、次に最も相関したビット対(c,d)を見つけ、それらを再マッピングして第2のブロックの最初の2ビットに格納する。
Figure 0006129253
方法は、次に最も相関したビット対(e,f)を見つけ、それらを再マッピングして第3のブロックの最初の2ビットに格納する。
Figure 0006129253
最後の完全なブロックに到達すると、方法は最初の完全なブロックに戻り、次に最も相関したビット対(g,h)を再マッピングする。いくつかの対が同一の相関性を有する場合、タイブレーカは、同一ブロックの前の対と最も相関した対(すなわち、(a,b)と最も相関した対)を選択する。
Figure 0006129253
アルゴリズム方法は、完全なブロック中の全てのビット対が再マッピングされるまで上記のように進む。
Figure 0006129253
この例において、ブロックサイズが奇数のビット数(11ビット)を有するため、再マッピングされていないビットが完全な各ブロックに依然として存在する。方法は、「z」と最も相関したビットを見つけ、それを第1のブロックに格納する。その後、Bと最も相関したビットを見つけ、それを第2のブロックに格納する。全ての完全なブロックが再マッピングされるまでこのような処理を行う。
Figure 0006129253
この時点で、全てのビットが完全なブロックに再マッピングされる。方法は、最後のブロックのビットを再マッピングし、完全なブロックに対して行ったように最も相関したビット対をグループ化しようとする。最後のブロックのビットを再順序付けすることは、地図のサイズを縮小することを助長できるが、以下の2つの理由により完全なブロックのビットの再順序付けほどは助長しない。
・完全なブロックの方が重要である。この例において、各符号は、完全なブロックに対して3つのハフマン符号を使用するが、一方、最後のブロックに対しては1つのハフマン符号しか使用しないため、完全なブロックが最後の不完全なブロックより全体の地図のサイズに寄与していることは普通であり、完全なブロックのハフマン符号化を最適化することがより有用である。
・最も相関したビットを全て既に選択してそれらを完全なブロックに再マッピングしたため、最後のブロックにおける再マッピングする残りのビットの相関性はより低い。従って、最後のブロックのビットのエントロピーは、完全なブロックのビットのエントロピーより高い。換言すると、最後のブロックのハフマン符号化は、完全なブロックのハフマン符号化ほど効率的ではない。
Figure 0006129253
尚、全ての領域の全ての完全なブロックに対して、同一のハフマン木が使用される。上記例におけるビットベクトルを符号化することにより、同一のハフマン符号を使用して全ての完全なブロックを符号化し、最終的に異なるハフマンコーデックにより最後のブロックを符号化する。
Figure 0006129253
方法が各ブロックの最初のビットを再マッピングする(第2のブロックに進む前に第1のブロックの全てのビットを再マッピングするのではなく)理由は、上記図面を見ることにより明らかである。同一のコーデックが全ての完全なブロックに使用されるため、全てのブロックに対する全ての符号を可能な限り同一にすることが望ましい。第1のブロックの全てのビット、次に第2のブロックの全てのビット(等)を再マッピングする場合、各ブロックは非常に異なるパターンを有する。すなわち、第1のブロックは最も相関したビットを有し、第2のブロックはより相関性の低いビットを有し、第3のブロックは更に相関性の低いビットを有する。完全なブロックの各列に対していくつかのハフマンコーデックを作成できるが、これはメモリに関して高価すぎると考えられる。ここまで概略を示した方法は、適切に動作する一方で、全ての完全なブロックに対して同一のハフマンコーデックを共有する。
可能な他の最適化
この節では、データを更に圧縮するために更なる実施形態において使用されてもよい最適化について説明する。
ページのページ
ページ情報は、各ビットベクトルページの開始オフセットを見つけるために使用されるデルタフィールドを格納する。デルタフィールドは、オフセットの線形補間を使用して格納される。しかし、小さなノードID(レベル0、高速自動車道路)の周囲のビットベクトルがより大きいノードID(レベル5、行先道路)の周囲のビットベクトルより多くのビットを必要とするため、オフセットはそれ程線形ではない。図15のグラフは、300個の領域を含むベネルクスの地図に対するデルタフィールドを示す。
補間が実際のオフセットを正確に予測しないため、ビットベクトルページ情報の符号化は要望される程の利点を有さない。補間を向上することにより、ビットベクトルページ情報テーブルの符号化を向上し、より効率的にすることができる。
本発明のいくつかの実施形態は、1つのレベルではなく2つのレベルを有するビットベクトルページ(及び可能性として領域ページ)を使用してもよい。データをグループ化する2個のノードのページ(これらをサブページと呼ぶ)は、2個のサブページのページにグループ化される。
従って、線形補間パラメータは、グローバルではなくページ毎に格納される(ヘッダに)。例えば指標レベル2は、サブページの最初の方で2=16個のノードをグループ化してもよく、指標1はページ中のそれらのサブページの210=1023個のノードをグループ化してもよい。線形補間は、全体のノード数(ヨーロッパ及びロシアの地図の50,000,000個のノード)に対してではなく、1024*16=16K個のノードに対して行われるため、可変サイズオフセットの線形補間ははるかに正確になり、指標2のデルタフィールドはより小さくなる。
ページが大きい(メモリに適合するのに十分に小さい)場合、追加の指標1のサイズは小さい。装置のメモリ内に適合可能であることは、データを使用する経路指定を遅くしないため有利である。平均ページサイズをヘッダに格納するのではなく、平均ページサイズは指標1のテーブルの全てのエントリに対して格納される。
Figure 0006129253
ビットベクトルページのインタリーブ
上述したように、ビットベクトルが重要な道路(多くの非自明なフラグ)及びあまり重要でない道路(多くの自明なフラグ)に対して異なるため、ページオフセットに対する補間は正確でない。補間をより線形にする1つの単純な方法は、種々のネットワークレベルのページをインタリーブすることであり、これは本発明の実施形態において使用されてもよい。
上記実施形態において説明したファイルは以下のページを格納する。
#0
#1
#2
#3
#4
・・・
#n−3
#n−2
#n−1
より効率的である可能性のある他の実施形態において、以下のようにインタリーブして格納できる。
#0
#n−1
#1
#n−2
#2
#n−3
#3
#n−4
・・・
ページ#xにアクセスする(例えば、経路計画アプリケーションにより)ために、ページはページ#x’をロードすることによりアクセスされる。
・x’ = 2 * x (xが偶数の場合)
・x’ = 2 * (x − (n − 1)) (xが奇数の場合)
このような一実施形態は、ページ毎に数ビットずつ指標付けのサイズを縮小するため有利である。しかし、データは、キャッシュするためにより不適切にグループ化される可能性があるため、データアクセスを遅くする可能性がある(ファイルシステムキャッシュにおいてヒット数が少なくなる)。
全てのノードに対する領域IDの非格納
領域IDは、末端のノード及び2つの連結道路区分を有するノードに対して格納される必要はない。これらのノードは経路指定に対して無視される。これらのノードのうちの1つに行くことは、近傍の決定ノードに行くことに変換される。
ページレベル及び/又はノードレベルにおける追加の情報の格納
地図データを見ると、自明なビットベクトル000...000又は111...111のみを含むビットベクトルページが多く存在する。いくつかの実施形態は、ページに印をつけるためにそれらページ毎に1ビットを格納してもよく、そのビットベクトルが000...000であるか又は111...111であるかを示すためにビットベクトル毎に単一ビットのみ必要とするため、ビットベクトルをそれらのページに格納することはより効率的になる。これは、自明なビットベクトルのみを含むページのサイズを縮小するだけでなく、非自明なビットベクトルを有するページに対してビットベクトル符号のハフマン木をより適切に最適化する(これらの符号の頻度のパーセント値が非常に増加するため、非自明なベクトルを示すためのビット数は減少される)。より精細なネットワークレベル(例えば、レベル3)において、殆どのページは自明なビットベクトルのみを含むため、約半分のページにおいてページ毎に1つのビットベクトルのみが存在する可能性がある。
決定ノードのビットベクトルのみの格納
上述したように、いくつかの実施形態は、1つ又は2つの連結道路区分を有するノードに対するビットベクトルを格納しなくてもよい。しかし、他の実施形態は、より積極的であってもよく、決定ノードの周囲のビットベクトルのみを格納する概念を一般化してもよい。
決定ノード及び決定道路区分の概念は、地図データの符号化に関して利点を有するため導入される。すなわち、次に説明するように、ビットベクトルは非決定道路区分に対して符号化される必要はない。
・決定ノードは、ノードを出る(Uターンをせずに)複数の選択肢があるように経路指定するための進入道路区分が存在するノードである。
・非決定ノードは、決定ノードでないノードである。従って、経路指定の出発地に関係なく、ノードを出る出口が常に1つのみ存在する。
・決定道路区分は、決定ノードを出るのに合法な道路区分である。
・非決定道路区分は、決定道路区分でない道路区分である。
全ての決定道路区分は、決定ノードの周囲にある。しかし、決定ノードの周囲にある全ての道路区分が決定道路区分ではない。非決定ノードの周囲にある全ての道路区分は非決定道路区分である。
ビットベクトルは、決定道路区分に対してのみ符号化される。データを使用する経路決定技術が道路区分に既に存在する情報から判定できるため、ビットベクトルは、非決定道路区分に対して黙示的である(000...000又は111...111)。
ノードが決定ノードであるかを判定する方法は?緩和できる基準は以下の通りである。
isDecisionNode=(lineCount>=3)&&(lineGoingOutCount>=2)
式中、lineCountは、経路指定不可能な線の種類(鉄道、基準線)を無視し、双方向に閉じた線を無視し、且つ通り抜け禁止道路(住宅エリア)を無視するノードに連結された線の合計である。lineGoingOutCountは、ノードを出るために利用するのに合法であるノードに連結された線の数である。
ノードを出るためにある道路区分を利用するのが合法か否かは、以下の道路区分属性に依存する。
・道路区分の種類(鉄道&基準線は常に違法である)
・道路の順方向/逆方向の流れ(道路区分フラグに格納される)
・道路区分フラグの通り抜け禁止属性(通り抜け禁止道路区分はいずれのビットベクトルも有さない)
いくつかの実施形態において、非決定道路区分を無視することは、約40%の道路区分を廃棄できる。このパーセント値は、地図に関係なく非常に安定していることが分かっている。自明なビットベクトルを主に除去するため、ビットベクトルの40%の符号化を回避することは利点であるが、節約される地図のサイズは40%未満である。
3つ未満の連結道路区分を有するノード(ダミーノード)の周囲のビットベクトルを除去することにより、非自明なビットベクトルが除去されるため、このカテゴリの非決定道路区分に対する地図のサイズの節約は非決定道路区分に対する節約より大きい。一方、フィルタリングは、復号器(地図を使用する経路指定方法等)が道路区分の種類及び線の道路区分フラグを復号化し且つ黙示的であるビットベクトルを計算するためにそれらに論理を適用することを必要とする。これは、処理を遅くする可能性がある。
理論上、実施形態は、退出道路区分が合法であるかを決定するために操作(すなわち、右左折制限)に着目するが、そのような技術は複雑さを増す。操作を無視することは、実施形態が厳密に必要な数より多くのビットベクトルを符号化してもよいが方法の単純化が達成されることを意味する。
非決定ノードの例
a−−<−>−−b−−<−>−−c
この例において、(b)は双方向にナビゲート可能である2つの道路区分に連結される。<=2個の連結道路区分が存在するため、(b)は決定ノードではない。
従って、ノード(b)を出る双方の道路区分のビットベクトルは符号化されない。復号器は、それらを111...111に黙示的に設定できる。
a−−>−−b−−<−>−−c




この例における矢印>は、フローの合法な方向を示す。出口が1つのみ存在するため、(b)は決定ブロックではない。従って、(b)の周囲のいずれの道路区分もビットベクトルを必要としない。
ノード(b)を出る道路区分(b)−>(c)に対するビットベクトルは符号化されず、黙示的に111...111となる。(b)を出る違法な道路区分に対するビットベクトルも符号化されず、黙示的に000...000となる。
決定ノードの例
a−−<−>−−b−−<−>−−c




(b)は、(d)から来る場合に選択肢があるため決定ノードである。すなわち、経路指定は(a)又は(c)に向かって継続可能である。
尚、この例において、(a)から来る場合、選択肢はない。すなわち、経路指定は(c)に向かってのみ継続可能である。しかし、ノード(b)は、(d)から来る場合に少なくとも選択肢があるため依然として決定ノードである。従って、ビットベクトルは、ノード(b)の周囲の2つの決定道路区分に対して格納されるべきである。
道路区分(b)−>(a)及び道路区分(b)−>(a)が決定道路区分であるため、ビットベクトルはこれらの道路区分に対して格納される。
交通の逆方向/順方向の流れによると道路区分(b)−>(d)を利用するのは違法であるため、ビットベクトルはこの道路区分に対して格納されない。これは、黙示的に000...000である。
ビットベクトルの論理和
ノードが3つの連結道路区分を有し、最初の2つの復号化道路区分が以下のビットベクトルを有すると仮定する。
00000000000000000000
00000000000000000000
第3のビットベクトルは、以下の通りであるため符号化される必要はない。
11111111111111111111
これは、ノードaの周囲の道路区分のビットベクトルがこの順序で現れる場合にのみ動作可能である。すなわち、全てのビットベクトルが000...000であり、最後のビットベクトルが111...111である。実際には、これはより精細なレベル(例えば、レベル3)のネットワーク(殆どの道路区分が存在する)において非常に頻繁に現れると考えられる。
最初の2つのビットベクトルは以下の通りとする。
00000000000000000110
00000000000000000010
第3のビットベクトルは、未知であり且つ何らかの方法で符号化される必要がある2ビット以外の全てのビットを1に設定できる。
11111111111111111??1
上記例において、殆どのビットが既知であるため、ビットベクトル全体を符号化するより効率的に2つの未知のビットを符号化するためにこの情報を使用できるべきである。従って、この例において、2ビットを符号化すればよい。
このプロパティを使用する可能な高速復号化方式は、道路区分の全ての先のビットベクトルの論理和をとることにより現在のノードの道路区分の全ての復号化ビットベクトルのビットマスクを計算することである。上記と同一の例を使用して、ノードが3つの連結道路区分を有する場合及び先の2つの道路区分が以下のビットベクトルを有する場合、
00000000000000000110
00000000000000000010
ORビットマスクは以下の通りである。
00000000000000000110
ノードの周囲の符号化する第3の最後のビットベクトルを以下の通りとする。
11111111111111111001
極めて稀な11111111111111111001のハフマン符号を符号化する代わりに、符号器は、以下の場合に他のあらゆる符号(otherCode)を自由に符号化できる。
value_to_encode = 〜bitMask | otherCode
この例において、otherCode=0000000000000*0000000は、以下が成り立つために適格である。
value_to_encode = 11111111111111111001 = 〜0000000000000*0000110 | 0000000000000*0000000
00000000000000000000の頻度がより高いため、00000000000000000000を符号化することは、11111111111111111001を符号化するより非常に効率的である。復号化は、ビットベクトルを復号化する時は常にビットマスク(又は動作)を計算し且つ最後に復号化されたビットベクトルにビットマスクを適用すればよいため、復号化は速い。
実際のビットベクトル=ビットマスク&復号化ビットベクトル
=〜00000000000000000110 & 00000000000000000000
=11111111111111111001
この最適化は、ノードの周囲の道路区分が最後の領域において殆どが1であるビットベクトルの道路区分を有するように格納される場合に適切に動作する。しかし、これは困難である。
・ノードの周囲の道路区分の格納は、ビットベクトルの計算前に行われる(再符号化するためにビットベクトル情報を帰納的に使用しない限り)。
・道路区分は道路名で既にソートされている。道路名が特定される場合、ノードの周囲の道路区分をソートできる。
ネットワークレベルの使用
領域のレベルに加えて、地図データ内の道路区分は道路区分レベルに従って分類される。出発ノードの周囲において道路区分ネットワークレベルとビットベクトルとの間には強い相関性がある。すなわち、一般に別の領域までの経路指定は、高速自動車道路等の高いレベルの道路区分ネットワークを利用するのを好む。最も重要な道路区分ネットワークレベルは、高速自動車道路レベルである可能性が高く、これはレベル1であってもよい。
以下の例は、異なるネットワークレベルにおける道路区分との交差点を示す。



1=======2=======3
線(2)−>(1)は、ネットワーク4(重要)にある。
線(2)−>(3)はネットワーク5(あまり重要でない)にある。
線(2)−>(3)はネットワーク5(あまり重要でない)にある。
ビットパターンは以下のようになる可能性が高い。
2 1 ????????????
2 3 ????????????
3 4 000000000000。
非重要道路区分ネットワークレベルのノードに対するビットベクトルの非格納
経路指定は、目的地又は出発地に近接する場所以外ではネットワークレベル5等の非重要道路区分ネットワークレベルをほぼ通過しない。従って、レベル5のビットベクトルを格納しないことが可能であり、従ってレベル5の道路区分数が多くても経路指定への影響は最小である。殆どの場合の経路指定は、いくつかの更なる重要な道路区分ネットワークレベルに迅速に到着するため、経路の開始又は終了において最も重要でないネットワークレベルの道路区分を殆ど探索しない。これらのノードに関する探索加速データは、最も重要でないネットワークレベルに戻るナビゲート区分をスキップし且つより重要なネットワークレベルに通じるか又は入るナビゲート区分を使用するようにルータにほぼ常に伝える。目的地が依然として遠い場合に最も重要なネットワークレベルが使用されるため、このことは、そのネットワークレベルにおいて当てはまる。
最も重要でない道路区分(例えば、レベル5)におけるビットベクトルをドロップすることに加えて、そのネットワークにおいて領域IDを符号化しないことも可能である。
ビットベクトルのいくつかの0の1への変換
これは、不可逆圧縮方式である。
ビットベクトルが1つの0だけ(又は可能性として小さい閾値未満)を含む場合、以下の結果(すなわち、その道路区分を最速経路の一部になるように設定する)が得られる場合はそれを1に変換できてもよい。
・自明なビットベクトル111...111(自明なビットベクトルは非自明なビットベクトルよりコンパクトに符号化されるため)
・現在のビットベクトルページの履歴で既に見つけられたビットベクトル(より効率的に符号化されるため)
ビットベクトルにおいて0を1に変換することは経路指定結果に影響を及ぼさず、経路指定がより多くの道路区分を考慮するようにすることにより遅くなるだけである(最速経路の一部になるように設定されるため)。しかし、特に経路指定の速度に関して性能への悪影響が小さく、地図の節約が大きい場合、本発明のいくつかの実施形態はこの方法を採用してもよい。
経路指定
図15は、従来のA*探索方法により探索された複数の道路区分と共に開始ノード1602及び行先ノード1604を有し且つあるエリアを範囲に含む地図1600を示す。選択された経路を点線1606で示す。
図16は、図15の地図と同一エリアを範囲に含み且つ同一の開始ノード1602及び行先ノード1604を示す地図1650を示す。図16は、図15の経路を生成するために使用したのと同一の道路ネットワーク及び基準(例えば、双方とも自動車で移動され、最小にするコスト関数として速度を使用することを要求する)を利用した本発明の一実施形態を使用して探索された道路を強調表示する。方法により選択された経路は、点線1606で示され、その線は図15で算出されたものと同一である。従って、本発明の実施形態により算出された経路は、いわゆる数学的に正確であり、最小になるように選択された所定のコストモデルに関して最善/最適な経路を見つける。従って、本発明の実施形態により探索された道路区分は、従来技術と比較して非常に少ないことが明らかである。本発明の実施形態の方法は、従来のA*方法より高速であり、一般にははるかに高速である。
尚、経路1606が目的地1604に近づくと開始時と比較してより多くの経路が探索される。すなわち、経路1606が地点1652を越えて進む場合、最小コスト経路以外に道路が探索される。この1つの説明としては、方法が地点1652においてレベル0領域からレベル1領域に切り替わったからである。目的地1604付近で更なる道路区分が探索されることが更に分かるだろう。ここでも、これは、経路計画方法がこの付近でレベル1からレベル2に切り替わったことを指摘することにより説明できる。
従って、長い範囲での経路指定の場合、一般に最速経路は1つのみ存在する。しかし、方法がより精細なレベルに切り替わると(例えば、レベル0から1に)、「最小コスト」として印がつけられ且つ従って探索される必要がある経路が2つ以上存在してもよい。
地図データが作成され、ビットベクトルが算出及び格納されると、2つの地点間の経路を算出するのに使用される。
図17は、ネットワークが経路計画アプリケーションにより探索される従来のA*方法を示す。ここで、ノードにおいて更に探索する道路区分に関する決定が行われる。これを達成するために、次のノードまで移動するためのコストは、次のノードから目的地まで移動するための推定されたコストに追加される。所定のノードからの最小コストを有するパスは、更に探索される。方法が進み且つ各繰り返しにおいて最小コストが考慮されるため、方法はそれまでに発生したコストの合計を保持する。
例えば、ノードBから開始すると、双方のノードC及びDは開始ノードであるBから2コスト単位だけ離れていることが分かる。しかし、ノードDからノードFに到達するための推定コストは3単位であり、ノードCからノードFに到達するための推定コストは5単位である。従って、A*方法は、次のノードまでのコスト+目的地までの推定コストがノードDまでの道路区分に対してより少ないため(すなわち、BC=2+5=7であるが、BD=2+3=5である)、ノードCへの経路よりノードDへの経路を好んで探索する。
経路計画が本発明の実施形態のビットベクトルを使用して実行されることを考慮すると、道路区分毎のビット(すなわち、図7の列704)は、行先領域までの最小コスト経路の一部となる候補である道路区分を特定する。従って、図17に関連して説明したA*方法は修正され、図18に示した方法が得られる。
一般に経路計画は、図18に関連して説明するようなビットベクトルを使用して実行される。しかし、本発明のいくつかの実施形態は、種々の状況下において経路計画がA*(又は他の従来の方法)にフォールバックすることを可能にしてもよい。種々の実施形態は、以下のうちのいずれかを利用してもよい。すなわち、ビットベクトル情報が失われていること(これにより、ビットベクトルがない場合でもシステムは機能できる)、コスト関数が使用されること、ビットベクトルが算出されたコスト関数以外の経路指定(一般に最速経路であるが必ずしも最速経路である必要はない)、ユーザがビットベクトルを事前計算するのに使用された基準と異なる基準を指定すること(例えば、ユーザは高速自動車道路を回避したい)、乗り物の種類がビットベクトルの事前計算に使用されたものと異なる(例えば、ユーザは自動車ではなく徒歩である)こと、及び経路が閾値の長さを下回ること(例えば、経路の開始点及び終了点が同一領域内にある)である。
図17と比較して、2つの追加の数字1800、1801を図18に示す。更に領域は、図18において破線1802及び1804により示される。「1」1800は、道路区分BDがノードBから目的地ノードが位置する領域までの1つの低コスト経路の一部であることを示す(他で説明するように、更に他の低コスト経路が存在してもよい)。「0」1801は、道路区分BCがノードBから目的地ノードが位置する領域までのいずれの低コスト経路の一部でないことを示す。
従って、ノードAから開始すると、本発明の実施形態は、上記で概略を示したA*を使用してAからノードを探索する。しかし、ノードBに到達すると、道路区分BDのみが最小コスト経路の一部である可能性があることの明示的な表記があるため、探索を更に使用する必要はない。従って、A*方法が使用され、最小コスト経路を見つけると、次にビットベクトル内の関連ビットを見ることにより最小コスト経路を選択する。
しかし、種々の最小コストパスが異なる時間において一対の領域の間に存在する場合、最小コストデータは、その対の領域間で2つ以上の最小コストパスを特定してもよい。従って、例えば道路区分BD及びBCに対する数字1800及び1801が、各道路区分が特定の時間において最小コストパスの一部であることを示す値「1」を有する場合、開始ノードと目的地ノードとの間(起点と目的地との間)の経路指定は、2つ以上の最小コストパスを見つけてもよく、競合する最小コストパス間で判定する必要がある。本実施形態において、ビットベクトルは、各道路区分が最小コストパスの一部である時間を特定しない。そのため、経路指定アルゴリズムは、パスの区分を移動する時間に基づいて双方の可能な最小コストパスに対してコスト解析を実行する。この時間は、起点/開始ノードからの出発時間から判定されてもよい。
図10aに示すように、区分中の推定移動速度がどのように計時変化するかの速度プロファイルは各区分と関連付けられる。これらの速度プロファイルから、関連する時間における推定速度が判定され、これは、その時間にその道路区分を移動するためのコストを判定するために使用される。各最小コストパスの道路区分を移動するためのコストを合計することにより、各最小コストパスに対するコストが判定される。ナビゲーション装置は、その時間に対する最小コストを有する最小コストパスを経路に選択してもよい。
ここまで説明した経路指定を実行するために、ビットベクトル情報は、復号化処理を使用して図8〜図10に関連して説明した符号化副ファイルから取得される。
上述した前処理の出力は以下を含む。
・殆どのノードに対する階層領域の割り当て
・これらのノードにおける退出道路区分に対するビットベクトルの割り当て
地図のロード
一貫性検査
地図データがロードされる場合、副ファイルの集合は地図ディレクトリに存在すべきであり、存在しない場合、復号器は経路探索が探索加速データなしで実行されるように探索加速データを非アクティブにする。データ完全性を保証するのを助長するいくつかの検査がある。これを一覧表示する。
副ファイルは命名規則に従う。
レベルの数は副ファイルの数により与えられるが、各副ファイルのヘッダにも格納され、副ファイルの数に等しい。
各副ファイルは、副ファイル名で指定されたレベルと同一の各レベルの領域数を格納する。更に副ファイルは、全ての副ファイルに対して同一であるべき以下の情報を格納する。
・副ファイルのバージョン
・「ビットベクトルページ」(以下に説明する)毎のノード数
各副ファイルには、以下を特定するチェックサムが存在する。
・全体の特定の副ファイル集合
・全体の地図
これらは、所定の電子地図に対して関連付けられた副ファイルに対して正確であるべきである。上記検査のいずれかが失敗した場合、探索加速データプロパティはこの地図に対してアクティブにされない。
メモリにロードされるデータ構造
復号器は、外部メモリの実現例の副ファイルを読み出す。これは、ビットベクトル副ファイルのコンテンツがメモリに完全にロードされず、必要に応じてのみ読み出されることを意味する。しかし、ある一般的なデータは最初にメモリにロードされ、地図がロードされる限りそこに保持される。
ヘッダ情報
各副ファイルは、図8〜図10に関連して上述したデータを含むヘッダセクションで開始する。この情報は、副ファイル毎にメモリに格納される。
ハフマン木の定義
副ファイルは、いくつかのハフマン木の定義を含む。ハフマン木の各定義は、特定のハフマン符号化の完全な記述を与え、副ファイルビットストリームの一部を元のデータに復号化するために(すなわち、副ファイルのビットシーケンスを数字又は他のある特定の値に復号化するために)後で使用される。以下のハフマン木の定義は、各副ファイルから読み出され且つメモリに保持される。
・各ノードにおいて道路区分数を復号化するためのハフマン木。(符号化された道路区分数は、基礎となる地図の道路区分数より少ない。尚、復号器は基礎となる地図とは無関係である。すなわち、地図を読み出す必要はない。)このハフマン木は、レベル0の副ファイルにのみ格納される。
・ページ符号を復号化するためのハフマン木(以下に説明する)。
・ビットベクトルブロックを復号化するためのいくつかのハフマン木。木の定義数は、副ファイルヘッダに格納されるような正規のビットベクトルのブロックの長さにより与えられる。これはブロックの長さ−1に等しい。(道路区分に対するビットベクトルのビット列全体はブロックに分割される。ビットベクトルのビット列の長さが正規のブロックの長さの倍数でない場合、最終的なブロックはより短い。2〜正規のブロックの長さまでのブロックの長さ毎に1つのハフマン木が存在する。長さ1のブロックの場合、これは単に1ビットであり、直接格納されるため、ハフマン木は使用されない。)
・ビットベクトルに対して復号化方法を選択するためのいくつかのハフマン木。これらの木の数はヘッダで指定される。その使用については以下に説明する。
近傍リスト
最も精細なレベル以外の各レベルにおいて、副ファイルは近傍リストを符号化する。レベルkにおける領域の近傍リストは、レベルk領域の近傍領域と呼ばれる0個以上のレベル(k+1)領域のリストである。レベルkの副ファイルの近傍リストセクションは以下の2つの部分を有する。
・第1の部分は、各レベルkサブ領域に対する近傍領域の数を含む。例えば(k=1)、グローバルレベル0において4000個の領域があり、各グローバル領域が10個のレベル1領域に細分される場合、レベル1の副ファイルは4000*10個のレベル1サブ領域を含む。これらの各々に対して、個別の近傍リスト(レベル2領域から成る)の長さが与えられる。
・第2の部分は、長さが第1の部分から既知である実際の近傍リストを含む。各近傍リストはレベル(k+1)サブ領域のリストである。
従って、近傍リストは、所定の行先領域に対して、その行先領域の可視エリアにある領域を指定する。地図データを使用するナビゲーション装置に対して可視エリアの範囲を特定する指標が提供される。探索加速データを使用する経路計画は、探索されるナビゲート可能区分を制約するのに使用可能な行先領域が更なる探索加速データを利用できるかを特定でき、それにより経路計画の速度を向上する。
領域再マッピングテーブル
副ファイルは、例えば結合及び再順序付け等により圧縮形式でビットベクトルを格納する。レベルkの副ファイルは、ブロックにより符号化されたビットベクトルを伸張するのに使用される領域再マッピングテーブルを有する。これは以下の2つの部分から成る。
・第1の部分は、レベルkサブ領域により指標をつけられる配列である。レベルkのサブ領域毎に、圧縮ビットベクトルの長さを含む。これは、ビットベクトルがブロックにより符号化される各サブ領域におけるノードの退出道路区分にとって有意義である。
・第2の部分は、(1)非圧縮ビットベクトルのビット位置及び(2)レベルkサブ領域により指標をつけられた2次元配列である。配列のエントリは、ブロックにより読み出された非圧縮ビット列の所定のビット位置に対する圧縮ビットベクトルのビット位置を指定する。
尚、第1の部分のみがメモリに保持される。第2の部分は、大きいため、復号化中に要望に応じてのみ使用される。現時点で、領域再マッピングテーブルはグローバルレベルの副ファイル(k=0)にのみ格納される。
経路クエリの開始
復号器は、出発位置から行先ノードの集合までの経路探索を加速するために使用される。(目的地が2つ以上のノードから成る一例は、全体の道路の広がりが目的地として使用される場合である。)行先ノードは1つ以上の目標領域の集合を規定する。
尚、目標領域は領域IDのシーケンスであり、各領域IDは各区分レベルに対するものであり、レベル0から開始する。新しい探索の各々の開始時、目標領域の集合は、先の目標領域集合をクリアし且つ新しい行先ノードを復号器に渡すことにより構築される。復号器は、重複のない目標領域のリストを判定する。所定のノードの領域を見つける機構は探索と同一であり、詳細については以下を参照。
経路探索中のノードの走査
残りの説明は、目標領域の集合が設定されたと仮定する。復号器の特徴は、道路ネットワークのノードIDを仮定すると、このノードを出る道路区分にわたり指標をつけられるビット配列(このノードに対するビットベクトル及び所定の目標領域)を返す関数である。ノード及びあるノードにおける道路区分の順序付けは、地図により規定される。ビット値が0である場合は必ず、これは対応する道路区分が探索中に無視されることを意味する。(通常、これにより探索空間は大きく減少され、従って探索の実行時間が短縮される。)
少数のノードの場合、領域情報もビットベクトルデータも副ファイルに格納されない。これらのノードに対して、復号器は全てのビットが1であるビット列を返す。(これにより、経路探索がこのノードにおける道路区分をスキップすることを防止する。)復号器は、これが所定のノードに当てはまるかを示すブールクエリ関数を有する。更に所定のノードが先に固定された目標領域の1つに配置されるかを示すブールクエリ関数が存在する。目標領域のノードに対して復号器により返されたビットベクトルは、ここでも全てのビットが1であるビット列である。これらのブールクエリ関数は経路探索における最適化のために使用される。
副ファイル形式に従って、所定のノードに対するビットベクトルデータはいくつかのステップで復号化される。各副ファイルにおいて、領域及びビットベクトル情報は、いわゆるページに編成される。ページ毎のノード数は2の既定の累乗(例えば、16)であり、副ファイル集合の副ファイル毎に同一である。これは、所定のノードIDに対してビットベクトルページのページ指標が単純なビットシフトにより計算されることを意味する。ノードの情報は、ノードIDで連続して格納される。
所定のノードに対するページオフセットの検索
ページ毎の平均バイト数は、副ファイル毎に副ファイルのヘッダに格納される。これは、ページ指標を平均サイズと乗算することによりページのバイトオフセットを近似するために使用される。修正項は、ページ指標により指標をつけられたテーブルに格納される。このテーブルは、副ファイルの別個のセクションに格納される。ページがクエリされると、修正項は、テーブルでルックアップされ且つ近似ページオフセットに加算され、それにより副ファイルにおけるページの位置が与えられる。
ページの復号化
キャッシュ
ページが初めてクエリされる場合、ページのノードに対するビットベクトル列は復号化され(固定の目標領域集合に関して)且つキャッシュされる。次に同一ページのノードに対してデータがクエリされると、キャッシュされたデータはいずれの副ファイルにもアクセスせずに使用される。復号化されたビットベクトルのビット列の特別なマーカビットは、ノードが非情報ノードであるかを記憶するために使用される。
ページ符号
いわゆるページ符号ビットは、ページの全てのノードが同一の領域IDを有するかをページ毎に指定する。ページ符号はレベル毎に1ビットを含むが、全てのビットは、レベル0の副ファイルのページ開始時にのみ共通のハフマンシンボルとして格納される。
退出道路区分数の復号化
上述したように、各ページは固定のノード数に対する情報を含む。このノード数は、各副ファイルのヘッダに格納される。ページの開始時(又はレベル0の場合はページ符号の後)、ページはページの各ノードに対する退出道路区分数を一覧表示する。退出道路区分数が0である場合は常に、これは対応するノードに対して情報が全く格納されていないことを意味する。ページが復号化される間、数字は一次配列に格納される。
領域の復号化
道路区分数セクションの後、領域セクションが続く。ノードの領域は、レベル毎に1つである領域IDのシーケンスにより与えられる。特定のレベルの領域IDは、対応する副ファイルに格納される。復号器は、ページの全てのノードに対して全てのレベルの領域を読み出す。ノードに対して情報が格納されていない場合(すなわち、ノードの道路区分数が0である場合)、領域情報は空のままである。復号器は、0より大きい道路区分数を有する第1のノードに対する領域IDシーケンスを読み出す。全ての領域IDが所定のレベルで同一であるとそのレベルのページ符号が指定する場合、そのレベルにおいて、同一の領域IDが全てのノードに対して設定される。指定しない場合、対応するレベルの領域IDが正の道路区分数の全てのノードに対して読み出される。この処理の終了時、復号器はページの全てのノードに対する完全な領域IDシーケンスでテーブルを埋めている(いくつかのシーケンスは空であってもよい)。
ビットベクトルの復号化
関連するビット位置の集合の検索
所定のノード及び目標領域に対して、特定のレベルの特定のビットは、そのノードを出る道路区分に対するビットベクトルのビットの値を判定する。2つ以上の目標領域がある場合、結果として得られるビットの論理和がとられる。ノード毎に、復号器は関連するビット位置の集合を計算する。関連するビット位置の集合は、そのノードの退出道路区分毎に同一である。これは、ノードの領域及び目標領域の集合にのみ依存する。目標領域が1つだけ存在する場合、1つのレベルにおいて関連するビット位置は1つだけ存在する。換言すると、他のレベルで格納された情報は、このノードに関しては無視される。2つ以上の目標領域がある場合、関連するビット位置の一部は一致するため、最大で存在する目標領域と同数の関連するビット位置が常に存在する。以下において、復号器が1つの目標領域に対する関連するビット位置を判定する方法について説明する。2つ以上の目標領域がある場合、関連するビット位置は、同様に見つけられ、1つの集合に組み合わされる。
近傍領域が規定されない場合、各レベルの目標領域毎にビットベクトルのビットが1つ存在する(退出道路区分毎に)。(簡潔にするために、ノード自体の領域IDに対してビットが格納されないということを無視する。)関連するビットは第1のレベルにあり、ノードの領域IDが目標領域の領域IDと異なるレベル0からカウントアップする。例えばグローバルレベルのノードの領域IDがグローバルの目標領域IDと等しいが、2つの領域IDがレベル1で異なる場合、関連するビット位置はレベル1にあり、目標領域IDと等しい。これは、そのレベルの非圧縮ビットベクトル列のビット位置である。この列は、可能な目標領域ID毎に1ビットを含む。領域再マッピングテーブルは、この位置を実際にはそのレベルで符号化される圧縮ビットベクトル列の位置に変換するために使用される。
近傍領域が規定される(すなわち、可視エリア内の領域)場合、関連するビットは、目標領域がノードの領域の近傍にある「最も精細な」レベルで判定される。4つのレベルを一例として利用して、目標領域IDシーケンスを(a,b,c,d)とし、ノードの領域IDシーケンスを(e,f,g,h)とする。近傍リストセクションで規定されるように(a,b,c,d)が(e,f,g)の近傍にあり、(a,b)が(e)の近傍にある場合、関連するビットは(a,b,c,d)により判定され且つレベル2で配置され、接頭辞(e,f,g)のレベルは近傍にあるものとして(a,b,c,d)を含む。より詳細には、関連するビット位置はレベル2の副ファイルにおける領域(e,f,g)の近傍の(a,b,c,d)の指標である。前の段落で説明したように、領域ID hに対する正規のビットはこの場合は関連がない。ここでも、この関連するビット位置は、非圧縮ビットベクトル列に対するものである。復号器は、領域再マッピングテーブルを使用して、それをレベル2の圧縮ビット列のビット位置に変換する。近傍リストに関するより多くの情報は、文献「Proposal for enhanced multi−level graph partitioning」に含まれる。
ビットベクトルのビットの復号化
固定の目標領域の集合を仮定すると、ページの各ノードのビットベクトルは退出道路区分毎に1ビットから成る。ノードの道路区分数が0である場合(すなわち、ノードが非情報ノードである場合)、各ビットは、そのノードに対して更に復号化を行わずに1に設定される。ノードが目標領域の1つに配置される場合、ここでもビットベクトルは全て1である。この場合、符号化データは、後続するノードに対するデータを復号化するためにスキップされる必要がある。
現在のノードに対するビットベクトルが単純に全て1でない場合、上述したように、復号器は関連するビット位置の集合を判定する。各ビット位置は、特定のレベルに対するものである。すなわち、ビットは特定の副ファイルに配置される。各レベルにおいて、副ファイルは完全な圧縮ビット列を含むが、復号器は関連するビット位置においてのみビットを抽出する必要がある。復号化中、実際に必要な情報が後続する時のみ、未使用の情報は読み出される(スキップされる)。そうでない場合、ビットストリームの未使用部分は全く読み出されない。
関連するビット位置の集合は、レベルに従ってグループ化される。圧縮ビット列を復号化し且つ関連する位置でビットを読み出すためにそれを伸張する代わりに、関連する位置は圧縮ビット列の位置に変換される。あるレベルにおいて関連するビットが存在する場合、最初に、先行ノードに対するデータが適宜スキップされる(復号器は、それがどの程度遠くから来たものかを各レベルの副ファイルに記憶する)。所定の副ファイルにおいて当該ノードに対するセクションに到達すると、ビットベクトルは線毎に復号化される。退出道路区分毎に1ビットが格納される。これは、全ての関連するビット位置に対する復号化ビットの論理和演算の結果である。現在のノードの特定の道路区分に対する情報は、復号化方法を指定するハフマンシンボルから開始する。これは以下の値のうちの1つを有する。
・このレベルにおける道路区分に対する全てのビットベクトルのビットが0であることを指定するシンボル(このレベルにおける全ての近傍ビットを含む)。この道路区分に対して、これ以上ビットが復号化される必要はない。
・このレベルにおける道路区分に対する全てのビットベクトルのビットが1であることを指定するシンボル(このレベルにおける全ての近傍ビットを含む)。この道路区分に対して、これ以上ビットが復号化される必要はない。
・ビットベクトルのビット列がブロックにより明示的に与えられることを指定するシンボル。ブロックによる圧縮ビットベクトルのビット列の復号化については以下に説明する。道路区分に対するビットベクトルのビットは、ページ全体の符号化中に構築される「履歴トラック」に入れられる。
・履歴トラックへの指標を指定するシンボル。所定の指標において、履歴トラックは道路区分に対する所望のビットベクトルのビット値を含む。
履歴トラックの現在のサイズに依存して、復号化方法セレクタのための異なるハフマン木が使用される。ハフマン木の数を指定する限界値が副ファイルのヘッダにある。履歴トラックのサイズがこの値を越える場合、最後のハフマン木が再利用される。
ビットベクトル列が明示的に符号化されるべきであることを方法セレクタシンボルが指定する場合、復号器は圧縮ビットベクトルのビット列をブロック毎に読み出す。これは、このレベルにおける関連するビット位置(圧縮ビットベクトル列に対する)のビット値を収集する。ビットの値の論理和がとられる。論理和の中間結果が1になるとすぐに、この道路区分に対する全ての更なるブロックの残りのビットがスキップされる。各ブロックを復号化するために使用されるハフマン木はブロック中のビット数に依存する。副ファイルヘッダで指定されるように、正規のブロックの長さに対して1つのハフマン木が存在する。道路区分に対する最後のブロックはより短くてもよい。そのサイズに依存して、復号化のために適切なハフマン木が使用される。長さ1のブロックは1ビットであり、ハフマン復号化を使用せずに直接読み出される。
ブロック数が少なくとも2である場合、ビットベクトルから生成されたビットストリームはブロックに対するハフマンシンボルの前に追加のビットを含む。その値は、復号化列全体が実際の値のビット毎の否定となると理解されるかを指定する。(この否定の目的はより適切なハフマン圧縮である。)
探索方法に関する注釈
従来のダイクストラ及びA*探索方法は探索木を生成し且つ従って木探索の例と呼ばれてもよいが、所定のナビゲート可能区分を根とする一般的な経路探索は探索が実行されるネットワークのサブネットワークを構成する有向非周期グラフを一般に生成してもよいこと、並びにその有向非周期グラフに含まれたいずれの所定のナビゲート可能区分に対してもその区分と探索の根との間に1つ以上の最小コスト経路が存在することが当業者には理解されるだろう。従って、探索木又は木探索に関して説明する場合、この概念は探索の結果として得られる有向非周期グラフに一般化される。
例えば、地図中のナビゲート可能区分に対して速度値を提供する時変関数を使用すると、所定のナビゲート可能区分と探索の根との間に2つ以上の最小コスト経路が存在するため、そのような探索は木探索ではなく有向非周期グラフを使用する。

Claims (15)

  1. それぞれが電子地図によってカバーされるエリアにおいてナビゲート可能な経路の区分を表す複数のナビゲート可能区分を含む前記電子地図を処理するために、少なくとも1つの処理装置を用いて、前記電子地図にわたって経路を計画する際の速度を向上するように構成された探索加速データを含む地図データを作成する方法であって、
    前記処理装置が、
    前記電子地図を複数の領域に分割する工程と、
    前記電子地図の領域内で前記複数のナビゲート可能区分の少なくともいくつかに対してビットベクトルを生成するために前記複数のナビゲート可能区分を処理する工程であって、前記ビットベクトルは複数のビットを含み、それぞれのビットが前記ナビゲート可能区分が他の前記領域の1つへの最小コストの経路の一部であるかどうかを示す工程と、
    前記探索加速データを圧縮するために前記領域に対する生成された複数の前記ビットベクトルを処理する工程であって、当該圧縮は複数の前記ビットベクトルの複数の前記ビットの相関性を計算し、前記計算した相関性に従って前記複数のビットを結合する工程と
    を実行することを特徴とする方法。
  2. 前記圧縮は、さらに、前記計算した相関性に従って複数の前記ビットベクトルの複数のビットを再順序付けすることを含むことを特徴とする請求項1に記載の方法。
  3. 前記圧縮は、さらに、複数の前記ビットベクトルをハフマン符号化することを含むことを特徴とする請求項1又は2に記載の方法。
  4. 各ナビゲート可能区分がそれぞれの階層レベルの少なくとも1つの領域に分類されるように、前記電子地図が複数の階層化領域へ分割されることを特徴とする請求項1乃至3の何れか1項に記載の方法。
  5. 時変関数が少なくともいくつかのナビゲート可能区分、一般的には各ナビゲート可能区分に関連付けられ、
    前記時変関数は、前記ナビゲート可能区分が複数の異なる時刻での他の複数の前記領域の1つへの最小コストの経路の一部であるかどうかを決定するために使用されることを特徴とする請求項1乃至4の何れか1項に記載の方法。
  6. 前記生成されたビットベクトルの前記複数のビットのそれぞれは、前記ナビゲート可能区分が前記複数の異なる時刻での他の複数の前記領域の1つへの最小コストの経路の一部であるかどうかを示すことを特徴とする請求項5に記載の方法。
  7. ナビゲート可能区分に関連付けられる前記時変関数は複数の時間間隔での前記ナビゲート可能区分の平均速度を表すことを特徴とする請求項5又は6に記載の方法。
  8. 複数のナビゲート可能区分のコアネットワークを形成するために、複数の区分を除去することによって、前記探索加速データの作成時に考慮される前記複数のナビゲート可能区分の数を減少させる工程をさらに含むことを特徴とする請求項1乃至7の何れか1項に記載の方法。
  9. 前記探索加速データの作成前に、少なくとも1つの以下の工程に従って、前記電子地図からナビゲート可能区分を除去し、
    前記以下の工程は、
    (i)道路プロパティに関連する所定の基準を満たすナビゲート可能区分を除去する工程と、
    (ii)所定の状況においてナビゲート可能区分の間の分岐点に存在するノードを他方のノードにまとめる工程と、
    (iii)ノードが2つ以下のナビゲート可能区分を接続させる場合に当該ノードを他方のノードにまとめる工程と
    を含むことを特徴とする請求項8に記載の方法。
  10. 前記電子地図の前記複数のナビゲート可能区分のそれぞれが、それぞれに関連する複数のノードを有し、前記ナビゲート可能な経路のパラメータを表す少なくとも1つの関連する属性を有し、
    ナビゲート可能区分に関連付けられる少なくとも1つの前記属性は、
    (i)前記ナビゲート可能区分の種類と、
    (ii)前記ナビゲート可能区分に沿った平均速度と、
    (iii)前記ナビゲート可能区分の長さと、
    (iv)他のナビゲート可能区分に対する前記ナビゲート可能区分の接続性と
    の何れかを含み、
    前記ナビゲート可能区分のそれぞれの分類が、前記ナビゲート可能区分に関連付けられる前記複数のノードが前記電子地図の前記複数の領域にわたって均衡されることを保証すべく、少なくとも1つの前記属性の評価を使用することを特徴とする請求項1乃至9の何れか1項に記載の方法。
  11. 前記最小コストの経路は、最短距離、最短移動時間、最小の環境への影響、最小の使用燃料、及び最小の生成COのコスト基準の1つに従って決定されることを特徴とする請求項1乃至10の何れか1項に記載の方法。
  12. 前記生成されたビットベクトルの第1の複数のビットのそれぞれが、前記ナビゲート可能区分が第1のコスト基準に従って他の複数の前記領域の1つへの最小コストの経路の一部であるかどうかを示し、
    前記生成されたビットベクトルの第2の複数のビットのそれぞれが、前記ナビゲート可能区分が第2のコスト基準に従って他の複数の前記領域の1つへの最小コストの経路の一部であるかどうかを示すことを特徴とする請求項1乃至11の何れか1項に記載の方法。
  13. それぞれが電子地図によってカバーされるエリアにおいてナビゲート可能な経路の区分を表す複数のナビゲート可能区分を含む前記電子地図を処理するために、少なくとも1つの処理装置を用いて、前記電子地図にわたって経路を計画する際の速度を向上するように構成された探索加速データを含む地図データを作成するコンピュータデバイスであって、
    前記少なくとも1つの処理装置は、
    前記電子地図を複数の領域に分割し、
    前記電子地図の領域内で前記複数のナビゲート可能区分の少なくともいくつかに対してビットベクトルを生成するために前記複数のナビゲート可能区分を処理し、前記ビットベクトルは複数のビットを含み、それぞれのビットが前記ナビゲート可能区分が他の前記領域の1つへの最小コストの経路の一部であるかどうかを示し、
    前記探索加速データを圧縮するために前記領域に対する生成された複数の前記ビットベクトルを処理し、当該圧縮は複数の前記ビットベクトルの複数のビットの相関性を計算し、前記計算した相関性に従って前記複数のビットを結合する
    ように構成されることを特徴とするコンピュータデバイス。
  14. コンピュータデバイスで読み取られると、請求項1乃至12の何れか1つに記載の方法をコンピュータデバイスに実行させる命令を含むコンピュータプログラム。
  15. 請求項14に記載のコンピュータプログラムを記憶したコンピュータで読取可能な記憶媒体。
JP2015160686A 2009-07-09 2015-08-17 経路探索加速データとともに地図データを用いるナビゲーション装置 Active JP6129253B2 (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US21374609P 2009-07-09 2009-07-09
US61/213,746 2009-07-09

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2012519022A Division JP2012533056A (ja) 2009-07-09 2010-07-09 経路探索加速データとともに地図データを用いるナビゲーション装置

Publications (2)

Publication Number Publication Date
JP2016020915A JP2016020915A (ja) 2016-02-04
JP6129253B2 true JP6129253B2 (ja) 2017-05-17

Family

ID=43126821

Family Applications (6)

Application Number Title Priority Date Filing Date
JP2012519022A Ceased JP2012533056A (ja) 2009-07-09 2010-07-09 経路探索加速データとともに地図データを用いるナビゲーション装置
JP2012519019A Active JP5785164B2 (ja) 2009-07-09 2010-07-09 経路計算の時間依存に関するナビゲーション装置及び方法
JP2015160685A Ceased JP2016020914A (ja) 2009-07-09 2015-08-17 経路探索加速データとともに地図データを用いるナビゲーション装置
JP2015160686A Active JP6129253B2 (ja) 2009-07-09 2015-08-17 経路探索加速データとともに地図データを用いるナビゲーション装置
JP2016245835A Active JP6282719B2 (ja) 2009-07-09 2016-12-19 経路探索加速データとともに地図データを用いるナビゲーション装置
JP2016245836A Active JP6431891B2 (ja) 2009-07-09 2016-12-19 経路探索加速データとともに地図データを用いるナビゲーション装置

Family Applications Before (3)

Application Number Title Priority Date Filing Date
JP2012519022A Ceased JP2012533056A (ja) 2009-07-09 2010-07-09 経路探索加速データとともに地図データを用いるナビゲーション装置
JP2012519019A Active JP5785164B2 (ja) 2009-07-09 2010-07-09 経路計算の時間依存に関するナビゲーション装置及び方法
JP2015160685A Ceased JP2016020914A (ja) 2009-07-09 2015-08-17 経路探索加速データとともに地図データを用いるナビゲーション装置

Family Applications After (2)

Application Number Title Priority Date Filing Date
JP2016245835A Active JP6282719B2 (ja) 2009-07-09 2016-12-19 経路探索加速データとともに地図データを用いるナビゲーション装置
JP2016245836A Active JP6431891B2 (ja) 2009-07-09 2016-12-19 経路探索加速データとともに地図データを用いるナビゲーション装置

Country Status (7)

Country Link
US (3) US9219500B2 (ja)
EP (4) EP2452325B1 (ja)
JP (6) JP2012533056A (ja)
CN (3) CN105758412B (ja)
ES (3) ES2525825T3 (ja)
IN (2) IN2012DN00279A (ja)
WO (2) WO2011004026A2 (ja)

Families Citing this family (86)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB0822893D0 (en) * 2008-12-16 2009-01-21 Tele Atlas Bv Advanced speed profiles - Further updates
US9109909B2 (en) * 2009-07-09 2015-08-18 Tomtom International B.V. Navigation devices
US9219500B2 (en) 2009-07-09 2015-12-22 Tomtom International B.V. Navigation devices and methods carried out thereon
US8396663B2 (en) * 2009-12-15 2013-03-12 Navteq B.V. Speed profile dictionary
EP2375364A1 (en) * 2010-04-12 2011-10-12 Karlsruher Institut für Technologie Method and system for time-dependent routing
WO2011131417A1 (en) 2010-04-21 2011-10-27 Tomtom International B.V. System and method of generating a route across an electronic map
JP6030544B2 (ja) 2010-04-23 2016-11-24 トムトム インターナショナル ベスローテン フエンノートシャップ コンピュータデバイス、その方法、記憶媒体、及びナビゲーション装置
JP5516209B2 (ja) * 2010-08-06 2014-06-11 アイシン・エィ・ダブリュ株式会社 ナビゲーション装置、ナビゲーション方法、及びナビゲーションプログラム
DE102010040587A1 (de) * 2010-09-10 2012-03-15 Bayerische Motoren Werke Aktiengesellschaft Navigationssystem und Verfahren zum Berechnen von Gesamtkosten einer Route
US9335793B2 (en) 2011-01-31 2016-05-10 Apple Inc. Cover attachment with flexible display
CN102735239B (zh) * 2011-03-29 2015-06-10 电装It研究所 导航装置、方法和系统
US8566030B1 (en) 2011-05-03 2013-10-22 University Of Southern California Efficient K-nearest neighbor search in time-dependent spatial networks
US8660789B2 (en) 2011-05-03 2014-02-25 University Of Southern California Hierarchical and exact fastest path computation in time-dependent spatial networks
EP2712432A4 (en) 2011-05-10 2014-10-29 Kopin Corp HEADSET COMPUTER WITH MOTION AND LANGUAGE COMMANDS TO CONTROL AN INFORMATION DISPLAY AND REMOTE DEVICES
EP2557395A1 (en) * 2011-08-11 2013-02-13 Harman Becker Automotive Systems GmbH Method and system for navigation
DE102011113419A1 (de) * 2011-09-15 2013-03-21 GM Global Technology Operations LLC (n. d. Gesetzen des Staates Delaware) Verfahren zum Ermitteln einer zwischen einem Anfangsort und einem Endort verlaufenden Fahrtroute unter Berücksichtigung von Gebietsbedingungen verschiedener Gebiete, Routenplanungsvorrichtung und Kraftfahrzeug
US8868332B2 (en) * 2011-10-26 2014-10-21 Right There Ware LLC Method and system for navigation using bounded geograhic regions
US8775059B2 (en) * 2011-10-26 2014-07-08 Right There Ware LLC Method and system for fleet navigation, dispatching and multi-vehicle, multi-destination routing
US9037399B2 (en) * 2012-06-20 2015-05-19 Microsoft Technology Licensing, Llc Pluggable route-planning module
WO2014001565A1 (en) * 2012-06-29 2014-01-03 Tomtom Development Germany Gmbh Apparatus and method for route searching
GB201211614D0 (en) * 2012-06-29 2012-08-15 Tomtom Dev Germany Gmbh Generating alternative routes
US9285218B2 (en) * 2012-08-24 2016-03-15 Regents Of The University Of Minnesota Shortest travel path determination using critical start time points
US9253077B2 (en) * 2012-11-30 2016-02-02 International Business Machines Corporation Parallel top-K simple shortest paths discovery
US9026517B2 (en) * 2012-12-13 2015-05-05 International Business Machines Corporation Searching a vertex in a path
EP2750087A1 (en) * 2012-12-28 2014-07-02 Exapaq Sas Methods and systems for determining estimated package delivery/pick-up times
EP2941690A1 (en) * 2013-01-04 2015-11-11 Kopin Corporation Controlled headset computer displays
WO2014118593A1 (en) * 2013-01-30 2014-08-07 Nokia Corporation Method and apparatus for use in navigational applications
CN104050512A (zh) * 2013-03-15 2014-09-17 Sap股份公司 基于多粒度地图的运输时间估计
GB201316013D0 (en) * 2013-09-09 2013-10-23 Tomtom Dev Germany Gmbh Methods and systems for generating alternative routes
GB201316386D0 (en) 2013-09-15 2013-10-30 Tomtom Dev Germany Gmbh Generating routes to optimise traffic flow
WO2015063237A1 (en) * 2013-10-31 2015-05-07 Tomtom International B.V. Apparatus and methods of determining paths through an electronic map
JP6298322B2 (ja) * 2014-02-27 2018-03-20 株式会社ゼンリン 経路探索装置、経路探索方法およびプログラム
TWI549538B (zh) * 2014-05-05 2016-09-11 Chunghwa Telecom Co Ltd The way to improve the reliability of cloud navigation and its computer program products
US9934683B2 (en) * 2014-05-29 2018-04-03 Here Global B.V. Traffic aggregation and reporting in real-time
US10122583B2 (en) * 2014-07-08 2018-11-06 Oracle International Corporation Aggregated network model with component network aggregation
GB201503227D0 (en) * 2015-02-26 2015-04-15 Tomtom Int Bv Methods and systems for generating routing policies and routes
CN104754332A (zh) * 2015-03-24 2015-07-01 深圳第一蓝筹科技有限公司 一种智能穿戴设备的视频图片传输方法
CN104765790B (zh) * 2015-03-24 2019-09-20 北京大学 一种数据查询的方法和装置
WO2016184501A1 (en) * 2015-05-19 2016-11-24 Fleetmatics Development Limited System and method for accelerating route search
US9726502B2 (en) * 2015-08-31 2017-08-08 Sap Se Route planner for transportation systems
US11158010B2 (en) 2015-08-31 2021-10-26 International Business Machines Corporation Incremental search based multi-modal journey planning
CN105118015A (zh) * 2015-09-21 2015-12-02 无锡知谷网络科技有限公司 用于公共场所的信息提示方法及移动服务终端
CN105222793B (zh) * 2015-10-23 2019-01-04 华中科技大学 一种基于矢量地图数据模型的城市层次化区域划分方法
US9671236B2 (en) * 2015-10-29 2017-06-06 Here Global B.V. Tile versioning to improve usability of streamed navigation data
US10739154B2 (en) * 2016-02-02 2020-08-11 Sap Se System and method for vehicle fuel consumption optimization
JP6323470B2 (ja) 2016-02-05 2018-05-16 トヨタ自動車株式会社 車両制御システム
JP6272373B2 (ja) * 2016-03-17 2018-01-31 株式会社トヨタマップマスター 地図情報作成装置、ナビゲーションシステム、情報表示方法、情報表示プログラム、記録媒体
MX2017004181A (es) * 2016-03-29 2018-02-09 Sirius Xm Radio Inc Codificacion de datos de trafico que utiliza referencias fijas.
US10178152B2 (en) 2016-04-29 2019-01-08 Splunk Inc. Central repository for storing configuration files of a distributed computer system
US10024673B1 (en) * 2016-05-25 2018-07-17 Uber Technologies, Inc. Identifying a map matched trip from received geographic position information
US20170350714A1 (en) * 2016-06-06 2017-12-07 International Business Machines Corporation Route planning based on connectivity of nodes
US10065654B2 (en) * 2016-07-08 2018-09-04 Toyota Motor Engineering & Manufacturing North America, Inc. Online learning and vehicle control method based on reinforcement learning without active exploration
US10061316B2 (en) * 2016-07-08 2018-08-28 Toyota Motor Engineering & Manufacturing North America, Inc. Control policy learning and vehicle control method based on reinforcement learning without active exploration
US10060753B2 (en) * 2016-08-17 2018-08-28 Apple Inc. On-demand shortcut computation for routing
US10274325B2 (en) * 2016-11-01 2019-04-30 Brain Corporation Systems and methods for robotic mapping
US10146224B2 (en) * 2016-11-09 2018-12-04 GM Global Technology Operations LLC Processor-implemented systems and methods for automated driving
EP3555569A1 (en) * 2016-11-09 2019-10-23 Inventive Cogs (Campbell) Limited Vehicle route guidance
US10248925B2 (en) * 2016-12-06 2019-04-02 Walmart Apollo, Llc Systems and methods for compressing shortest path matrices for delivery route optimization
CN108204813B (zh) * 2016-12-19 2021-02-23 北京四维图新科技股份有限公司 一种路径计算的方法、装置及导航系统
US10480947B2 (en) 2016-12-21 2019-11-19 X Development Llc Boolean satisfiability (SAT) reduction for geometry and kinematics agnostic multi-agent planning
CN106918348B (zh) * 2017-03-29 2020-05-26 联想(北京)有限公司 一种信息处理方法及电子设备
US10715175B2 (en) * 2017-08-28 2020-07-14 Tesla, Inc. Systems and methods for encoding and decoding
US10429195B2 (en) 2017-09-19 2019-10-01 Here Global B.V. Method, apparatus, and computer program product for generation of a route using time and space
US11238409B2 (en) 2017-09-29 2022-02-01 Oracle International Corporation Techniques for extraction and valuation of proficiencies for gap detection and remediation
CN109861923B (zh) 2017-11-30 2022-05-17 华为技术有限公司 一种数据调度方法及tor交换机
DE102018208700A1 (de) * 2018-06-01 2019-12-05 Volkswagen Aktiengesellschaft Konzept für die Steuerung einer Anzeige eines mobilen Augmented-Reality-Gerätes
CN108981739B (zh) * 2018-06-08 2022-02-22 南方科技大学 一种路径规划方法、装置、服务器及存储介质
US10990615B2 (en) 2018-06-27 2021-04-27 Uber Technologies, Inc. Visual search system for finding trip destination
US20200097879A1 (en) * 2018-09-25 2020-03-26 Oracle International Corporation Techniques for automatic opportunity evaluation and action recommendation engine
CN112970039A (zh) 2018-09-27 2021-06-15 甲骨文国际公司 用于度量的数据驱动关联的技术
US20210405212A1 (en) * 2018-11-01 2021-12-30 Sony Semiconductor Solutions Corporation Information processing apparatus, information processing method, and program
US11435194B2 (en) * 2019-01-28 2022-09-06 Uatc, Llc Scaffolds for globally consistent maps
JP7291252B2 (ja) * 2019-06-27 2023-06-14 グラブタクシー ホールディングス プライベート リミテッド 処理ルート情報
US11112251B2 (en) 2019-09-03 2021-09-07 Here Global B.V. Method, apparatus, and computer program product for generating correspondence between map versions
US10969232B1 (en) * 2019-12-06 2021-04-06 Ushr Inc. Alignment of standard-definition and High-Definition maps
US11410560B2 (en) 2019-12-10 2022-08-09 Here Global B.V. Method and apparatus for representing an aerial route in a three-dimensional space
CN111275964B (zh) * 2020-01-14 2021-03-23 浙江浙大中控信息技术有限公司 基于卡口数据的路段相关性矩阵的计算方法
AU2020277094C1 (en) * 2020-03-26 2023-06-29 Commonwealth Scientific And Industrial Research Organisation Path Planning
CN111603099B (zh) * 2020-05-06 2021-08-06 珠海市一微半导体有限公司 一种具备区域遍历优先级的清扫规划方法及芯片
CN111680118B (zh) * 2020-06-10 2023-04-18 四川易利数字城市科技有限公司 一种融合图形视觉表达的系统及方法
US11808602B2 (en) * 2020-06-22 2023-11-07 Grabtaxi Holdings Pte. Ltd. Method and device for correcting errors in map data
CN112504291B (zh) * 2020-11-17 2023-05-23 腾讯科技(深圳)有限公司 一种车辆导航的方法及装置
WO2023003540A1 (en) * 2021-07-20 2023-01-26 Google Llc Flexible navigation and route generation
CN116358575A (zh) * 2021-12-27 2023-06-30 格步计程车控股私人有限公司 用于为区域生成多个行进路线的系统和方法
CN116312072B (zh) * 2023-03-21 2024-01-26 中国人民解放军93209部队 一种基于空域网格的航迹运行冲突解耦控制方法
CN116403410B (zh) * 2023-06-06 2023-08-22 中南大学 一种考虑拥堵车源的高速公路混合路径诱导模型构建方法

Family Cites Families (60)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH03238599A (ja) 1990-02-15 1991-10-24 Clarion Co Ltd 車載用ナビゲーション装置
US5428396A (en) 1991-08-03 1995-06-27 Sony Corporation Variable length coding/decoding method for motion vectors
JPH0541862A (ja) * 1991-08-03 1993-02-19 Sony Corp 動きベクトルの可変長符号化方式
US7006881B1 (en) 1991-12-23 2006-02-28 Steven Hoffberg Media recording device with remote graphic user interface
US6084908A (en) 1995-10-25 2000-07-04 Sarnoff Corporation Apparatus and method for quadtree based variable block size motion estimation
JP3223782B2 (ja) * 1996-02-08 2001-10-29 三菱電機株式会社 車両経路算出装置
EP0917357A4 (en) 1997-05-28 2009-05-06 Sony Corp BLOCK DECELERATION METHOD AND DEVICE, AND CODING METHOD AND DEVICE
JP3500928B2 (ja) * 1997-09-17 2004-02-23 トヨタ自動車株式会社 地図データ処理装置、地図データ処理方法および地図データ処理システム
WO1999022205A1 (de) 1997-10-27 1999-05-06 Siemens Aktiengesellschaft Verfahren und anordnung zur rechnergestützten bearbeitung eines graphen
JP3171574B2 (ja) * 1998-03-05 2001-05-28 松下電器産業株式会社 経路選出方法
US6266610B1 (en) 1998-12-31 2001-07-24 Honeywell International Inc. Multi-dimensional route optimizer
JP4086994B2 (ja) * 1999-02-08 2008-05-14 株式会社デンソー 画像データ供給装置及び画像圧縮装置
JP2000283776A (ja) * 1999-03-29 2000-10-13 Toyota Central Res & Dev Lab Inc 道路ネットワーク階層化経路探索装置
JP2001074482A (ja) * 1999-09-06 2001-03-23 Alpine Electronics Inc 経路探索装置
JP2002310702A (ja) 2001-04-18 2002-10-23 Fujitsu Ten Ltd ナビゲーション装置
JP2003021524A (ja) * 2001-07-09 2003-01-24 Kenwood Corp ナビゲーション装置、到着時刻算出方法、及びプログラム
US7206448B2 (en) 2002-02-28 2007-04-17 At&T Corp. System and method for using pattern vectors for video and image coding and decoding
US7082443B1 (en) * 2002-07-23 2006-07-25 Navteq North America, Llc Method and system for updating geographic databases
JP4416996B2 (ja) * 2002-11-01 2010-02-17 三菱電機株式会社 地図情報処理装置および地図情報提供装置
JP4380151B2 (ja) * 2002-12-20 2009-12-09 株式会社デンソー 地図評価システム、及び、地図評価装置
JP4048963B2 (ja) * 2003-01-31 2008-02-20 株式会社日立製作所 ナビゲーション端末装置
JP4138561B2 (ja) 2003-04-09 2008-08-27 パイオニア株式会社 ナビゲーション装置、ナビゲーション方法、および、経路データ生成プログラム
JP4255007B2 (ja) * 2003-04-11 2009-04-15 株式会社ザナヴィ・インフォマティクス ナビゲーション装置、およびその旅行時間算出方法
US7079943B2 (en) 2003-10-07 2006-07-18 Deere & Company Point-to-point path planning
JP3802026B2 (ja) 2003-11-05 2006-07-26 本田技研工業株式会社 経路探索装置
US20050096842A1 (en) * 2003-11-05 2005-05-05 Eric Tashiro Traffic routing method and apparatus for navigation system to predict travel time and departure time
JP2005202248A (ja) 2004-01-16 2005-07-28 Fujitsu Ltd オーディオ符号化装置およびオーディオ符号化装置のフレーム領域割り当て回路
JP2005201793A (ja) 2004-01-16 2005-07-28 Xanavi Informatics Corp ナビゲーション装置の経路探索方法
JP4207793B2 (ja) * 2004-02-20 2009-01-14 アイシン・エィ・ダブリュ株式会社 経路探索装置及び経路探索方法
JP4476104B2 (ja) 2004-04-22 2010-06-09 三洋電機株式会社 符号化回路
DE102004027292A1 (de) * 2004-06-04 2005-12-29 Siemens Ag Vefahren zur Bestimmung von Positionsdaten
JP4419721B2 (ja) 2004-07-02 2010-02-24 アイシン・エィ・ダブリュ株式会社 ナビゲーションシステム
US7739029B2 (en) 2004-09-08 2010-06-15 Aisin Aw Co., Ltd. Navigation apparatus and method with traffic ranking and display
US20070010941A1 (en) * 2005-07-07 2007-01-11 Marsh David C Land navigation system
JP2007040912A (ja) * 2005-08-05 2007-02-15 Aisin Aw Co Ltd ナビゲーション装置
JP2009516829A (ja) 2005-11-21 2009-04-23 フォード モーター カンパニー 車両用ナビゲーション・システム
JP4513740B2 (ja) 2005-12-28 2010-07-28 アイシン・エィ・ダブリュ株式会社 経路案内システム及び経路案内方法
JP5116236B2 (ja) * 2006-01-30 2013-01-09 アルパイン株式会社 地図データ作成方法及び地図データ作成装置
JP4682865B2 (ja) * 2006-02-17 2011-05-11 アイシン・エィ・ダブリュ株式会社 経路探索システム、経路案内システムにおける経路案内方法、及びナビゲーション装置
US20070208498A1 (en) * 2006-03-03 2007-09-06 Inrix, Inc. Displaying road traffic condition information and user controls
JP5013738B2 (ja) * 2006-04-25 2012-08-29 アルパイン株式会社 地図データ作成装置
JP2008020414A (ja) * 2006-07-14 2008-01-31 Aisin Aw Co Ltd 経路探索方法及びナビゲーション装置
GB2440958A (en) 2006-08-15 2008-02-20 Tomtom Bv Method of correcting map data for use in navigation systems
JP2008122266A (ja) * 2006-11-14 2008-05-29 Pioneer Electronic Corp 経路探索装置、経路探索方法、経路探索プログラム及び記憶媒体
JP2008145193A (ja) * 2006-12-07 2008-06-26 Pioneer Electronic Corp 経路探索装置、経路探索方法、経路探索プログラム及び記憶媒体
JP2007139794A (ja) 2006-12-25 2007-06-07 Aisin Aw Co Ltd ナビゲーション装置及びそれを備えたナビゲーションシステム
JP5121255B2 (ja) 2007-02-28 2013-01-16 クラリオン株式会社 ナビゲーション装置
JP4450000B2 (ja) 2007-03-14 2010-04-14 アイシン・エィ・ダブリュ株式会社 経路選択支援装置および経路選択支援方法
JP4997597B2 (ja) 2007-06-15 2012-08-08 国立大学法人東京海洋大学 最短経路探索方法
US20090006399A1 (en) * 2007-06-29 2009-01-01 International Business Machines Corporation Compression method for relational tables based on combined column and row coding
CN101334285B (zh) * 2007-06-29 2012-12-19 鸿富锦精密工业(深圳)有限公司 车辆导航装置及导航方法
CN101836081A (zh) 2007-10-26 2010-09-15 通腾科技股份有限公司 处理定位数据的方法
CN101246021B (zh) 2007-12-18 2011-05-11 北京捷易联科技有限公司 一种智能导航的实现方法、设备及系统
US20110022310A1 (en) * 2007-12-28 2011-01-27 Takaaki Ishii Information terminal device, information processing method and information processing program
FR2926880B1 (fr) 2008-01-24 2010-09-10 Mediamobile Estimation de plus court chemin dependant du temps dans un reseau routier
CN101685020A (zh) 2008-09-27 2010-03-31 佛山市顺德区顺达电脑厂有限公司 导航系统及其导航方法,及其机器可读取媒体
US8150620B2 (en) * 2009-04-14 2012-04-03 Alpine Electronics, Inc. Route search method and apparatus for navigation system utilizing map data of XML format
US9219500B2 (en) 2009-07-09 2015-12-22 Tomtom International B.V. Navigation devices and methods carried out thereon
US8392113B2 (en) 2009-12-11 2013-03-05 Qualcomm Incorporated Method and apparatus for accounting for user experience in pedestrian navigation routing
JP6030544B2 (ja) 2010-04-23 2016-11-24 トムトム インターナショナル ベスローテン フエンノートシャップ コンピュータデバイス、その方法、記憶媒体、及びナビゲーション装置

Also Published As

Publication number Publication date
CN105758412B (zh) 2019-04-12
JP2016020915A (ja) 2016-02-04
JP2012533056A (ja) 2012-12-20
IN2012DN00279A (ja) 2015-05-08
CN102612709B (zh) 2015-09-30
CN102612709A (zh) 2012-07-25
JP2016020914A (ja) 2016-02-04
US10132640B2 (en) 2018-11-20
WO2011004026A8 (en) 2011-06-30
ES2474815T3 (es) 2014-07-09
JP6431891B2 (ja) 2018-11-28
EP2452325A2 (en) 2012-05-16
US20160178386A1 (en) 2016-06-23
WO2011004029A2 (en) 2011-01-13
EP2452325B1 (en) 2014-04-23
ES2468795T3 (es) 2014-06-17
CN102483333B (zh) 2016-03-09
US9219500B2 (en) 2015-12-22
JP5785164B2 (ja) 2015-09-24
EP2452158A2 (en) 2012-05-16
CN105758412A (zh) 2016-07-13
US20120158301A1 (en) 2012-06-21
IN2012DN00281A (ja) 2015-05-08
EP2565582B1 (en) 2014-05-14
JP6282719B2 (ja) 2018-02-21
EP2452158B1 (en) 2014-11-12
JP2017083459A (ja) 2017-05-18
US20130173152A1 (en) 2013-07-04
WO2011004026A2 (en) 2011-01-13
US8788202B2 (en) 2014-07-22
EP2565582A1 (en) 2013-03-06
WO2011004029A3 (en) 2011-03-24
ES2525825T3 (es) 2014-12-30
JP2017083460A (ja) 2017-05-18
EP2746727A1 (en) 2014-06-25
WO2011004026A3 (en) 2011-05-05
EP2746727B1 (en) 2016-09-07
JP2012533055A (ja) 2012-12-20
CN102483333A (zh) 2012-05-30

Similar Documents

Publication Publication Date Title
JP6282719B2 (ja) 経路探索加速データとともに地図データを用いるナビゲーション装置
JP6030544B2 (ja) コンピュータデバイス、その方法、記憶媒体、及びナビゲーション装置
US9835466B2 (en) Navigation devices
JP5675838B2 (ja) 走行ルートの記述を簡略化するための方法
TW201211509A (en) Navigation devices

Legal Events

Date Code Title Description
A711 Notification of change in applicant

Free format text: JAPANESE INTERMEDIATE CODE: A711

Effective date: 20151112

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20160930

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20161226

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20170321

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20170411

R150 Certificate of patent or registration of utility model

Ref document number: 6129253

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250