use burn_tensor::activation::hard_sigmoid;
use crate as burn;
use crate::config::Config;
use crate::module::Module;
use crate::module::{Content, DisplaySettings, ModuleDisplay};
use crate::tensor::backend::Backend;
use crate::tensor::Tensor;
#[derive(Module, Clone, Debug)]
#[module(custom_display)]
pub struct HardSigmoid {
pub alpha: f64,
pub beta: f64,
}
#[derive(Config, Debug)]
pub struct HardSigmoidConfig {
#[config(default = "0.2")]
pub alpha: f64,
#[config(default = "0.5")]
pub beta: f64,
}
impl HardSigmoidConfig {
pub fn init(&self) -> HardSigmoid {
HardSigmoid {
alpha: self.alpha,
beta: self.beta,
}
}
}
impl ModuleDisplay for HardSigmoid {
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("alpha", &self.alpha)
.add("beta", &self.beta)
.optional()
}
}
impl HardSigmoid {
pub fn forward<B: Backend, const D: usize>(&self, input: Tensor<B, D>) -> Tensor<B, D> {
hard_sigmoid(input, self.alpha, self.beta)
}
}
#[cfg(test)]
mod tests {
use super::*;
use crate::tensor::TensorData;
use crate::TestBackend;
#[test]
fn test_hard_sigmoid_forward() {
let device = <TestBackend as Backend>::Device::default();
let model: HardSigmoid = HardSigmoidConfig::new().init();
let input =
Tensor::<TestBackend, 2>::from_data(TensorData::from([[0.4410, -0.2507]]), &device);
let out = model.forward(input);
let expected = TensorData::from([[0.5882, 0.44986]]);
out.to_data().assert_approx_eq(&expected, 4);
}
#[test]
fn display() {
let config = HardSigmoidConfig::new().init();
assert_eq!(
alloc::format!("{}", config),
"HardSigmoid {alpha: 0.2, beta: 0.5}"
);
}
}