|
@@ -1,5 +1,6 @@
|
|
|
#include "voices.h"
|
|
|
#include "stdlib.h"
|
|
|
+#include "vibrato_lut.h"
|
|
|
|
|
|
|
|
|
extern uint16_t envelope_index;
|
|
@@ -99,6 +100,36 @@ float voice_envelope(float frequency) {
|
|
|
if ((envelope_index % 8) == 0)
|
|
|
note_timbre = 0;
|
|
|
break;
|
|
|
+ case delayed_vibrato:
|
|
|
+ polyphony_rate = 0;
|
|
|
+ note_timbre = TIMBRE_50;
|
|
|
+ #define VOICE_VIBRATO_DELAY 150
|
|
|
+ #define VOICE_VIBRATO_SPEED 50
|
|
|
+ switch (compensated_index) {
|
|
|
+ case 0 ... VOICE_VIBRATO_DELAY:
|
|
|
+ break;
|
|
|
+ default:
|
|
|
+ frequency = frequency * VIBRATO_LUT[(int)fmod((((float)compensated_index - (VOICE_VIBRATO_DELAY + 1))/1000*VOICE_VIBRATO_SPEED), VIBRATO_LUT_LENGTH)];
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ break;
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
|
|
|
|
|
|
|