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

世間ではiPhone7が発売されていますが、オイラは引き続きiPhone6sを使います(笑)

1年前にiPhone6Sへ機種変更してからiPhone6sのカメラで結構たくさん写真や動画を撮ったので、画像・動画がだいぶ溜まった。
それらの画像・動画のレンズの歪みを補正したいんだけど、良い方法が他に思いつかないので、OpenCVでやってみることにする。(最新のPhotoshopとかだとできたりするんだろうか)

例のごとく、OpenCV 3.1に同梱のサンプルコードでできてしまう。

opencv/samples/cpp/calibration.cpp

OpenCVに実装されているのはZhangのキャリブレーション手法(A Flexible New Technique for Camera Calibration)
Zhangのキャリブレーション手法では、既知の幾何形状として平面のチェッカーパターンを3枚以上撮影する必要がある。(OpenCV3.1公式のサンプルの方にはチェッカーパターンだけでなく、円形のパターンを使用した例も入っている)

こちらの書籍にもっとシンプルなサンプルが載っている。↓

OpenCV 3 プログラミングブック

どうでも良いですが、書籍97ページの出典論文の記載箇所、何故か論文タイトルの”Fl”が抜けて”exible”という謎の単語になってますね。


スポンサーリンク


で、まあ、iPhoneでチェッカーパターンを撮ってやってみることにした。チェッカーパターンはOpenCVで生成しても良いし、ネットで拾っても良い。オイラはここにある10×7のチェッカーパターンを使わせてもらった。
印刷したチェッカーパターンをとりあえず4K(3840×2160)解像度の動画で色んな角度から撮影した。ところで、気になっているのが、iPhoneだと静止画と動画で撮影画角が変わること。何で動画撮影時は狭くなるんだろうな。

cv::calibrateCamera関数を使ってカメラの内部パラメータと歪み係数を求めた。
その結果を使って動画の歪みを補正してやる。
http://qiita.com/tunepolo/items/76058121238be386bb21

また例の動画で試してみた。


スポンサーリンク
OpenCVでレンズの歪み補正

って、これキャリブレーション失敗なのか?しかもファイル書き出しミスって動画の尺が半分になった。。。


スポンサーリンク

関連記事

PCA (主成分分析)
Adobeの手振れ補正機能『ワープスタビライザー』の秘密
JavaScriptとかWebGLとかCanvasとか
ブログをGoogle App EngineからAmazon EC2へ移行
「ベンジャミン·バトン数奇な人生」でどうやってCGの顔を作ったのか
サンプルコードにも間違いはある?
なんかすごいサイト
C#で使える遺伝的アルゴリズムライブラリ『GeneticSharp』
スマホのカメラで3Dスキャンできるアプリ『Qlone』
ポリゴン用各種イテレータと関数セット
Mayaのプラグイン開発
SONYの自律型エンタテインメントロボット『aibo』
Pythonの自然言語処理ライブラリ『NLTK(Natural Language Toolkit)』
畳み込みニューラルネットワーク (CNN:Convolutional Neural Network)
書籍『仕事ではじめる機械学習』を読みました
Deep Learningとその他の機械学習手法の性能比較
Windows10でPyTorchをインストールしてVSCodeで使う
UnityのAR FoundationでARKit 3
SSII2014 チュートリアル講演会の資料
Amazon EC2ログイン用の秘密鍵を無くした場合の対処方法
Maya API Reference
読みやすくて高速なディープラーニングのフレームワーク『Caffe』
WordPress on Google App Engineを1週間運用してみて
3Dスキャンに基づくプロシージャルフェイシャルアニメーション
バージョン管理の履歴を可視化するツール『Gource』
C++ 標準テンプレートライブラリ (STL)
オープンソースの汎用レンダラ『Mitsuba 2』
オープンソースのSLAMライブラリ『Cartographer』
ニューラルネットワークと深層学習
RSSフィードを読込んで表示するWordpressプラグイン『RSSImport』
DCGAN (Deep Convolutional GAN):畳み込みニューラルネットワークによる敵...
書籍『ゼロから作るDeep Learning』で自分なりに学ぶ
Raspberry PiでIoTごっこ
OpenCVの顔検出過程を可視化した動画
コンピュータビジョン研究のためのUnreal Engineプラグイン『UnrealCV』
Multi-View Stereoによる3次元復元ライブラリ『OpenMVS』
OpenCV
Active Appearance Models(AAM)
OpenCVベースのマーカーARライブラリ『OpenAR』
pythonの機械学習ライブラリ『scikit-learn』
UnityでTweenアニメーションを実装できる3種類の無料Asset
ニューラルネットワークの構造を可視化するフレームワーク『TensorSpace.js』

コメント