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

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

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

Kerasは、TheanoやTensorFlow/CNTK対応のラッパーライブラリです。DeepLearningの数学的部分を短いコードでネットワークとして表現することが可能。DeepLearningの最新手法を迅速に試すことができます。

深層学習

深層学習は、多数のレイヤのニューラルネットワークによる機械学習手法。人工知能研究の一つでディープラーニングとも呼ばれています。コンピューター自体がデータの潜在的な特徴を汲み取り、効率的で的確な判断を実現することができます。

CNN (Convolutional Neural Network)

CNN (Convolutional Neural Network)は、全結合層のみではなく畳み込み層とプーリング層で構成されるニューラルネットワークです。画像認識において優れた性能を持ち、畳み込みニューラルネットワークとも呼ばれています。

機械学習

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

Python

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

Q&A

解決済

2回答

2715閲覧

ディープラーニングのレイヤーの決め方の考え方

seyu0930

総合スコア20

Keras

Kerasは、TheanoやTensorFlow/CNTK対応のラッパーライブラリです。DeepLearningの数学的部分を短いコードでネットワークとして表現することが可能。DeepLearningの最新手法を迅速に試すことができます。

深層学習

深層学習は、多数のレイヤのニューラルネットワークによる機械学習手法。人工知能研究の一つでディープラーニングとも呼ばれています。コンピューター自体がデータの潜在的な特徴を汲み取り、効率的で的確な判断を実現することができます。

CNN (Convolutional Neural Network)

CNN (Convolutional Neural Network)は、全結合層のみではなく畳み込み層とプーリング層で構成されるニューラルネットワークです。画像認識において優れた性能を持ち、畳み込みニューラルネットワークとも呼ばれています。

機械学習

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

Python

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

0グッド

0クリップ

投稿2021/08/11 01:10

画像認識プログラミングレシピという本で画像認識について学習中です。(keras)

この本に「今回の中間層のニューロンの数は128としましたが自由に設定できます。この部分には基準があるわけではなく、階層の数。ニューロンの数などは学習時間、効率、学習効果に影響しますのでその中で適切な組み合わせを見つけ出しましょう」

とあります。


①中間層を作るのに慣れている方にとって、これらの値や層の組み方はどのように決めているのでしょうか。

今の私には128→256にしたところで違いがわかりません。


②作った層が最適だ、と思うにはどのような確認作業があるのでしょうか。

どこが見るべき場所があるのか、確認するための作業があるのか、それとも長年の経験なのか知りたいです。

データ量が多いから学習が遅いのか、それとも自分の組み方が悪いのか、わからない時があるので知りたいです。ご回答よろしくお願いします。

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

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

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

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

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

guest

回答2

0

以下に述べるのは基本的なことかも知れないので、既に存じ挙げていたら申し訳ございません.

中間層を作るのに慣れている方にとって、これらの値や層の組み方はどのように決めているのでしょうか.

モデルの最適な作り方は、アカデミックな分野に入ると思うので論文を読み込むことが必要になると思います.キーワードとしてはEfficientNetやNASなどと調べて頂けるとppaul様が欲しい情報が得られると思います.

基本的には代表的なモデルを使用することをお勧めします.from tensorflow.keras.applications import *で確認することが可能です.画像認識系ならResNetやEfficientNetが一般的です.最近ではViT, MLP-Mixer等もあります.このように、代表的なモデルを常にキャッチアップする必要があります.

作った層が最適だと思うにはどのような確認作業があるのでしょうか.

様々な確認方法があると思いますが、一般的には評価指標を設定するところから始まると思います.例えば、モデルの精度をAccuracyを用いて評価したい場合、計算時間と精度のバランスを取りたい場合など様々な評価方法があるので、その問題にあった方法で評価してみてください.因みにBestな構築方法は誰も分からないので、研究分野として成り立っていると考えて下さい.

先ほど挙げたモデル群はILSVRC(コンペティション形式の研究集会)でTop-1 AcuuracyとTop-5 Accuracyで評価されています.

投稿2021/08/16 09:06

HelloQ

総合スコア81

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

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

0

ベストアンサー

  • 今の私には128→256にしたところで違いがわかりません。

128→256ににすれば、確実に遅くなります。
良く似たものを見分けるにはノード数(ニューロン数)を増やしましょう。
似ていないものを見分けるならノード数(ニューロン数)は少なくても良いです。

  • ②作った層が最適だ、と思うにはどのような確認作業があるのでしょうか。

簡単な方法はありません。
動かしてみて、学習が遅くて耐えられないなら、層数やノード数(ニューロン数)を減らすしかありません。
学習が終わって認識の精度が悪ければ、層数やノード数(ニューロン数)を増やします。
両方を満足できる結果が得られないなら高性能のコンピュータに買い換えます。
それでも足りなければ、並列コンピュータを使うしかありませんが、プログラムの並列化は大変です。
普通はあきらめて、分類を減らすとかします。

簡単に言うと、理論とかはあまりなく、職人芸の世界です。

投稿2021/08/11 02:13

ppaul

総合スコア24666

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問