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

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



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


スポンサーリンク

関連記事

第25回コンピュータビジョン勉強会@関東に行って来た
立体視を試してみた
機械学習のオープンソースソフトウェアフォーラム『mloss(machine learning ope...
WordPressのテーマを自作する
UnrealCLR:Unreal Engineで.NET Coreを利用できるプラグイン
OpenCLに対応したオープンソースの物理ベースレンダラ『LuxRender(ルクスレンダー)』
C#で使える遺伝的アルゴリズムライブラリ『GeneticSharp』
Faceshiftで表情をキャプチャしてBlender上でMakeHumanのメッシュを動かすデモ
なんかすごいサイト
Faster R-CNN:ディープラーニングによる一般物体検出手法
オープンソースの物理ベースレンダラ『Mitsuba』をMayaで使う
OpenCV 3.1とopencv_contribモジュールをVisual Studio 2015で...
WordPress on Windows Azure
adskShaderSDK
iOSで使えるJetpac社の物体認識SDK『DeepBelief』
ZScript
Amazon EC2ログイン用の秘密鍵を無くした場合の対処方法
CGレンダラ研究開発のためのフレームワーク『Lightmetrica (ライトメトリカ)』
AnacondaとTensorFlowをインストールしてVisual Studio 2015で使う
WebGL開発に関する情報が充実してきている
SSD (Single Shot Multibox Detector):ディープラーニングによる一般...
Unityからkonashiをコントロールする
機械学習で遊ぶ
動的なメモリの扱い
Unityで画面タッチ・ジェスチャ入力を扱う無料Asset『TouchScript』
Managing Software Requirements: A Unified Approach
GeoGebra:無料で使える数学アプリ
科学技術計算向けスクリプト言語『Julia』
Google XML Sitemap Generatorプラグインを3.4.1へダウングレード
MVStudio:オープンソースのPhotogrammetryツール
OpenCV3.3.0でsfmモジュールのビルドに成功!
Raspberry Piでセンサーの常時稼働を検討する
HerokuでMEAN stack
3Dグラフィックスの入門書
OpenCVで顔のランドマークを検出する『Facemark API』
libigl:軽量なジオメトリ処理ライブラリ
html5のcanvasの可能性
Unityで強化学習できる『Unity ML-Agents』
OpenCVの顔検出過程を可視化した動画
ブログをGoogle App EngineからAmazon EC2へ移行
Leap MotionでMaya上のオブジェクトを操作できるプラグイン
チャットツール用bot開発フレームワーク『Hubot』

コメント