File: PenroseOscil.c

package info (click to toggle)
pd-lyonpotpourri 2.0%2Bgit20121009-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd, stretch
  • size: 2,920 kB
  • ctags: 1,880
  • sloc: ansic: 18,330; makefile: 364
file content (40 lines) | stat: -rw-r--r-- 751 bytes parent folder | download | duplicates (5)
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;
}