conv_conv_fuse_pass.cc 2.4 KB
Newer Older
H
HappyAngel 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
// 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.

#include "lite/core/mir/fusion/conv_conv_fuse_pass.h"
#include <memory>
#include <vector>
#include "lite/core/mir/fusion/conv_conv_fuser.h"
#include "lite/core/mir/graph_visualize_pass.h"
#include "lite/core/mir/pass_registry.h"

namespace paddle {
namespace lite {
namespace mir {

void ConvConvFusePass::Apply(const std::unique_ptr<SSAGraph>& graph) {
  // initialze fuser params
  std::vector<bool> conv_has_bias_cases{true, false};
  std::vector<std::string> conv_type_cases{"conv2d", "depthwise_conv2d"};
H
HappyAngel 已提交
30 31
  bool has_fp32 = false;
  bool has_int8 = false;
H
HappyAngel 已提交
32
  for (auto& place : graph->valid_places()) {
33
    if (place.target == TARGET(kARM) || place.target == TARGET(kHost)) {
H
HappyAngel 已提交
34 35 36 37 38 39 40
      if (place.precision == PRECISION(kFloat)) {
        has_fp32 = true;
      }
      if (place.precision == PRECISION(kInt8)) {
        has_int8 = true;
      }
    } else {
41
      VLOG(5) << "place.target: " << static_cast<int>(place.target);
H
HappyAngel 已提交
42
      return;
H
HappyAngel 已提交
43 44
    }
  }
H
HappyAngel 已提交
45 46
  // only support arm-fp32
  if (has_int8 || (has_fp32 && has_int8)) {
H
HappyAngel 已提交
47 48 49 50 51 52
    return;
  }
  // only support fp32 fusion
  for (auto conv_has_bias0 : conv_has_bias_cases) {
    for (auto conv_has_bias1 : conv_has_bias_cases) {
      for (auto conv_type0 : conv_type_cases) {
H
HappyAngel 已提交
53
        for (auto conv_type1 : {"conv2d"}) {  // it mustbe 1x1s1p0_conv
54
          VLOG(5) << "conv_has_bias0:" << conv_has_bias0
H
HappyAngel 已提交
55
                  << " conv_type0:" << conv_type0;
56
          VLOG(5) << "conv_has_bias1:" << conv_has_bias1
H
HappyAngel 已提交
57 58
                  << " conv_type1:" << conv_type1;
          fusion::ConvConvFuser fuser(
59
              conv_type0, conv_type1, conv_has_bias0, conv_has_bias1, graph);
H
HappyAngel 已提交
60 61 62 63 64 65 66 67 68 69 70 71 72
          fuser(graph.get());
        }
      }
    }
  }
}

}  // namespace mir
}  // namespace lite
}  // namespace paddle

REGISTER_MIR_PASS(lite_conv_conv_fuse_pass, paddle::lite::mir::ConvConvFusePass)
    .BindTargets({TARGET(kARM)});