如何在Keras中构建完全卷积神经网络?

时间:2016-06-17 18:29:12

标签: conv-neural-network keras

我正在与Keras合作,在尝试使用与VGG类似的架构实现FCNN时,我收到错误:

  

TypeError:img必须是4D张量

这是我的FCNN代码:

def buildmodel():
  model = Sequential()
  model.add(Convolution2D(4,3,3,border_mode='same',input_shape=(3,64,64)))
  model.add(LeakyReLU(alpha=0.3))
  model.add(MaxPooling2D((2,2),strides=(2,2),border_mode='valid', dim_ordering='th'))
  model.add(Convolution2D(8,3,3,border_mode='same'))
  model.add(LeakyReLU(alpha=0.3))
  model.add(MaxPooling2D((2,2),strides=(2,2),border_mode='valid', dim_ordering='th'))

  model.add(UpSampling2D((2,2)))
  model.add(Convolution2D(16,3,3,border_mode='same',input_shape=x[0].shape))
  model.add(LeakyReLU(alpha=0.3))
  model.add(MaxPooling2D((2,2),strides=(2,2),border_mode='valid', dim_ordering='th'))
  model.add(Convolution2D(32,3,3,border_mode='same'))
  model.add(LeakyReLU(alpha=0.3))
  model.add(MaxPooling2D((2,2),strides=(2,2),border_mode='valid', dim_ordering='th'))

  model.add(UpSampling2D((2,2)))
  model.add(Convolution2D(64,3,3,border_mode='same',input_shape=x[0].shape))
  model.add(LeakyReLU(alpha=0.3))
  model.add(Convolution2D(64,3,3,border_mode='same'))
  model.add(LeakyReLU(alpha=0.3))
  model.add(MaxPooling2D((2,2),strides=(2,2),border_mode='valid', dim_ordering='th'))

  model.add(UpSampling2D((2,2)))
  model.add(Convolution2D(128,3,3,border_mode='same',input_shape=x[0].shape))
  model.add(LeakyReLU(alpha=0.3))
  model.add(Convolution2D(128,3,3,border_mode='same'))
  model.add(LeakyReLU(alpha=0.3))
  model.add(MaxPooling2D((2,2),strides=(2,2),border_mode='valid', dim_ordering='th'))

  model.add(UpSampling2D((2,2)))
  model.add(Convolution2D(4,3,3,border_mode='same',input_shape=x[0].shape))
  model.add(LeakyReLU(alpha=0.3))
  model.add(Convolution2D(1,3,3,border_mode='same',activation='sigmoid'))

  return model

inputs = Input(shape=(len(x),3,64,64))
fcnn = buildmodel()
outputs = fcnn(inputs)
print(fcnn.inbound_nodes)
opt = RMSprop(lr=0.001, rho=0.9, epsilon=1e-6) 
model = Model(input=inputs, output=outputs)
model.compile(loss='hinge', optimizer=opt)
model.fit(x)

x具有形状(nsamples,3,64,64)。当在Keras中逐字使用VGG模型并使用完全连接的层时,似乎没有问题,因此我对新架构如何导致图像形状出现问题感到困惑。

0 个答案:

没有答案