-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathwaveform_internal.h
More file actions
69 lines (54 loc) · 2.27 KB
/
waveform_internal.h
File metadata and controls
69 lines (54 loc) · 2.27 KB
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
// Pithesiser - a software synthesiser for Raspberry Pi
// Copyright (C) 2015 Nicholas Tuckett
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
/*
* waveform_internal.h
*
* Created on: 2 Nov 2012
* Author: ntuckett
*/
#ifndef WAVEFORM_INTERNAL_H_
#define WAVEFORM_INTERNAL_H_
#include <sys/types.h>
#define GENFLAG_NONE 0x00000000
#define GENFLAG_LINEAR_INTERP 0x00000001
typedef struct
{
void *waveform_data;
u_int32_t flags;
} waveform_generator_def_t;
typedef struct oscillator_t oscillator_t;
typedef void (*generator_output_func_t)(waveform_generator_def_t *generator_def, oscillator_t* osc, sample_t *sample_data, int sample_count);
typedef struct
{
waveform_generator_def_t definition;
generator_output_func_t output_func;
generator_output_func_t mix_func;
generator_output_func_t mid_func;
} waveform_generator_t;
extern waveform_generator_t generators[];
#define AMPL_INTERP_PRECISION 15
#define CALC_AMPLITUDE_INTERPOLATION(osc, amp_scale, amp_delta, sample_count) \
int32_t amp_delta = ((osc->level - osc->last_level) << AMPL_INTERP_PRECISION) / sample_count; \
int32_t amp_scale = osc->last_level << AMPL_INTERP_PRECISION;
#define INTERPOLATE_AMPLITUDE(amp_scale, amp_delta) amp_scale += amp_delta;
#define SCALE_AMPLITUDE(amp_scale, sample) sample = (sample * amp_scale) / SAMPLE_MAX;
#define MIX(original, sample, mixed) int32_t mixed = original + sample; \
if (mixed < -SAMPLE_MAX) \
mixed = -SAMPLE_MAX; \
else if (mixed > SAMPLE_MAX) \
mixed = SAMPLE_MAX;
#define STORE_SAMPLE(sample, sample_ptr) *sample_ptr++ = (sample_t)sample;
#endif /* WAVEFORM_INTERNAL_H_ */