-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathTestAudioHash.c
71 lines (55 loc) · 1.72 KB
/
TestAudioHash.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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#include <stdlib.h>
#include <stdio.h>
#include <assert.h>
#include "AudioHash.h"
void runtest(){
const char *file = "sample.txt";
const int sr = 6000;
const int p = 12;
FILE *samplefile = fopen(file, "r");
assert(samplefile != NULL);
int i, buflen;
fscanf(samplefile, "%d", &buflen);
float *buf = malloc(buflen*sizeof(float));
assert(buf != NULL);
for (i=0;i<buflen;i++){
fscanf(samplefile, "%f", buf+i);
}
fclose(samplefile);
AudioHash hash;
int ret = ph_audiohash_wrapped(buf, buflen, &hash, p, sr);
assert(ret == 0);
assert(hash.nbhashes == 33);
assert(hash.nbframes == 35);
assert(hash.nbcoeffs == 32);
assert(hash.hasharray[0] == 0xcb0f9ef0);
assert(hash.hasharray[1] == 0xcb0fbaf0);
assert(hash.hasharray[2] == 0xcb0eb870);
assert(hash.hasharray[3] == 0xcb0ef870);
assert(hash.hasharray[30] == 0xf0b86b00);
assert(hash.hasharray[31] == 0xf0b86901);
assert(hash.hasharray[32] == 0xf0b8780b);
assert(hash.toggles[0] == 0x6889fc00);
assert(hash.toggles[1] == 0x6889fc00);
assert(hash.toggles[2] == 0x6889db00);
assert(hash.toggles[3] == 0x3889d980);
assert(hash.toggles[30] == 0x21c8fe00);
assert(hash.toggles[31] == 0x9c8f700);
assert(hash.toggles[32] == 0x8c8ff00);
AudioHash subhash;
ret = ph_audiohash_wrapped(buf+500, buflen-500, &subhash, p, sr);
assert(ret == 0);
int pos;
float cs;
ret = ph_audiohash_distance_ber(&subhash, &hash, &pos, &cs);
assert(ret == 0);
printf("pos %d, cs %f\n", pos, cs);
free(buf);
ph_free_hash(&hash);
ph_free_hash(&subhash);
}
int main(int argc, char **argv){
printf("1 run test.\n");
runtest();
return 0;
}