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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
use super::Float;
use super::{Wavetable, WavetableRef};
use log::{info, debug, trace, warn};
use std::sync::Arc;
pub struct WtCreator {
}
impl WtCreator {
fn insert_sine(table: &mut [Float], _start_freq: Float, _sample_freq: Float) {
Wavetable::add_sine_wave(table, 1.0, 1.0);
}
fn insert_saw(table: &mut [Float], start_freq: Float, sample_freq: Float) {
let num_harmonics = Wavetable::calc_num_harmonics(start_freq * 2.0, sample_freq);
let mut sign: Float;
for i in 1..num_harmonics + 1 {
sign = if (i & 1) == 0 { 1.0 } else { -1.0 };
Wavetable::add_sine_wave(table, i as Float, 1.0 / i as Float * sign);
}
Wavetable::normalize(table);
Wavetable::shift(table, table.len() & 0xFFFFFFFC, table.len() / 2);
}
fn insert_saw_2(table: &mut [Float], start_freq: Float, sample_freq: Float) {
let num_harmonics = Wavetable::calc_num_harmonics(start_freq * 2.0, sample_freq);
for i in 1..num_harmonics + 1 {
Wavetable::add_sine_wave(table, i as Float, 1.0 / i as Float);
}
Wavetable::normalize(table);
}
fn insert_tri(table: &mut [Float], start_freq: Float, sample_freq: Float) {
let num_harmonics = Wavetable::calc_num_harmonics(start_freq * 2.0, sample_freq);
for i in (1..num_harmonics + 1).step_by(2) {
Wavetable::add_cosine_wave(table, i as Float, 1.0 / ((i * i) as Float));
}
Wavetable::normalize(table);
Wavetable::shift(table, table.len() & 0xFFFFFFFC, table.len() / 4);
}
fn insert_square(table: &mut [Float], start_freq: Float, sample_freq: Float) {
let num_harmonics = Wavetable::calc_num_harmonics(start_freq * 2.0, sample_freq);
for i in (1..num_harmonics + 1).step_by(2) {
Wavetable::add_sine_wave(table, i as Float, 1.0 / i as Float);
}
Wavetable::normalize(table);
}
pub fn create_default_waves(sample_rate: Float) -> WavetableRef {
debug!("Initializing default waveshapes");
let mut wt = Wavetable::new(4, 11, 2048);
let start_freq = Wavetable::get_start_frequency(440.0);
wt.insert_tables(0, start_freq, sample_rate, WtCreator::insert_sine);
wt.insert_tables(1, start_freq, sample_rate, WtCreator::insert_tri);
wt.insert_tables(2, start_freq, sample_rate, WtCreator::insert_saw);
wt.insert_tables(3, start_freq, sample_rate, WtCreator::insert_square);
Arc::new(wt)
}
pub fn create_pwm_waves(sample_rate: Float, num_pwm_tables: usize) -> WavetableRef {
info!("Initializing PWM table");
let num_samples = 2048;
let mut saw_wt = Wavetable::new(1, 11, num_samples);
let start_freq = Wavetable::get_start_frequency(440.0);
saw_wt.insert_tables(0, start_freq, sample_rate, WtCreator::insert_saw);
let saw_wave = &saw_wt.table[0];
info!("num_samples: {}", num_samples);
let mut wt = Wavetable::new(num_pwm_tables, 11, num_samples);
for i in 0..num_pwm_tables {
wt.combine_tables(i, &saw_wave, &saw_wave, (i + 1) as Float / (num_pwm_tables + 2) as Float);
}
Arc::new(wt)
}
}