PaddlePaddle在使用N-gram神经网络训练时出现ids[i]>row_number的错误

  • 关键字:词向量N-gram神经网络

  • 问题描述:在使用N-gram神经网络训练PTB数据集时,手动设置了字典大小,最后在启动训练的时候出现错误,错误提示ids[i]>row_number。

  • 报错信息:

<ipython-input-6-daf8837e1db3> in train(use_cuda, train_program, params_dirname)
     37         num_epochs=1,
     38         event_handler=event_handler,
---> 39         feed_order=['firstw', 'secondw', 'thirdw', 'fourthw', 'nextw'])

/usr/local/lib/python3.5/dist-packages/paddle/fluid/contrib/trainer.py in train(self, num_epochs, event_handler, reader, feed_order)
    403         else:
    404             self._train_by_executor(num_epochs, event_handler, reader,
--> 405                                     feed_order)
    406 
    407     def test(self, reader, feed_order):

/usr/local/lib/python3.5/dist-packages/paddle/fluid/contrib/trainer.py in _train_by_executor(self, num_epochs, event_handler, reader, feed_order)
    481             exe = executor.Executor(self.place)
    482             reader = feeder.decorate_reader(reader, multi_devices=False)
--> 483             self._train_by_any_executor(event_handler, exe, num_epochs, reader)
    484 
    485     def _train_by_any_executor(self, event_handler, exe, num_epochs, reader):

/usr/local/lib/python3.5/dist-packages/paddle/fluid/contrib/trainer.py in _train_by_any_executor(self, event_handler, exe, num_epochs, reader)
    510                                       fetch_list=[
    511                                           var.name
--> 512                                           for var in self.train_func_outputs
    513                                       ])
    514                 else:

/usr/local/lib/python3.5/dist-packages/paddle/fluid/executor.py in run(self, program, feed, fetch_list, feed_var_name, fetch_var_name, scope, return_numpy, use_program_cache)
    468 
    469         self._feed_data(program, feed, feed_var_name, scope)
--> 470         self.executor.run(program.desc, scope, 0, True, True)
    471         outs = self._fetch_data(fetch_list, fetch_var_name, scope)
    472         if return_numpy:

EnforceNotMet: Enforce failed. Expected ids[i] < row_number, but received ids[i]:2073 >= row_number:32.
 at [/paddle/paddle/fluid/operators/lookup_table_op.h:59]
PaddlePaddle Call Stacks: 
  • 问题复现:在是使用fluid.layers.embedding接口构造N-gram神经网络,其中设置size参数的值为[32, 32],在执行训练的时候就会报该错误。错误代码如下:
dict_size = 32
embed_first = fluid.layers.embedding(
    input=first_word,
    size=[dict_size, EMBED_SIZE],
    dtype='float32',
    is_sparse=is_sparse,
    param_attr='shared_w')
embed_second = fluid.layers.embedding(
    input=second_word,
    size=[dict_size, EMBED_SIZE],
    dtype='float32',
    is_sparse=is_sparse,
    param_attr='shared_w')
embed_third = fluid.layers.embedding(
    input=third_word,
    size=[dict_size, EMBED_SIZE],
    dtype='float32',
    is_sparse=is_sparse,
    param_attr='shared_w')
embed_fourth = fluid.layers.embedding(
    input=fourth_word,
    size=[dict_size, EMBED_SIZE],
    dtype='float32',
    is_sparse=is_sparse,
    param_attr='shared_w')
  • 解决问题:fluid.layers.embedding接口的size参数的值应该是[数据集的字典大小, 词向量大小]。所以第一个参数的值应该是字典的大小,所以要根据字典的实际大小来进行赋值。正确代码如下:
word_dict = paddle.dataset.imikolov.build_dict()
dict_size = len(word_dict)

embed_first = fluid.layers.embedding(
    input=first_word,
    size=[dict_size, EMBED_SIZE],
    dtype='float32',
    is_sparse=is_sparse,
    param_attr='shared_w')
embed_second = fluid.layers.embedding(
    input=second_word,
    size=[dict_size, EMBED_SIZE],
    dtype='float32',
    is_sparse=is_sparse,
    param_attr='shared_w')
embed_third = fluid.layers.embedding(
    input=third_word,
    size=[dict_size, EMBED_SIZE],
    dtype='float32',
    is_sparse=is_sparse,
    param_attr='shared_w')
embed_fourth = fluid.layers.embedding(
    input=fourth_word,
    size=[dict_size, EMBED_SIZE],
    dtype='float32',
    is_sparse=is_sparse,
    param_attr='shared_w')
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值