-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathmodel.py
52 lines (38 loc) · 1.7 KB
/
model.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
52
# -*- coding: utf-8 -*-
"""
@author:sunwill
基于resnet的fcn模型
resnet采用在ImageNet的预训练模型,去掉最后一层,经过上采样,输出分割图
"""
from keras.models import Model
from keras.layers import (Input, Activation, Reshape, Conv2D, Lambda, Add)
import tensorflow as tf
from resnet50 import ResNet50
FCN_RESNET = 'fcn_resnet'
n_classes = 2
def make_fcn_resnet(input_shape, nb_labels, use_pretraining, freeze_base):
nb_rows, nb_cols, _ = input_shape
input_tensor = Input(shape=input_shape)
weights = 'imagenet' if use_pretraining else None
model = ResNet50(include_top=False, weights=weights, input_tensor=input_tensor)
if freeze_base:
for layer in model.layers:
layer.trainable = False
x32 = model.get_layer('act3d').output
x16 = model.get_layer('act4f').output
x8 = model.get_layer('act5c').output
c32 = Conv2D(nb_labels, (1, 1), name='conv_labels_32')(x32)
c16 = Conv2D(nb_labels, (1, 1), name='conv_labels_16')(x16)
c8 = Conv2D(nb_labels, (1, 1), name='conv_labels_8')(x8)
## 采用双线性插值法调整图像大小,http://www.cnblogs.com/zzw-in/p/Bilinear_interpolation.html
def resize_bilinear(images):
return tf.image.resize_bilinear(images, [nb_rows, nb_cols])
r32 = Lambda(resize_bilinear, name='resize_labels_32')(c32)
r16 = Lambda(resize_bilinear, name='resize_labels_16')(c16)
r8 = Lambda(resize_bilinear, name='resize_labels_8')(c8)
m = Add(name='merge_labels')([r32, r16, r8])
x = Reshape((nb_rows * nb_cols, nb_labels))(m)
x = Activation('softmax')(x)
x = Reshape((nb_rows, nb_cols, nb_labels))(x)
model = Model(inputs=input_tensor, outputs=x)
return model