36 #define ASSERT_LEVEL 2
134 out[i]= in + i*plane_size;
141 static int cmp(
const int *
a,
const int *
b){
149 double v, f,
a, ampa;
155 #define PUT_SAMPLE set(data, ch, k, channels, sample_fmt, v);
156 #define uint_rand(x) (x = x * 1664525 + 1013904223)
157 #define dbl_rand(x) (uint_rand(x)*2.0 / (double)UINT_MAX - 1)
162 for (i = 0; i < 1 * sample_rate && k < nb_samples; i++, k++) {
164 for (ch = 0; ch < channels; ch++)
166 a +=
M_PI * 1000.0 * 2.0 / sample_rate;
171 for (i = 0; i < 1 * sample_rate && k < nb_samples; i++, k++) {
173 for (ch = 0; ch < channels; ch++)
175 f = 100.0 + (((10000.0 - 100.0) * i) / sample_rate);
180 for (i = 0; i < sample_rate / 2 && k < nb_samples; i++, k++) {
182 for (ch = 0; ch < channels; ch++)
187 for (i = 0; i < sample_rate / 2 && k < nb_samples; i++, k++) {
189 for (ch = 0; ch < channels; ch++)
194 for (ch = 0; ch < channels; ch++) {
199 for (i = 0; i < 1 * sample_rate && k < nb_samples; i++, k++) {
200 for (ch = 0; ch < channels; ch++) {
201 v = sin(taba[ch]) * 0.30;
203 f = tabf1[ch] + (((tabf2[ch] - tabf1[ch]) * i) /
sample_rate);
211 for (i = 0; i < 2 * sample_rate && k < nb_samples; i++, k++) {
212 for (ch = 0; ch < channels; ch++) {
213 double amp = (1.0 + sin(ampa)) * 0.15;
224 int main(
int argc,
char **argv){
225 int in_sample_rate, out_sample_rate, ch ,i, flush_count;
226 uint64_t in_ch_layout, out_ch_layout;
236 int num_tests = 10000;
238 uint32_t rand_seed = 0;
242 int specific_test= -1;
248 if (!strcmp(argv[1],
"-h") || !strcmp(argv[1],
"--help")) {
250 "num_tests Default is %d\n", num_tests);
253 num_tests = strtol(argv[1], NULL, 0);
255 num_tests = -num_tests;
258 if(num_tests<= 0 || num_tests>max_tests)
259 num_tests = max_tests;
261 specific_test = strtol(argv[1], NULL, 0);
265 for(i=0; i<max_tests; i++)
266 remaining_tests[i] = i;
268 for(test=0; test<num_tests; test++){
271 r = (seed * (uint64_t)(max_tests - test)) >>32;
272 FFSWAP(
int, remaining_tests[r], remaining_tests[max_tests - test - 1]);
274 qsort(remaining_tests + max_tests - num_tests, num_tests,
sizeof(remaining_tests[0]), (
void*)
cmp);
275 in_sample_rate=16000;
276 for(test=0; test<num_tests; test++){
277 char in_layout_string[256];
278 char out_layout_string[256];
279 unsigned vector= remaining_tests[max_tests - test - 1];
281 int out_count, mid_count, out_ch_count;
290 if(specific_test == 0){
291 if(out_sample_rate != in_sample_rate || in_ch_layout != out_ch_layout)
299 fprintf(stderr,
"TEST: %s->%s, rate:%5d->%5d, fmt:%s->%s\n",
300 in_layout_string, out_layout_string,
301 in_sample_rate, out_sample_rate,
303 forw_ctx =
swr_alloc_set_opts(forw_ctx, out_ch_layout, out_sample_fmt, out_sample_rate,
304 in_ch_layout, in_sample_fmt, in_sample_rate,
306 backw_ctx =
swr_alloc_set_opts(backw_ctx, in_ch_layout, in_sample_fmt, in_sample_rate,
307 out_ch_layout, out_sample_fmt, out_sample_rate,
310 fprintf(stderr,
"Failed to init forw_cts\n");
314 fprintf(stderr,
"Failed to init backw_ctx\n");
318 fprintf(stderr,
"swr_init(->) failed\n");
320 fprintf(stderr,
"swr_init(<-) failed\n");
326 for(ch=0; ch<in_ch_count; ch++){
328 set(ain, ch, i, in_ch_count, in_sample_fmt, sin(i*i*3/SAMPLES));
343 shift(ain, 1, in_ch_count, in_sample_fmt);
345 shift(amid, mid_count, out_ch_count, out_sample_fmt); tmp_count = mid_count;
347 shift(amid, mid_count-tmp_count, out_ch_count, out_sample_fmt); tmp_count = mid_count;
348 shift(ain, 2, in_ch_count, in_sample_fmt);
350 shift(amid, mid_count-tmp_count, out_ch_count, out_sample_fmt); tmp_count = mid_count;
351 shift(ain, -3, in_ch_count, in_sample_fmt);
353 shift(amid, -tmp_count, out_ch_count, out_sample_fmt);
357 for(ch=0; ch<in_ch_count; ch++){
358 double sse, maxdiff=0;
364 for(i=0; i<out_count; i++){
374 sse= sum_aa + sum_bb - 2*sum_ab;
375 if(sse < 0 && sse > -0.00001) sse=0;
377 fprintf(stderr,
"[e:%f c:%f max:%f] len:%5d\n", out_count ? sqrt(sse/out_count) : 0, sum_ab/(sqrt(sum_aa*sum_bb)), maxdiff, out_count);
382 flush_count =
swr_convert(backw_ctx,aout, flush_i, 0, 0);
383 shift(aout, flush_i, in_ch_count, in_sample_fmt);
385 shift(aout, -flush_i, in_ch_count, in_sample_fmt);
387 for(ch=0; ch<in_ch_count; ch++){
388 double sse, maxdiff=0;
394 for(i=0; i<flush_count; i++){
395 double a=
get(ain , ch, i+out_count, in_ch_count,
in_sample_fmt);
404 sse= sum_aa + sum_bb - 2*sum_ab;
405 if(sse < 0 && sse > -0.00001) sse=0;
407 fprintf(stderr,
"[e:%f c:%f max:%f] len:%5d F:%3d\n", sqrt(sse/flush_count), sum_ab/(sqrt(sum_aa*sum_bb)), maxdiff, flush_count, flush_i);
412 fprintf(stderr,
"\n");