OpenMVS:Multi-View Stereoによる3次元復元ライブラリ

複数枚の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の入力に使う例も載ってる↓

使い方

secene dense

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


関連資料

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

コンピュータビジョン最先端ガイド5 (CVIMチュートリアルシリーズ)




関連記事

組み込み向けのWindows OS 『Windows Emb...

PyMC:Pythonのベイズ統計ライブラリ

機械学習について最近知った情報

PyTorch3D:3Dコンピュータービジョンライブラリ

PSPNet (Pyramid Scene Parsing ...

VCG Library:C++のポリゴン操作ライブラリ

Open Shading Language (OSL)

OpenCV 3.1のsfmモジュールのビルド再び

Googleが画像解析旅行ガイドアプリのJetpac社を買収

Mayaのシェーディングノードの区分

ポリゴンジオメトリ処理ライブラリ『pmp-library (...

Pythonの自然言語処理ライブラリ『NLTK(Natura...

Python拡張モジュールのWindows用インストーラー配...

Unity MonoBehaviourクラスのオーバーライド...

OpenCV 3.1とopencv_contribモジュール...

OpenMayaRender

Adobeの手振れ補正機能『ワープスタビライザー』の秘密

C++の抽象クラス

書籍『ゼロから作るDeep Learning』で自分なりに学...

Point Cloud Utils:Pythonで3D点群・...

Deep Learningとその他の機械学習手法の性能比較

Netron:機械学習モデルを可視化するツール

hloc:SuperGlueで精度を向上させたSfM・Vis...

Amazon EC2ログイン用の秘密鍵を無くした場合の対処方...

WordPressプラグインの作り方

fSpy:1枚の写真からカメラパラメーターを割り出すツール

NumSharp:C#で使えるNumPyライクな数値計算ライ...

OpenGV:画像からカメラの3次元位置・姿勢を推定するライ...

BlenderでPhotogrammetryできるアドオン

ManuelBastioniLAB:人体モデリングできるBl...

フォトンの放射から格納までを可視化した動画

OpenCVのバージョン3が正式リリースされたぞ

clearcoat Shader

CGのためのディープラーニング

WordPress on Windows Azure

Kinect for Windows v2の日本価格決定

第25回コンピュータビジョン勉強会@関東に行って来た

Kubric:機械学習用アノテーション付き動画生成パイプライ...

スクラッチで既存のキャラクターを立体化したい

畳み込みニューラルネットワーク (CNN: Convolut...

GoogleのDeep Learning論文

FCN (Fully Convolutional Netwo...

コメント

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