.wp-block-jetpack-rating-star span.screen-reader-text { border: 0; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; word-wrap: normal; }

サイトアイコン NegativeMindException

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

使い方



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


関連資料

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







スポンサーリンク

関連記事

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

R-CNN (Regions with CNN features):ディープラーニングによる一般物体...

U-Net:ディープラーニングによるSemantic Segmentation手法

pythonの機械学習ライブラリ『scikit-learn』

マルコフ連鎖モンテカルロ法

池袋パルコで3Dのバーチャルフィッティング『ウェアラブル クロージング バイ アーバンリサーチ』

チャットツール用bot開発フレームワーク『Hubot』

Konashiを買った

1枚の画像からマテリアルを作成できる無料ツール『Materialize』

OpenCV 3.1から追加されたSfMモジュール

仮想関数

定数

Fast R-CNN:ディープラーニングによる一般物体検出手法

Open Shading Language (OSL)

Pylearn2:ディープラーニングに対応したPythonの機械学習ライブラリ

MFnDataとMFnAttribute

ManimML:機械学習の概念を視覚的に説明するためのライブラリ

参考書

Autodesk Mementoでゴジラを3次元復元する

KelpNet:C#で使える可読性重視のディープラーニングライブラリ

オーバーロードとオーバーライド

PythonのHTML・XMLパーサー『BeautifulSoup』

手を動かしながら学ぶデータマイニング

顔検出・認識のAPI・ライブラリ・ソフトウェアのリスト

UnityでShaderの入力パラメータとして行列を渡す

オープンソースのIT資産・ライセンス管理システム『Snipe-IT』

Unityからkonashiをコントロールする

iPadをハンディ3Dスキャナにするガジェット『iSense 3D Scanner』

UnityのMonoBehaviourクラスをシングルトン化する

Structure from Motion (多視点画像からの3次元形状復元)

OpenCVで動画の手ぶれ補正

iPhoneアプリ開発 Xcode 5のお作法

BlenderでPhotogrammetryできるアドオン

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

AndroidもopenGLも初心者さ (でもJavaは知ってるよ)

hloc:SuperGlueで精度を向上させたSfM実装

OpenCVの超解像(SuperResolution)モジュールを試す

SONYの自律型エンタテインメントロボット『aibo』

Managing Software Requirements: A Unified Approach

.NETで使えるTensorFlowライクなニューラルネットワークライブラリ『NeuralNetwo...

html5のcanvasの可能性

openMVGをWindows10 Visual Studio 2015環境でビルドする

モバイルバージョンを終了