OpenCVで動画の手ぶれ補正

こちらのサイトに手振れ補正する理屈とOpenCVで書いたサンプルが載ってる。

Simple video stabilization using OpenCV

  1. オプティカルフローを用いて、前後フレーム間のトランスフォームを求める。
  2. トランスフォームは3つのパラメータ:dx, dy, da(角度)で構成され、基本的に剛体の剛性のユークリッド変換とし、スケーリングや共有は考慮しない。

  3. ブレの軌跡を得るために、各フレームのx, y, 角度のトランスフォームを保存する。
  4. 移動平均窓を使用して軌跡を滑らかにする。
  5. ユーザが平滑化に使用するフレーム数となる半径を指定する。

  6. 以下のように新しいトランスフォームを求める。
  7. 新しいトランスフォーム = 元のトランスフォーム + (平滑化した軌跡 – 元の軌跡)

  8. 動画に新しいトランスフォームを適用する。

サンプルコードもある。



補正結果比較動画。



2020年10月 追記:このC++実装をもとに有志がPythonで実装したPython Video StabilizationがGitHubで公開されている↓
https://github.com/AdamSpannbauer/python_video_stab

2019年1月 追記:Learn OpenCVでも手振れ補正のチュートリアルが公開されたぞ↓
https://www.learnopencv.com/video-stabilization-using-point-feature-matching-in-opencv/


関連記事

Deep Fluids:流体シミュレーションをディープラーニ...

PCA (主成分分析)

顔追跡による擬似3D表示『Dynamic Perspecti...

Raspberry PiでIoTごっこ

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

マルコフ連鎖モンテカルロ法

WebGL開発に関する情報が充実してきている

Caffe:読みやすくて高速なディープラーニングのフレームワ...

OpenCVでiPhone6sのカメラをキャリブレーションす...

Raspberry PiのGPIOを操作するPythonライ...

UnityのAR FoundationでARKit 3

Twitter APIのPythonラッパー『python-...

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

PythonのHTML・XMLパーサー『BeautifulS...

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

Verilog HDL

3Dスキャンに基づくプロシージャルフェイシャルアニメーション

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

Google App EngineでWordPress

2D→3D復元技術で使われる用語まとめ

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

Netron:機械学習モデルを可視化するツール

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

NumSharp:C#で使えるNumPyライクな数値計算ライ...

bpy-renderer:レンダリング用Pythonパッケー...

NeRF (Neural Radiance Fields):...

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

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

AR (Augmented Reality)とDR (Dim...

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

Google App Engine上のWordPressでF...

自前Shaderの件 解決しました

PyTorch3D:3Dコンピュータービジョンライブラリ

スクラッチで既存のキャラクターを立体化したい

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

HD画質の無駄遣い その2

Google Chromecast

TeleSculptor:空撮動画からPhotogramme...

ZScript

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

COLMAP:オープンソースのSfM・MVSツール

Autodesk Mementoでゴジラを3次元復元する

コメント