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

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

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

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

深層学習

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

機械学習

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

Python

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

Q&A

解決済

1回答

1632閲覧

二値分類の学習が進まない

co_shgci.k

総合スコア4

Keras

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

深層学習

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

機械学習

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

Python

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

0グッド

0クリップ

投稿2020/07/15 05:42

編集2020/07/15 05:48

前提・実現したいこと

pythonで画像を用いた二値分類の学習をさせようとしています。(画像は100枚ずつ)
そこで、下記のコードを用いて実行したところ、loss acc val_loss val_accがどうしても一定値になってしまい学習が進みません。
この原因としては何が考えられるか教えていただきたいです。

発生している問題・エラーメッセージ

192/192 [==============================] - 55s 286ms/step - loss: 6.1643 - acc: 0.4844 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 2/30
192/192 [==============================] - 49s 254ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 3/30
192/192 [==============================] - 48s 252ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 4/30
192/192 [==============================] - 50s 260ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 5/30
192/192 [==============================] - 85s 445ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 6/30
192/192 [==============================] - 106s 552ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 7/30
192/192 [==============================] - 78s 406ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 8/30
192/192 [==============================] - 85s 444ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 9/30
192/192 [==============================] - 79s 411ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 10/30
192/192 [==============================] - 98s 508ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 11/30
192/192 [==============================] - 80s 418ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 12/30
192/192 [==============================] - 51s 263ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 13/30
192/192 [==============================] - 55s 286ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 14/30
192/192 [==============================] - 72s 377ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792
Epoch 15/30
192/192 [==============================] - 67s 347ms/step - loss: 7.9751 - acc: 0.5052 - val_loss: 8.3948 - val_acc: 0.4792

エラーメッセージ

### 該当のソースコード

import numpy as np
import tensorflow as tf
import random as rn
import os
import keras
from keras import backend as K

from keras.preprocessing import image
from sklearn.model_selection import train_test_split

from keras.models import Sequential
from keras.layers import Dense, Dropout, Flatten
from keras.layers import Conv2D, MaxPooling2D

os.environ['PYTHONHASHSEED'] = '0'
np.random.seed(0)
rn.seed(0)
session_conf = tf.ConfigProto(intra_op_parallelism_threads=1, inter_op_parallelism_threads=1)
tf.set_random_seed(0)
sess = tf.Session(graph=tf.get_default_graph(), config=session_conf)
K.set_session(sess)

input_shape = (224, 224, 3)
batch_size = 32
epochs = 30
num_classes = 2
x = []
y = []
for f in os.listdir("sakura"):
x.append(image.img_to_array(image.load_img("sakura/"+f, target_size=input_shape[:2])))
y.append(0)
for f in os.listdir("cosmos"):
x.append(image.img_to_array(image.load_img("cosmos/"+f, target_size=input_shape[:2])))
y.append(1)
x = np.asarray(x)
x /= 255
y = np.asarray(y)
y = keras.utils.to_categorical(y, num_classes)
x_train, x_test, y_train, y_test = train_test_split(x, y, test_size=0.2, random_state= 3)

model = Sequential()
model.add(Conv2D(32, kernel_size=(3, 3),
activation='relu',
input_shape=input_shape))
model.add(Conv2D(64, (3, 3), activation='relu'))
model.add(MaxPooling2D(pool_size=(2, 2)))
model.add(Dropout(0.25))
model.add(Flatten())
model.add(Dense(128, activation='relu'))
model.add(Dropout(0.5))
model.add(Dense(num_classes, activation='softmax'))
model.compile(loss=keras.losses.categorical_crossentropy,
optimizer="SGD",
metrics=['acc'])
history = model.fit(x_train, y_train,
batch_size=batch_size,
epochs=epochs,
verbose=1,
validation_data=(x_test, y_test))

model.save_weights('param.hdf5')

acc = history.history["acc"]
val_acc = history.history["val_acc"]
loss = history.history["loss"]
val_loss = history.history["val_loss"]

epochs = range(1, len(acc) + 1)

試したこと

バッチサイズやエポックの数字を変えてみたりしました。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

原因は指摘できませんが、私ならとりあえず以下を試します。

  • 入力画像をImageDataGeneratorで数十倍程度に水増しする。
  • 入力サイズを64x64と小さいサイズにする。

投稿2020/07/15 07:42

can110

総合スコア38341

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問