Latest psychoacoustics work -- still highly experimental
[opus.git] / tests / laplace-test.c
1 #ifdef HAVE_CONFIG_H
2 #include "config.h"
3 #endif
4
5 #include <stdio.h>
6 #include <stdlib.h>
7 #include "laplace.h"
8 #include "stack_alloc.h"
9
10 int main(void)
11 {
12    int i;
13    int ret = 0;
14    ec_enc enc;
15    ec_dec dec;
16    ec_byte_buffer buf;
17    int val[10000], decay[10000];
18    ALLOC_STACK;
19    ec_byte_writeinit(&buf);
20    ec_enc_init(&enc,&buf);
21    
22    val[0] = 3; decay[0] = 6000;
23    val[1] = 0; decay[1] = 5800;
24    val[2] = -1; decay[2] = 5600;
25    for (i=3;i<10000;i++)
26    {
27       val[i] = rand()%15-7;
28       decay[i] = rand()%11000+5000;
29    }
30    for (i=0;i<10000;i++)
31       ec_laplace_encode(&enc, &val[i], decay[i]);      
32       
33    ec_enc_done(&enc);
34
35    ec_byte_readinit(&buf,ec_byte_get_buffer(&buf),ec_byte_bytes(&buf));
36    ec_dec_init(&dec,&buf);
37
38    for (i=0;i<10000;i++)
39    {
40       int d = ec_laplace_decode(&dec, decay[i]);
41       if (d != val[i])
42       {
43          fprintf (stderr, "Got %d instead of %d\n", d, val[i]);
44          ret = 1;
45       }
46    }
47    
48    ec_byte_writeclear(&buf);
49    return ret;
50 }