blob: 3915e5ae2b81c9d4e27e6bb760e5ff85b7c449b0 (
plain) (
blame)
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
#ifndef OSC_H
#define OSC_H
#include <math.h>
/**
* The main idea of the osc is the following:
* The root of the sound is a periodic wave function.
* This can be a stored period of a wave in a wavetable
* or a function like sin(). In order to play a sound with
* the wave an external float offset is kept that points to the
* next sample, a function is provided to advance this offset
* a calucalted step amount, depending on the desired frequency.
* Linear interpolation is used so that a float offset can work
* and provide autosmoothing.
*/
enum osc_type {
WAVE,
SAMPLE
};
typedef struct osc_t {
char name[16];
float * data;
long len;
long start;
long end;
enum osc_type type;
} osc_t;
/* Initializes the wavetables and functions for the oscilators */
void init_osc();
float osc_interpolate(float offset, float start, float end);
float osc_next_offset(osc_t * osc, float f, float offset);
int osc_next_index(osc_t * osc, float offset);
int osc_load_wav(osc_t * osc, const char * path);
/***************/
/* OSCILATORS */
/***************/
#define OSC_COMMON(osc) \
void \
set_##osc##_start(long start) \
{ OSC_##osc.start = start; } \
void \
set_##osc##_end(long end) \
{ OSC_##osc.end = end; }
#define OSC_COMMON_H(osc) \
void \
set_##osc##_start(long start); \
void \
set_##osc##_end(long end); \
float \
osc_##osc(float offset); \
float \
osc_##osc##_next(float f, float offset);
/*****************/
/* osc functions */
/*****************/
OSC_COMMON_H(tri)
OSC_COMMON_H(sin)
OSC_COMMON_H(weird)
OSC_COMMON_H(sound)
#endif /* OSC_H */
|