-
-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathworklet.c
49 lines (44 loc) · 945 Bytes
/
worklet.c
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
#include <emscripten.h>
#include <stdlib.h>
#include <rnnoise.h>
static float ring[1920], vad_prob = 0;
static size_t input = 0;
static DenoiseState *state;
float *EMSCRIPTEN_KEEPALIVE getInput() { return &ring[input]; }
float EMSCRIPTEN_KEEPALIVE getVadProb() { return vad_prob; }
float *EMSCRIPTEN_KEEPALIVE transform()
{
input += 128;
input %= 1920;
size_t p;
switch (input)
{
case 128:
p = 1440;
break;
case 512:
p = 0;
break;
case 1024:
p = 480;
break;
case 1536:
p = 960;
break;
default:
goto Buffer;
}
float *const o = &ring[p];
for (size_t i = 0; i < 480; ++i)
o[i] *= 32768;
vad_prob = rnnoise_process_frame(state, o, o);
for (size_t i = 0; i < 480; ++i)
o[i] /= 32768;
Buffer:
return &ring[(input + 1280) % 1920];
}
int main()
{
state = rnnoise_create(NULL);
return 0;
}