cannam@154
|
1 /* Copyright (c) 2008-2011 Xiph.Org Foundation, Mozilla Corporation
|
cannam@154
|
2 Written by Jean-Marc Valin and Timothy B. Terriberry */
|
cannam@154
|
3 /*
|
cannam@154
|
4 Redistribution and use in source and binary forms, with or without
|
cannam@154
|
5 modification, are permitted provided that the following conditions
|
cannam@154
|
6 are met:
|
cannam@154
|
7
|
cannam@154
|
8 - Redistributions of source code must retain the above copyright
|
cannam@154
|
9 notice, this list of conditions and the following disclaimer.
|
cannam@154
|
10
|
cannam@154
|
11 - Redistributions in binary form must reproduce the above copyright
|
cannam@154
|
12 notice, this list of conditions and the following disclaimer in the
|
cannam@154
|
13 documentation and/or other materials provided with the distribution.
|
cannam@154
|
14
|
cannam@154
|
15 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
cannam@154
|
16 ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
cannam@154
|
17 LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
cannam@154
|
18 A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
|
cannam@154
|
19 OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
cannam@154
|
20 EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
cannam@154
|
21 PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
cannam@154
|
22 PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
cannam@154
|
23 LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
cannam@154
|
24 NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
cannam@154
|
25 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
cannam@154
|
26 */
|
cannam@154
|
27
|
cannam@154
|
28 #ifdef HAVE_CONFIG_H
|
cannam@154
|
29 #include "config.h"
|
cannam@154
|
30 #endif
|
cannam@154
|
31
|
cannam@154
|
32 #include <stdio.h>
|
cannam@154
|
33 #include <stdlib.h>
|
cannam@154
|
34 #define CELT_C
|
cannam@154
|
35 #include "laplace.h"
|
cannam@154
|
36 #include "stack_alloc.h"
|
cannam@154
|
37
|
cannam@154
|
38 #include "entenc.c"
|
cannam@154
|
39 #include "entdec.c"
|
cannam@154
|
40 #include "entcode.c"
|
cannam@154
|
41 #include "laplace.c"
|
cannam@154
|
42
|
cannam@154
|
43 #define DATA_SIZE 40000
|
cannam@154
|
44
|
cannam@154
|
45 int ec_laplace_get_start_freq(int decay)
|
cannam@154
|
46 {
|
cannam@154
|
47 opus_uint32 ft = 32768 - LAPLACE_MINP*(2*LAPLACE_NMIN+1);
|
cannam@154
|
48 int fs = (ft*(16384-decay))/(16384+decay);
|
cannam@154
|
49 return fs+LAPLACE_MINP;
|
cannam@154
|
50 }
|
cannam@154
|
51
|
cannam@154
|
52 int main(void)
|
cannam@154
|
53 {
|
cannam@154
|
54 int i;
|
cannam@154
|
55 int ret = 0;
|
cannam@154
|
56 ec_enc enc;
|
cannam@154
|
57 ec_dec dec;
|
cannam@154
|
58 unsigned char *ptr;
|
cannam@154
|
59 int val[10000], decay[10000];
|
cannam@154
|
60 ALLOC_STACK;
|
cannam@154
|
61 ptr = (unsigned char *)malloc(DATA_SIZE);
|
cannam@154
|
62 ec_enc_init(&enc,ptr,DATA_SIZE);
|
cannam@154
|
63
|
cannam@154
|
64 val[0] = 3; decay[0] = 6000;
|
cannam@154
|
65 val[1] = 0; decay[1] = 5800;
|
cannam@154
|
66 val[2] = -1; decay[2] = 5600;
|
cannam@154
|
67 for (i=3;i<10000;i++)
|
cannam@154
|
68 {
|
cannam@154
|
69 val[i] = rand()%15-7;
|
cannam@154
|
70 decay[i] = rand()%11000+5000;
|
cannam@154
|
71 }
|
cannam@154
|
72 for (i=0;i<10000;i++)
|
cannam@154
|
73 ec_laplace_encode(&enc, &val[i],
|
cannam@154
|
74 ec_laplace_get_start_freq(decay[i]), decay[i]);
|
cannam@154
|
75
|
cannam@154
|
76 ec_enc_done(&enc);
|
cannam@154
|
77
|
cannam@154
|
78 ec_dec_init(&dec,ec_get_buffer(&enc),ec_range_bytes(&enc));
|
cannam@154
|
79
|
cannam@154
|
80 for (i=0;i<10000;i++)
|
cannam@154
|
81 {
|
cannam@154
|
82 int d = ec_laplace_decode(&dec,
|
cannam@154
|
83 ec_laplace_get_start_freq(decay[i]), decay[i]);
|
cannam@154
|
84 if (d != val[i])
|
cannam@154
|
85 {
|
cannam@154
|
86 fprintf (stderr, "Got %d instead of %d\n", d, val[i]);
|
cannam@154
|
87 ret = 1;
|
cannam@154
|
88 }
|
cannam@154
|
89 }
|
cannam@154
|
90
|
cannam@154
|
91 free(ptr);
|
cannam@154
|
92 return ret;
|
cannam@154
|
93 }
|