[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

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





スポンサーリンク

関連記事

動的なメモリの扱い
Geogram:C++の3D幾何アルゴリズムライブラリ
Pythonの自然言語処理ライブラリ『NLTK(Natural Language Toolkit)』
geometry3Sharp:Unity C#で使えるポリゴン操作ライブラリ
SONYの自律型エンタテインメントロボット『aibo』
Digital Emily Project:人間の顔をそっくりそのままCGで復元する
Regard3D:オープンソースのStructure from Motionツール
機械学習に役立つPythonライブラリ一覧
OpenMayaのPhongShaderクラス
OpenAR:OpenCVベースのマーカーARライブラリ
NeRF (Neural Radiance Fields):深層学習による新規視点合成
OpenMesh:オープンソースの3Dメッシュデータライブラリ
Kinect for Windows v2の日本価格決定
Pythonのソースコードに特化した検索エンジン『Nullege』
IronPythonを使ってUnity上でPythonのコードを実行する
ベイズ推定とグラフィカルモデル
Google App Engineのデプロイ失敗
YOLO (You Only Look Once):ディープラーニングによる一般物体検出手法
ManimML:機械学習の概念を視覚的に説明するためのライブラリ
Google App EngineでWordPress
「ベンジャミン·バトン数奇な人生」でどうやってCGの顔を作ったのか
Dlib:C++の機械学習ライブラリ
続・ディープラーニングの資料
画像認識による位置情報取得 - Semi-Direct Monocular Visual Odome...
CNN Explainer:畳み込みニューラルネットワーク可視化ツール
ニューラルネットワークと深層学習
SDカードサイズのコンピューター『Intel Edison』
OpenCVでiPhone6sのカメラをキャリブレーションする
ROSの薄い本
畳み込みニューラルネットワーク (CNN: Convolutional Neural Network...
iPhoneで3D写真が撮れるアプリ『seene』
openMVG:複数視点画像から3次元形状を復元するライブラリ
OpenCVの三角測量関数『cv::triangulatepoints』
Mayaのプラグイン開発
ブログのデザイン変えました
RSSフィードを読込んで表示するWordpressプラグイン『RSSImport』
FacebookがDeep learningツールの一部をオープンソース化
顔画像処理技術の過去の研究
FCN (Fully Convolutional Network):ディープラーニングによるSema...
GeoGebra:無料で使える数学アプリ
池袋パルコで3Dのバーチャルフィッティング『ウェアラブル クロージング バイ アーバンリサーチ』
オープンソースのロボットアプリケーションフレームワーク『ROS (Robot Operating S...

コメント

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