use crate as burn;
use crate::config::Config;
use crate::module::Module;
use crate::tensor::backend::Backend;
use crate::tensor::Tensor;
use burn_tensor::module::adaptive_avg_pool1d;
#[derive(Config)]
pub struct AdaptiveAvgPool1dConfig {
pub output_size: usize,
}
#[derive(Module, Clone, Debug)]
pub struct AdaptiveAvgPool1d {
output_size: usize,
}
impl AdaptiveAvgPool1dConfig {
pub fn init(&self) -> AdaptiveAvgPool1d {
AdaptiveAvgPool1d {
output_size: self.output_size,
}
}
}
impl AdaptiveAvgPool1d {
pub fn forward<B: Backend>(&self, input: Tensor<B, 3>) -> Tensor<B, 3> {
adaptive_avg_pool1d(input, self.output_size)
}
}