Ikhwan Nuttaqwa
Ikhwan Nuttaqwa

Reputation: 51

The channel dimension of the inputs should be defined. Found `None`

I'm trying to make some LSTM+CNN hybrid for my college project and here's my code

def model_robo():
  grid=tf.keras.Input(shape=(1,10,12),dtype=tf.float32)
  print(grid.shape)
  cnn_result=tf.keras.layers.TimeDistributed(Conv2D(1,kernel_size=(3,3),data_format="channels_first"))(grid)
  cnn_result=tf.keras.layers.TimeDistributed(MaxPooling2D(2,2))(cnn_result)
  cnn_result=tf.keras.layers.TimeDistributed(flatten())(cnn_result)
  lstm_input=Concatenate()([price,cnn_result])
  masked_position=Masking(mask_value=-1)(lstm_input)
  result=LSTM(50, name='LSTM')(masked_position)
  prediction=(TimeDistributed(Dense(1,activation="relu")))(result)
  model=tf.keras.Model(inputs=[grid,price],outputs=[prediction])
  optim=tf.keras.optimizers.Adam(lr=0.001,amsgrad=False)
  model.compile(optimizer=optim,loss='mae')
  return model

but when I'm trying to call the model with

model=model_robo()

it gives:

ValueError: The channel dimension of the inputs should be defined. Found None

which stems from:

cnn_result=tf.keras.layers.TimeDistributed(Conv2D(1,kernel_size=(3,3),data_format="channels_first"))(grid)

I've tried searching for answer but I think most error comes from the images format like here or here while I don't really use one (the CNN input is numerical matrix put together to form an "image"). the would-be input is 2159x1x10x12 matrix and the grid.shape result is (none,1,10,12)

how can i fix this? let me know if you need additional information and thanks!

Upvotes: 1

Views: 872

Answers (1)

Ikhwan Nuttaqwa
Ikhwan Nuttaqwa

Reputation: 51

It works after I delete the channels_first (and changed it to Conv1D but that's another matters. see here for detail)

My hypothesis is channels_first took the first dimension (None) as the channel instead of the second one. API docs said first channel should be reserved for batch size but like the comment said, it's probably a bug

Upvotes: 1

Related Questions