サイトアイコン NegativeMindException

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

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

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

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



スポンサーリンク

関連記事

  • OpenCVで顔のランドマークを検出する『Facemark API』
  • 書籍『ゼロから作るDeep Learning』で自分なりに学ぶ
  • Model View Controller
  • MPFB2:Blenderの人体モデリングアドオン
  • FreeMoCap Project:オープンソースのマーカーレスモーションキャプチャ
  • 定数
  • Live CV:インタラクティブにComputer Visionコーディングができるツール
  • ZScript
  • オープンソースのロボットアプリケーションフレームワーク『ROS (Robot Operating S...
  • ManuelBastioniLAB:人体モデリングできるBlenderアドオン
  • Math.NET Numerics:Unityで使える数値計算ライブラリ
  • UnityでPoint Cloudを表示する方法
  • Python2とPython3
  • OpenCVの顔検出過程を可視化した動画
  • pythonの機械学習ライブラリ『scikit-learn』
  • OpenMVSのサンプルを動かしてみる
  • PCA (主成分分析)
  • MythTV:Linuxでテレビの視聴・録画ができるオープンソースプロジェクト
  • iPadをハンディ3Dスキャナにするガジェット『iSense 3D Scanner』
  • PGGAN:段階的に解像度を上げて学習を進めるGAN
  • Python拡張モジュールのWindows用インストーラー配布サイト
  • UnityのAR FoundationでARKit 3
  • Twitter APIのPythonラッパー『python-twitter』
  • Raspberry Pi
  • DCGAN (Deep Convolutional GAN):畳み込みニューラルネットワークによる敵...
  • Open3D:3Dデータ処理ライブラリ
  • Quartus II
  • ブログの復旧が難航してた話
  • 池袋パルコで3Dのバーチャルフィッティング『ウェアラブル クロージング バイ アーバンリサーチ』
  • SSD (Single Shot Multibox Detector):ディープラーニングによる一般...
  • プログラムによる景観の自動生成
  • PSPNet (Pyramid Scene Parsing Network):ディープラーニングによ...
  • Open Shading Language (OSL)
  • AmazonEC2のインスタンスをt1.microからt2.microへ移行する
  • ArUco:OpenCVベースのコンパクトなARライブラリ
  • 機械学習で遊ぶ
  • Runway ML:クリエイターのための機械学習ツール
  • Fast R-CNN:ディープラーニングによる一般物体検出手法
  • OpenCVのバージョン3が正式リリースされたぞ
  • 写真に3Dオブジェクトを違和感無く合成する『3DPhotoMagic』
  • cvui:OpenCVのための軽量GUIライブラリ
  • チャットツール用bot開発フレームワーク『Hubot
  • モバイルバージョンを終了