sine.rs 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. use std::f32::consts::PI;
  2. use super::*;
  3. const TAU: f32 = 2f32 * PI;
  4. #[derive(Debug)]
  5. pub struct Sine {
  6. pub freq: GenBox,
  7. pub phase: f32,
  8. pub buf: SampleBuffer,
  9. }
  10. impl Generator for Sine {
  11. fn eval<'a>(&'a mut self, params: &Parameters) -> &'a SampleBuffer {
  12. self.buf.rate = Rate::Sample;
  13. let pvel = TAU * self.freq.eval(params).first() / params.env.sample_rate;
  14. for i in 0..self.buf.len() {
  15. self.buf[i] = (self.phase + pvel * (i as f32)).sin()
  16. }
  17. self.phase = (self.phase + pvel * (self.buf.len() as f32)) % TAU;
  18. &self.buf
  19. }
  20. fn buffer(&self) -> &SampleBuffer { &self.buf }
  21. fn set_buffer(&mut self, buf: SampleBuffer) -> SampleBuffer {
  22. mem::replace(&mut self.buf, buf)
  23. }
  24. }
  25. pub struct SineFactory;
  26. impl GeneratorFactory for SineFactory {
  27. fn new(&self, params: &mut FactoryParameters) -> Result<GenBox, GenFactoryError> {
  28. Ok(Box::new(Sine {
  29. freq: params.remove_param("freq", 0)?.into_gen()?,
  30. phase: params.get_param("phase", 1, &ParamValue::Float(0.0)).as_f32()?,
  31. buf: SampleBuffer::new(params.env.default_buffer_size),
  32. }))
  33. }
  34. }
  35. pub static Factory: SineFactory = SineFactory;