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

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



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

関連記事

画像認識による位置情報取得 - Semi-Direct Monocular Visual Odome...

Seleniumを使ったFXや株の自動取引

池袋パルコで3Dのバーチャルフィッティング『ウェアラブル クロージング バイ アーバンリサーチ』

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

Google App Engine上のWordPressでFlickrの画像を貼る

OpenCVで平均顔を作るチュートリアル

MVStudio:オープンソースのPhotogrammetryツール

Accord.NET Framework:C#で使える機械学習ライブラリ

Kaolin:3Dディープラーニング用のPyTorchライブラリ

ManimML:機械学習の概念を視覚的に説明するためのライブラリ

Google製オープンソース機械学習ライブラリ『TensorFlow』のWindows版が公開された

OpenCV3.3.0でsfmモジュールのビルドに成功!

書籍『3次元コンピュータビジョン計算ハンドブック』を購入

ブログのデザイン変えました

疑似3D写真が撮れるiPhoneアプリ『Seene』がアップデートでついにフル3Dモデルが撮影できる...

ManuelBastioniLAB:人体モデリングできるBlenderアドオン

顔追跡による擬似3D表示『Dynamic Perspective』

RSSフィードを読込んで表示するWordpressプラグイン『RSSImport』

オープンソースの取引プラットフォーム

LuxCoreRender:オープンソースの物理ベースレンダラ

iPhoneアプリ開発 Xcode 5のお作法

自前のShaderがおかしい件

Iterator

AfterEffectsプラグイン開発

Human Generator:Blenderの人体生成アドオン

Point Cloud Consortiumのセミナー「3D点群の未来」に行ってきたよ

Runway ML:クリエイターのための機械学習ツール

Photogrammetry (写真測量法)

まだ続くブログの不調

Fast R-CNN:ディープラーニングによる一般物体検出手法

手を動かしながら学ぶデータマイニング

U-Net:ディープラーニングによるSemantic Segmentation手法

MythTV:Linuxでテレビの視聴・録画ができるオープンソースプロジェクト

Google App EngineでWordPress

Live CV:インタラクティブにComputer Visionコーディングができるツール

Raspberry Pi 2のGPIOピン配置

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

OpenCV 3.1とopencv_contribモジュールをVisual Studio 2015で...

WordPressのサーバ引っ越し方法を考える

iPhone・iPod touchで動作する知育ロボット『ROMO』

trimesh:PythonでポリゴンMeshを扱うライブラリ

Point Cloud Libraryに動画フォーマットが追加されるらしい

コメント