yading@11: /* yading@11: * Copyright (C) 2011-2012 Michael Niedermayer (michaelni@gmx.at) yading@11: * Copyright (c) 2002 Fabrice Bellard yading@11: * yading@11: * This file is part of libswresample yading@11: * yading@11: * libswresample is free software; you can redistribute it and/or modify yading@11: * it under the terms of the GNU General Public License as published by yading@11: * the Free Software Foundation; either version 2 of the License, or yading@11: * (at your option) any later version. yading@11: * yading@11: * libswresample is distributed in the hope that it will be useful, yading@11: * but WITHOUT ANY WARRANTY; without even the implied warranty of yading@11: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the yading@11: * GNU General Public License for more details. yading@11: * yading@11: * You should have received a copy of the GNU General Public License yading@11: * along with libswresample; if not, write to the Free Software yading@11: * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA yading@11: */ yading@11: yading@11: #include "libavutil/avassert.h" yading@11: #include "libavutil/channel_layout.h" yading@11: #include "libavutil/common.h" yading@11: #include "libavutil/opt.h" yading@11: #include "swresample.h" yading@11: yading@11: #undef time yading@11: #include "time.h" yading@11: #undef fprintf yading@11: yading@11: #define SAMPLES 1000 yading@11: yading@11: #define ASSERT_LEVEL 2 yading@11: yading@11: static double get(uint8_t *a[], int ch, int index, int ch_count, enum AVSampleFormat f){ yading@11: const uint8_t *p; yading@11: if(av_sample_fmt_is_planar(f)){ yading@11: f= av_get_alt_sample_fmt(f, 0); yading@11: p= a[ch]; yading@11: }else{ yading@11: p= a[0]; yading@11: index= ch + index*ch_count; yading@11: } yading@11: yading@11: switch(f){ yading@11: case AV_SAMPLE_FMT_U8 : return ((const uint8_t*)p)[index]/127.0-1.0; yading@11: case AV_SAMPLE_FMT_S16: return ((const int16_t*)p)[index]/32767.0; yading@11: case AV_SAMPLE_FMT_S32: return ((const int32_t*)p)[index]/2147483647.0; yading@11: case AV_SAMPLE_FMT_FLT: return ((const float *)p)[index]; yading@11: case AV_SAMPLE_FMT_DBL: return ((const double *)p)[index]; yading@11: default: av_assert0(0); yading@11: } yading@11: } yading@11: yading@11: static void set(uint8_t *a[], int ch, int index, int ch_count, enum AVSampleFormat f, double v){ yading@11: uint8_t *p; yading@11: if(av_sample_fmt_is_planar(f)){ yading@11: f= av_get_alt_sample_fmt(f, 0); yading@11: p= a[ch]; yading@11: }else{ yading@11: p= a[0]; yading@11: index= ch + index*ch_count; yading@11: } yading@11: switch(f){ yading@11: case AV_SAMPLE_FMT_U8 : ((uint8_t*)p)[index]= av_clip_uint8 (lrint((v+1.0)*127)); break; yading@11: case AV_SAMPLE_FMT_S16: ((int16_t*)p)[index]= av_clip_int16 (lrint(v*32767)); break; yading@11: case AV_SAMPLE_FMT_S32: ((int32_t*)p)[index]= av_clipl_int32(llrint(v*2147483647)); break; yading@11: case AV_SAMPLE_FMT_FLT: ((float *)p)[index]= v; break; yading@11: case AV_SAMPLE_FMT_DBL: ((double *)p)[index]= v; break; yading@11: default: av_assert2(0); yading@11: } yading@11: } yading@11: yading@11: static void shift(uint8_t *a[], int index, int ch_count, enum AVSampleFormat f){ yading@11: int ch; yading@11: yading@11: if(av_sample_fmt_is_planar(f)){ yading@11: f= av_get_alt_sample_fmt(f, 0); yading@11: for(ch= 0; ch 1) { yading@11: if (!strcmp(argv[1], "-h") || !strcmp(argv[1], "--help")) { yading@11: av_log(NULL, AV_LOG_INFO, "Usage: swresample-test [[ ]] \n" yading@11: "num_tests Default is %d\n", num_tests); yading@11: return 0; yading@11: } yading@11: num_tests = strtol(argv[1], NULL, 0); yading@11: if(num_tests < 0) { yading@11: num_tests = -num_tests; yading@11: rand_seed = time(0); yading@11: } yading@11: if(num_tests<= 0 || num_tests>max_tests) yading@11: num_tests = max_tests; yading@11: if(argc > 2) { yading@11: specific_test = strtol(argv[1], NULL, 0); yading@11: } yading@11: } yading@11: yading@11: for(i=0; i>32; yading@11: FFSWAP(int, remaining_tests[r], remaining_tests[max_tests - test - 1]); yading@11: } yading@11: qsort(remaining_tests + max_tests - num_tests, num_tests, sizeof(remaining_tests[0]), (void*)cmp); yading@11: in_sample_rate=16000; yading@11: for(test=0; test%s, rate:%5d->%5d, fmt:%s->%s\n", yading@11: in_layout_string, out_layout_string, yading@11: in_sample_rate, out_sample_rate, yading@11: av_get_sample_fmt_name(in_sample_fmt), av_get_sample_fmt_name(out_sample_fmt)); yading@11: forw_ctx = swr_alloc_set_opts(forw_ctx, out_ch_layout, out_sample_fmt, out_sample_rate, yading@11: in_ch_layout, in_sample_fmt, in_sample_rate, yading@11: 0, 0); yading@11: backw_ctx = swr_alloc_set_opts(backw_ctx, in_ch_layout, in_sample_fmt, in_sample_rate, yading@11: out_ch_layout, out_sample_fmt, out_sample_rate, yading@11: 0, 0); yading@11: if(!forw_ctx) { yading@11: fprintf(stderr, "Failed to init forw_cts\n"); yading@11: return 1; yading@11: } yading@11: if(!backw_ctx) { yading@11: fprintf(stderr, "Failed to init backw_ctx\n"); yading@11: return 1; yading@11: } yading@11: if(swr_init( forw_ctx) < 0) yading@11: fprintf(stderr, "swr_init(->) failed\n"); yading@11: if(swr_init(backw_ctx) < 0) yading@11: fprintf(stderr, "swr_init(<-) failed\n"); yading@11: //FIXME test planar yading@11: setup_array(ain , array_in , in_sample_fmt, SAMPLES); yading@11: setup_array(amid, array_mid, out_sample_fmt, 3*SAMPLES); yading@11: setup_array(aout, array_out, in_sample_fmt , SAMPLES); yading@11: #if 0 yading@11: for(ch=0; ch -0.00001) sse=0; //fix rounding error yading@11: yading@11: 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); yading@11: } yading@11: yading@11: flush_i++; yading@11: flush_i%=21; yading@11: flush_count = swr_convert(backw_ctx,aout, flush_i, 0, 0); yading@11: shift(aout, flush_i, in_ch_count, in_sample_fmt); yading@11: flush_count+= swr_convert(backw_ctx,aout, SAMPLES-flush_i, 0, 0); yading@11: shift(aout, -flush_i, in_ch_count, in_sample_fmt); yading@11: if(flush_count){ yading@11: for(ch=0; ch -0.00001) sse=0; //fix rounding error yading@11: yading@11: 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); yading@11: } yading@11: } yading@11: yading@11: yading@11: fprintf(stderr, "\n"); yading@11: } yading@11: yading@11: return 0; yading@11: }