8点アルゴリズムのソースを表示
←
8点アルゴリズム
ナビゲーションに移動
検索に移動
あなたには「このページの編集」を行う権限がありません。理由は以下の通りです:
この操作は、次のグループに属する利用者のみが実行できます:
登録利用者
。
このページのソースの閲覧やコピーができます。
'''8点アルゴリズム'''は、[[コンピュータビジョン|コンピュータービジョン]]の分野で使用されるアルゴリズムで、対応する画像上の点のセットから、ステレオカメラペアに対応する[[基本行列 (コンピュータビジョン)|基本行列]]または[[基礎行列 (コンピュータビジョン)|基礎行列]]を推定する。これは、1981 年に[[ロングエット・ヒギンズ|クリストファー・ロンゲ・ヒギンズ]]によって基本行列の推定のために導入された。理論的には、このアルゴリズムは基礎行列にも使用できるが、実際上は1997年に[[リチャード・ハートレー(科学者)|リチャード・ハートレー]]によって記述され正規化された8点アルゴリズムがこのケースにより適している。 このアルゴリズムの名前は、対応する8つ(またはそれ以上)の画像上の点のセットから基本行列または基礎行列を推定するということに由来している。ただし、このアルゴリズムの変形は、8点未満の場合でも使用できる。 == 共平面性制約 == [[ファイル:Epipolar_Geometry1.svg|リンク=//upload.wikimedia.org/wikipedia/commons/thumb/f/f2/Epipolar_Geometry1.svg/300px-Epipolar_Geometry1.svg.png|右|サムネイル|300x300ピクセル|'''エピポーラ幾何の例。'''投影点'''O''' <sub>L</sub>および'''O''' <sub>R</sub>のそれぞれの中心を持つ 2 つのカメラは点'''P'''を観測する。各画像平面への'''P'''の投影は、'''p'''<sub>L</sub>および'''p'''<sub>R</sub>で示される。点'''E'''<sub>L</sub>と'''E'''<sub>R</sub>はエピポールである。]] 2台のカメラの[[エピポーラ幾何]]と空間内の点を代数方程式で表すことができる。点<math>P</math>がどこにあったとしても、ベクトル<math>\overline{O_L P}</math>、<math>\overline{O_R P}</math>、<math> \overline{O_R O_L}</math>は同一平面上にあることがわかる。「左目」の画像内の点<math>P</math>の座標を<math>X_L</math>、「右目」の画像内の点<math>P</math>の座標を<math>X_R</math>、2画像間の回転と平行移動を<math>R, T</math>とする。2つの画像座標系でそれぞれ表された<math>P</math>の座標の間の関係は<math>X_R = R (X_L-T) </math>と表せる。記号<math>\wedge </math>を[[ウェッジ積]]とすると、<math>T \wedge X_L </math>から生成されるベクトルは<math>T</math>と<math>X_L</math>の両方に直交するから、次の式が常に成り立つ。 : <math> X_L^T T \wedge X_L - T^T T \wedge X_L = (X_L-T)^T T \wedge X_L = 0 </math> <math> I = R^T R </math>であるから、次が得られる。 : <math> (X_L-T)^T R^T R T \wedge X_L = 0 </math> . <math>(X_L-T)^TR^T </math>を<math>X_R^T</math>に置き換えることで、次が得られる。 : <math> X_R^T R T \wedge X_L = X_R^T R S X_L = X_R^T E X_L = 0 </math> <math>T \wedge </math>は行列とみなすことができる。ロンゲ・ヒギンズは記号<math>S</math>を用いてそれを示した。積<math> R T \wedge = R S </math>はしばしば[[基本行列 (コンピュータビジョン)|基本行列]]と呼ばれ<math> E </math>で表される。 ベクトル<math>\overline{O_L p_L}, \overline{O_R p_R}</math>はベクトル<math> \overline{O_L P}, \overline{O_R P}</math>と平行であるから、これらのベクトルを置き換えても共平面性の制約は保持される。左右の画像平面へ<math>P</math>を投影した座標を<math>y, y'</math>とすると、共平面性制約は次のように記述できる。 : <math> y'^T \mathbf{E} y = 0 </math> == 基本的なアルゴリズム == ここでは、基本行列<math> \mathbf{E} </math>を推定する場合の基本的な8点アルゴリズムについて説明する。これは3つのステップで構成されている。まず、[[線型方程式系|同次線形方程式]]を定式化する。ここで、解は<math> \mathbf{E} </math>に直接関連しており、正しい解がない可能性があることを考慮して方程式を解く。最後に、得られた行列の内部制約を利用する。1番目のステップはロンゲ・ヒギンズの論文で説明されているもので、2番目と3番目のステップは推定理論の標準的なアプローチである。 基本行列<math> \mathbf{E} </math>によって定義される制約は次のように表せる。 : <math> (\mathbf{y}')^{T} \, \mathbf{E} \, \mathbf{y} = 0</math> <math> \mathbf{y}, \mathbf{y}' </math>は対応する画像上の点の正規化画像座標である。 アルゴリズムが解くべき問題は、対応する画像上の点の集合から基本行列<math> \mathbf{E} </math>を決定することである。実際には、画像点の画像座標はノイズの影響を受け、解も過剰決定される可能性がある。つまり、すべての点について上記の制約を正確に満たす<math> \mathbf{E} </math>を見つけることができない場合がある。この問題は、アルゴリズムの2番目のステップで対処される。 === ステップ 1:[[線型方程式系|同次線形方程式]]の定式化 === 次のように、 : <math> \mathbf{y} = \begin{pmatrix} y_{1} \\ y_{2} \\ 1 \end{pmatrix} </math> と <math> \mathbf{y}' = \begin{pmatrix} y'_{1} \\ y'_{2} \\ 1 \end{pmatrix} </math> と <math> \mathbf{E} = \begin{pmatrix} e_{11} & e_{12} & e_{13} \\ e_{21} & e_{22} & e_{23} \\ e_{31} & e_{32} & e_{33} \end{pmatrix} </math> と書くと、制約は次のように書き換えることもできる。 : <math> y'_1 y_1 e_{11} + y'_1 y_2 e_{12} + y'_1 e_{13} + y'_2 y_1 e_{21} + y'_2 y_2 e_{22} + y'_2 e_{23} + y_1 e_{31} + y_2 e_{32} + e_{33} = 0 \, </math> あるいは : <math> \mathbf{e} \cdot \tilde{\mathbf{y}} = 0 </math> ここで、それぞれ以下を表している。 : <math> \tilde{\mathbf{y}} = \begin{pmatrix} y'_1 y_1 \\ y'_1 y_2 \\ y'_1 \\ y'_2 y_1 \\ y'_2 y_2 \\ y'_2 \\ y_1 \\ y_2 \\ 1 \end{pmatrix} </math> と <math> \mathbf{e} = \begin{pmatrix} e_{11} \\ e_{12} \\ e_{13} \\ e_{21} \\ e_{22} \\ e_{23} \\ e_{31} \\ e_{32} \\ e_{33} \end{pmatrix} </math> つまり、これら2つのベクトルは直交している必要がある、ということである。<math> \mathbf{e} </math>は基本行列を9次元ベクトルの形式で表したものであり、同様に<math> \tilde{\mathbf{y}} </math>も<math> 3 \times 3 </math>行列<math> \mathbf{y}' \, \mathbf{y}^{T} </math>を9次元ベクトルの形式で表したものになっている。 対応する画像上の点の各ペアは、ベクトル<math> \tilde{\mathbf{y}} </math>を生成する。3次元点<math> \mathbf{P}_k </math>の集合が与えられたとき、これらをベクトル<math> \tilde{\mathbf{y}}_{k} </math>の集合とみなすと、これらの全てがベクトル<math> \mathbf{e} </math>に対して次の式を満たさなければならない。 : <math> \mathbf{e} \cdot \tilde{\mathbf{y}}_{k} = 0 </math> 十分な数(少なくとも8つ)の線形独立なベクトル<math> \tilde{\mathbf{y}}_{k} </math>が与えられると、簡単な方法で<math> \mathbf{e} </math>を決定することができる。行列<math> \mathbf{Y} </math>の列としてすべてのベクトル<math> \tilde{\mathbf{y}}_{k} </math>を集めると、次のようになる必要がある。 : <math> \mathbf{e}^{T} \, \mathbf{Y} = \mathbf{0} </math> これは<math> \mathbf{e} </math>が[[線型方程式系|同次線形方程式]]の解であることを意味する。 === ステップ 2: 方程式を解く === この方程式を解くための標準的なアプローチは、 <math> \mathbf{e} </math>をゼロに等しい特異値に対応する<math> \mathbf{Y} </math>の[[特異値分解|右特異ベクトル]]として求める方法である。<math> \mathbf{Y} </math>を構成するために少なくとも8つの線形独立ベクトル<math> \tilde{\mathbf{y}}_{k} </math>が使用される場合、この特異ベクトルは(スカラー乗算を無視すれば)一意であり、<math> \mathbf{e} </math>と<math> \mathbf{E} </math>を決定できる。 <math> \mathbf{Y} </math>を構成するために8より多くの対応点が使用される場合、ゼロに等しい特異値を持たない可能性がある。このケースは、画像座標がさまざまな種類のノイズの影響を受ける場合に実際に発生する。この状況に対処するための一般的なアプローチは、これを[[最小二乗法|最小二乗]]問題として記述することである。すなわち、<math> \| \mathbf{e} \| = 1 </math>のもとで以下を最小にする<math> \mathbf{e} </math>を求める。 : <math> \| \mathbf{e}^{T} \, \mathbf{Y} \| </math> 解は<math> \mathbf{Y} </math>の''最小''特異値に対応する左特異ベクトルとして<math> \mathbf{e} </math>を選択することで得られる。この<math> \mathbf{e} </math>を<math> 3 \times 3 </math>行列に並べ替えると、このステップの結果(ここでは<math> \mathbf{E}_{\rm est} </math>と呼ぶ)が得られる。 === ステップ 3: 内部制約の適用 === ノイズの多い画像座標を扱っている場合は、結果の行列が基本行列の内部制約(その特異値のうち2つは互いに等しく非ゼロであり、もう1つはゼロでなければならない)を満たさない可能性もある。利用場面によって、内部制約からの偏差が小さい場合も大きい場合も、問題になる場合と問題にならない場合がある。推定された行列が内部制約を満たすことが重要な場合、これは以下を最小化するランク2の行列<math> \mathbf{E}' </math>を見つけることによって達成できる。 : <math> \| \mathbf{E}' - \mathbf{E}_{\rm est} \| </math> ここで<math> \mathbf{E}_{\rm est} </math>はステップ2で得られた行列で、[[行列ノルム|フロベニウス行列ノルム]]が使用される。この問題を解くために、まず次のように<math> \mathbf{E}_{\rm est} </math>を[[特異値分解]]する。 : <math> \mathbf{E}_{\rm est} = \mathbf{U} \, \mathbf{S} \, \mathbf{V}^{T} </math> ここで<math> \mathbf{U}, \mathbf{V} </math>は直交行列であり、 <math> \mathbf{S} </math>は<math> \mathbf{E}_{\rm est} </math>の特異値を含む対角行列である。理想的には<math> \mathbf{S} </math>の対角要素の1つはゼロであるが、少なくとも互いに等しいことが期待されている他の2つと比較して小さい必要がある。いずれにせよ、次を設定する。 : <math> \mathbf{S}' = \begin{pmatrix} s_1 & 0 & 0 \\ 0 & s_2 & 0 \\ 0 & 0 & 0 \end{pmatrix} ,</math> ここで<math> s_1, s_2 </math>はそれぞれ<math> \mathbf{S} </math>の最大および2番目に大きい特異値である。 結局、<math> \mathbf{E}' </math>は次のように与えられる。 : <math> \mathbf{E}' = \mathbf{U} \, \mathbf{S}' \, \mathbf{V}^{T} </math> 行列<math> \mathbf{E}' </math>がこのアルゴリズムによって得られた基本行列の推定結果である。 == 正規化されたアルゴリズム == 基本的な8点アルゴリズムは、原理的に基礎行列<math> \mathbf{F} </math>の推定にも使用できる。定義される<math> \mathbf{F} </math>の制約は次のようになる。 : <math> (\mathbf{y}')^{T} \, \mathbf{F} \, \mathbf{y} = 0</math> ここで<math> \mathbf{y}, \mathbf{y}' </math>対応した画像座標の同次表現である(正規化していなくともよい)。これは、以下のように基本行列と同様の方法で行列<math> \mathbf{Y} </math>を形成し、方程式を解くことができることを意味する。 : <math> \mathbf{f}^{T} \, \mathbf{Y} = \mathbf{0} </math> ここで<math> \mathbf{f} </math>は<math> \mathbf{F} </math>のベクトル表現である。上記の手順に従うことで、8つの対応点の集合から<math> \mathbf{F} </math>を決定することができる。ただし実際には結果として得られる基本行列は[[エピポーラ幾何|エピポーラ制約]]を決定するのに役立たない場合がある。 === 問題点 === 問題は、結果として得られる<math> \mathbf{Y} </math>がしばしば[[条件数|悪条件]](英 : ''ill-conditioned'')となることである。理論上、<math> \mathbf{Y} </math>はゼロに等しい特異値を1つ持つ必要があり、残りは非ゼロである。ただし実際には、非ゼロの特異値の一部は、大きな特異値に比べて小さくなる可能性がある。 <math> \mathbf{Y} </math>を構成するために8よりも多い対応点が使用され、座標がほぼ正確である場合、ほぼゼロとして識別できる[[well-defined]]な特異値が存在しない可能性がある。その結果、同次連立一次方程式の解は、実用に耐えうるほどの正確さが得られない可能性がある。 === 原因 === ハートレーは、1997年の記事でこの推定問題に対処した。彼の問題の分析は、問題がその空間<math> \mathbb{R}^{3} </math>内の同次画像座標の分布の悪さによって引き起こされることを示している。二次元画像座標<math> (y_{1}, y_{2}) \, </math>の典型的な同次表現は次のようになる。 : <math> \mathbf{y} = \begin{pmatrix} y_{1} \\ y_{2} \\ 1 \end{pmatrix} </math> ここで<math> y_{1}, y_{2} \, </math>はいずれも一般的なデジタルカメラでは、0から1000~2000の範囲にある。これは、<math> \mathbf{y} </math>の最初の2つの座標が3番目の座標よりもはるかに広い範囲にわたって変化することを意味する。さらに、<math> \mathbf{Y} </math>を構築するために使用される画像上の点が画像の比較的小さな領域、例えば<math> (700,700) \pm (100,100) \, </math>にある場合、ベクトル<math> \mathbf{y} </math>はすべての点に対してだいたい同じような方向を指す。結果として、<math> \mathbf{Y} </math>には1つの大きな特異値があり、残りは小さい値になってしまう。 === 解決策 === この問題の解決策としてハートレーは次の原則に従って2画像のそれぞれの座標系を独立して新しい座標系に変換することを提案した。 * 新しい座標系の原点は、画像の図心(重心)を中心とする(原点を持つ)必要がある。これは、元の原点を新しい原点に平行移動することで実現できる。 * 平行移動後、原点から点までの距離の平均が<math> \sqrt{2} </math>に等しくなるように、座標を均一にスケーリングする。 この原則により通常2つの画像のそれぞれに対して個別に座標変換が行われる。その結果、新しい同次画像座標<math> \mathbf{\bar y}, \mathbf{\bar y}' </math>は次の式で与えられる。 : <math> \mathbf{\bar y} = \mathbf{T} \, \mathbf{y} </math> : <math> \mathbf{\bar y}' = \mathbf{T}' \, \mathbf{y}' </math> ここで<math> \mathbf{T}, \mathbf{T}' </math>は、元の画像座標から新しい正規化された画像座標への変換(平行移動とスケーリング)である。この正規化は、単一の画像で使用される画像点のみに依存するもので、一般に正規化されたカメラによって生成される正規化画像座標とは異なるものである。 基礎行列に基づくエピポーラ制約は、次のように書き換えられる。 : <math> 0 = (\mathbf{\bar y}')^{T} \, ((\mathbf{T}')^{T})^{-1} \, \mathbf{F} \, \mathbf{T}^{-1}\, \mathbf{\bar y} = (\mathbf{\bar y}')^{T} \, \mathbf{\bar F} \, \mathbf{\bar y} </math> ここで<math> \mathbf{\bar F} = ((\mathbf{T}')^{T})^{-1} \, \mathbf{F} \, \mathbf{T}^{-1} </math>である。これは、正規化された同次画像座標<math> \mathbf{\bar y}, \mathbf{\bar y}' </math>を使用して、上記の基本的な8点アルゴリズムを使用して変換された基本行列<math> \mathbf{\bar F} </math>を推定できることを意味する。 正規化変換の目的は、一般に正規化された画像座標から構築された行列<math> \mathbf{\bar Y} </math>が、<math> \mathbf{Y} </math>よりも優れた[[条件数]]を持つようにすることである。これは、解<math> \mathbf{\bar f} </math>が同次方程式<math> \mathbf{\bar Y} \, \mathbf{\bar f} </math>の解として、<math> \mathbf{Y} </math>に対する<math> \mathbf{f} </math>に比べてより well-defined であることを意味する。<math> \mathbf{\bar f} </math>が決定し<math> \mathbf{\bar F} </math>が再形成されると次の式に従って''非正規化を行い<math> \mathbf{F} </math>''を得ることができる。 : <math> \mathbf{F} = (\mathbf{T}')^{T} \, \mathbf{\bar F} \, \mathbf{T} </math> 一般に、基礎行列のこの推定値は、正規化されていない座標からの推定値よりも優れている。 == 8未満の点を用いる場合 == 各点ペアは<math> \mathbf{E} </math>の要素に対して1つの拘束方程式に与える。<math> \mathbf{E} </math>には5つの自由度があるため、<math> \mathbf{E} </math>の決定には5つの点ペアだけで十分なはずである。これは理論的な観点からは可能だが、実際に実装するのは簡単ではなく、さまざまな非線形方程式を解く必要がある。 カヴェ・ファシアンらは、回転[[クォータニオン]]を直接計算することにより、基本行列の計算を回避する5、6、および7点のアルゴリズムを提案した。 <ref>{{Cite journal|last=Fathian|first=Kaveh|year=2018|title=QuEst: A Quaternion-Based Approach for Camera Motion Estimation From Minimal Feature Points|url=https://drive.google.com/uc?export=download&id=1CBaHmTtslH662Fgqn2tim3NQup0Rh8L1|journal=IEEE Robotics and Automation Letters|volume=3|issue=2|pages=857–864|arxiv=1704.02672|DOI=10.1109/LRA.2018.2792142}}</ref> <ref>{{Cite journal|last=Fathian|first=Kaveh|year=2018|title=Camera relative pose estimation for visual servoing using quaternions|url=https://drive.google.com/uc?export=download&id=1MhADXukLWHFAjxa1hyw0HgUrdv8lUq-Y|journal=Robotics and Autonomous Systems.|volume=107|pages=45–62|DOI=10.1016/j.robot.2018.05.014}}</ref> == 関連項目 == * [[基本行列 (コンピュータビジョン)|基本行列]] ** [[基本行列 (コンピュータビジョン)#回転と平行移動の抽出|基本行列#回転と平行移動の抽出]] * [[基礎行列 (コンピュータビジョン)|基礎行列]] * [[三焦点テンソル]] == 脚注 == <references group="" responsive="1"></references> == 参考文献 == * {{Cite journal|last=Richard I. Hartley|date=June 1997|title=In Defense of the Eight-Point Algorithm|journal=IEEE Transactions on Pattern Recognition and Machine Intelligence|volume=19|issue=6|pages=580–593|DOI=10.1109/34.601246}} * {{Cite book|last=Richard Hartley and Andrew Zisserman|title=Multiple View Geometry in computer vision|publisher=Cambridge University Press|year=2003|isbn=978-0-521-54051-3}} * {{Cite journal|last=H. Christopher Longuet-Higgins|date=September 1981|title=A computer algorithm for reconstructing a scene from two projections|journal=Nature|volume=293|issue=5828|pages=133–135|bibcode=1981Natur.293..133L|DOI=10.1038/293133a0}} [[Category:射影幾何学]] [[Category:コンピュータビジョン]]
このページで使用されているテンプレート:
テンプレート:Cite book
(
ソースを閲覧
)
テンプレート:Cite journal
(
ソースを閲覧
)
8点アルゴリズム
に戻る。
ナビゲーション メニュー
個人用ツール
ログイン
名前空間
ページ
議論
日本語
表示
閲覧
ソースを閲覧
履歴表示
その他
検索
案内
メインページ
最近の更新
おまかせ表示
MediaWiki についてのヘルプ
特別ページ
ツール
リンク元
関連ページの更新状況
ページ情報