use crate as burn;
use crate::config::Config;
use crate::module::Module;
use crate::nn::PaddingConfig2d;
use crate::tensor::backend::Backend;
use crate::tensor::Tensor;
use burn_tensor::module::max_pool2d;
#[derive(Debug, Config)]
pub struct MaxPool2dConfig {
pub kernel_size: [usize; 2],
#[config(default = "[1, 1]")]
pub strides: [usize; 2],
#[config(default = "PaddingConfig2d::Valid")]
pub padding: PaddingConfig2d,
#[config(default = "[1, 1]")]
pub dilation: [usize; 2],
}
#[derive(Module, Debug, Clone)]
pub struct MaxPool2d {
stride: [usize; 2],
kernel_size: [usize; 2],
padding: PaddingConfig2d,
dilation: [usize; 2],
}
impl MaxPool2dConfig {
pub fn init(&self) -> MaxPool2d {
MaxPool2d {
stride: self.strides,
kernel_size: self.kernel_size,
padding: self.padding.clone(),
dilation: self.dilation,
}
}
}
impl MaxPool2d {
pub fn forward<B: Backend>(&self, input: Tensor<B, 4>) -> Tensor<B, 4> {
let [_batch_size, _channels_in, height_in, width_in] = input.dims();
let padding =
self.padding
.calculate_padding_2d(height_in, width_in, &self.kernel_size, &self.stride);
max_pool2d(input, self.kernel_size, self.stride, padding, self.dilation)
}
}