pass.h 3.6 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
/* 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. */

#pragma once

#include <glog/logging.h>
#include <iosfwd>
19
#include <string>
20 21

#include "paddle/fluid/framework/framework.pb.h"
Y
Yan Chunwei 已提交
22
#include "paddle/fluid/inference/analysis/argument.h"
23 24 25 26 27 28 29 30 31 32 33
#include "paddle/fluid/inference/analysis/data_flow_graph.h"
#include "paddle/fluid/inference/analysis/helper.h"
#include "paddle/fluid/inference/analysis/node.h"

namespace paddle {
namespace inference {
namespace analysis {

class Pass {
 public:
  Pass() = default;
Y
Yan Chunwei 已提交
34
  virtual ~Pass() = default;
35 36
  // Virtual method overridden by subclasses to do only necessary initialization
  // before any pass is run.
Y
Yan Chunwei 已提交
37
  // virtual bool Initialize() { return false; }
38 39 40
  // There is some passes such as FlowToDataFlowGraphPass that needs a
  // ProgramDesc. Here use the native ProgramDesc ProtoBuf message, so that it
  // only couple with the proto file.
Y
Yan Chunwei 已提交
41 42
  // virtual bool Initialize(const framework::proto::ProgramDesc &desc) { return
  // false; }
43 44
  // There are some Passes such as DataFlowGraphToFluidPass that will output a
  // ProgramDesc.
Y
Yan Chunwei 已提交
45 46 47 48 49 50 51
  // virtual bool Initialize(framework::proto::ProgramDesc *desc) { return
  // false; }

  // Mutable Pass.
  virtual bool Initialize(Argument *argument) { return false; }
  // Readonly Pass.
  virtual bool Initialize(const Argument &argument) { return false; }
52 53 54 55 56 57 58

  // Virtual method overriden by subclasses to do any necessary clean up after
  // all passes have run.
  virtual bool Finalize() { return false; }

  // Get a Pass appropriate to print the Node this pass operates on.
  virtual Pass *CreatePrinterPass(std::ostream &os,
Y
Yan Chunwei 已提交
59 60 61
                                  const std::string &banner) const {
    return nullptr;
  }
62

63 64 65
  // Create a debugger Pass that draw the DFG by graphviz toolkit.
  virtual Pass *CreateGraphvizDebugerPass() const { return nullptr; }

66 67 68 69 70 71 72 73
  // Run on a single Node.
  virtual void Run(Node *x) { LOG(FATAL) << "not valid"; }
  // Run on a single Function.
  virtual void Run(Function *x) { LOG(FATAL) << "not valid"; }
  // Run on a single FunctionBlock.
  virtual void Run(FunctionBlock *x) { LOG(FATAL) << "not valid"; }
  // Run on a single DataFlowGraph.
  virtual void Run(DataFlowGraph *x) { LOG(FATAL) << "not valid"; }
Y
Yan Chunwei 已提交
74 75 76 77 78

  // Human-readable short representation.
  virtual std::string repr() const = 0;
  // Human-readable long description.
  virtual std::string description() const = 0;
79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
};

// NodePass process on any Node types.
class NodePass : public Pass {
 public:
  virtual void Run(Node *node) = 0;
};

// NodePass process on any Function node types.
class FunctionPass : public Pass {
 public:
  virtual void Run(Function *node) = 0;
};

// NodePass process on any FunctionBlock node types.
class FunctionBlockPass : public Pass {
 public:
  virtual void Run(FunctionBlock *node) = 0;
};

// GraphPass processes on any GraphType.
class DataFlowGraphPass : public Pass {
 public:
  virtual void Run(DataFlowGraph *graph) = 0;
};

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