use super::delay_line::DelayLine;
#[derive(Debug)]
pub struct AllPass {
delay_line: DelayLine,
}
impl AllPass {
pub fn new(delay_length: usize) -> Self {
Self {
delay_line: DelayLine::new(delay_length),
}
}
pub fn tick(&mut self, input: f64) -> f64 {
let delayed = self.delay_line.read();
let output = -input + delayed;
let feedback = 0.5;
self.delay_line
.write_and_advance(input + delayed * feedback);
output
}
}
#[cfg(test)]
mod tests {
#[test]
fn basic_ticking() {
let mut allpass = super::AllPass::new(2);
assert_eq!(allpass.tick(1.0), -1.0);
assert_eq!(allpass.tick(0.0), 0.0);
assert_eq!(allpass.tick(0.0), 1.0);
assert_eq!(allpass.tick(0.0), 0.0);
assert_eq!(allpass.tick(0.0), 0.5);
assert_eq!(allpass.tick(0.0), 0.0);
assert_eq!(allpass.tick(0.0), 0.25);
}
}