OpenSfM:PythonのStructure from Motionライブラリ

スウェーデンのスタートアップMapillary社が公開しているOpenSfMというStructure from Motion用のライブラリがあるそうです。ライセンスは簡易BSDライセンス(Simplified BSD License)。2条項BSDライセンス(BSD 2-Clause license)とも呼ばれるやつで、著作権を表示すれば商用利用、修正、配布、サブライセンスOKだ。

OpenSfM

OpenSfM

OpenSfMは、OpenCVを用いてPythonで書かれたStructure from Motionライブラリです。このライブラリは、複数枚の画像からカメラの姿勢と3Dシーンを再構成するための処理パイプラインとして機能します。ロバストでスケーラブルな復元パイプラインの構築を重視したStructure from Motionの基本モジュール(特徴検出/マッチング、minimal solvers)で構成されています。
また、外部センサー(例えば、GPS、加速度センサー)の値を統合し、地理的な位置合わせや、よりロバストな結果を得ることができます。JavaScriptのビューアを設けており、モデルのプレビューや、パイプラインのデバッグに利用できます。

要はスマートフォンなどで撮影した複数枚の画像からGoogleストリートビューのようなものを作成するためのライブラリということのようです。画像だけでなくGPSや加速度センサーの情報も利用するあたり、とてもストリートビュー的な規模を意識している感じ。専用の撮影車両に依存しない、スマホユーザー達による民主的なストリートビュー作成ツールと言ったところ。
https://blog.mapillary.com/update/2014/12/15/sfm-preview.html


スポンサーリンク


このライブラリは、クラウドソーシングでストリート映像を作成するプロジェクトのためのものですかね。↓
http://gigazine.net/news/20140903-mapillary/
https://jp.techcrunch.com/2018/09/15/2018-09-13-mapillary-rekognition-amazon/

このライブラリを使うには以下の依存ライブラリも必要となります。


スポンサーリンク

依存ライブラリ

ソースコードはGitHubにある↓
https://github.com/mapillary/OpenSfM

OpenCVだけでなくOpenGVも使っているんですね。



QiitaではDocker上で動かす方法を書いている人がいる。
http://qiita.com/takahi/items/c0b21714a62935f67606

名称の”SfM”は”Structure from Motion”の略だと思うけど、カメラ位置の推定と撮影画像の補間までもStructure from Motionと呼ぶんですかね。てっきり3次元形状復元までの処理も含めてStructure from Motionだと思っていた。

このライブラリのリポジトリをGourceで可視化した動画を見つけた。2013年から始まってるのね。



むちゃくちゃ巨大なライブラリというわけでもなさそうだな。

コンピュータビジョン最先端ガイド5 (CVIMチュートリアルシリーズ)


スポンサーリンク

関連記事

OpenCVの顔検出過程を可視化した動画
Adobe MAX 2015
Russian3DScannerのトポロジー転送ツール『WrapX』
Active Appearance Models(AAM)
顔追跡による擬似3D表示『Dynamic Perspective』
IronPythonを使ってUnity上でPythonのコードを実行する
OpenCVで顔のランドマークを検出する『Facemark API』
Theia:オープンソースのStructure from Motionライブラリ
Windows10でPyTorchをインストールしてVSCodeで使う
MVStudio:オープンソースのPhotogrammetryツール
画像生成AI Stable Diffusionで遊ぶ
Unity ARKitプラグインサンプルのチュートリアルを読む
ディープラーニングに対応したPythonの機械学習ライブラリ『Pylearn2』
OpenFace:Deep Neural Networkによる顔の個人識別フレームワーク
ブログのデザイン変えました
読みやすくて高速なディープラーニングのフレームワーク『Caffe』
U-Net:ディープラーニングによるSemantic Segmentation手法
UnityでTweenアニメーションを実装できる3種類の無料Asset
Iterator
CGALDotNet:計算幾何学ライブラリ CGALのC#ラッパー
Deep Learningとその他の機械学習手法の性能比較
オープンソースのIT資産・ライセンス管理システム『Snipe-IT』
今年もSSII
FacebookがDeep learningツールの一部をオープンソース化
ArUco:OpenCVベースのコンパクトなARライブラリ
OpenCVで平均顔を作るチュートリアル
3D復元技術の情報リンク集
CGレンダラ研究開発のためのフレームワーク『Lightmetrica (ライトメトリカ)』
Mask R-CNN:ディープラーニングによる一般物体検出・Instance Segmentatio...
オープンソースの取引プラットフォーム
Raspberry Pi
ブログの復旧が難航してた話
畳み込みニューラルネットワーク (CNN: Convolutional Neural Network...
BGSLibrary:OpenCVベースの背景差分ライブラリ
adskShaderSDK
Boost オープンソースライブラリ
Alice Vision:オープンソースのPhotogrammetryフレームワーク
Pythonのソースコードに特化した検索エンジン『Nullege』
OpenCVでPhotoshopのプラグイン開発
OpenMesh:オープンソースの3Dメッシュデータライブラリ
Multi-View Environment:複数画像から3次元形状を再構築するライブラリ
Webスクレイピングの勉強会に行ってきた

コメント