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");