69ab4f24bf509e225eadaf808f168196cdc64bf2
[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
9 int main()
10 {
11    int i;
12    ec_enc enc;
13    ec_dec dec;
14    ec_byte_buffer buf;
15    int val[10000], decay[10000];
16    ec_byte_writeinit(&buf);
17    ec_enc_init(&enc,&buf);
18    
19    for (i=0;i<10000;i++)
20    {
21       val[i] = rand()%15-7;
22       decay[i] = rand()%11000+5000;
23       ec_laplace_encode(&enc, val[i], decay[i]);      
24    }
25       
26    ec_enc_done(&enc);
27
28    ec_byte_readinit(&buf,ec_byte_get_buffer(&buf),ec_byte_bytes(&buf));
29    ec_dec_init(&dec,&buf);
30
31    for (i=0;i<10000;i++)
32    {
33       int d = ec_laplace_decode(&dec, decay[i]);
34       if (d != val[i])
35          fprintf (stderr, "Got %d instead of %d\n", d, val[i]);
36    }
37    
38    ec_byte_writeclear(&buf);
39    return 0;
40 }