Correct many whitespace errors under libcelt/ and remove
[opus.git] / libcelt / tests / tandem-test.c
1 /* (C) 2009 Gregory Maxwell
2
3    This test runs pink noise through the encoder and decoder many times
4    while feeding the output back into the input. It checks that after
5    a number of cycles the energy has not increased or decreased by too
6    large an amount.
7
8    Redistribution and use in source and binary forms, with or without
9    modification, are permitted provided that the following conditions
10    are met:
11
12    - Redistributions of source code must retain the above copyright
13    notice, this list of conditions and the following disclaimer.
14
15    - Redistributions in binary form must reproduce the above copyright
16    notice, this list of conditions and the following disclaimer in the
17    documentation and/or other materials provided with the distribution.
18
19    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20    ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21    LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22    A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR
23    CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
24    EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25    PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
26    PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
27    LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
28    NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
29    SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 */
31
32 #ifdef HAVE_CONFIG_H
33 #include "config.h"
34 #endif
35
36 #include "celt.h"
37 #include "arch.h"
38 #include <stdio.h>
39 #include <stdlib.h>
40 #include <sys/types.h>
41 #include <time.h>
42 #include <math.h>
43 #include <string.h>
44
45 #ifndef _MSC_VER
46 #include <unistd.h>
47 #endif
48
49 int async_tandem(int rate, int frame_size, int channels, int bitrate_min,
50                  int bitrate_max)
51 {
52     int error;
53     unsigned char data[648];
54     CELTMode *mode = NULL;
55     CELTEncoder *enc;
56     short carry[2];
57     short pcm[960 * 2];
58     CELTDecoder *dec;
59     int bmin, bmax;
60     float ms;
61     int ret, i, j, bytes_per_frame;
62     int increment = 1;
63
64     bmin = floor((bitrate_min / (rate / (float) frame_size)) / 8.0);
65     bmax = ceil((bitrate_max / (rate / (float) frame_size)) / 8.0);
66     if (bmin < 8)
67         bmin = 8;
68     if (bmax > 640)
69         bmax = 640;
70     if (bmin >= bmax)
71         bmax = bmin + 8;
72
73     increment += (bmax - bmin) / 128;
74
75     printf ("Testing asynchronous tandeming (%dHz, %dch, %d samples, %d - %d bytes).\n",
76          rate, channels, frame_size, bmin, bmax);
77
78     mode = celt_mode_create(rate, frame_size, &error);
79     if (mode == NULL || error) {
80         fprintf(stderr, "Error: failed to create a mode: %s\n", celt_strerror(error));
81         exit(1);
82     }
83
84     dec = celt_decoder_create_custom(mode, channels, &error);
85     if (error){
86       fprintf(stderr, "Error: celt_decoder_create returned %s\n", celt_strerror(error));
87       exit(1);
88     }
89     enc = celt_encoder_create_custom(mode, channels, &error);
90     if (error){
91       fprintf(stderr, "Error: celt_encoder_create returned %s\n", celt_strerror(error));
92       exit(1);
93     }
94
95     for (j = 0; j < frame_size * channels; j++)
96         pcm[j] = 0;
97
98     for (bytes_per_frame = bmin; bytes_per_frame <= bmax;
99          bytes_per_frame += increment) {
100         /*Prime the encoder and decoder */
101         for (i = 0; i < (1024 + (frame_size >> 1)) / frame_size + 2; i++) {
102
103             for (j = 0; j < channels; j++)
104                 pcm[j] = pcm[frame_size * channels - (channels - j + 1)];
105             for (j = channels; j < frame_size * channels - 1; j++)
106                 pcm[j] = ((rand() % 4096) - 2048) + .9 * pcm[j - channels];
107
108             ret = celt_encode(enc, pcm, frame_size, data, bytes_per_frame);
109             if (ret != bytes_per_frame) {
110                 fprintf(stderr, "Error: celt_encode returned %s\n", celt_strerror(ret));
111                 exit(1);
112             }
113
114             ret = celt_decode(dec, data, ret, pcm, frame_size);
115             if (ret < 0) {
116                 fprintf(stderr, "Error: celt_decode returned %s\n", celt_strerror(ret));
117             }
118         }
119
120         for (j = 0; j < channels; j++)
121             pcm[j] = pcm[frame_size * channels - (channels - j)];
122         for (j = channels; j < frame_size * channels - 1; j++)
123             pcm[j] = ((rand() % 4096) - 2048) + .9 * pcm[j - channels];
124
125         for (i = 0; i < 8; i++) {
126             for (j = 0; j < channels; j++)
127                 carry[j] = pcm[frame_size * channels - (channels - j)];
128             memmove(pcm + channels, pcm, sizeof(short) * frame_size * channels);
129             for (j = 0; j < channels; j++)
130                 pcm[j] = carry[j];
131
132             ret = celt_encode(enc, pcm, frame_size, data, bytes_per_frame);
133             if (ret != bytes_per_frame) {
134                 fprintf(stderr, "Error: at %d bytes_per_frame celt_encode returned %s\n",
135                         bytes_per_frame, celt_strerror(ret));
136                 exit(1);
137             }
138
139             ret = celt_decode(dec, data, ret, pcm, frame_size);
140             if (ret < 0) {
141                 fprintf(stderr, "Error: at %d bytes_per_frame celt_decode returned %s\n",
142                         bytes_per_frame, celt_strerror(ret));
143                 exit(1);
144             }
145         }
146         ms = 0;
147         for (j = 0; j < frame_size * channels; j++)
148             ms += pcm[j] * pcm[j];
149         ms = sqrt(ms / (frame_size * channels));
150         if (ms > 7000 || ms < 1000) {
151             fprintf(stderr, "Error: Signal out of expected range. %d %d %d %d %f\n",
152                     rate, channels, frame_size, bytes_per_frame, ms);
153             exit(1);
154         }
155     }
156
157     celt_encoder_destroy(enc);
158     celt_decoder_destroy(dec);
159     celt_mode_destroy(mode);
160
161     return 0;
162 }
163
164 int main(int argc, char *argv[])
165 {
166 #ifdef CUSTOM_MODES
167     int sizes[8]={960,512,480,256,240,128,120,64};
168 #else
169     int sizes[4]={960,480,240,120};
170 #endif
171     unsigned int seed;
172     int ch, n;
173
174     if (argc > 2) {
175         fprintf(stderr, "Usage: %s [<seed>]\n", argv[0]);
176         return 1;
177     }
178
179     if (argc > 1)
180         seed = atoi(argv[1]);
181     else
182         seed = (time(NULL) ^ ((getpid() % 65536) << 16));
183
184     srand(seed);
185     printf("CELT codec tests. Random seed: %u (%.4X)\n", seed, rand() % 65536);
186
187 #ifdef CUSTOM_MODES
188     for (n = 0; n < 8; n++) {
189         for (ch = 1; ch <= 2; ch++) {
190             async_tandem(48000, sizes[n], ch, 12000 * ch, 128000 * ch);
191             async_tandem(44100, sizes[n], ch, 12000 * ch, 128000 * ch);
192             if(n>0)async_tandem(32000, sizes[n], ch, 12000 * ch, 128000 * ch);
193             if(n>2)async_tandem(16000, sizes[n], ch, 12000 * ch, 64000 * ch);
194         }
195     }
196 #else
197     for (n = 0; n < 4; n++) {
198         for (ch = 1; ch <= 2; ch++) {
199             async_tandem(48000, sizes[n], ch, 12000 * ch, 128000 * ch);
200         }
201     }
202 #endif
203     return 0;
204 }