forked from sensorium/Mozzi
-
Notifications
You must be signed in to change notification settings - Fork 1
/
WaveShaper.h
executable file
·105 lines (85 loc) · 2.84 KB
/
WaveShaper.h
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
/*
* WaveShaper.h
*
* Copyright 2012 Tim Barrass.
*
* This file is part of Mozzi.
*
* Mozzi is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License.
*
*/
#ifndef WAVESHAPER_H_
#define WAVESHAPER_H_
#include "Arduino.h"
/** WaveShaper maps values from its input to values in a table, which are returned as output.
@tparam T the type of numbers being input to be shaped, chosen to match the table.
*/
template <class T>
class WaveShaper
{}
;
/** int8_t specialisation of WaveShaper template*/
template <>
class WaveShaper <char>
{
public:
/** Constructor. Use the template parameter to set type of numbers being mapped. For
example, WaveShaper <int> myWaveShaper; makes a WaveShaper which uses ints.
@tparam T the type of numbers being input to be shaped, chosen to match the table.
@param TABLE_NAME the name of the table being used, which can be found in the
".h" file containing the table. */
WaveShaper(const int8_t * TABLE_NAME):table(TABLE_NAME)
{
;
}
/** Maps input to output, transforming it according to the table being used.
@param in the input signal. For flexibility, it's up to you to give the correct offset
to your input signal. So if you're mapping a signed 8-bit signal (such as the output of
an Oscil) into a 256 cell table centred around cell 128, add 128 to offset the
input value.
@return the shaped signal.
*/
inline
int8_t next(byte in)
{
return (int8_t) pgm_read_byte_near(table + in);
}
private:
const int8_t * table;
};
/** int specialisation of WaveShaper template*/
template <>
class WaveShaper <int>
{
public:
/** Constructor. Use the template parameter to set type of numbers being mapped. For
example, WaveShaper <int> myWaveShaper; makes a WaveShaper which uses ints.
@tparam T the type of numbers being input to be shaped, chosen to match the table.
@param TABLE_NAME the name of the table being used, which can be found in the
".h" file containing the table. */
WaveShaper(const int16_t * TABLE_NAME):table(TABLE_NAME)
{
;
}
/** Maps input to output, transforming it according to the table being used.
@param in the input signal. For flexibility, it's up to you to give the
correct offset to your input signal. So if you're mapping a signed 9-bit signal
(such as the sum of 2 8-bit Oscils) into a 512 cell table centred around
cell 256, add 256 to offset the input value. With a sigmoid table, this
may be useful for compressing a bigger signal into the -244 to 243
output range of Mozzi, rather than dividing the signal and returning a
int8_t from updateAudio().
@return the shaped signal.
*/
inline
int next(int in)
{
return (uint16_t) pgm_read_word_near(table + in);
}
private:
const int16_t * table;
};
/** @example 06.Synthesis/WaveShaper/WaveShaper.ino
This is an example of how to use the WaveShaper class.
*/
#endif /* WAVESHAPER_H_ */