forked from JorenSix/Pidato
-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy pathTest_Yin.c
35 lines (26 loc) · 1 KB
/
Test_Yin.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
/* Use ./TestAudio/audioExtract.py to create audioData.h - this converts a wave file to an array of doubles in C.
* Copy audioData.h into same folder as this test then build and run - the program should give F0 of the signal in
* audioData.h */
#include "Yin.h"
#include <stdio.h>
#include <stdint.h>
/* Audio array with samples from .wav file
* contains
* #define NUM_SAMPLES 176400
* int audio[176400] = {...}
*/
#include "audioData.h"
int main(int argc, char** argv) {
int buffer_length = 100;
Yin yin;
float pitch;
printf("About to test how many samples are needed to detect the pitch in a given signal\n");
printf("WARNING: this test has an absolute disregard for memory managment, hang tight this could hurt a little...\n");
while (pitch < 10 ) {
Yin_init(&yin, buffer_length, 0.05);
pitch = Yin_getPitch(&yin, audio);
buffer_length++;
}
printf("Pitch is found to be %f with buffer length %i and probabiity %f\n",pitch, buffer_length, Yin_getProbability(&yin) );
return 0;
}