From 65ae9d0f0131529176bf21bcb53da380bb2e0315 Mon Sep 17 00:00:00 2001 From: hjchen2 Date: Tue, 19 Mar 2019 12:57:58 +0800 Subject: [PATCH] Refine memory optimize pass for multiple blocks --- src/framework/tensor.h | 4 ---- src/pass/memory_optimize.cpp | 41 +++++++++++++++++++----------------- src/pass/memory_optimize.h | 2 +- 3 files changed, 23 insertions(+), 24 deletions(-) diff --git a/src/framework/tensor.h b/src/framework/tensor.h index 8b56dc77c9..8e30b4dc46 100644 --- a/src/framework/tensor.h +++ b/src/framework/tensor.h @@ -28,8 +28,6 @@ limitations under the License. */ #include "framework/tensor_base.h" #include "memory/t_malloc.h" -#include - namespace paddle_mobile { namespace framework { @@ -84,10 +82,8 @@ class Tensor : public TensorBase { int64_t size = numel() * SizeOfType(type); if (holder_ == nullptr || holder_->size() < size + offset_) { if (holder_ == nullptr) { - std::cout << "reset holder... size " << size << std::endl; holder_.reset(new PlaceholderImpl(size, type)); } else { - std::cout << "resize holder... size " << size << std::endl; holder_->resize(size); } offset_ = 0; diff --git a/src/pass/memory_optimize.cpp b/src/pass/memory_optimize.cpp index 68c7d442f8..dec9b7f3a2 100644 --- a/src/pass/memory_optimize.cpp +++ b/src/pass/memory_optimize.cpp @@ -18,8 +18,8 @@ limitations under the License. */ namespace paddle_mobile { namespace pass { -void MemoryOptPass::InitBlockVars(const framework::BlockDesc *block) { - block_vars_.clear(); +void MemoryOptPass::AppendBlockVars(const framework::BlockDesc *block) { + // block_vars_.clear(); for (const auto var : block->Vars()) { block_vars_[var->Name()] = var.get(); } @@ -51,8 +51,8 @@ void MemoryOptPass::operator()(const framework::ProgramDesc *program, framework::Scope *scope) { const auto &blocks = program->Blocks(); for (const auto &block : blocks) { - // access all variables in block, and stored in map - InitBlockVars(block.get()); + // access all variables in each block + AppendBlockVars(block.get()); reused_nodes_.clear(); // collect all not persistable variables, and accumulate @@ -91,6 +91,8 @@ void MemoryOptPass::operator()(const framework::ProgramDesc *program, } } + DLOG << "analysis_nodes_ size: " << analysis_nodes_.size(); + // apply optimize while (!analysis_nodes_.empty()) { auto *node = analysis_nodes_.top(); @@ -117,21 +119,22 @@ void MemoryOptPass::operator()(const framework::ProgramDesc *program, node->visited = true; node->count -= 1; } - } - // shared data within all variables in the same reused list - for (const auto &list : reused_nodes_) { - DLOG << "\n"; - DLOG << "share memory within these variables"; - std::string name = list[0]->name; - auto *reused_var = scope->Var(name); - auto *reuse_tensor = - reused_var->template GetMutable(); - reuse_tensor->mutable_data(); - for (const auto &node : list) { - DLOG << node->name; - auto *var = scope->Var(node->name); - auto *tensor = var->template GetMutable(); - tensor->ShareDataWith(*reuse_tensor); + + // shared data within all variables in the same reused list + for (const auto &list : reused_nodes_) { + DLOG << "\n"; + DLOG << "share memory within these variables"; + std::string name = list[0]->name; + auto *reused_var = scope->Var(name); + auto *reuse_tensor = + reused_var->template GetMutable(); + reuse_tensor->mutable_data(); + for (const auto &node : list) { + DLOG << node->name; + auto *var = scope->Var(node->name); + auto *tensor = var->template GetMutable(); + tensor->ShareDataWith(*reuse_tensor); + } } } } diff --git a/src/pass/memory_optimize.h b/src/pass/memory_optimize.h index 466af72e46..116100af0b 100644 --- a/src/pass/memory_optimize.h +++ b/src/pass/memory_optimize.h @@ -49,7 +49,7 @@ class MemoryOptPass : public PassBase { void operator()(const framework::ProgramDesc *program, framework::Scope *scope); - void InitBlockVars(const framework::BlockDesc *block); + void AppendBlockVars(const framework::BlockDesc *block); bool IsPersistable(const std::string name); -- GitLab