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でレンズの歪み補正

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


スポンサーリンク

関連記事

YOLO (You Only Look Once):ディープラーニングによる一般物体検出手法
MFnDataとMFnAttribute
Autodesk Mementoでゴジラを3次元復元する
HerokuでMEAN stack
R-CNN (Regions with CNN features):ディープラーニングによる一般物体...
C++の機械学習ライブラリ『Dlib』
OpenCV 3.3.0-RCでsfmモジュールをビルド
オーバーロードとオーバーライド
UnityプロジェクトをGitHubで管理する
Raspberry Pi
1枚の画像からマテリアルを作成できる無料ツール『Materialize』
WinSCP
CGAN (Conditional GAN):条件付き敵対的生成ネットワーク
Mean Stack開発の最初の一歩
SDカードサイズのコンピューター『Intel Edison』
UnityでOpenCVを使うには?
adskShaderSDK
Raspberry PiでIoTごっこ
Unityの薄い本
RefineNet (Multi-Path Refinement Network):ディープラーニン...
定数
HD画質の無駄遣い
AmazonEC2のインスタンスをt1.microからt2.microへ移行する
DCGAN (Deep Convolutional GAN):畳み込みニューラルネットワークによる敵...
MythTV:Linuxでテレビの視聴・録画ができるオープンソースプロジェクト
Unity Scriptコーディング→Unreal Engine Scriptコーディング
プログラミングスキルとは何か?
このブログのデザインに飽きてきた
Faster R-CNN:ディープラーニングによる一般物体検出手法
人体モデリングできるBlenderアドオン『ManuelBastioniLAB』
『手を動かしながら学ぶエンジニアのためのデータサイエンス』ハンズオンセミナーに行ってきた
バージョン管理の履歴を可視化するツール『Gource』
OpenCVでカメラ画像から自己位置認識 (Visual Odometry)
「ベンジャミン·バトン数奇な人生」でどうやってCGの顔を作ったのか
Konashiを買った
Pix2Pix:CGANによる画像変換
Active Appearance Models(AAM)
AnacondaとTensorFlowをインストールしてVisual Studio 2015で使う
WordPressプラグインの作り方
Unity MonoBehaviourクラスのオーバーライド関数が呼び出される順番
Paul Debevec
OpenCVで顔のランドマークを検出する『Facemark API』

コメント