複数枚の2D画像から、カメラの3D姿勢情報と被写体の疎(sparse)な3D点群を推定するのがStructure from Motionという手法。そこで求めたカメラの姿勢、点群の情報を使ってさらに密(dense)な点群を求めるのがMulti-View Stereoという手法。
Structure from Motionのライブラリは結構色々あるみたいなんだけど、そこから密な点群を求めるMulti-View Stereoのライブラリはあんまり見かけないんだよね。(PMVSというツールは有名ですが)
このOpenMVS(Multi-View Stereo)は、名前の通り、密な点群を復元するMulti-View Stereoのアルゴリズムを実装したライブラリ。OpemMVS自体はAGPLライセンスだけど、依存しているサードパーティのライブラリが細々と沢山あり、それぞれのライセンスに従うのでこちらを参照。
OpenMVS
OpenMVS(Multi-View Stereo)は、コンピュータビジョン科学者、特にMulti-View Stereo reconstructionの分野を対象としたライブラリです。
Structure-from-Motionのパイプラインを実装した(OpenMVGなどの)オープンソースプロジェクトを使えば、入力画像セットからカメラの姿勢や疎な3次元点群を復元できますが、それだけではphotogrammetry chain-flowの最後のプロセスが欠けています。OpenMVSは、この最後のプロセス、再構築するシーンの完全なサーフェイスを復元するためのアルゴリズムを提供します。
OpenMVSへの入力はカメラの姿勢セットと疎な点群、OpenMVSからの出力はテクスチャ付きのMeshになります。
このプロジェクトの主な特長は以下の通りです。
- 密な点群の復元:可能な限り完全・正確な点群を得るための復元
- Meshの再構築:入力点群から高品質なMesh表面を推定するためのMesh再構築
- Meshの分割:全てのディティールを復元するためのMesh分割
- Meshのテクスチャリング:Meshを着色するためのシャープで正確なテクスチャ計算
詳細なドキュメントはWikiをご覧ください。
このライブラリ、OpenMVGのドキュメントで紹介されていたのだ。
OpenMVGのドキュメントによると、OpenMVGとOpenMVSの連携は比較的簡単にできるみたい。
ソースコードはGitHubにある↓
https://github.com/cdcseacave/openMVS
ドキュメントはGitHub上のWikiに↓
https://github.com/cdcseacave/openMVS/wiki
OpenMVGの出力結果をOpenMVSの入力に使う例も載ってる↓
使い方

追記:ドキュメントに従ってサンプルを動かしてみた↓

関連資料
Multi-View Stereoについては、毎度おなじみコンピュータビジョン最先端ガイド5と、コンピュータビジョン勉強会@関東の第28回の資料が参考になる。

関連記事
顔検出・認識のAPI・ライブラリ・ソフトウェアのリスト
TensorSpace.js:ニューラルネットワークの構造を...
Mechanizeで要認証Webサイトをスクレイピング
Mitsuba 2:オープンソースの物理ベースレンダラ
openMVG:複数視点画像から3次元形状を復元するライブラ...
機械学習について最近知った情報
MeshroomでPhotogrammetry
BlenderのPython環境にPyTorchをインストー...
OpenCVで顔のモーフィングを実装する
Adobe MAX 2015
Rerun:マルチモーダルデータの可視化アプリとSDK
iPhone・iPod touchで動作する知育ロボット『R...
池袋パルコで3Dのバーチャルフィッティング『ウェアラブル ク...
ブログの復旧が難航してた話
iPhoneアプリ開発 Xcode 5のお作法
iPhoneで3D写真が撮れるアプリ『seene』
画像認識による位置情報取得 - Semi-Direct Mo...
機械学習手法『Random Forest』
Blendify:コンピュータービジョン向けBlenderラ...
Unity ARKitプラグインサンプルのドキュメントを読む
ポリゴン用各種イテレータと関数セット
ポイントクラウドコンソーシアム
Mean Stack開発の最初の一歩
Raspberry PiのGPIOを操作するPythonライ...
Javaで作られたオープンソースの3DCGレンダラ『Sunf...
OpenMVSのサンプルを動かしてみる
Runway ML:クリエイターのための機械学習ツール
Qlone:スマホのカメラで3Dスキャンできるアプリ
Fast R-CNN:ディープラーニングによる一般物体検出手...
ブラウザ操作自動化ツール『Selenium』を試す
Mitsuba 3:オープンソースの研究向けレンダラ
ブログのデザイン変えました
Math.NET Numerics:Unityで使える数値計...
UnityのTransformクラスについて調べてみた
Russian3DScannerのトポロジー転送ツール『Wr...
MLDemos:機械学習について理解するための可視化ツール
2D→3D復元技術で使われる用語まとめ
スクレイピング
Amazon EC2ログイン用の秘密鍵を無くした場合の対処方...
ニューラルネットワークで画像分類
OpenCVで動画の手ぶれ補正
Accord.NET Framework:C#で使える機械学...


コメント
[…] がとうございます。 NegativeMindさんありがとうございます。 NegativeMindException | Multi-View Stereoによる3次元復元ライブラリ『OpenMVS』 NegativeMindException | 複数視点画像から3次元形状を復元するラ […]