【问题标题】:Resume training convolutional neural network继续训练卷积神经网络
【发布时间】:2019-01-14 05:41:52
【问题描述】:

我有一个已经训练了 75 个 epoch 的模型。我用model.save() 保存了模型。训练代码是

from keras.preprocessing.image import ImageDataGenerator
from keras.models import Sequential, load_model
from keras.layers import Conv2D, MaxPooling2D
from keras.layers import Activation, Dropout, Flatten, Dense
from keras import backend as K

# dimensions of our images.
img_width, img_height = 320, 240

train_data_dir = 'dataset/Training_set'
validation_data_dir = 'dataset/Test_set'
nb_train_samples = 4000  #total
nb_validation_samples = 1000  # total
epochs = 25
batch_size = 10

if K.image_data_format() == 'channels_first':
    input_shape = (3, img_width, img_height)
else:
    input_shape = (img_width, img_height, 3)

model = Sequential()
model.add(Conv2D(32, (3, 3), input_shape=input_shape))
model.add(Activation('relu'))
model.add(MaxPooling2D(pool_size=(2, 2)))

model.add(Conv2D(32, (3, 3)))
model.add(Activation('relu'))
model.add(MaxPooling2D(pool_size=(2, 2)))

model.add(Conv2D(64, (3, 3)))
model.add(Activation('relu'))
model.add(MaxPooling2D(pool_size=(2, 2)))

model.add(Flatten())
model.add(Dense(64))
model.add(Activation('relu'))
model.add(Dropout(0.5))
model.add(Dense(1))
model.add(Activation('sigmoid'))

model.compile(loss='binary_crossentropy',
              optimizer='rmsprop',
              metrics=['accuracy'])

# this is the augmentation configuration we will use for training
train_datagen = ImageDataGenerator(
    rescale=1. / 255,
    shear_range=0.2,
    zoom_range=0.2,
    horizontal_flip=True)

# this is the augmentation configuration we will use for testing:
# only rescaling
test_datagen = ImageDataGenerator(rescale=1. / 255)

train_generator = train_datagen.flow_from_directory(
    train_data_dir,
    target_size=(img_width, img_height),
    batch_size=batch_size,
    class_mode='binary')

validation_generator = test_datagen.flow_from_directory(
    validation_data_dir,
    target_size=(img_width, img_height),
    batch_size=batch_size,
    class_mode='binary')

model.fit_generator(
    train_generator,
    steps_per_epoch=nb_train_samples // batch_size,
    epochs=epochs,
    validation_data=validation_generator,
    validation_steps=5)

model.save('model1.h5')

如何重新开始训练?我只是再次运行此代码吗?或者我需要做出改变吗?这些改变是什么?

我阅读了那篇文章并试图理解一些内容。我在这里读到这个:Loading a trained Keras model and continue training

【问题讨论】:

  • iirc 你应该可以只加载模型,然后再做一个 model.fit() 你试过了吗?
  • LIKE THIS: model.save('model1.h5') new_model = load_model("model1.h5") new_model.fit_generator( train_generator, steps_per_epoch=nb_train_samples // batch_size, epochs=25, validation_data= validation_generator, validation_steps=5) 只需将此代码添加到代码中并再次运行???

标签: tensorflow machine-learning keras python-3.6 conv-neural-network


【解决方案1】:

您可以简单地使用

加载您的模型
from keras.models import load_model
model = load_model('model1.h5')

【讨论】:

  • 是的,我正在这样做。加载模型后,我创建了新变量 new _model 并且 new_model = load_model("model1.h5") new_model.fit_generator( train_generator, steps_per_epoch=nb_train_samples // batch_size, epochs=25, validation_data=validation_generator, validation_steps=5) 现在运行代码对吗?
  • 是的。为了安全起见,请在保存模型后(以及再次加载之前)删除模型,确保不要编译加载的模型,因为这会重置其权重。
  • 我收到 NameError: name 'load_model' is not defined
  • 好吧,它开始了......培训......现在我明白了,这是一个很好的学习
  • 为什么要删除模型?
猜你喜欢
  • 2018-05-01
  • 1970-01-01
  • 1970-01-01
  • 2016-07-21
  • 2020-09-10
  • 2016-08-17
  • 2017-08-31
  • 2016-07-01
  • 2016-07-24
相关资源
最近更新 更多