forked from foamliu/Deep-Image-Matting
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtrain_refinement.py
51 lines (41 loc) · 2.16 KB
/
train_refinement.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
import keras
from keras.callbacks import ModelCheckpoint, EarlyStopping, ReduceLROnPlateau
from keras.optimizers import SGD
from config import patience, batch_size, epochs, num_train_samples, num_valid_samples
from data_generator import train_gen, valid_gen
from model import build_encoder_decoder, build_refinement
from utils import custom_loss_wrapper, get_available_cpus
if __name__ == '__main__':
checkpoint_models_path = 'models/'
# Callbacks
tensor_board = keras.callbacks.TensorBoard(log_dir='./logs', histogram_freq=0, write_graph=True, write_images=True)
model_names = checkpoint_models_path + 'refinement.{epoch:02d}-{val_loss:.4f}.hdf5'
model_checkpoint = ModelCheckpoint(model_names, monitor='val_loss', verbose=1, save_best_only=True)
early_stop = EarlyStopping('val_loss', patience=patience)
reduce_lr = ReduceLROnPlateau('val_loss', factor=0.1, patience=int(patience / 4), verbose=1)
pretrained_path = 'models/model.98-0.0459.hdf5'
encoder_decoder = build_encoder_decoder()
encoder_decoder.load_weights(pretrained_path)
# fix encoder-decoder part parameters and then update the refinement part.
for layer in encoder_decoder.layers:
layer.trainable = False
refinement = build_refinement(encoder_decoder)
# sgd = SGD(lr=1e-3, decay=1e-6, momentum=0.9, nesterov=True)
refinement.compile(optimizer='nadam', loss=custom_loss_wrapper(refinement.input))
print(refinement.summary())
# Summarize then go!
num_cpu = get_available_cpus()
workers = int(round(num_cpu / 2))
# Final callbacks
callbacks = [tensor_board, model_checkpoint, early_stop, reduce_lr]
# Start Fine-tuning
refinement.fit_generator(train_gen(),
steps_per_epoch=num_train_samples // batch_size,
validation_data=valid_gen(),
validation_steps=num_valid_samples // batch_size,
epochs=epochs,
verbose=1,
callbacks=callbacks,
use_multiprocessing=True,
workers=workers
)