OpenCVで2D情報をもとに3Dの計算を行う際、実装が間違ってないかopencv_contribのvizモジュールで可視化して確かめてるんだけど、vizモジュールって割と低レベルな機能しか提供していないのでちょっとしんどくなってきた。

デバッグ目的の可視化はUnityEditorぐらい手軽に済ませたいところ。だったら最初からUnityを使ってしまおうと思って調べ始めた。
3つの有料Asset
UnityのAssetStoreで調べてみると、Unity上でOpenCVの機能を使えるようにする有料Assetが3つある。
- OpenCV plus Unity:価格74.99ドル
- OpenCV for Unity:価格95ドル
- Emgu CV v3.x:価格399ドル
UnityでOpenCVの機能を使うには、もちろん自分でC++ネイティブプラグインを作るという手もある。
だけど、オイラはあくまで自分の3D実装が正しいのか確認するプロセス(つまりデバッグ)の効率を上げたいので、Assetを購入して手間を減らす方針。もうさっさと課金しちゃいましょう。
最初はこちらのQiita記事を読んでEmguCVに気持ちが傾きかけたんだけど、これはやや古い記事なので今現在の状況を調べた方が良い。↓
http://qiita.com/jhorikawa/items/fafee3373eb3ccef02c8
結論から言うと、OpenCV for Unityを使うことにしました。以下調べたことを順にメモ書き。
OpenCV plus Unity
OpenCV plus Unityは、OpenCVをC#で使えるようにポートしたオープンソースプロジェクトOpenCVSharpがベースになっている。
公式ドキュメントはこちら↓
http://paperplanetools.com/cvwd_doc/html/class_open_cv_sharp_1_1_cv2.html
OpenCV for Unity
OpenCV for Unityは3つの中で断然有名。
https://enoxsoftware.com/opencvforunity/
上記の古いQiita記事では、OpenCVのJavaラッパーをポートしていると書かれていたけど、どうやら現在は違う模様。API仕様はOpenCV Javaに合わせているけど、バックの実装は直にC++っぽいです。処理のオーバーヘッドはあんまり気にしなくて良さそう。(少なくとも、C++でOpenCV vizモジュールを使って可視化するより高速だった)
現在はOpenCVの最新版
公式ドキュメントはこちら↓
http://enoxsoftware.github.io/OpenCVForUnity/3.0.0/doc/html/index.html
Emgu CV v3.x
Emgu CV v3.xはQiita記事にある通り、OpenCVをクロスプラットフォーム化するオープンソースの.NETラッパープロジェクトEmguCVがベースとなっている。
EmguCVのソースコードはこちら↓
https://github.com/emgucv/emgucv
EmguCV自体はオープンソースだけど、商用利用するには有償版を購入する必要があり、Windows版のみ商用利用不可の無償版が配布されている。↓
https://sourceforge.net/projects/emgucv/
公式ドキュメントはこちら↓
http://www.emgu.com/wiki/index.php/Documentation
決め手
で、オイラ的には、UnityのTexture型とOpenCVのMat型の相互変換メソッドがすでに用意されているOpenCV for Unityがベストに思えたのだ。だって頻繁に行う処理だし。
OpenCV for Unityならユーザーが多くてアップデート頻度も高そうだ。
ところで、どのAssetもopencv_contribのArUcoは含まれているのが面白い。AR機能の需要は高いんですかね。

関連記事
OpenCV3.3.0でsfmモジュールのビルドに成功!
Qlone:スマホのカメラで3Dスキャンできるアプリ
UnityのGlobal Illumination
Web経由でRaspberry PiのGPIOを操作したい
Manim:Pythonで使える数学アニメーションライブラリ
libigl:軽量なジオメトリ処理ライブラリ
COLMAP:オープンソースのSfM・MVSツール
OpenCVでカメラ画像から自己位置認識 (Visual O...
cvui:OpenCVのための軽量GUIライブラリ
uGUI:Unityの新しいGUI作成システム
AR (Augmented Reality)とDR (Dim...
CGのためのディープラーニング
MeshLab:3Dオブジェクトの確認・変換に便利なフリーウ...
Adobeの手振れ補正機能『ワープスタビライザー』の秘密
OpenCV 3.3.0 contribのsfmモジュールの...
Mitsuba 3:オープンソースの研究向けレンダラ
Runway ML:クリエイターのための機械学習ツール
python-twitterで自分のお気に入りを取得する
WebGL開発に関する情報が充実してきている
FCN (Fully Convolutional Netwo...
Unity ARKitプラグインサンプルのドキュメントを読む
ポリゴン用各種イテレータと関数セット
ニューラルネットワークと深層学習
Unity ARKitプラグインサンプルのチュートリアルを読...
WordPressプラグインの作り方
Google製オープンソース機械学習ライブラリ『Tensor...
ZBrushで作った3Dモデルを立体視で確認できるVRアプリ...
Google Colaboratoryで遊ぶ準備
2D→3D復元技術で使われる用語まとめ
Mechanizeで要認証Webサイトをスクレイピング
Raspberry PiのGPIOを操作するPythonライ...
DUSt3R:3Dコンピュータービジョンの基盤モデル
Amazon Web ServicesでWordPress
iOSで使えるJetpac社の物体認識SDK『DeepBel...
TensorFlowでCGを微分できる『TensorFlow...
機械学習のオープンソースソフトウェアフォーラム『mloss(...
WordPressのテーマを自作する
OpenCV
「ベンジャミン·バトン数奇な人生」でどうやってCGの顔を作っ...
書籍『イラストで学ぶ ディープラーニング』
TorchStudio:PyTorchのための統合開発環境と...
Iridescence:プロトタイピング向け軽量3D可視化ラ...


コメント