Тренировка неисправностей VGG16 на наборе данных CIFAR100 [Keras] - PullRequest
0 голосов
/ 11 ноября 2019

Я пытаюсь обучить VGGNET-16 из Keras библиотеки на CIFAR-100 наборе данных, но точность проверки и потери не улучшаются, я думаю, что я делаю некоторую ошибку при предварительной обработке данных.

Я пробовал набор данных CIFAR-100 из библиотеки Keras, но все еще сталкивался с той же проблемой.

Код

from tensorflow.keras.applications.vgg16 import VGG16
from tensorflow.keras import optimizers
from keras.utils import to_categorical

import numpy as np
import cv2 as cv
import glob
import os


train_path = r'/content/cifar-100/train'
test_path  = r'/content/cifar-100/test'

classes = ['class1', 'class2', ...,  'class100']


def load_train():

    images    = []
    labels    = []

    for fields in classes:

        index = classes.index(fields)
        path = os.path.join(train_path, fields, '*g')
        files = glob.glob(path)

        for fl in files:

          # Image
          image = cv.imread(fl)
          images.append(image)

          # Label
          label = np.zeros(len(classes))
          label[index] = 1.0
          labels.append(label)

    images = np.array(images)
    labels = np.array(labels)

    return images, labels

X_train, y_train = load_train()

model = VGG16(weights=None, classes=len(classes), input_shape=(32, 32, 3))

model.compile(loss='categorical_crossentropy', optimizer='sgd', metrics=['accuracy'])

history = model.fit(x=X_train, y=y_train, batch_size=256, epochs=40, verbose=1, validation_split=0.1, shuffle=True)

Вывод

Epoch 1/40
45000/45000 [==============================] - 16s 357us/sample - loss: 4.5153 - acc: 0.0157 - val_loss: 7.7937 - val_acc: 0.0000e+00
...
Epoch 10/40
45000/45000 [==============================] - 11s 248us/sample - loss: 3.2936 - acc: 0.1981 - val_loss: 10.8545 - val_acc: 0.0000e+00
...
Epoch 20/40
45000/45000 [==============================] - 11s 248us/sample - loss: 2.3035 - acc: 0.3951 - val_loss: 13.5597 - val_acc: 0.0000e+00
...
Epoch 30/40
45000/45000 [==============================] - 11s 248us/sample - loss: 0.7384 - acc: 0.7818 - val_loss: 21.9027 - val_acc: 0.0000e+00
...
Epoch 40/40
45000/45000 [==============================] - 11s 248us/sample - loss: 0.1570 - acc: 0.9527 - val_loss: 30.7987 - val_acc: 0.0000e+00

Каталог данных

enter image description here

Может кто-нибудь взглянуть на код.

1 Ответ

2 голосов
/ 11 ноября 2019

Вы можете попробовать несколько вещей, если ваши метки и изображения верны.

1) Вы можете попытаться нормализовать изображение перед тем, как задать модель t.

    image = image / 255.

или вы также можете использовать нормализацию min-max

min_val = np.min(image)
max_val = np.max(image)
image = (image-min_val) / (max_val-min_val)

2)Вы можете использовать предварительно обученные веса из imagenet следующим образом:

model = VGG16(weights="imagenet", classes=len(classes), input_shape=(32, 32, 3))

3) Вы можете использовать собственный оптимизатор и настроить скорость обучения.

optimizer = keras.optimizers.adam(lr=2e-5)

4) По предложению ДаниэляМожно добавить выпадающие и пакетные нормализационные слои, чтобы уменьшить перегонку.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...