pooling.h 6.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 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
// 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 <algorithm>
#include <string>
#include <vector>
#include "lite/utils/cp_logging.h"

namespace paddle {
namespace lite {
namespace arm {
namespace math {

// !pooling fp32 Op
void pooling_basic(const float* din,
                   float* dout,
                   int num,
                   int chout,
                   int hout,
                   int wout,
                   int chin,
                   int hin,
                   int win,
                   const std::vector<int>& ksize,
                   const std::vector<int>& strides,
                   const std::vector<int>& paddings,
                   bool global_pooling,
                   bool exclusive,
                   bool adaptive,
                   bool ceil_mode,
                   bool use_quantizer,
                   const std::string& pooling_type);

void pooling_global_max(const float* din,
                        float* dout,
                        int num,
                        int chout,
                        int hout,
                        int wout,
                        int chin,
                        int hin,
                        int win);

void pooling_global_avg(const float* din,
                        float* dout,
                        int num,
                        int chout,
                        int hout,
                        int wout,
                        int chin,
                        int hin,
                        int win);

67 68 69 70 71 72 73 74
void pooling1x1s2p0_max(const float* din,
                        float* dout,
                        int num,
                        int chout,
                        int hout,
                        int wout,
                        int chin,
                        int hin,
75 76 77
                        int win,
                        int pad_bottom,
                        int pad_right);
78

Y
Yan Chunwei 已提交
79 80 81 82 83 84 85 86
void pooling2x2s2_max(const float* din,
                      float* dout,
                      int num,
                      int chout,
                      int hout,
                      int wout,
                      int chin,
                      int hin,
87 88 89
                      int win,
                      int pad_bottom,
                      int pad_right);
Y
Yan Chunwei 已提交
90 91 92 93 94 95 96 97 98 99

void pooling2x2s2_avg(const float* din,
                      float* dout,
                      int num,
                      int chout,
                      int hout,
                      int wout,
                      int chin,
                      int hin,
                      int win,
100 101 102
                      bool exclusive,
                      int pad_bottom,
                      int pad_right);
Y
Yan Chunwei 已提交
103 104 105 106 107 108 109 110 111

void pooling3x3s1p1_max(const float* din,
                        float* dout,
                        int num,
                        int chout,
                        int hout,
                        int wout,
                        int chin,
                        int hin,
112 113 114
                        int win,
                        int pad_bottom,
                        int pad_right);
Y
Yan Chunwei 已提交
115 116 117 118 119 120 121 122 123 124

void pooling3x3s1p1_avg(const float* din,
                        float* dout,
                        int num,
                        int chout,
                        int hout,
                        int wout,
                        int chin,
                        int hin,
                        int win,
125 126 127
                        bool exclusive,
                        int pad_bottom,
                        int pad_right);
Y
Yan Chunwei 已提交
128 129 130 131 132 133 134 135 136

void pooling3x3s2p1_max(const float* din,
                        float* dout,
                        int num,
                        int chout,
                        int hout,
                        int wout,
                        int chin,
                        int hin,
137 138 139
                        int win,
                        int pad_bottom,
                        int pad_right);
Y
Yan Chunwei 已提交
140

141 142 143 144 145 146 147 148
void pooling3x3s1p0_max(const float* din,
                        float* dout,
                        int num,
                        int chout,
                        int hout,
                        int wout,
                        int chin,
                        int hin,
149 150 151
                        int win,
                        int pad_bottom,
                        int pad_right);
152 153 154 155 156 157 158 159 160 161

void pooling3x3s1p0_avg(const float* din,
                        float* dout,
                        int num,
                        int chout,
                        int hout,
                        int wout,
                        int chin,
                        int hin,
                        int win,
162 163 164
                        bool exclusive,
                        int pad_bottom,
                        int pad_right);
165

Y
Yan Chunwei 已提交
166 167 168 169 170 171 172 173 174
void pooling3x3s2p1_avg(const float* din,
                        float* dout,
                        int num,
                        int chout,
                        int hout,
                        int wout,
                        int chin,
                        int hin,
                        int win,
175 176 177
                        bool exclusive,
                        int pad_bottom,
                        int pad_right);
Y
Yan Chunwei 已提交
178 179 180 181 182 183 184 185 186

void pooling3x3s2p0_max(const float* din,
                        float* dout,
                        int num,
                        int chout,
                        int hout,
                        int wout,
                        int chin,
                        int hin,
187 188 189
                        int win,
                        int pad_bottom,
                        int pad_right);
Y
Yan Chunwei 已提交
190 191 192 193 194 195 196 197 198 199

void pooling3x3s2p0_avg(const float* din,
                        float* dout,
                        int num,
                        int chout,
                        int hout,
                        int wout,
                        int chin,
                        int hin,
                        int win,
200 201 202
                        bool exclusive,
                        int pad_bottom,
                        int pad_right);
Y
Yan Chunwei 已提交
203 204 205 206 207

}  // namespace math
}  // namespace arm
}  // namespace lite
}  // namespace paddle