□α拡張を用いたステレオマッチングアルゴリズム
- 現在のラベルβを初期化
- グラフの総コストEを初期化
- 最大視差の分だけ以下をループ
- グラフを初期化
- ノードを追加
- 全ての画素kに対してノードのソース側にD(βk),シンク側にD(α)
を設定
- 全てのエッジに対して,(以下では,画素p, qのエッジ)
- ノードaソース側にV(βp, βq),シンク側にV(α, α)を設定
- ノードpとノードaのエッジの重み(双方向)にV(βp, βq)を設定
- ノードpとノードaのエッジの重み(双方向)にV(α, α)を設定
- 最大流・最小カットアルゴリズムを適用し,総コストE'を計算
- もし,E > E' ならば
- 現在のラベルβkをαに更新
- 総コストの更新(E = E')
- グラフの消去
- 総コストが収束するまで4を繰り返す
□階層グラフカットを用いたステレオマッチングアルゴリズム
- 現在のラベルβを初期化
- 階層ラベルAを作成
- グラフの総コストEを初期化
- 階層の深さdepthだけ以下をループ
- グラフを初期化
- ノードを追加
- 全ての画素kに対して
- 現在の深さiの階層ラベルA[i]のうち最もβ[k]に最も近い値
をαkに設定
- ノードのソース側にD(βk),シンク側にD(αk)を設定
- 全てのエッジに対して,(以下では,画素p, qのエッジ)
- 現在の深さiの階層ラベルA[i]のうち最もβ[p]に最も近い値をαpに設定
- 現在の深さiの階層ラベルA[i]のうち最もβ[q]に最も近い値をαqに設定
- ノードaソース側にV(βp, βq),シンク側にV(αp, αq)を設定
- もし,V(βp, βq) ≦ V(αp, αq)ならば,
- ノードaからノードpへのエッジの重みに10000(比較的大きい数)を設定
- ノードaからノードqへのエッジの重みに10000(比較的大きい数)を設定
- ノードpからノードaへのエッジの重みに,V(αp, βq)-V(βp, βq)か0のうち大きいほうを設定
- ノードqからノードaへのエッジの重みに,V(βp, αq)-V(βp, βq)か0のうち大きいほうを設定
- もし,V(βp, βq) ≧ V(αp, αq)ならば,
- ノードpからノードaへのエッジの重みに10000(比較的大きい数)を設定
- ノードqからノードaへのエッジの重みに10000(比較的大きい数)を設定
- ノードaからノードpへのエッジの重みに,V(αp, βq)-V(αp, αq)か0のうち大きいほうを設定
- ノードaからノードqへのエッジの重みに,V(βp, αq)-V(αp, αq)か0のうち大きいほうを設定
- 最大流・最小カットアルゴリズムを適用し,総コストE'を計算
- もし,E > E' ならば
- 現在のラベルβkを求まったラベル更新
- 総コストの更新(E = E')
- グラフの消去
- 総コストが収束するまで4を繰り返す
コスト関数
コスト関数は,アルファ拡張,階層グラフカットのどちらも講義で紹介されたものを参考にした.
- データコスト
- 出力画像fpが入力画像Ipに出来るだけ近くなるようにする項
- D(β) = SAD(β) = Σ|I(x, y) - I(x - β, y)|
- スムーズコスト
- 隣り合った画素fp,fqの明るさが出来るだけ近くなるようにする項
- V(fp) = |fp - fq|
実行結果
α拡張を用いたステレオマッチング,階層グラ
フカットを用いたステレオマッチングを行った.現在のラベルβ
の初期値は0とした.入力画像とα拡張を用いた場合の実行結果,
階層グラフカットを用いた結果を示す.なお,どちらの視差画像も,最大階調を
256に変換した結果である.
入力画像
|
|
左画像 (300×250) | 右画像 (300x250) |
|
結果画像
|
|
階層グラフカットによる結果画像 実行時間:6.8sec | α拡張による結果画像 実行時間:29.3sec |
|
ソースプログラム等
□用いたライブラリ
- MAXFLOW
- グラフカットのライブラリ
- http://www.cs.ucl.ac.uk/staff/V.Kolmogorov/software.html
□α拡張
alphaExtend DownLoad (zip)
階層グラフカット
hierarchicalGraphCut DownLoad (zip)
ソースプログラムを用いるにあたって
以下の点に注意してください.
- 入力画像はppmまたはppm,かつascii形式でしか実行できません.
- また出力画像はpgm形式のみとなっています.
- 出力は,最大階調を256に調整したものです.
- コンパイル方法は,makeコマンドで.
- 以下のコマンドを実行
$ ./GraphCut [leftimagefile] [rightimagefile] [outputfile]