LoginSignup
16
16

More than 5 years have passed since last update.

OpenCV For Unityを使ってiPhone上でYOLOを動かす

Posted at

はじめに

OpenCV for Unityには色々なサンプルが入っており、その中にYOLOを使ったものがあります。

YOLOとは画像認識のアルゴリズムで、比較的処理が高速なことが知られています。

OpenCV for Unityに含まれているYOLOのデモは以下の2つで、WebGLでのデモページからも試すことが出来ます。

  • YoloObjectDetectionExample
    • 画像を使ったYOLOのデモ
  • YoloObjectDetectionWebCamTextureExample
    • Webカメラを使ったYOLOのデモ

また、このデモをiPhone XSで動かした動画が以下になります。

OpenCV for UnityはiOSを始めとして様々なプラットフォームに対応したアセットなのですが、2018/10/26現在の環境で動かすためにはいくつかの手順が必要でしたので、記しておきたいと思います。

手順

予めOpenCV for Unityをプロジェクトにインポートしておきます。

YOLOを使うためには、まずモデルデータをインポートする必要があります。ライセンスの関係でOpenCVForUnityのパッケージ自体には入っていないので、別途リポジトリからダウンロードしてきます。

必要なファイル以下の3つです。

これを、Assets/StreamingAssets/dnn以下に置いておく必要があります。

OpenCVForUnityの直下にあるStreamingAssetsに雛形があるので、フォルダ毎Assets直下に移動させると良いと思います。

ちなみにですが、StreamingAssets/dnn以下にあるドキュメントではcoco.namesの記述が抜けているのと、実行時のファイル参照エラーメッセージでは指定されているyoloのバージョンが異なっていました。罠っぽい…。

ここまでやると、エディタ上で実行ができる状態になります。
OpenCVForUnity/Examples/MainModules/dnn/YoloExample以下にあるシーンを再生してみてください。

スクリーンショット 2018-10-26 21.25.57.png
画像: YoloObjectDetectionExample.unityを再生した例

iPhoneで再生するためにはもう一つ手順が必要です。

iOSで実行した場合Utils.csstring getFilePath (string filepath, bool refresh = false)という関数内にあるFile.Exists (destPath)がtrueを返してくれない事象を確認しました。そのため、モデルデータを読み込めず、正常に実行されません。

対処としては、ファイルの存在チェックを行わずにpathを返すようにすれば良いです。

変更前.cs
if (File.Exists (destPath)) {
    return destPath;
} else {
    return String.Empty;
}
変更後.cs
return destPath;

この状態でビルドすれば冒頭の動画のように実行出来ると思います。

16
16
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
16
16