(19)【発行国】日本国特許庁(JP)
(12)【公報種別】公開特許公報(A)
(11)【公開番号】P2022158951
(43)【公開日】2022-10-17
(54)【発明の名称】ドローン映像を活用した航空地図のアップデート方法およびシステム
(51)【国際特許分類】
G06T 17/05 20110101AFI20221006BHJP
G09B 29/00 20060101ALI20221006BHJP
G01C 11/12 20060101ALI20221006BHJP
【FI】
G06T17/05
G09B29/00 Z
G01C11/12
【審査請求】有
【請求項の数】20
【出願形態】OL
(21)【出願番号】P 2022026347
(22)【出願日】2022-02-24
(31)【優先権主張番号】10-2021-0042556
(32)【優先日】2021-04-01
(33)【優先権主張国・地域又は機関】KR
(71)【出願人】
【識別番号】319012978
【氏名又は名称】ネイバーラボス コーポレーション
(74)【代理人】
【識別番号】100107766
【弁理士】
【氏名又は名称】伊東 忠重
(74)【代理人】
【識別番号】100070150
【弁理士】
【氏名又は名称】伊東 忠彦
(74)【代理人】
【識別番号】100135079
【弁理士】
【氏名又は名称】宮崎 修
(72)【発明者】
【氏名】チェー ハンスン
(72)【発明者】
【氏名】ピョ セヨン
(72)【発明者】
【氏名】ユン ヨイル
(72)【発明者】
【氏名】キム ジンソク
(72)【発明者】
【氏名】イ ジンハン
【テーマコード(参考)】
2C032
5B050
【Fターム(参考)】
2C032HB22
2C032HC09
5B050BA02
5B050BA09
5B050BA13
5B050BA17
5B050CA07
5B050CA08
5B050DA07
5B050DA10
5B050EA07
5B050EA12
5B050EA18
5B050EA19
5B050EA27
5B050FA02
5B050FA09
5B050GA08
(57)【要約】
【課題】 ドローン映像を活用した航空地図のアップデート方法およびシステムを提供する。
【解決手段】 一実施形態に係るアップデート方法は、既存の航空地図ベースのDEM(Digital Elevation Model)、DSM(Digital Surface Model)、およびトゥルーオルソフォト(true-orthophoto)を利用して予め設定された高さ以上の映像を含むルーフ(roof)トゥルーオルソフォトを生成する段階、ドローン映像とルーフトゥルーオルソフォトをマッチングする段階、およびマッチングされたドローン映像を基準に、他のドローン映像にGCP(Ground Control Point)を入力する段階を含む。
【選択図】
図2
【特許請求の範囲】
【請求項1】
少なくとも1つのプロセッサを含むコンピュータ装置のアップデート方法であって、
前記少なくとも1つのプロセッサにより、既存の航空地図ベースのDEM、DSM、およびトゥルーオルソフォトを利用して、予め設定された高さ以上の映像を含むルーフトゥルーオルソフォトを生成する段階、
前記少なくとも1つのプロセッサにより、ドローン映像と前記ルーフトゥルーオルソフォトをマッチングする段階、および
前記少なくとも1つのプロセッサにより、前記マッチングされたドローン映像を基準に、他のドローン映像にGCPを入力する段階
を含むことを特徴とする、アップデート方法。
【請求項2】
前記ルーフトゥルーオルソフォトを生成する段階は、
前記トゥルーオルソフォトから前記DSMと前記DEMの差が予め設定された高さ以上の部分を抽出して前記ルーフトゥルーオルソフォトを生成することを特徴とする、請求項1に記載のアップデート方法。
【請求項3】
前記ドローン映像と前記ルーフトゥルーオルソフォトをマッチングする段階は、
前記ドローン映像と前記ルーフトゥルーオルソフォトの特徴点マッチングを処理する段階、
前記ドローン映像の一部から少なくとも1つのマッチングポイントを選定する段階、および
前記選定されたマッチングポイントに対応する前記ルーフトゥルーオルソフォトの位置に対する実際の地形の3次元座標を、前記選定されたマッチングポイントに対する仮想GCPとして選定する段階
を含むことを特徴とする、請求項1または2に記載のアップデート方法。
【請求項4】
前記特徴点マッチングを処理する段階は、
R2D2マッチングを利用して、前記ドローン映像の特徴点と前記ルーフトゥルーオルソフォトの特徴点をマッチングすることを特徴とする、請求項3に記載のアップデート方法。
【請求項5】
前記ドローン映像と前記ルーフトゥルーオルソフォトをマッチングする段階は、
前記ルーフトゥルーオルソフォトでアップデートしようとする範囲に予め設定された長さに基づいてシードを設定する段階、
前記設定されたシードから最も近いルーフトゥルーオルソフォトをロードする段階、
前記ロードされたルーフトゥルーオルソフォトから特徴点を抽出した後、前記設定されたシードの位置を前記抽出された特徴点の密集度に基づいて再設定する段階、および
前記再設定されたシードの位置から最も近いドローン映像の一部をロードする段階
をさらに含むことを特徴とする、請求項3に記載のアップデート方法。
【請求項6】
前記シードを設定する段階は、
一辺の長さが前記予め設定された長さである複数の正方形で構成される範囲に対し、前記複数の正方形それぞれに予め設定された数のシードをランダムに設定することを特徴とする、請求項5に記載のアップデート方法。
【請求項7】
前記再設定する段階は、
前記シードの位置を前記抽出された特徴点の密集度が最も高い位置に再設定することを特徴とする、請求項5に記載のアップデート方法。
【請求項8】
前記他のドローン映像にGCPを入力する段階は、
前記マッチングされたドローン映像のポイントに前記ルーフトゥルーオルソフォトのマッチングされたポイントによる3次元座標を仮想GCPとして入力する段階、および
前記マッチングされたドローン映像のポイントとマッチングする前記他のドローン映像のポイントに前記仮想GCPを入力する段階
を含むことを特徴とする、請求項1~7のうちのいずれか一項に記載のアップデート方法。
【請求項9】
前記仮想GCPを入力する段階は、
デンスマッチングを利用して、前記マッチングされたドローン映像のポイントと前記他のドローン映像のポイントをマッチングすることを特徴とする、請求項8に記載のアップデート方法。
【請求項10】
前記少なくとも1つのプロセッサにより、前記GCPをフィルタリングする段階
をさらに含む、請求項1~9のうちのいずれか一項に記載のアップデート方法。
【請求項11】
前記GCPをフィルタリングする段階は、
前記マッチングされたドローン映像のピクセルの位置点に基づいて、前記GCPに対応する映像座標との差が最小となるドローンカメラの内部焦点距離、歪曲係数、前記ドローンカメラの回転情報、および補正されたGCPを決定することを特徴とする、請求項10に記載のアップデート方法。
【請求項12】
前記少なくとも1つのプロセッサにより、前記フィルタリングされたGCPが入力されたドローン映像に基づいてアップデートされたDSMを生成する段階、および
前記少なくとも1つのプロセッサにより、前記アップデートされたDSMに基づいてアップデートされたトゥルーオルソフォトを生成する段階
をさらに含む、請求項10に記載のアップデート方法。
【請求項13】
請求項1~12のうちのいずれか一項に記載の方法をコンピュータ装置に実行させるためのコンピュータプログラム。
【請求項14】
請求項1~12のうちのいずれか一項に記載の方法をコンピュータ装置に実行させるためのコンピュータプログラムが記録されている、コンピュータ読み取り可能な記録媒体。
【請求項15】
コンピュータ読み取り可能な命令を実行ように実現される少なくとも1つのプロセッサ
を含み、
前記少なくとも1つのプロセッサにより、
既存の航空地図ベースのDEM、DSM、およびトゥルーオルソフォトを利用して、予め設定された高さ以上の映像を含むルーフトゥルーオルソフォトを生成し、
ドローン映像と前記ルーフトゥルーオルソフォトをマッチングし、
前記マッチングされたドローン映像を基準に、他のドローン映像にGCPを入力すること
を特徴とする、コンピュータ装置。
【請求項16】
前記ルーフトゥルーオルソフォトを生成するために、前記少なくとも1つのプロセッサにより、
前記トゥルーオルソフォトから前記DSMと前記DEMの差が予め設定された高さ以上の部分を抽出して前記ルーフトゥルーオルソフォトを生成すること
を特徴とする、請求項15に記載のコンピュータ装置。
【請求項17】
前記ドローン映像と前記ルーフトゥルーオルソフォトをマッチングするために、前記少なくとも1つのプロセッサにより、
前記ドローン映像と前記ルーフトゥルーオルソフォトの特徴点マッチングを処理し、
前記ドローン映像の一部から少なくとも1つのマッチングポイントを選定し、
前記選定されたマッチングポイントに対応する前記ルーフトゥルーオルソフォトの位置に対する実際の地形の3次元座標を、前記選定されたマッチングポイントに対する仮想GCPとして選定すること
を特徴とする、請求項15または16に記載のコンピュータ装置。
【請求項18】
前記ドローン映像と前記ルーフトゥルーオルソフォトをマッチングするために、前記少なくとも1つのプロセッサにより、
前記ルーフトゥルーオルソフォトでアップデートしようとする範囲に予め設定された長さに基づいてシードを設定し、
前記設定されたシードから最も近いルーフトゥルーオルソフォトをロードし、
前記ロードされたルーフトゥルーオルソフォトから特徴点を抽出した後、前記設定されたシードの位置を前記抽出された特徴点の密集度に基づいて再設定し、
前記再設定されたシードの位置から最も近いドローン映像の一部をロードすること
を特徴とする、請求項17に記載のコンピュータ装置。
【請求項19】
前記設定されたシードの位置を前記抽出された特徴点の密集度に基づいて再設定するために、前記少なくとも1つのプロセッサにより、
前記シードの位置を、前記抽出された特徴点の密集度が最も高い位置に再設定すること
を特徴とする、請求項18に記載のコンピュータ装置。
【請求項20】
前記他のドローン映像にGCPを入力するために、前記少なくとも1つのプロセッサにより、
前記マッチングされたドローン映像のポイントに前記ルーフトゥルーオルソフォトのマッチングされたポイントによる3次元座標を仮想GCPとして入力し、
前記マッチングされたドローン映像のポイントとマッチングする前記他のドローン映像のポイントに前記仮想GCPを入力すること
を特徴とする、請求項15~19のうちのいずれか一項に記載のコンピュータ装置。
【発明の詳細な説明】
【技術分野】
【0001】
以下の説明は、ドローン映像を活用した航空地図のアップデート方法およびシステムに関する。
【背景技術】
【0002】
航空地図とは、航空写真を利用して生成した地図を意味する。航空地図の取得周期は長く(一例として、2年)、道路などの領域に変更が生じた場合にこれを迅速に反映することが難しいという問題があった。
【0003】
このような問題点を解決するために、ドローンが生成した映像を活用する方法もあるが、ドローン映像を活用して既存の地図を生成および/またはアップデートするためには、直接外部に出向いてGCP(Ground Control Point(地上基準点))を測量し、これを利用して地図を製作および/またはアップデートしなければならないという問題があった。
【0004】
さらに、測量したGCPとドローン映像とのマッチング作業を手動でしか行うことができないという問題もあった。
【先行技術文献】
【特許文献】
【0005】
【特許文献1】韓国登録特許第10-0940118号公報
【発明の概要】
【発明が解決しようとする課題】
【0006】
ドローン映像を活用して航空地図を生成および/またはアップデートするにあたり、既存の3次元航空地図をGCPとして活用することにより、航空地図の生成および/またはアップデートのための時間および費用を減らすことができる、アップデート方法およびシステムを提供することを目的とする。
【0007】
GCPとして活用される3次元航空地図とドローン映像の自動マッチングを支援することによって人力と時間を節約することができる、アップデート方法およびシステムを提供することを他の目的とする。
【課題を解決するための手段】
【0008】
少なくとも1つのプロセッサを含むコンピュータ装置のアップデート方法であって、前記少なくとも1つのプロセッサにより、既存の航空地図ベースのDEM(Digital Elevation Model(数値標高モデル))、DSM(Digital Surface Model(数値表層モデル))、およびトゥルーオルソフォト(true-orthophoto)を利用して、予め設定された高さ以上の映像を含むルーフ(roof)トゥルーオルソフォトを生成する段階、前記少なくとも1つのプロセッサにより、ドローン映像と前記ルーフトゥルーオルソフォトをマッチングする段階、および前記少なくとも1つのプロセッサにより、前記マッチングされたドローン映像を基準に、他のドローン映像にGCP(Ground Control Point)を入力する段階を含むことを特徴とする、アップデート方法を提供する。
【0009】
一態様によると、前記ルーフトゥルーオルソフォトを生成する段階は、前記トゥルーオルソフォトから前記DSMと前記DEMの差が予め設定された高さ以上の部分を抽出して前記ルーフトゥルーオルソフォトを生成することを特徴としてよい。
【0010】
他の態様によると、前記ドローン映像と前記ルーフトゥルーオルソフォトをマッチングする段階は、前記ドローン映像と前記ルーフトゥルーオルソフォトの特徴点マッチングを処理する段階、前記ドローン映像の一部から少なくとも1つのマッチングポイントを選定する段階、および前記選定されたマッチングポイントに対応する前記ルーフトゥルーオルソフォトの位置に対する実際の地形の3次元座標を、前記選定されたマッチングポイントに対する仮想GCPとして選定する段階を含むことを特徴としてよい。
【0011】
また他の態様によると、前記特徴点マッチングを処理する段階は、R2D2マッチングを利用して、前記ドローン映像の特徴点と前記ルーフトゥルーオルソフォトの特徴点をマッチングすることを特徴としてよい。
【0012】
また他の態様によると、前記ドローン映像と前記ルーフトゥルーオルソフォトをマッチングする段階は、前記ルーフトゥルーオルソフォトでアップデートしようとする範囲に予め設定された長さに基づいてシード(seed)を設定する段階、前記設定されたシードから最も近いルーフトゥルーオルソフォトをロードする段階、前記ロードされたルーフトゥルーオルソフォトから特徴点を抽出した後、前記設定されたシードの位置を前記抽出された特徴点の密集度に基づいて再設定する段階、および前記再設定されたシードの位置から最も近いドローン映像の一部をロードする段階をさらに含むことを特徴としてよい。
【0013】
また他の態様によると、前記シードを設定する段階は、一辺の長さが前記予め設定された長さである複数の正方形で構成される範囲に対し、前記複数の正方形それぞれに予め設定された数のシードをランダムに設定することを特徴としてよい。
【0014】
また他の態様によると、前記再設定する段階は、前記シードの位置を、前記抽出された特徴点の密集度が最も高い位置に再設定することを特徴としてよい。
【0015】
また他の態様によると、前記他のドローン映像にGCPを入力する段階は、前記マッチングされたドローン映像のポイントに前記ルーフトゥルーオルソフォトのマッチングされたポイントによる3次元座標を仮想GCPとして入力する段階、および前記マッチングされたドローン映像のポイントとマッチングする前記他のドローン映像のポイントに前記仮想GCPを入力する段階を含むことを特徴としてよい。
【0016】
また他の態様によると、前記仮想GCPを入力する段階は、デンスマッチング(dense matching)を利用して、前記マッチングされたドローン映像のポイントと前記他のドローン映像のポイントをマッチングすることを特徴としてよい。
【0017】
また他の態様によると、前記アップデート方法は、前記少なくとも1つのプロセッサにより、前記GCPをフィルタリングする段階をさらに含んでよい。
【0018】
また他の態様によると、前記GCPをフィルタリングする段階は、前記マッチングされたドローン映像のピクセルの位置点に基づいて、前記GCPに対応する映像座標との差が最小となるドローンカメラの内部焦点距離、歪曲係数、前記ドローンカメラの回転情報、および補正されたGCPを決定することを特徴としてよい。
【0019】
さらに他の態様によると、前記アップデート方法は、前記少なくとも1つのプロセッサにより、前記フィルタリングされたGCPが入力されたドローン映像に基づいてアップデートされたDSMを生成する段階、および前記少なくとも1つのプロセッサにより、前記アップデートされたDSMに基づいてアップデートされたトゥルーオルソフォトを生成する段階をさらに含んでよい。
【0020】
前記方法をコンピュータ装置に実行させるためのコンピュータプログラムを提供する。
【0021】
前記方法をコンピュータ装置に実行させるためのプログラムが記録されている、コンピュータ読み取り可能な記録媒体を提供する。
【0022】
コンピュータ読み取り可能な命令を実行するように実現される少なくとも1つのプロセッサを含み、前記少なくとも1つのプロセッサにより、既存の航空地図ベースのDEM(Digital Elevation Model)、DSM(Digital Surface Model)、およびトゥルーオルソフォト(true-ortho photo)を利用して予め設定された高さ以上の映像を含むルーフ(roof)トゥルーオルソフォトを生成し、ドローン映像と前記ルーフトゥルーオルソフォトをマッチングし、前記マッチングされたドローン映像を基準に、他のドローン映像にGCP(Ground Control Point)を入力することを特徴とする、コンピュータ装置を提供する。
【発明の効果】
【0023】
ドローン映像を活用して航空地図を生成および/またはアップデートするにあたり、既存の3次元航空地図をGCPとして活用することにより、航空地図の生成および/またはアップデートのための時間および費用を減らすことができる。
【0024】
GCPとして活用される3次元航空地図とドローン映像の自動マッチングを支援することにより、人力と時間を節約することができる。
【図面の簡単な説明】
【0025】
【
図1】本発明の一実施形態における、コンピュータ装置の例を示したブロック図である。
【
図2】本発明の一実施形態における、アップデート方法の例を示したフローチャートである。
【
図3】本発明の一実施形態における、ドローン映像とルーフトゥルーオルソフォトをマッチングする方法の例を示したフローチャートである。
【
図4】本発明の一実施形態における、設定されたシードの例を示した図である。
【
図5】本発明の一実施形態における、シードの位置を再設定する例を示した図である。
【
図6】本発明の一実施形態における、ドローン映像とルーフトゥルーオルソフォトのマッチングの例を示した図である。
【
図7】本発明の一実施形態における、ドローン映像の座標に対応する3次元座標を選定する例を示した図である。
【
図8】本発明の一実施形態における、サブドローン映像と仮想GCPの連結を設定する例を示した図である。
【
図9】本発明の一実施形態における、デンスマッチングによって同一地点をマッチングした例を示した図である。
【
図10】本発明の一実施形態における、デンスマッチングによって同一地点をマッチングした例を示した図である。
【
図11】本発明の一実施形態における、加重値を補正する例を示した図である。
【
図12】本発明の一実施形態における、加重値を補正する例を示した図である。
【
図13】本発明の一実施形態における、ドローン映像と航空映像の解像度の差を示した図である。
【
図14】本発明の一実施形態における、ドローン映像を利用して航空地図をアップデートした例を示した図である。
【発明を実施するための形態】
【0026】
以下、実施形態について、添付の図面を参照しながら詳しく説明する。
【0027】
本発明の実施形態に係るアップデートシステムは、少なくとも1つのコンピュータ装置によって実現されてよく、本発明の実施形態に係るアップデート方法は、アップデートシステムを実現する少なくとも1つのコンピュータ装置によって実行されてよい。コンピュータ装置においては、本発明の一実施形態に係るコンピュータプログラムがインストールされて実行されてよく、コンピュータ装置は、実行されたコンピュータプログラムの制御にしたがって本発明の実施形態に係るアップデート方法を実行してよい。上述したコンピュータプログラムは、コンピュータ装置と結合してアップデート方法をコンピュータ装置に実行させるために、コンピュータ読み取り可能な記録媒体に記録されてよい。
【0028】
以下、添付の図面を参照しながら、実施形態について詳しく説明する。各図面に提示された同一の参照符号は、同一の部材を示す。
【0029】
図1は、本発明の一実施形態における、コンピュータ装置の例を示したブロック図である。コンピュータ装置(Computer device)100は、
図1に示すように、メモリ(Memory)110、プロセッサ(Processor)120、通信インタフェース(Communication interface)130、および入力/出力(I/O)インタフェース(I/O interface)140を含んでよい。メモリ110は、コンピュータ読み取り可能な記録媒体であって、RAM(random access memory)、ROM(read only memory)、およびディスクドライブのような永続的大容量記録装置を含んでよい。ここで、ROMやディスクドライブのような永続的大容量記録装置は、メモリ110とは区分される別の永続的記録装置としてコンピュータ装置100に含まれてもよい。また、メモリ110には、オペレーティングシステムと、少なくとも1つのプログラムコードが記録されてよい。このようなソフトウェア構成要素は、メモリ110とは別のコンピュータ読み取り可能な記録媒体からメモリ110にロードされてよい。このような別のコンピュータ読み取り可能な記録媒体は、フロッピー(登録商標)ドライブ、ディスク、テープ、DVD/CD-ROMドライブ、メモリカードなどのコンピュータ読み取り可能な記録媒体を含んでよい。他の実施形態において、ソフトウェア構成要素は、コンピュータ読み取り可能な記録媒体ではない通信インタフェース130を通じてメモリ110にロードされてもよい。例えば、ソフトウェア構成要素は、ネットワーク(Network)160を介して受信されるファイルによってインストールされるコンピュータプログラムに基づいてコンピュータ装置100のメモリ110にロードされてよい。
【0030】
プロセッサ120は、基本的な算術、ロジック、および入出力演算を実行することにより、コンピュータプログラムの命令を処理するように構成されてよい。命令は、メモリ110または通信インタフェース130によって、プロセッサ120に提供されてよい。例えば、プロセッサ120は、メモリ110のような記録装置に記録されたプログラムコードにしたがって受信される命令を実行するように構成されてよい。
【0031】
通信インタフェース130は、ネットワーク160を介してコンピュータ装置100が他の装置と互いに通信するための機能を提供してよい。一例として、コンピュータ装置100のプロセッサ120がメモリ110のような記録装置に記録されたプログラムコードにしたがって生成した要求や命令、データ、ファイルなどが、通信インタフェース130の制御にしたがってネットワーク160を介して他の装置に伝達されてよい。これとは逆に、他の装置からの信号や命令、データ、ファイルなどが、ネットワーク160を介してコンピュータ装置100の通信インタフェース130を通じてコンピュータ装置100に受信されてよい。通信インタフェース130を通じて受信された信号や命令、データなどは、プロセッサ120やメモリ110に伝達されてよく、ファイルなどは、コンピュータ装置100がさらに含むことのできる記録媒体(上述した永続的記録装置)に記録されてよい。
【0032】
入力/出力インタフェース140は、入力/出力(I/O)装置150とのインタフェースのための手段であってよい。例えば、入力装置は、マイク、キーボード、またはマウスなどの装置を、出力装置は、ディスプレイ、スピーカなどのような装置を含んでよい。他の例として、入力/出力インタフェース140は、タッチスクリーンのように入力と出力のための機能が1つに統合された装置とのインタフェースのための手段であってもよい。入力/出力装置150は、コンピュータ装置100と1つの装置で構成されてもよい。
【0033】
また、他の実施形態において、コンピュータシステム100は、
図1の構成要素よりも少ないか多くの構成要素を含んでもよい。しかし、大部分の従来技術の構成要素を明確に図に示す必要はない。例えば、コンピュータ装置100は、上述した入力/出力装置150のうちの少なくとも一部を含むように実現されてもよいし、トランシーバ、データベースなどのような他の構成要素をさらに含んでもよい。
【0034】
図2は、本発明の一実施形態における、アップデート方法の例を示したフローチャートである。本実施形態に係るアップデート方法は、
図1を参照しながら説明したコンピュータ装置100によって実行されてよい。このとき、コンピュータ装置100のプロセッサ120は、メモリ110が含むオペレーティングシステムのコードと、少なくとも1つのコンピュータプログラムのコードとによる制御命令(instruction)を実行するように実現されてよい。ここで、プロセッサ120は、コンピュータ装置100に記録されたコードが提供する制御命令にしたがってコンピュータ装置100が
図2の方法に含まれる段階210~260を実行するようにコンピュータ装置100を制御してよい。
【0035】
段階210で、コンピュータ装置100は、既存の航空地図ベースのDEM(Digital Elevation Model(数値標高モデル))、DSM(Digital Surface Model(数値表層モデル))、およびトゥルーオルソフォト(true-orthophoto)を利用して、予め設定された高さ以上の映像を含むルーフ(roof)トゥルーオルソフォトを生成してよい。DEMは、実世界の地形情報のうちから建物、樹木、人工構造物などを除いた地形(bareearth)部分を表現する数値模型であり、DSMは、実世界のすべての情報、言い換えれば、地形、樹木、建物、人工構造物などを表現した模型である。したがって、DSMとDEMの差(DSM-DEM=CHM(Canopy Height Model(キャノピー高さモデル)))が予め設定された値以上の部分は、建物、樹木、人工構造物などに対応することになる。このとき、コンピュータ装置100は、トゥルーオルソフォトにおいてDSMとDEMの差が予め設定された高さ(一例として、17m)以上となる部分だけをトゥルー(true)として抽出することによってルーフトゥルーオルソフォトを生成してよい。
【0036】
段階220で、コンピュータ装置100は、ドローン映像とルーフトゥルーオルソフォトをマッチングしてよい。ここで、ドローン映像とは、ドローンで撮影した映像を意味してよい。マッチングされたポイントはGCP(Ground Control Point(地上基準点))として活用されてよく、DSMトゥルーオルソフォトを利用することで、マッチングされたポイントの3次元座標が分かるようになる。ドローン映像とルーフトゥルーオルソフォトをマッチングする方法については、
図3を参照しながらさらに詳しく説明する。
【0037】
段階230で、コンピュータ装置100は、マッチングされたドローン映像を基準に、他のドローン映像にGCPを入力してよい。ここで、GCPは、実際に測量されたGCOでなく、ドローン映像にマッチングされたルーフトゥルーオルソフォトから得られる3次元座標であってよい。言い換えれば、コンピュータ装置100は、マッチングされたドローン映像をメインとして置きながら、周辺のサブドローン映像と仮想GCPとの連結を設定してよい。GCPを入力する方法については、
図8~10を参照しながらさらに詳しく説明する。
【0038】
段階240で、コンピュータ装置100は、GCPをフィルタリングしてよい。航空映像のカメラ内部情報は正確であるが、ドローン映像は低価型カメラを使用することから内部情報が不正確であり、カメラポーズとカメラ内部情報を補正する必要がある。このような補正のために、コンピュータ装置100は、仮想GCPを利用してバンドル調整を実行してよい。バンドル調整については、以下でさらに詳しく説明する。
【0039】
段階250で、コンピュータ装置100は、フィルタリングされたGCPが入力されたドローン映像に基づいてアップデートされたDSMを生成してよい。このとき、映像のソースが航空映像からドローン映像に変わることで発生するイシューが修正されてよい。
【0040】
段階260で、コンピュータ装置100は、アップデートされたDSMに基づいてアップデートされたトゥルーオルソフォトを生成してよい。この過程は、航空地図の生成のためのプロセスにおいて周知の事項であるため、具体的な説明は省略する。
【0041】
図3は、本発明の一実施形態における、ドローン映像とルーフトゥルーオルソフォトをマッチングする方法の例を示したフローチャートである。
図3の段階310~370は
図2の段階220に含まれてよく、コンピュータ装置100によって実行されてよい。
【0042】
段階310で、コンピュータ装置100は、ルーフトゥルーオルソフォトでアップデートしようとする範囲(Region Of Interest(関心領域):ROI)に予め設定された長さに基づいてシード(seed)を設定してよい。シードとは以後にGCP位置になるポイントであり、予め設定された長さは、一例として120mであってよい。ここで、予め設定された長さはシードの間隔となってよく、予め設定された数のシードが設定される領域を示す長さであってよい。
【0043】
図4は、本発明の一実施形態における、設定されたシードの例を示した図である。
図4は、ルーフトゥルーオルソフォト410の特定の範囲に、一辺の長さが予め設定された長さ(一例として、120m)に設定された正方形420が表示された例を示している。このとき、コンピュータ装置100は、このような正方形420にm(
図4の実施形態においてm=5)個のシードを設定してよい。1つのルーフトゥルーオルソフォト410には複数の正方形がランダムに設定されてよく、各正方形にm個のシードがランダムに設定されてよい。
【0044】
このような
図4の実施形態は、GCPを均一に選定して正確度を確保するための一方式に過ぎず、シード設定方法が
図4の実施形態に限定されることはない。一例として、ルーフトゥルーオルソフォト410内のアップデートしようとする範囲で、予め設定された長さの間隔で均一にシードを設定してもよい。
【0045】
図3を再び参照すると、段階320で、コンピュータ装置100は、各シードから最も近いルーフトゥルーオルソフォトをロードしてよい。このとき、各シードから最も近いルーフトゥルーオルソフォトとは、ルーフトゥルーオルソフォトのうちで該当のシードを含む映像の一部であってよい。
【0046】
段階330で、コンピュータ装置100は、ロードされたルーフトゥルーオルソフォトから特徴点を抽出した後、設定されたシードの位置を抽出された特徴点の密集度に基づいて再設定してよい。一定の間隔でシードを設定するため、シードの位置がルーフにないことがある。これにより、コンピュータ装置100は、シードの位置を該当のシードから最も近いルーフトゥルーオルソフォトの特徴点が密集した位置に移動させて、シードの位置を再設定してよい。
【0047】
図5は、本発明の一実施形態における、シードの位置を再設定する例を示した図である。
図5は、ルーフトゥルーオルソフォト510でシード520がルーフ上にない場合、最も近いルーフ530において特徴点が密集した位置にシード520の位置を再設定する例を示している。一例として、コンピュータ装置100は、シード520の位置から最も近いルーフ530の特徴点を抽出した後、特徴点の密度が最も高い位置にシード520の位置を再設定してよい。
【0048】
図3を再び参照すると、段階340で、コンピュータ装置100は、再設定されたシードの位置から最も近いドローン映像の一部をロードしてよい。ドローン映像の一部とは、該当のドローン映像から切り取られた一部のピース映像を意味してよい。
【0049】
段階350で、コンピュータ装置100は、ロードされたドローン映像の一部とルーフトゥルーオルソフォトの特徴点マッチングを処理してよい。一例として、コンピュータ装置100は、R2D2(Repeatable and Reliable Detector and Descriptor)マッチングにより、ロードされたドローン映像の一部とルーフトゥルーオルソフォトのポイント(特徴点)をマッチングしてよい。ポイントのマッチングは、R2D2の他にも、SIFT(Scale-Invariant Feature Transform)、HardNet、LogPolarDescなどの周知のイメージマッチング技術のうちの1つが活用されてもよい。ただし、R2D2は、視空間解像度が異なる2つの映像のマッチングの性能を高めるために学習されたマッチング技法であることから、トゥルーオルソフォトとドローン映像の映像の取得時間と空間解像度の差を考慮するとき、R2D2を利用してポイントのマッチングを処理することが好ましい。このとき、コンピュータ装置100は、n(一例として、nは100)個のポイントをマッチングしてよい。
【0050】
段階360で、コンピュータ装置100は、ドローン映像の一部から少なくとも1つのマッチングポイントを選定してよい。一例として、コンピュータ装置100は、マッチングされた複数のポイントのうちで最も適切にマッチングがなれたポイントを選定してよい。一例として、特徴点マッチングを実行するときに、コンピュータ装置100は、2つの映像で特徴点周辺のピクセル値が最も類似する特徴点のマッチングを実行してよい。このような特徴点周辺のピクセル値の類似度をディスタンス(distance)と呼ぶが、ディスタンスの値が大きいほど類似度は低く、ディスタンスの値が小さいほど類似度は高いと判断されてよい。したがって、コンピュータ装置100は、マッチングされた点のうちでディスタンスの値が最も小さいマッチングポイントを、最も適切にマッチングがなされたポイントとして選定してよい。
【0051】
図6は、本発明の一実施形態における、ドローン映像とルーフトゥルーオルソフォトのマッチングの例を示した図である。
図6は、ドローン映像610とルーフトゥルーオルソフォト620の対応するポイントを連結した例を示している。このとき、
図6は、複数のポイントのうちで最も適切にマッチングがなされたポイントを連結する線630を他の線よりも太く示している。このとき、線630によって連結されたポイント640、650が選定されてよい。
図6では、マッチングされるポイントを簡略化して説明したが、上述したように、コンピュータ装置100は、n個のポイントをマッチングした後、マッチングされたn個のポイントのうちから最も適切にマッチングがなされたポイントを選定してよい。ここで、n個のポイントをマッチングするということは、ドローン映像610を基準にn個のポイントをルーフトゥルーオルソフォト620のn個のポイントとマッチングすることを意味してよい。
【0052】
図3を再び参照すると、段階370で、コンピュータ装置100は、選定されたマッチングポイントに対応するルーフトゥルーオルソフォトの位置に対する実際の地形の3次元座標を、選定されたマッチングポイントに対する仮想GCPとして選定してよい。このように、コンピュータ装置100は、既存の航空地図から得られるルーフトゥルーオルソフォトにおいて、ドローン映像の特定の座標(x、y)に対し、実際に測量したものと同じ地形の3次元座標(X、Y、Z)を取得することができる。
【0053】
図7は、本発明の一実施形態における、ドローン映像の座標に対応する3次元座標を選定する例を示した図である。
図7は、ドローン映像610のポイントの映像位置(x、y)とルーフトゥルーオルソフォト620のマッチングされたポイントに対応する実際の地形の3次元座標(X、Y、Z)を仮想GCPとして選定してよい。ここで、ルーフトゥルーオルソフォト620のマッチングされたポイントに対応する実際の地形の3次元座標(X、Y、Z)は、DSMによって得られてよい。より具体的に、XとYはトゥルーオルソフォトから得られてよく、DSMがピルセルごとに高さ値を含んでいるため、トゥルーオルソフォトに対応するDSMの位置から高さ値を抽出することでZが得られてよい。
【0054】
図2を再び参照すると、段階230で、コンピュータ装置100は、マッチングされたドローン映像を基準に他のドローン映像にGCPを入力するため、マッチングされたドローン映像を基準に、周辺のサブドローン映像と仮想GCPの連結を設定してよい。
【0055】
図8は、本発明の一実施形態における、サブドローン映像と仮想GCPの連結を設定する例を示した図である。
図8は、メインドローン映像810とルーフトゥルーオルソフォト820でマッチングされたポイントに基づいて、メインドローン映像810周辺のサブドローン映像830それぞれに対してもポイントをマッチングすることにより、サブドローン映像の映像位置(x、y)と仮想GCPの3次元座標(X、Y、Z)を連結した様子を示している。一例として、コンピュータ装置100は、メインドローン映像810がルーフトゥルーオルソフォト820の仮想GCPと連結した地点と同一のサブドローン映像830それぞれの地点をマッチングすることで、サブドローン映像830それぞれの地点に対して仮想GCPを連結してよい。言い換えれば、コンピュータ装置100は、ルーフトゥルーオルソフォト820にマッチングされたメインドローン映像810のポイントにルーフトゥルーオルソフォト820のマッチングされたポイントによる3次元座標を仮想GCPとして入力してよく、マッチングされたメインドローン映像810のポイントとマッチングする他のサブドローン映像830それぞれのポイントに仮想GCPを入力してよい。このとき、メインドローン映像810とサブドローン映像830それぞれの同一地点は、デンスマッチング(dense matching)によってマッチングされてよい。
【0056】
図9および
図10は、本発明の一実施形態における、デンスマッチングによって同一地点をマッチングした例を示している。
図9は、デンスマッチングを利用してメインドローン映像910とサブドローン映像920の同一地点をマッチングする過程の例を示しており、
図10は、デンスマッチングを利用してメインイメージ(Main image)1010とサブイメージ(Sub images)1020、1030の同一地点をマッチングした例を示している。ここで、メインイメージ1010はメインドローンイメージに対応してよく、サブイメージ1020、1030はサブドローンイメージに対応してよい。
【0057】
図2を再び参照すると、段階240で、コンピュータ装置200は、GCPをフィルタリングするためにバンドル調整を処理してよい。このとき、段階210~230を実行することで、GCPがドローンイメージに自動で入力されてよい。したがって、人間が実際に外部に出向いてGCPを測量する必要がなくなり、測量されたGCPをドローンイメージと手動でマッチングする必要がなくなるため、費用と時間を減らすことができる。
【0058】
ただし、測量されたGCP(正確度2~3cm)に比べて自動入力された仮想GCP(正確度8~15cm)は正確度が下がるため、複数のフィルタリングが適用されてよい。ドローン映像は航空映像に比べて初期値が不正確であるため、コンピュータ装置100は、GCPを補正するために7-parametersを処理してよい。7-parametersは、剛体変換(Rigid Transformation)という同一の2つのモデルのスケール、回転、移動を調整して同じように合わせる技法である。本実施形態では、航空地図から抽出したGCP(X、Y、Z)とドローン映像でマッチングされたGCPを三角測量(Triangulation)することで3次元座標(X、Y、Z)を得るが、GCPと3次元座標が同一の位置でなければならない。しかし、ドローン映像は低価型GPSを使用するため、3次元座標はGCPとは異なる位置を示すことがある。このとき、7-parameters処理によって3次元座標がGCP位置に合うようにスケール、回転、移動を計算し、その媒介変数を(スケール、回転、移動)ドローン映像に適用および変換することにより、実際の地形と類似する当時撮影されたドローンの位置を推定することができる。コンピュータ装置100は、7-parametersを処理しながら、仮想GCPの3次元座標でX、Y、Zそれぞれに対する評価を加重値によって考慮してよい。一例として、コンピュータ装置100は、加重値を補正して自己校正(self-calibration)を実行してよい。このとき、コンピュータ装置100は、映像のサイド(side)側により強い加重値を置き、特徴点の密集度から離れるほど強い加重値を与えてよい。
【0059】
図11および
図12は、本発明の一実施形態における、加重値を補正する例を示した図である。
図11は、映像のサイド側に位置する地点であるほど共分散(covariance)が減少することを示している。自己校正をするときには映像の歪曲(distortion)を補正することが核心となるが、通常、映像の歪曲は、映像の終端部分で起こる。したがって、映像の終端部分にあるポイントに共分散(covariance)を少なく置いて歪曲を補正するときにより多くの影響を受けるようにすることにより、歪曲をより正確に補正することができる。
【0060】
図12は、特徴点の密集度が減少する地点であるほど加重値(weight)が増加することを示している。
【0061】
以下の数式(1)は、バンドル調整の基本数式の例を示している。
【0062】
【数1】
ここで、xgcpはドローン映像のピクセルの位置点を示してよく、Kはドローンカメラの内部焦点距離および歪曲係数を含む情報を含んでよく、Rはドローンカメラの回転情報を、Gは3次元座標(GCP)に対応する映像座標を示してよい。ρは損失関数(loss function)を、eは費用関数(cost function)を、Pはプロジェクション関数(projection function)を、Wgcpは加重値をそれぞれ示してよい。Gは外部に出向いて直接測量したデータではないため、正確度で8~15cmの差が生じることがある。これにより、GCPを完全なトゥルー(true)として置かず、多少の調整が可能な未知数として置いて方程式を解くようになる。言い換えれば、Gは初めに得られたGCPであってよく、
【0063】
【数2】
は推定されたGCPであってよい。推定されたGCPと初めに得られたGCPの差が極端に開かないようにするために加重値(Wgcp)を置いて推定してよい。このように、ピクセルの位置点xgcpは事前マッチングによって既に決定されているため、コンピュータ装置100は、ピクセルの位置点xgcpを利用してGCPに対応する映像座標との差が最小となるR、Kを決定してよい。追加的に、コンピュータ装置100は、推定された(または、補正されたGCPである)
【0064】
【数3】
を決定してよい。言い換えれば、コンピュータ装置100は、マッチングされたドローン映像のピクセルの位置点に基づいて、GCPに対応する映像座標との差が最小となるドローンカメラの内部焦点距離、歪曲係数、ドローンカメラの回転情報、および補正されたGCPを決定してよい。
【0065】
一方、損失関数は、以下の数式(2)のように示されてよい。
【0066】
【数4】
ここで、rはエラーを、δは予め設定された閾値をそれぞれ示してよい。また、c’は数式(3)のように、s’は数式(4)のように表現されてよい。
【0067】
【0068】
数式(2)は、エラーが予め設定された閾値未満の場合に加重値を一定の値に固定するために活用されてよい。
【0069】
このように、コンピュータ装置100で仮想GCPをフィルタリングすることにより、ある程度の異常値(outlier)があったとしても、既存の航空地図にドローン映像を適切にマッピングすることができる。
【0070】
図13は、本発明の一実施形態における、ドローン映像と航空映像の解像度の差を示した図であり、
図14は、本発明の一実施形態における、ドローン映像を利用して航空地図をアップデートした例を示した図である。
【0071】
図13では、ドローン映像(Drone)1310の解像度が航空映像(Aerial)1320よりも高いことを示しており、
図14では、解像度が相対的により高いドローン映像を利用して航空地図をアップデートすることによって、ドローン映像を利用してアップデートされた航空地図の領域の解像度が増加した例を示している。
【0072】
このように、本発明の実施形態によると、ドローン映像を活用して航空地図を生成および/またはアップデートするにあたり、既存の3次元航空地図をGCPとして活用することにより、航空地図の生成および/またはアップデートのための時間および費用を減らすことができる。また、GCPとして活用される3次元航空地図とドローン映像の自動マッチングを支援することにより、人力と時間を節約することができる。
【0073】
上述したシステムまたは装置は、ハードウェア構成要素、またはハードウェア構成要素とソフトウェア構成要素との組み合わせによって実現されてよい。例えば、実施形態で説明された装置および構成要素は、例えば、プロセッサ、コントローラ、ALU(arithmetic logic unit)、デジタル信号プロセッサ、マイクロコンピュータ、FPGA(field programmable gate array)、PLU(programmable logic unit)、マイクロプロセッサ、または命令を実行して応答することができる様々な装置のように、1つ以上の汎用コンピュータまたは特殊目的コンピュータを利用して実現されてよい。処理装置は、オペレーティングシステム(OS)およびOS上で実行される1つ以上のソフトウェアアプリケーションを実行してよい。また、処理装置は、ソフトウェアの実行に応答し、データにアクセスし、データを記録、操作、処理、および生成してもよい。理解の便宜のために、1つの処理装置が使用されるとして説明される場合もあるが、当業者は、処理装置が複数個の処理要素および/または複数種類の処理要素を含んでもよいことが理解できるであろう。例えば、処理装置は、複数個のプロセッサまたは1つのプロセッサおよび1つのコントローラを含んでよい。また、並列プロセッサのような、他の処理構成も可能である。
【0074】
ソフトウェアは、コンピュータプログラム、コード、命令、またはこれらのうちの1つ以上の組み合わせを含んでもよく、思うままに動作するように処理装置を構成したり、独立的または集合的に処理装置に命令したりしてよい。ソフトウェアおよび/またはデータは、処理装置に基づいて解釈されたり、処理装置に命令またはデータを提供したりするために、いかなる種類の機械、コンポーネント、物理装置、仮想装置、コンピュータ記録媒体または装置に具現化されてよい。ソフトウェアは、ネットワークによって接続されたコンピュータシステム上に分散され、分散された状態で記録されても実行されてもよい。ソフトウェアおよびデータは、1つ以上のコンピュータ読み取り可能な記録媒体に記録されてよい。
【0075】
実施形態に係る方法は、多様なコンピュータ手段によって実行可能なプログラム命令の形態で実現されてコンピュータ読み取り可能な媒体に記録されてよい。コンピュータ読み取り可能な媒体は、プログラム命令、データファイル、データ構造などを単独または組み合わせて含んでよい。媒体は、コンピュータ実行可能なプログラムを継続して記録するものであっても、実行またはダウンロードのために一時記録するものであってもよい。また、媒体は、単一または複数のハードウェアが結合した形態の多様な記録手段または格納手段であってよく、あるコンピュータシステムに直接接続する媒体に限定されることはなく、ネットワーク上に分散して存在するものであってもよい。媒体の例としては、ハードディスク、フロッピー(登録商標)ディスク、および磁気テープのような磁気媒体、CD-ROMおよびDVDのような光媒体、フロプティカルディスク(floptical disk)のような光磁気媒体、およびROM、RAM、フラッシュメモリなどを含み、プログラム命令が記録されるように構成されたものであってよい。また、媒体の他の例として、アプリケーションを配布するアプリケーションストアやその他の多様なソフトウェアを供給または配布するサイト、サーバなどで管理する記録媒体または格納媒体が挙げられる。プログラム命令の例は、コンパイラによって生成されるもののような機械語コードだけではなく、インタプリタなどを使用してコンピュータによって実行される高級言語コードを含む。
【0076】
以上のように、実施形態を、限定された実施形態および図面に基づいて説明したが、当業者であれば、上述した記載から多様な修正および変形が可能であろう。例えば、説明された技術が、説明された方法とは異なる順序で実行されたり、かつ/あるいは、説明されたシステム、構造、装置、回路などの構成要素が、説明された方法とは異なる形態で結合されたりまたは組み合わされたり、他の構成要素または均等物によって対置されたり置換されたとしても、適切な結果を達成することができる。
【0077】
したがって、異なる実施形態であっても、特許請求の範囲と均等なものであれば、添付される特許請求の範囲に属する。
【符号の説明】
【0078】
100:コンピュータ装置
110:メモリ
120:プロセッサ
130:通信インタフェース
140:入力/出力インタフェース
150:入力/出力装置
160:ネットワーク