argument.h 3.6 KB
Newer Older
Y
Yan Chunwei 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
// Copyright (c) 2018 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.

/*
 * This file defines the class Argument, which is the input and output of the
 * analysis module. All the fields that needed either by Passes or PassManagers
 * are contained in Argument.
 *
 * TODO(Superjomn) Find some way better to contain the fields when it grow too
 * big.
 */

G
gongweibao 已提交
24 25
#pragma once

G
gongweibao 已提交
26
#include <string>
Y
Yan Chunwei 已提交
27 28
#include "paddle/fluid/framework/program_desc.h"
#include "paddle/fluid/inference/analysis/data_flow_graph.h"
29
#include "paddle/fluid/platform/variant.h"
Y
Yan Chunwei 已提交
30 31 32 33 34 35 36 37 38 39 40

namespace paddle {
namespace inference {
namespace analysis {

/*
 * The argument definition of both Pass and PassManagers.
 *
 * All the fields should be registered here for clearness.
 */
struct Argument {
Y
Yan Chunwei 已提交
41 42 43 44 45 46 47 48 49 50
  Argument() = default;
  explicit Argument(const std::string& fluid_model_dir)
      : fluid_model_dir(new std::string(fluid_model_dir)) {}
  // The directory of the trained model.
  std::unique_ptr<std::string> fluid_model_dir;
  // The path of `__model__` and `param`, this is used when the file name of
  // model and param is changed.
  std::unique_ptr<std::string> fluid_model_program_path;
  std::unique_ptr<std::string> fluid_model_param_path;

Y
Yan Chunwei 已提交
51 52 53 54 55
  // The graph that process by the Passes or PassManagers.
  std::unique_ptr<DataFlowGraph> main_dfg;

  // The original program desc.
  std::unique_ptr<framework::proto::ProgramDesc> origin_program_desc;
56 57 58

  // The processed program desc.
  std::unique_ptr<framework::proto::ProgramDesc> transformed_program_desc;
Y
Yan Chunwei 已提交
59 60 61

  // The output storage path of ModelStorePass.
  std::unique_ptr<std::string> model_output_store_path;
62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101

  // Support for any other attributes.
  template <typename T>
  void Set(const std::string& key, T* data) {
    PADDLE_ENFORCE_NOT_NULL(data);
    PADDLE_ENFORCE(!attrs_.count(key), "duplicate attr called %s", key);
    attrs_[key] = data;
    attr_deleters_[key] = [data, key, this]() {
      VLOG(3) << "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx";
      VLOG(3) << "argument delete attr: " << key;
      delete data;
    };
  }

  bool Has(const std::string& name) const { return attrs_.count(name); }

  template <typename T>
  T* Release(const std::string& key) {
    PADDLE_ENFORCE(attrs_.count(key));
    auto* res = boost::any_cast<T*>(attrs_.at(key));
    attrs_.erase(key);
    attr_deleters_.erase(key);
    return res;
  }

  template <typename T>
  T& Get(const std::string& key) {
    PADDLE_ENFORCE(Has(key));
    return *boost::any_cast<T*>(attrs_.at(key));
  }

  ~Argument() {
    for (auto& item : attr_deleters_) {
      item.second();
    }
  }

 private:
  std::unordered_map<std::string, boost::any> attrs_;
  std::unordered_map<std::string, std::function<void()>> attr_deleters_;
Y
Yan Chunwei 已提交
102 103 104 105
};

#define UNLIKELY(condition) __builtin_expect(static_cast<bool>(condition), 0)
#define ANALYSIS_ARGUMENT_CHECK_FIELD(field__)               \
G
gongweibao 已提交
106
  if (UNLIKELY(!(field__))) {                                \
Y
Yan Chunwei 已提交
107 108 109 110 111 112 113
    LOG(ERROR) << "field " << #field__ << " should be set."; \
    return false;                                            \
  }

}  // namespace analysis
}  // namespace inference
}  // namespace paddle