質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Caffe

Caffeは、深層学習に用いられるオープンソースフレームワークの一つです。C++で実装されており、C++/Python/MATLABで用いることができます。画像認識に特化しており、動作も早い点が特徴。GUPにも対応しています。

OpenCV

OpenCV(オープンソースコンピュータービジョン)は、1999年にインテルが開発・公開したオープンソースのコンピュータビジョン向けのクロスプラットフォームライブラリです。

機械学習

機械学習は、データからパターンを自動的に発見し、そこから知能的な判断を下すためのコンピューターアルゴリズムを指します。人工知能における課題のひとつです。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

0回答

853閲覧

SqueezeNetのCaffeモデルをOpenCVのDNNモジュールを使って読み出す

deka-cho

総合スコア18

Caffe

Caffeは、深層学習に用いられるオープンソースフレームワークの一つです。C++で実装されており、C++/Python/MATLABで用いることができます。画像認識に特化しており、動作も早い点が特徴。GUPにも対応しています。

OpenCV

OpenCV(オープンソースコンピュータービジョン)は、1999年にインテルが開発・公開したオープンソースのコンピュータビジョン向けのクロスプラットフォームライブラリです。

機械学習

機械学習は、データからパターンを自動的に発見し、そこから知能的な判断を下すためのコンピューターアルゴリズムを指します。人工知能における課題のひとつです。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2020/10/06 01:07

SqueezeNetのCaffeモデル(ネットワーク記述.prototxt、と.caffemodel、mean.npyの平均画像、label.txtのラベルファイルの4つのファイル,その他所定のimage_dims等)からOpenCVのDNNモジュールを使って読み出す方法を教えてください。
MobileNetの場合なら cv2.dnn.readNetFromCaffe(args["prototxt"],arg["model"])
のようにprototxtとcaffemodelの2つから参照する様ですがSqeezeNetの場合が見つかりません。
https://www.ebenezertechs.com/mobilenet-ssd-using-opencv-3-4-1-deep-learning-module-python/
はMobileNetのものですが、OpenCV 3.4.1でSqeezeNetに対応していると書いてあります。
よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

marusa

2020/10/06 01:52 編集

ネットワークを読み出したいだけであれば、参照されているコードで SqueezeNetやMobileNetは関係なく動作するかと思います。 見ておられる場所はネットワークの定義となるprototxtファイルとその学習したモデルcaffemodelを読み出しており、SqueezeNetとMobileNetではその中身が異なるだけなので。 //追記 meanやlabelも登場しているので真にやりたいことは恐らく別なのかなと想像しているのですがいかがでしょうか。
deka-cho

2020/10/06 05:33

あがとうございます。このご指摘だけでも勉強になります。最終的にやりたいことは https://www.pyimagesearch.com/2018/08/13/opencv-people-counter/ でMobileNetのperson検知が私の持っている画像では今一つなので、SqeezeNetで転移学習済みのデータで置き換えたいというものです。上記コードの38行目net=cv2.dnn.readNetFromCaffe(args["prototxt"],args["model"])のnet に転移学習済みのデータを渡せば119行~121行の blob=cv2.dnn.blobFromImage(frame,0.007843,(W,H),127.5) net.setInput(blob) detection=net.foward() が動作してobject_detectとトラッキングするのではと思うのですが・・・ 追記のご指摘のように上記コードになぜmeanを使ってないのかがわかっておりません。ご指導よろしくお願いいたします。
marusa

2020/10/06 10:16

ごめんなさい。分かる範囲の内容でコメントしただけで最終的にやりたいことに対する答えは持ち合わせておりません。 やりたいことが分かるように質問の編集を行うとまた別の回答が付くかもしれません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問