aboutsummaryrefslogtreecommitdiff
path: root/lib/PenroseOscil.c
blob: 78cd7b68428b290cee4d6db4f2c2a601047e39e5 (plain)
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
#include <math.h>
#include "PenroseOscil.h"


float frequencyToIncrement( float samplingRate, float frequency, int bufferLength ) {

  return (frequency / samplingRate) * (float) bufferLength;
} 

void makeSineBuffer( float *buffer, int bufferLength ) {
  
  int   i;

  float myTwoPi = 8. * atan(1.);

  for ( i=0; i <= bufferLength; i++ )
    *(buffer+i) = sin( myTwoPi * ((float) i / (float) bufferLength) );

  return;
}


float bufferOscil( float *phase, float increment, float *buffer,
                   int bufferLength )
{

  float sample;

  while ( *phase > bufferLength )
    *phase -= bufferLength;

  while ( *phase < 0. )
    *phase += bufferLength;

  sample = *( buffer + (int) (*phase) );

  *phase += increment;

  return sample;
}