こちらのサイトに手振れ補正する理屈とOpenCVで書いたサンプルが載ってる。
Simple video stabilization using OpenCV
- オプティカルフローを用いて、前後フレーム間のトランスフォームを求める。
トランスフォームは3つのパラメータ:dx, dy, da(角度)で構成され、基本的に剛体の剛性のユークリッド変換とし、スケーリングや共有は考慮しない。
- ブレの軌跡を得るために、各フレームのx, y, 角度のトランスフォームを保存する。
- 移動平均窓を使用して軌跡を滑らかにする。
ユーザが平滑化に使用するフレーム数となる半径を指定する。
- 以下のように新しいトランスフォームを求める。
新しいトランスフォーム = 元のトランスフォーム + (平滑化した軌跡 – 元の軌跡)
- 動画に新しいトランスフォームを適用する。
サンプルコードもある。
補正結果比較動画。
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/
関連記事
ポリゴン用各種イテレータと関数セット
MVStudio:オープンソースのPhotogrammetr...
OpenCV 3.1とopencv_contribモジュール...
Unityの各コンポーネント間でのやり取り
ZScript
html5のcanvasの可能性
Regard3D:オープンソースのStructure fro...
機械学習のオープンソースソフトウェアフォーラム『mloss(...
Kinect for Windows V2のプレオーダー開始
MythTV:Linuxでテレビの視聴・録画ができるオープン...
Iridescence:プロトタイピング向け軽量3D可視化ラ...
3分の動画でプログラミングを学習できるサイト『ドットインスト...
Active Appearance Models(AAM)
SONY製のニューラルネットワークライブラリ『NNabla』
DUSt3R:3Dコンピュータービジョンの基盤モデル
pythonの機械学習ライブラリ『scikit-learn』
Alice Vision:オープンソースのPhotogram...
PythonでMayaのShapeノードプラグインを作る
ROSでガンダムを動かす
3Dモデルを立体視で確認できるVRアプリを作っている
3Dグラフィックスの入門書
画像生成AI Stable Diffusionで遊ぶ
OpenGVのライブラリ構成
UnrealCV:コンピュータビジョン研究のためのUnrea...
PythonでBlenderのAdd-on開発
WordPressの表示を高速化する
iOSで使えるJetpac社の物体認識SDK『DeepBel...
オープンソースの物理ベースレンダラ『Mitsuba』をMay...
BlenderProc:Blenderで機械学習用の画像デー...
Quartus II
PyDataTokyo主催のDeep Learning勉強会
Unreal Engineの薄い本
Point Cloud Libraryに動画フォーマットが追...
OpenCVでPhotoshopのプラグイン開発
WinSCP
クラスの基本
R-CNN (Regions with CNN featur...
「ベンジャミン·バトン数奇な人生」でどうやってCGの顔を作っ...
Pythonの自然言語処理ライブラリ『NLTK(Natura...
Rerun:マルチモーダルデータの可視化アプリとSDK
iPadをハンディ3Dスキャナにするガジェット『iSense...
Super Resolution:OpenCVの超解像処理モ...


コメント