【发布时间】:2019-11-20 06:32:58
【问题描述】:
我根据Analytics Vidhya 上的教程改编了一个简单的 CNN。
问题是我在保持集上的准确性并不比随机好。我正在对大约 8600 张猫和狗的图像进行训练,这对于体面的模型来说应该是足够的数据,但测试集的准确率是 49%。我的代码中是否有明显的遗漏?
import os
import numpy as np
import keras
from keras.models import Sequential
from sklearn.model_selection import train_test_split
from datetime import datetime
from PIL import Image
from keras.utils.np_utils import to_categorical
from sklearn.utils import shuffle
def main():
cat=os.listdir("train/cats")
dog=os.listdir("train/dogs")
filepath="train/cats/"
filepath2="train/dogs/"
print("[INFO] Loading images of cats and dogs each...", datetime.now().time())
#print("[INFO] Loading {} images of cats and dogs each...".format(num_images), datetime.now().time())
images=[]
label = []
for i in cat:
image = Image.open(filepath+i)
image_resized = image.resize((300,300))
images.append(image_resized)
label.append(0) #for cat images
for i in dog:
image = Image.open(filepath2+i)
image_resized = image.resize((300,300))
images.append(image_resized)
label.append(1) #for dog images
images_full = np.array([np.array(x) for x in images])
label = np.array(label)
label = to_categorical(label)
images_full, label = shuffle(images_full, label)
print("[INFO] Splitting into train and test", datetime.now().time())
(trainX, testX, trainY, testY) = train_test_split(images_full, label, test_size=0.25)
filters = 10
filtersize = (5, 5)
epochs = 5
batchsize = 32
input_shape=(300,300,3)
#input_shape = (30, 30, 3)
print("[INFO] Designing model architecture...", datetime.now().time())
model = Sequential()
model.add(keras.layers.InputLayer(input_shape=input_shape))
model.add(keras.layers.convolutional.Conv2D(filters, filtersize, strides=(1, 1), padding='same',
data_format="channels_last", activation='relu'))
model.add(keras.layers.MaxPooling2D(pool_size=(2, 2)))
model.add(keras.layers.Flatten())
model.add(keras.layers.Dense(units=2, input_dim=50,activation='softmax'))
#model.add(keras.layers.Dense(units=2, input_dim=5, activation='softmax'))
model.compile(loss='categorical_crossentropy', optimizer='adam', metrics=['accuracy'])
print("[INFO] Fitting model...", datetime.now().time())
model.fit(trainX, trainY, epochs=epochs, batch_size=batchsize, validation_split=0.3)
model.summary()
print("[INFO] Evaluating on test set...", datetime.now().time())
eval_res = model.evaluate(testX, testY)
print(eval_res)
if __name__== "__main__":
main()
【问题讨论】:
-
是二分类还是多分类?
-
我确实看到您没有对数据进行洗牌。由于您首先为猫加载数据,然后为狗加载数据,因此很可能在训练期间,网络最初学习的是 Cats 的表示,然后是 Dogs 的表示。但是在学习 Dogs 的表示时,网络得到了优化,因此没有 Cats。
-
你是对的。我打乱了数据并重新运行。但准确度还是一样的。相应地更新了上面的原始代码
-
你只做了 5 个 epochs...如果这个数字是 500 会发生什么?通常,您会一直运行直到您的错误率达到可接受的水平或 epoch 数很大。你不能指望它只经过 5 次迭代就能学到任何东西。
-
epoch 数一定不是这里的问题。即 5 次通过约 16K 图像,每 32 图像调整权重。这对于网络来说应该是足够的数据了。
标签: python machine-learning keras conv-neural-network