use crate as burn;
use crate::config::Config;
use crate::module::{Content, DisplaySettings, ModuleDisplay};
use crate::module::{Ignored, Module};
use crate::nn::PaddingConfig1d;
use crate::tensor::backend::Backend;
use crate::tensor::Tensor;
use crate::tensor::module::max_pool1d;
#[derive(Config, Debug)]
pub struct MaxPool1dConfig {
pub kernel_size: usize,
#[config(default = "1")]
pub stride: usize,
#[config(default = "PaddingConfig1d::Valid")]
pub padding: PaddingConfig1d,
#[config(default = "1")]
pub dilation: usize,
}
#[derive(Module, Clone, Debug)]
#[module(custom_display)]
pub struct MaxPool1d {
pub stride: usize,
pub kernel_size: usize,
pub padding: Ignored<PaddingConfig1d>,
pub dilation: usize,
}
impl ModuleDisplay for MaxPool1d {
fn custom_settings(&self) -> Option<DisplaySettings> {
DisplaySettings::new()
.with_new_line_after_attribute(false)
.optional()
}
fn custom_content(&self, content: Content) -> Option<Content> {
content
.add("kernel_size", &self.kernel_size)
.add("stride", &self.stride)
.add("padding", &self.padding)
.add("dilation", &self.dilation)
.optional()
}
}
impl MaxPool1dConfig {
pub fn init(&self) -> MaxPool1d {
MaxPool1d {
stride: self.stride,
kernel_size: self.kernel_size,
padding: Ignored(self.padding.clone()),
dilation: self.dilation,
}
}
}
impl MaxPool1d {
pub fn forward<B: Backend>(&self, input: Tensor<B, 3>) -> Tensor<B, 3> {
let [_batch_size, _channels, length] = input.dims();
let padding = self
.padding
.calculate_padding_1d(length, self.kernel_size, self.stride);
max_pool1d(input, self.kernel_size, self.stride, padding, self.dilation)
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn display() {
let config = MaxPool1dConfig::new(3);
let layer = config.init();
assert_eq!(
alloc::format!("{}", layer),
"MaxPool1d {kernel_size: 3, stride: 1, padding: Valid, dilation: 1}"
);
}
}