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
use super::*;
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
}
}
}