sine.rs 594 B

123456789101112131415161718192021222324
  1. use std::f32::consts::PI;
  2. use super::*;
  3. const TAU: f32 = 2f32 * PI;
  4. pub struct Sine {
  5. pub freq: GenBox,
  6. pub phase: f32,
  7. pub buf: SampleBuffer,
  8. }
  9. impl Generator for Sine {
  10. fn eval<'a>(&'a mut self, params: &Parameters) -> &'a SampleBuffer {
  11. self.buf.rate = Rate::Control;
  12. let pvel = TAU * self.freq.eval(params).first() / params.env.sample_rate;
  13. for i in 0..self.buf.len() {
  14. self.buf[i] = (self.phase + pvel * (i as f32)).sin()
  15. }
  16. self.phase = (self.phase + pvel * (self.buf.len() as f32)) % TAU;
  17. &self.buf
  18. }
  19. }