首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用fit_generator

如何使用fit_generator
EN

Stack Overflow用户
提问于 2018-09-07 06:44:12
回答 1查看 800关注 0票数 0

Iam类型实现了一个简单的RNN LSTM模型,但陷入了困境。问题本身很简单。我将给模型提供5个连续数字(但每次1位),然后我希望模型预测第6个数字。

示例:输入数据:1、2、3、4、5 (每个时间步骤1位数),该序列的输出应为6

我有一个csv文件,其中:

  • 第一行是标题。
  • 有6列
  • 第一列仅为ID。不用于训练。
  • 接下来的5列是输入数据(x)。
  • 最后一列是标签(y)

我想用Keras开发一个模型,成功地猜出第六个数字。

HEre是我所做的:

1)首先实现一些我们需要的常量。

代码语言:javascript
复制
NR_FEATURES = 5
ITERATOR_BATCH_SIZE = 1
NR_EPOCHS = 15

2)定义训练时使用的生成器。

代码语言:javascript
复制
def train_data_generator():

    dataset = tf.contrib.data.make_csv_dataset(train_path1, 
                                               batch_size=ITERATOR_BATCH_SIZE, 
                                               num_epochs=NR_EPOCHS, 
                                               shuffle=True)

    iter = dataset.make_one_shot_iterator()
    next = iter.get_next()
    ID = next['ID']
    features = [next['nr1'], next['nr2'], next['nr3'], next['nr4'], next['nr5']]
    features = tf.reshape(features, [NR_FEATURES, 1])
    label = next['next_nr']
    yield (features, label)

3)建立模型,开展培训。

代码语言:javascript
复制
input_data = Input(shape=(5, 1), name='input_data')
layer1_out = LSTM(1, return_sequences=False)(input_data)  # only return the last output
lstm_model = Model(inputs=input_data, outputs=layer1_out)

lstm_model.compile(loss='mean_absolute_error', optimizer='adam', metrics=['accuracy'])

lstm_model.fit_generator(train_data_generator(), 
                         steps_per_epoch=(150/ITERATOR_BATCH_SIZE),
                         epochs=NR_EPOCHS, 
                         verbose=1)

但它马上就坠毁了..。

我得到的错误消息:

代码语言:javascript
复制
Epoch 1/15

---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-5-af9dcbcbe289> in <module>()
      8                          steps_per_epoch=(150/ITERATOR_BATCH_SIZE),
      9                          epochs=NR_EPOCHS,
---> 10                          verbose=1)

~/anaconda3/envs/tensorflow/lib/python3.6/site-packages/keras/legacy/interfaces.py in wrapper(*args, **kwargs)
     89                 warnings.warn('Update your `' + object_name +
     90                               '` call to the Keras 2 API: ' + signature, stacklevel=2)
---> 91             return func(*args, **kwargs)
     92         wrapper._original_function = func
     93         return wrapper

~/anaconda3/envs/tensorflow/lib/python3.6/site-packages/keras/engine/training.py in fit_generator(self, generator, steps_per_epoch, epochs, verbose, callbacks, validation_data, validation_steps, class_weight, max_queue_size, workers, use_multiprocessing, shuffle, initial_epoch)
   2212                     # build batch logs
   2213                     batch_logs = {}
-> 2214                     if x is None or len(x) == 0:
   2215                         # Handle data tensors support when no input given
   2216                         # step-size = 1 for data tensors

TypeError: object of type 'Tensor' has no len()

我只是不明白。有人知道吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-09-08 11:50:44

您可以通过tensor直接将numpy转换为eval()

代码语言:javascript
复制
features = tf.reshape(features, [NR_FEATURES, 1])
# convert tensor to numpy
with tf.Session() as sess:
    features = features.eval()
# Your data shape needs to be adjusted relative to your model input.
features = features.reshape(-1,NR_FEATURES,1) 
label = next['next_nr']
label = np.array([label])
yield (features, label)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52216747

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档