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

複数枚の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チュートリアルシリーズ)





スポンサーリンク

関連記事

続・ディープラーニングの資料
機械学習について最近知った情報
OpenCV バージョン4がリリースされた!
網元AMIで作ったWordpressサイトのインスタンスをt1microからt2microへ移行した
C++の抽象クラス
html5のcanvasの可能性
複数視点画像から3次元形状を復元するライブラリ『openMVG』
Pix2Pix:CGANによる画像変換
ROMOハッカソンに行ってきた
『手を動かしながら学ぶエンジニアのためのデータサイエンス』ハンズオンセミナーに行ってきた
PythonのStructure from Motionライブラリ『OpenSfM』
オープンソースのIT資産・ライセンス管理システム『Snipe-IT』
オープンソースの人体モデリングツール『MakeHuman』のAPI開発プロジェクトがスタート
UnityのAR FoundationでARKit 3
SONY製のニューラルネットワークライブラリ『NNabla』
HD画質の無駄遣い その2
3Dオブジェクトの確認・変換に便利なフリーウェア『MeshLab』
OpenCVの超解像処理モジュール『Super Resolution』
OANDAのfxTrade API
Webスクレイピングの勉強会に行ってきた
ニューラルネットワークで画像分類
Point Cloud Libraryに動画フォーマットが追加されるらしい
Javaで作られたオープンソースの3DCGレンダラ『Sunflow』
ディープラーニングに対応したPythonの機械学習ライブラリ『Pylearn2』
科学技術計算向けスクリプト言語『Julia』
コンピュータビジョンの技術マップ
WordPressプラグインの作り方
Unityからkonashiをコントロールする
Deep Learningとその他の機械学習手法の性能比較
adskShaderSDK
Model View Controller
ブラウザ操作自動化ツール『Selenium』を試す
Google製オープンソース機械学習ライブラリ『TensorFlow』のWindows版が公開された
MythTV:Linuxでテレビの視聴・録画ができるオープンソースプロジェクト
オープンソースの顔認識フレームワーク『OpenBR』
WebGL開発に関する情報が充実してきている
疑似3D写真が撮れるiPhoneアプリ『Seene』がアップデートでついにフル3Dモデルが撮影できる...
CGレンダラ研究開発のためのフレームワーク『Lightmetrica (ライトメトリカ)』
チャットツール用bot開発フレームワーク『Hubot』
HD画質の無駄遣い
pythonの機械学習ライブラリ『scikit-learn』
OpenCV3.3.0でsfmモジュールのビルドに成功!

コメント

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