カメラ行列のソースを表示
←
カメラ行列
ナビゲーションに移動
検索に移動
あなたには「このページの編集」を行う権限がありません。理由は以下の通りです:
この操作は、次のグループに属する利用者のみが実行できます:
登録利用者
。
このページのソースの閲覧やコピーができます。
{{Refimprove|date=July 2010}} '''カメラ行列'''(カメラぎょうれつ、{{lang-en|''camera matrix''}})または'''(カメラ)射影行列'''(とうえいぎょうれつ、{{lang-en|''projection matrix''}})は[[コンピュータビジョン]]の分野で用いられる3次元空間内の3次元点から画像内の2次元点への[[ピンホールカメラモデル]]による投影を記述する <math>3 \times 4</math> [[行列]]である。 <math> \mathbf{x} </math> を[[同次座標]](4次元ベクトル)での3次元点の表現とし、 <math> \mathbf{y} </math> を同次座標(3次元ベクトル)でのピンホールカメラモデルでこの点を投影したときの画像上の点の表現とすると、次の関係が成り立つ : <math> \mathbf{y} \sim \mathbf{C} \, \mathbf{x} </math> ここで <math> \mathbf{C} </math> はカメラ行列で、記号 <math>\, \sim </math> は、左辺と右辺が非ゼロのスカラー倍を許容して等しいことを意味する。 カメラ行列 <math> \mathbf{C} </math> は2つの[[射影空間]]の要素間の写像に関与するため、これも射影要素とみなせる。これは、スカラー倍(ゼロ以外)したカメラ行列も元と等価なカメラ行列になるため、自由度が11しかないことを意味する。 == 導出 == [[ピンホールカメラモデル]]によると、3次元点 '''P''' の座標から、画像平面への点の投影の2次元画像座標へのマッピングは、次の式で与えられる。 : <math> \begin{pmatrix} y_1 \\ y_2 \end{pmatrix} = \frac{f}{x_3} \begin{pmatrix} x_1 \\ x_2 \end{pmatrix} </math> ここで<math> (x_1, x_2, x_3) </math>は、カメラ中心座標系に対する '''P''' の3次元座標、<math> (y_1, y_2) </math> は結果となる画像座標、''f'' はカメラの焦点距離で ''f'' > 0 と仮定する。また、 ''x<sub>3</sub> > 0'' であると仮定する。 カメラ行列を導出するために、上記の式を同次座標で書き直す。2次元ベクトル <math> (y_1,y_2) </math> の代わりに射影要素(3次元ベクトル)<math> \mathbf{y} = (y_1,y_2,1) </math> を考え、等式の代わりに <math>\, \sim </math> で示されるゼロ以外の数値によるスケーリングまで許容するような等式を考える。まず、同次画像座標を通常の3次元座標の式として記述する。 : <math> \begin{pmatrix} y_1 \\ y_2 \\ 1 \end{pmatrix} = \begin{pmatrix} \frac{f}{x_3} x_1 \\ \frac{f}{x_3} x_2 \\ 1 \end{pmatrix} \sim \begin{pmatrix} x_1 \\ x_2 \\ \frac{x_3}{f} \end{pmatrix} </math> 最後に、3次元座標も同次表現 <math> \mathbf{x} </math> で表され、カメラ行列は次のように表される。 : <math> \begin{pmatrix} y_1 \\ y_2 \\ 1 \end{pmatrix} \sim \begin{pmatrix} 1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & \frac{1}{f} & 0 \end{pmatrix} \, \begin{pmatrix} x_1 \\ x_2 \\ x_3 \\ 1 \end{pmatrix} </math> または <math> \mathbf{y} \sim \mathbf{C} \, \mathbf{x} </math> ここで <math> \mathbf{C} </math> はカメラ行列で、ここでは次の式で与えられる。 : <math> \mathbf{C} = \begin{pmatrix} 1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & \frac{1}{f} & 0 \end{pmatrix} </math> 、 そして対応するカメラ行列は次のようになる。 : <math> \mathbf{C} = \begin{pmatrix} 1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & \frac{1}{f} & 0 \end{pmatrix} \sim \begin{pmatrix} f & 0 & 0 & 0 \\ 0 & f & 0 & 0 \\ 0 & 0 & 1 & 0 \end{pmatrix} </math> 最後のステップは、 <math> \mathbf{C} </math> 自体が射影要素であることの結果である。 ここで導出されたカメラ行列は、ゼロ以外の要素がほとんど含まれていないという意味で自明に見えるかもしれない。これは、3次元点および2次元点に選ばれた特定の座標系に大きく依存する。ただし、実際には、以下に示すように他の形式のカメラ行列が一般的である。 == カメラの位置 == 前のセクションで導出されたカメラ行列 <math> \mathbf{C} </math> には、次のベクトルがまたがる[[零空間]]がある。 : <math> \mathbf{n} = \begin{pmatrix} 0 \\ 0 \\ 0 \\ 1 \end{pmatrix} </math> これは、座標 (0,0,0) を持つ3次元点の同次表現でもある。つまり、「カメラの中心」([[入射瞳]]とも呼ばれる[[ピンホールカメラ|ピンホール カメラ]]のピンホールの位置)は '''O''' にある。つまり、カメラの中心は(そしてこの点だけが)、カメラによって画像平面内の点にマッピングすることができない(あるいは、画像上のすべての光線はこのポイントを通過するため、画像上のすべての点にマッピングされる)。 <math>x_3 = 0</math> の他の3次元点の場合、結果の <math> \mathbf{y} \sim\mathbf{C}\,\mathbf{x} </math> は [[well-defined]] であり、<math> \mathbf{y} = (y_1\,y_2\,0)^\top </math> の形式になる。これは、[[射影平面|射影]]画像平面の無限遠点に対応する(ただし、画像平面が[[平面|ユークリッド平面]]であるとみなされる場合、対応する交点は存在しない)。 == 正規化されたカメラ行列と正規化された画像座標 == ''f = 1'' と仮定すると、上で導出されたカメラ行列をさらに単純化できる。 : <math> \mathbf{C}_{0} = \begin{pmatrix} 1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & 1 & 0 \end{pmatrix} = \left ( \begin{array}{c|c} \mathbf{I} & \mathbf{0} \end{array} \right ) </math> ここで <math> \mathbf{I} </math> は <math> 3 \times 3 </math> 恒等行列である。ここでの <math> 3 \times 4 </math> 行列 <math> \mathbf{C} </math> は、<math> 3 \times 3 </math> 行列と3次元ベクトルの連結に分割されることに注意されたい。カメラ行列 <math> \mathbf{C}_{0} </math> は正準形式({{lang-en|''canonical form''}})と呼ばれることもある。 ここまでで、3次元空間内のすべての点は''カメラ中心''座標系、つまりカメラ中心([[ピンホールカメラ]]のピンホールの位置)に原点を持つ座標系で表される。しかし実際は、3次元点は任意の座標系 (X1', X2', X3') に対する座標として表せる。カメラの座標軸 (X1, X2, X3) とある座標軸 (X1', X2', X3') がユークリッド型(直交かつ等方)であると仮定すると、2つの座標系の間にユークリッド3次元変換(回転と平行移動)が唯一存在する。つまりカメラは原点にあり ''z'' 軸方向を見ている必要はないということである。 3次元座標の回転と平行移動という2つの操作は、次の2つの <math> 4 \times 4 </math> 行列として表せる。 : <math> \left ( \begin{array}{c|c} \mathbf{R} & \mathbf{0} \\ \hline \mathbf{0} & 1 \end{array} \right ) </math> と <math> \left ( \begin{array}{c|c} \mathbf{I} & \mathbf{t} \\ \hline \mathbf{0} & 1 \end{array} \right ) </math> ここで <math> \mathbf{R} </math>は<math> 3 \times 3 </math> [[回転行列]]であり、<math> \mathbf{t} </math> は3次元並進ベクトルである。1番目の行列が3次元点の同次表現に乗算されると、結果は回転した点の同次表現になり、2番目の行列は同様に平行移動を実行する。2つの操作を順番に、つまり、最初に回転、次に平行移動(回転後の座標系で表された平行移動ベクトルを使用)を実行すると、回転と平行移動を組み合わせた行列が得られる。 : <math> \left ( \begin{array}{c|c} \mathbf{R} & \mathbf{t} \\ \hline \mathbf{0} & 1 \end{array} \right ) </math> <math> \mathbf{R} </math> と <math> \mathbf{t} </math> がちょうど上記の2つの座標系 (X1, X2, X3) と (X1', X2', X3') を関係づける回転と平行移動であると仮定すると、これは次のことを意味する。 : <math> \mathbf{x} = \left ( \begin{array}{c|c} \mathbf{R} & \mathbf{t} \\ \hline \mathbf{0} & 1 \end{array} \right ) \mathbf{x}' </math> ここで <math> \mathbf{x}' </math> は座標系 (X1', X2', X3') における点 '''P''' の同次表現である。 また、カメラ行列が <math> \mathbf{C}_{0} </math> で与えられると仮定すると (X1, X2, X3) 系の座標から同次画像座標へのマッピングは次のようになる。 : <math> \mathbf{y} \sim \mathbf{C}_{0} \, \mathbf{x} = \left ( \begin{array}{c|c} \mathbf{I} & \mathbf{0} \end{array} \right ) \, \left ( \begin{array}{c|c} \mathbf{R} & \mathbf{t} \\ \hline \mathbf{0} & 1 \end{array} \right ) \mathbf{x}' = \left ( \begin{array}{c|c} \mathbf{R} & \mathbf{t} \end{array} \right ) \, \mathbf{x}' </math> したがって、座標系 (X1',X2',X3') の点を画像座標に関連付けるカメラ行列は、次のような3次元回転行列と3次元平行移動ベクトルの連結となる。 : <math> \mathbf{C}_{N} = \left ( \begin{array}{c|c} \mathbf{R} & \mathbf{t} \end{array} \right ) </math> このタイプのカメラ行列は''正規化''されたカメラ行列と呼ばれ、焦点距離 = 1 であり、画像座標は原点が軸 X3 と画像平面の交点に位置し、3次元座標と同じ単位で測定されることを仮定している。結果の画像座標は、''正規化された画像''座標と呼ばれる。 === カメラの位置 === ここでも、上記の正規化されたカメラ行列 <math> \mathbf{C}_{N} </math> の零空間は、4次元ベクトルによって渡っている。 : <math> \mathbf{n} = \begin{pmatrix} -\mathbf{R}^{-1} \, \mathbf{t} \\ 1 \end{pmatrix} = \begin{pmatrix} \tilde{\mathbf{n}} \\ 1 \end{pmatrix}</math> これもやはりカメラの中心の座標であり、 (X1', X2', X3') 系で表現されている。これは最初に回転を適用し、次に平行移動を3次元ベクトル<math> \tilde{\mathbf{n}} </math>に適用することで確認できる。結果は、3次元座標 (0,0,0) の同次表現となる。 これは、カメラの中心(同次表現)が、カメラ行列が参照している座標系と同じ座標系を基準とした3次元座標で表現されている場合、カメラ行列の零空間にあることを意味する。 正規化されたカメラ行列 <math> \mathbf{C}_{N} </math> は次のように記述できる。 : <math> \mathbf{C}_{N} = \mathbf{R} \, \left ( \begin{array}{c|c} \mathbf{I} & \mathbf{R}^{-1} \, \mathbf{t} \end{array} \right ) = \mathbf{R} \, \left ( \begin{array}{c|c} \mathbf{I} & -\tilde{\mathbf{n}} \end{array} \right ) </math> ここで <math> \tilde{\mathbf{n}} </math> は (X1',X2',X3') 系に対するカメラの3次元座標である。 == 一般化されたカメラ行列 == 正規化されたカメラ行列により生成されたマッピングが与えられると、結果の正規化された画像座標は、任意の2次元[[ホモグラフィ]]によって変換できる。これには、2次元の平行移動と回転とスケーリング(等方性と異方性)だけでなく、一般的な二次元透視変換も含まれる。このような変換は正規化された同次画像座標 <math> \mathbf{y} </math> を変換された同次画像座標 <math> \mathbf{y}' </math> にマッピングする <math> 3 \times 3 </math> 行列 <math> \mathbf{H} </math> として表せる。 : <math> \mathbf{y}' = \mathbf{H} \, \mathbf{y} </math> 3次元座標に関して正規化された画像座標に上記の式を挿入すると、 : <math> \mathbf{y}' = \mathbf{H} \, \mathbf{C}_{N} \, \mathbf{x}' </math> こうして、最も一般的な形式のカメラ行列が得られる。 : <math> \mathbf{C} = \mathbf{H} \, \mathbf{C}_{N} = \mathbf{H} \, \left ( \begin{array}{c|c} \mathbf{R} & \mathbf{t} \end{array} \right ) </math> == 関連項目 == * [[3次元投影]] * [[カメラリセクショニング]] == 参考文献 == * {{Cite book|last=Richard Hartley and Andrew Zisserman|title=Multiple View Geometry in computer vision|publisher=Cambridge University Press|year=2003|isbn=0-521-54051-8}} [[Category:射影幾何学]] [[Category:コンピュータビジョン]]
このページで使用されているテンプレート:
テンプレート:Cite book
(
ソースを閲覧
)
テンプレート:Lang-en
(
ソースを閲覧
)
テンプレート:Refimprove
(
ソースを閲覧
)
カメラ行列
に戻る。
ナビゲーション メニュー
個人用ツール
ログイン
名前空間
ページ
議論
日本語
表示
閲覧
ソースを閲覧
履歴表示
その他
検索
案内
メインページ
最近の更新
おまかせ表示
MediaWiki についてのヘルプ
特別ページ
ツール
リンク元
関連ページの更新状況
ページ情報