オープンソースのStructure from Motionライブラリ『Theia』

度々似たような話題ですが(笑)
また別のオープンソースStructure from Motionライブラリを見つけた。↓

Theia

Theia-SfM

TheiaChris Sweeneyが開発したコンピュータービジョンライブラリで、効率的で信頼性の高いStructure from Motion(SfM)アルゴリズムを提供するために作られました。このライブラリは、研究者達へmulti-view reconstructionのための簡単に拡張可能なbox-toolの提供を目指しています。
姿勢推定、特徴検出と特長記述、マッチング、再構築のための多くの共通アルゴリズムが実装されています。シンプルなインターフェイス、少ない依存関係、そして豊富なドキュメントが用意されています。

ライセンスは修正BSDライセンス(New BSD License)なので商用利用も可能。
ソースコードはこちら↓
https://github.com/sweeneychris/TheiaSfM


スポンサーリンク


このライブラリは、ACMが主催するOpen Source Software Competition 2015でファイナリストにまで残ったライブラリだそうです。
(それがどれほどすごいことなのかはよくわかりません。。。)

もともとはカリフォルニア大学サンタバーバラ校のFour Eyes Labで開発されていたものがベースで、後にオープンソース化されたものだそうだ。
現在の開発の中心となっているChris Sweeney氏のページはこちら↓
http://cs.ucsb.edu/~cmsweeney/

Theiaライブラリのビルド方法を見てみたら、以下のライブラリに依存しているらしい。


スポンサーリンク

この手のライブラリではお馴染みのCeres Solverが入っている。ここの解説にもある通り、Ceres Solverは「非線形問題」を解くためのライブラリ。Structure from Motionでは、推定した変換行列の再投影誤差が最小となるパラメータを求めるBundle Adjustment処理で使われている。(最近やっと理解)

ちょっとライブラリの構成を眺めてみた。OpenMVGのサンプルでも感じたけど、Structure from Motionのライブラリって、画像のExifデータを利用する仕様が割と当たり前なのね。大抵、ライブラリにカメラの機種ごとのプロファイルデータベースもセットになっている。


スポンサーリンク

関連記事

Leap MotionでMaya上のオブジェクトを操作できるプラグイン
C#で使える可読性重視のディープラーニングライブラリ『KelpNet』
OpenCVでカメラ画像から自己位置認識 (Visual Odometry)
R-CNN (Regions with CNN features):ディープラーニングによる一般物体...
adskShaderSDK
iPhoneアプリ開発 Xcode 5のお作法
C++ 標準テンプレートライブラリ (STL)
プログラムによる景観の自動生成
UnityでTweenアニメーションを実装できる3種類の無料Asset
C++の機械学習ライブラリ『Dlib』
立体視を試してみた
網元AMIで作ったWordpressサイトのインスタンスをt1microからt2microへ移行した
AfterEffectsプラグイン開発
GeoGebra:無料で使える数学アプリ
Boost オープンソースライブラリ
Mask R-CNN:ディープラーニングによる一般物体検出・Instance Segmentatio...
OANDAのfxTrade API
Fast R-CNN:ディープラーニングによる一般物体検出手法
なんかすごいサイト
Raspberry PiでIoTごっこ
Googleが画像解析旅行ガイドアプリのJetpac社を買収
OpenCV 3.3.0-RCでsfmモジュールをビルド
OpenMayaRender
Point Cloud Consortiumのセミナー「3D点群の未来」に行ってきたよ
統計的な顔モデル
fSpy:1枚の写真からカメラパラメーターを割り出すツール
マルコフ連鎖モンテカルロ法
OpenCLに対応したオープンソースの物理ベースレンダラ『LuxRender(ルクスレンダー)』
2D→3D復元技術で使われる用語まとめ
書籍『仕事ではじめる機械学習』を読みました
第1回 3D勉強会@関東『SLAMチュートリアル大会』
Unityで画面タッチ・ジェスチャ入力を扱う無料Asset『TouchScript』
Unityの各コンポーネント間でのやり取り
RSSフィードを読込んで表示するWordpressプラグイン『RSSImport』
Pix2Pix:CGANによる画像変換
OpenCVでiPhone6sのカメラをキャリブレーションする
Seleniumを使ったFXや株の自動取引
オープンソースの物理ベースGIレンダラ『appleseed』
Russian3DScannerのトポロジー転送ツール『WrapX』
FacebookがDeep learningツールの一部をオープンソース化
池袋パルコで3Dのバーチャルフィッティング『ウェアラブル クロージング バイ アーバンリサーチ』
iOSで使えるJetpac社の物体認識SDK『DeepBelief』

コメント

  1. わたなべ より:

    いつもCV関係の紹介記事、参考にさせていただいてます。
    このTheia、作者がWindows向けに作っていないため、何回かCMakeで挑戦してみましたがceres等他の必要なライブラリ部分で詰まり中断していました。

    Visual Studio 2015(Update 3)/2017限定になりますが、C++のオープンソフトウェアパッケージ管理のvcpkgにTheiaが登録されたため、(vcpkgを導入すれば)コマンドライン1行たたくだけで使えるようになっています。vcpkg自体もGitHubからpullしてbatファイルを叩くだけなので簡単でした。

    exeもありますが、APIを利用できる感じになっているので、SfM部分を勉強したりトレンド(CVPR2017のHybridSfMも最近実装されました)をおいかけたりするには良さそうです。