.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回の資料が参考になる。







スポンサーリンク

関連記事

書籍『3次元コンピュータビジョン計算ハンドブック』を購入

Raspberry Pi

Dlib:C++の機械学習ライブラリ

Regard3D:オープンソースのStructure from Motionツール

Unityの薄い本

WordPressのテーマを自作する

まだ続くブログの不調

Adobe MAX 2015

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

Mean Stack開発の最初の一歩

UnityのGameObjectの向きをScriptで制御する

Blendify:コンピュータービジョン向けBlenderラッパー

HD画質の無駄遣い その2

C++の抽象クラス

ZBrushで作った3Dモデルを立体視で確認できるVRアプリを作る

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

WordPress on Google App Engineを1週間運用してみて

網元AMIで作ったWordpressサイトのインスタンスをt1microからt2microへ移行した

UnityのAR FoundationでARKit 3

3Dスキャンに基づくプロシージャルフェイシャルアニメーション

WinSCP

科学技術計算向けスクリプト言語『Julia』

SONY製のニューラルネットワークライブラリ『NNabla』

iPhone・iPod touchで動作する知育ロボット『ROMO』

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

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

3分の動画でプログラミングを学習できるサイト『ドットインストール』

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

clearcoat Shader

YOLO (You Only Look Once):ディープラーニングによる一般物体検出手法

フィーリングに基づくタマムシの質感表現

OpenCVのfindEssentialMat関数を使ったサンプルを読んでみる

写真に3Dオブジェクトを違和感無く合成する『3DPhotoMagic』

OpenCVの三角測量関数『cv::triangulatepoints』

ニューラルネットワークと深層学習

3D復元技術の情報リンク集

Google App Engineのデプロイ失敗

OpenCVの顔検出過程を可視化した動画

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

Manim:Pythonで使える数学アニメーションライブラリ

WordPressプラグインによるサイトマップの自動生成

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

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