From e32103645e22943914a99e303e63e0e84dabde57 Mon Sep 17 00:00:00 2001 From: yangyaming Date: Thu, 4 Jan 2018 14:31:19 +0800 Subject: [PATCH] Only shrink for the first level LoD. --- paddle/operators/shrink_rnn_memory_op.cc | 22 ++++++---------------- 1 file changed, 6 insertions(+), 16 deletions(-) diff --git a/paddle/operators/shrink_rnn_memory_op.cc b/paddle/operators/shrink_rnn_memory_op.cc index 29f88896e7..b958e6c595 100644 --- a/paddle/operators/shrink_rnn_memory_op.cc +++ b/paddle/operators/shrink_rnn_memory_op.cc @@ -48,26 +48,16 @@ class ShrinkRNNMemoryOp : public ArrayOp { PADDLE_ENFORCE(out_var != nullptr, "Output Out must be set"); auto &out_tensor = *out_var->GetMutable(); - // should consider multiple levels size_t height = dst_num_rows; - auto lod_level = rank_table.level(); - if (x_tensor.lod().size() > lod_level && - x_tensor.lod()[lod_level].size() > static_cast(dst_num_rows)) { - auto lod_offset = framework::GetSubLoDAndAbsoluteOffset( - x_tensor.lod(), 0, dst_num_rows, lod_level); + // do shrink for the top level LoD + if (x_tensor.lod().size() > 0 && + x_tensor.lod()[0].size() > static_cast(dst_num_rows)) { + auto lod_offset = framework::GetSubLoDAndAbsoluteOffset(x_tensor.lod(), 0, + dst_num_rows, 0); height = lod_offset.second.second; auto out_lod = out_tensor.mutable_lod(); - auto x_lod = x_tensor.lod(); - out_lod->reserve(lod_level + lod_offset.first.size()); - for (size_t i = 0; i < lod_level; ++i) { - out_lod->emplace_back(x_lod.at(i)); - } - framework::LoD remain; - framework::AppendLoD(&remain, lod_offset.first); - for (size_t j = 0; j < remain.size(); ++j) { - out_lod->emplace_back(remain[j]); - } + framework::AppendLoD(out_lod, lod_offset.first); } if (dst_num_rows != 0) { -- GitLab