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年から始まってるのね。

https://www.youtube.com/watch?v=7YHvFVwUwcw

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

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

関連記事

Kornia:微分可能なコンピュータービジョンライブラリ

ブログのデザイン変えました

第1回 3D勉強会@関東『SLAMチュートリアル大会』

AmazonEC2のインスタンスをt1.microからt2.microへ移行する

UnityでARKit2.0

Math Inspector:科学計算向けビジュアルプログラミングツール

SVM (Support Vector Machine)

書籍『ゼロから作るDeep Learning』で自分なりに学ぶ

Amazon EC2ログイン用の秘密鍵を無くした場合の対処方法

Unity ARKitプラグインサンプルのチュートリアルを読む

Iterator

html5のcanvasの可能性

Qlone:スマホのカメラで3Dスキャンできるアプリ

画像認識による位置情報取得 - Semi-Direct Monocular Visual Odome...

Math.NET Numerics:Unityで使える数値計算ライブラリ

HerokuでMEAN stack

Kinect for Windows V2のプレオーダー開始

OpenCVでカメラ画像から自己位置認識 (Visual Odometry)

UnityプロジェクトをGitHubで管理する

Amazon Web ServicesでWordPress

Point Cloud Utils:Pythonで3D点群・Meshを扱うライブラリ

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

Model View Controller

Pylearn2:ディープラーニングに対応したPythonの機械学習ライブラリ

TorchStudio:PyTorchのための統合開発環境とエコシステム

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

写真から3Dメッシュの生成・編集ができる無料ツール『Autodesk Memento』

オープンソースの人体モデリングツール『MakeHuman』のAPI開発プロジェクトがスタート

OpenGV:画像からカメラの3次元位置・姿勢を推定するライブラリ

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

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

Raspberry PiのGPIOを操作するPythonライブラリ『RPi.GPIO』の使い方

PythonのHTML・XMLパーサー『BeautifulSoup』

頭蓋骨からの顔復元と進化過程の可視化

OpenCVのバージョン3が正式リリースされたぞ

Russian3DScannerのトポロジー転送ツール『WrapX』

畳み込みニューラルネットワーク (CNN: Convolutional Neural Network...

PSPNet (Pyramid Scene Parsing Network):ディープラーニングによ...

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

Pix2Pix:CGANによる画像変換

python-twitterで自分のお気に入りを取得する

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

コメント