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

度々似たような話題ですが(笑)
また別のオープンソース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データを利用する仕様が割と当たり前なのね。大抵、ライブラリにカメラの機種ごとのプロファイルデータベースもセットになっている。

関連記事

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

SSII2014 チュートリアル講演会の資料

PCA (主成分分析)

ZScript

Boost オープンソースライブラリ

ポリゴンジオメトリ処理ライブラリ『pmp-library (...

組み込み向けのWindows OS 『Windows Emb...

書籍『イラストで学ぶ ディープラーニング』

C++始めようと思うんだ

ブラウザ操作自動化ツール『Selenium』を試す

Web経由でRaspberry PiのGPIOを操作したい

DUSt3R:3Dコンピュータービジョンの基盤モデル

MeshroomでPhotogrammetry

Raspberry Piでセンサーの常時稼働を検討する

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

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

OpenMesh:オープンソースの3Dメッシュデータライブラ...

Pylearn2:ディープラーニングに対応したPythonの...

Alice Vision:オープンソースのPhotogram...

YOLO (You Only Look Once):ディープ...

Multi-View Environment:複数画像から3...

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

ドットインストールのWordPress入門レッスン

CycleGAN:ドメイン関係を学習した画像変換

BlenderProc:Blenderで機械学習用の画像デー...

Geogram:C++の3D幾何アルゴリズムライブラリ

Unityで強化学習できる『Unity ML-Agents』

Super Resolution:OpenCVの超解像処理モ...

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

自前Shaderの件 解決しました

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

このブログのデザインに飽きてきた

Mitsuba 2:オープンソースの物理ベースレンダラ

clearcoat Shader

OpenVDB:3Dボリュームデータ処理ライブラリ

OpenAR:OpenCVベースのマーカーARライブラリ

cvui:OpenCVのための軽量GUIライブラリ

OpenCVの超解像(SuperResolution)モジュ...

UnrealCV:コンピュータビジョン研究のためのUnrea...

OANDAのfxTrade API

統計的な顔モデル

MFnDataとMFnAttribute

コメント

  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も最近実装されました)をおいかけたりするには良さそうです。