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
/// Generate a triangle wave with a single up and down wave
pub fn generate_triangle_wave(length: usize) -> Vec<f64> {
    let mut out = Vec::with_capacity(length);

    let half_way = length / 2;
    let delta = 2.0 / length as f64;
    let mut val: f64 = 0.0;
    for i in 0..length {
        if i > half_way {
            val -= delta;
        } else {
            val += delta;
        }
        out.push(val);
    }

    out
}

#[cfg(test)]
mod tests {
    use super::*;
    use crate::plot_2d;

    #[test]
    fn triangle_wave_plot() {
        let trg = generate_triangle_wave(256);

        let filename = "img/triangle_wave.png";
        plot_2d(trg, filename).unwrap();
    }
}