13 #ifndef MLPACK_METHODS_ANN_LAYER_MAX_POOLING_HPP
14 #define MLPACK_METHODS_ANN_LAYER_MAX_POOLING_HPP
33 template<
typename MatType>
36 return arma::as_scalar(arma::find(input.max() == input, 1));
49 typename InputDataType = arma::mat,
50 typename OutputDataType = arma::mat
68 const size_t kernelHeight,
69 const size_t strideWidth = 1,
70 const size_t strideHeight = 1,
71 const bool floor =
true);
81 void Forward(
const arma::Mat<eT>& input, arma::Mat<eT>& output);
94 const arma::Mat<eT>& gy,
103 const OutputDataType&
Delta()
const {
return delta; }
105 OutputDataType&
Delta() {
return delta; }
154 bool Floor()
const {
return floor; }
166 template<
typename Archive>
177 template<
typename eT>
178 void PoolingOperation(
const arma::Mat<eT>& input,
179 arma::Mat<eT>& output,
180 arma::Mat<eT>& poolingIndices)
182 for (
size_t j = 0, colidx = 0; j < output.n_cols;
183 ++j, colidx += strideHeight)
185 for (
size_t i = 0, rowidx = 0; i < output.n_rows;
186 ++i, rowidx += strideWidth)
188 arma::mat subInput = input(
189 arma::span(rowidx, rowidx + kernelWidth - 1 - offset),
190 arma::span(colidx, colidx + kernelHeight - 1 - offset));
192 const size_t idx = pooling.
Pooling(subInput);
193 output(i, j) = subInput(idx);
197 arma::Mat<size_t> subIndices = indices(arma::span(rowidx,
198 rowidx + kernelWidth - 1 - offset),
199 arma::span(colidx, colidx + kernelHeight - 1 - offset));
201 poolingIndices(i, j) = subIndices(idx);
214 template<
typename eT>
215 void Unpooling(
const arma::Mat<eT>& error,
216 arma::Mat<eT>& output,
217 arma::Mat<eT>& poolingIndices)
219 for (
size_t i = 0; i < poolingIndices.n_elem; ++i)
221 output(poolingIndices(i)) += error(i);
271 arma::cube outputTemp;
274 arma::cube inputTemp;
280 MaxPoolingRule pooling;
283 OutputDataType delta;
286 OutputDataType gradient;
289 OutputDataType outputParameter;
292 arma::Mat<size_t> indices;
295 arma::Col<size_t> indicesCol;
298 std::vector<arma::cube> poolingIndices;
305 #include "max_pooling_impl.hpp"