executor_gc_helper.h 2.5 KB
Newer Older
S
sneaxiy 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
// Copyright (c) 2019 PaddlePaddle Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#pragma once

#include <memory>
#include <string>
#include <unordered_map>
#include <vector>
W
wanghuancoder 已提交
21

S
sneaxiy 已提交
22 23 24 25 26 27 28
#include "paddle/fluid/framework/garbage_collector.h"
#include "paddle/fluid/framework/operator.h"
#include "paddle/fluid/framework/scope.h"

namespace paddle {
namespace framework {

S
sneaxiy 已提交
29
// Result map: op -> variable names that can be deleted after op runs
W
wanghuancoder 已提交
30 31 32 33
class GarbageCollector;
class OperatorBase;
class Scope;

W
wanghuancoder 已提交
34 35
struct OpInOutInfo {
 public:
L
Leo Chen 已提交
36
  void Build(const OperatorBase *op);
W
wanghuancoder 已提交
37 38 39

  bool IsBuilt() const { return is_built_; }

L
Leo Chen 已提交
40
  bool IsInArgBufferNeeded(const std::string &in_arg_name) const;
W
wanghuancoder 已提交
41 42 43 44 45 46 47 48 49

 private:
  // A set to record unused buffer input vars of op
  std::unordered_set<std::string> no_need_buffer_ins_;
  // A set to record other args of op (including in, out)
  std::unordered_set<std::string> other_args_set_;
  bool is_built_{false};
};

50 51 52 53
std::unordered_map<const OperatorBase *, std::vector<std::string>>
GetUnusedVars(const BlockDesc &block,
              const std::vector<std::unique_ptr<OperatorBase>> &ops,
              const std::vector<std::string> &skip_vars);
S
sneaxiy 已提交
54

55 56 57 58 59
// Collect unused tensors
void DeleteUnusedTensors(const Scope &scope,
                         const std::vector<std::string> &delete_vars,
                         GarbageCollector *gc);

S
sneaxiy 已提交
60
// Collect unused tensors after op runs
S
sneaxiy 已提交
61
void DeleteUnusedTensors(
62 63
    const Scope &scope, const OperatorBase *op,
    const std::unordered_map<const OperatorBase *, std::vector<std::string>>
S
sneaxiy 已提交
64 65 66
        &delete_vars_map,
    GarbageCollector *gc);

67 68 69 70 71 72
// Get the clean vars of GC after each op runs. This function is used for
// analysis statically.
// result is in the format: result[block_idx][op_idx][delete_var_idx]
std::vector<std::vector<std::vector<std::string>>> GetEagerDeletionCleanVars(
    const ProgramDesc &program, const std::vector<std::string> &skip_vars = {});

S
sneaxiy 已提交
73 74
}  // namespace framework
}  // namespace paddle