// Copyright (c) 2022 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 #include "paddle/fluid/operators/math/im2col.h" #include "paddle/phi/core/dense_tensor.h" #include "paddle/phi/kernels/funcs/math_function.h" #include "paddle/phi/kernels/funcs/unfold_functor.h" namespace phi { template void UnfoldKernel(const Context& ctx, const DenseTensor& x, const std::vector& kernel_sizes, const std::vector& strides, const std::vector& paddings, const std::vector& dilations, DenseTensor* out) { const int batch_size = static_cast(x.dims()[0]); ctx.template Alloc(out); paddle::operators::math:: Im2ColFunctor im2col; const auto& x_dims = x.dims(); int out_height = phi::funcs::CalcOutputSize(x_dims[2], kernel_sizes[0], dilations[0], paddings[0], paddings[2], strides[0]); int out_width = phi::funcs::CalcOutputSize(x_dims[3], kernel_sizes[1], dilations[1], paddings[1], paddings[3], strides[1]); DDim x_shape = make_ddim({x_dims[1], x_dims[2], x_dims[3]}); DDim out_matrix_shape = make_ddim( {x_dims[1], kernel_sizes[0], kernel_sizes[1], out_height, out_width}); for (int i = 0; i < batch_size; i++) { DenseTensor in_batch = x.Slice(i, i + 1).Resize(x_shape); DenseTensor out_batch = out->Slice(i, i + 1).Resize(out_matrix_shape); im2col(ctx, in_batch, dilations, strides, paddings, &out_batch); } } } // namespace phi