1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
//! # Square
//! 
//! A square wave generator.

use super::*;

/// Struct for generating square wave samples at a specified frequency
pub struct Square {
    ind:SampleT,
    inv:MathT,
}

impl FreqMod for Square {
    fn new(f:MathT) -> Self {
        Square {
            ind: 0.0,
            inv: SAMPLE_RATE as MathT/(2.0 * f)
        }
    }

    fn set_frequency(&mut self, f: MathT) {
        self.inv = SAMPLE_RATE as MathT/(2.0 * f);
    }

    fn get_frequency(&self) -> MathT {
        SAMPLE_RATE as MathT/(2.0 * self.inv)
    }
}

impl Generator for Square {
    fn process(&mut self) -> SampleT {
        let y: SampleT = if self.ind >= self.inv as SampleT && self.ind < 2.0 * self.inv as SampleT {
            -1.0
        } else {
            1.0
        };

        if self.ind >= 2.0 * self.inv as SampleT {
            self.ind -= 2.0 * self.inv as SampleT;
        }

        self.ind += 1.0;

        y
    }
}

impl Clone for Square {
    fn clone(&self) -> Self {
        Square {
            ind: 0.0,
            inv: self.inv
        }
    }
}