Newer
Older
monitord / lame-3.97 / misc / .svn / text-base / scalartest.c.svn-base
#include <stdio.h>
#include <math.h>
#include <asm/msr.h>
#include "resample.h"

#define CLK    300.e6
#define LOOPS  20000


typedef double ( *ddf ) ( double );


float a1 [256];
float a2 [256];

void init ( void )
{
    int  i;
    
    for ( i = 0; i < sizeof(a1)/sizeof(*a1); i++ ) {
        a1 [i] = sin(i)+0.2*sin(1.8*i)+log(2+i);
	a2 [i] = cos(0.1*i);
    }
}

void test ( int no, scalar_t f )
{
    unsigned long long  t1;
    unsigned long long  t2;
    unsigned long long  t3;
    unsigned long long  t4;
    int                 l;
    double              last = 0;
    double              curr = 0;
    
    printf ( "[%3u] %22.14f\t\t", no, (double)f (a1,a2) );
    fflush ( stdout );

    do {
    rdtscll (t1);
    l = LOOPS;
    do
        ;
    while (--l);
    rdtscll (t2);
    rdtscll (t3);
    l = LOOPS;
    do
        f(a1,a2), f(a1,a2), f(a1,a2), f(a1,a2);
    while (--l);
    rdtscll (t4);
    last = curr;
    curr = (t4-t3-t2+t1) / CLK / LOOPS / 4 * 1.e9;
    } while ( fabs(curr-last) > 1.e-4 * (curr+last) );
    printf ("%8.2f ns\n", (curr+last) / 2 );
}

void testn ( scalarn_t f )
{
    unsigned long long  t1;
    unsigned long long  t2;
    unsigned long long  t3;
    unsigned long long  t4;
    int                 l;
    int                 i;
    double              last = 0;
    double              curr = 0;
    
    for ( i = 1; i <= 64; i += i<6 ? 1 : i<8 ? 2 : i ) {
        printf ( "[%3u] %22.14f\t\t", 4*i, (double)f (a1,a2,i) );
        fflush ( stdout );

    do {
        rdtscll (t1);
        l = LOOPS;
        do
            ;
        while (--l);
        rdtscll (t2);
        rdtscll (t3);
        l = LOOPS;
        do
            f(a1,a2,i), f(a1,a2,i), f(a1,a2,i), f(a1,a2,i);
        while (--l);
        rdtscll (t4);
    last = curr;
    curr = (t4-t3-t2+t1) / CLK / LOOPS / 4 * 1.e9;
    } while ( fabs(curr-last) > 1.e-4 * (curr+last) );
    printf ("%8.2f ns\n", (curr+last) / 2 );
    }
}

void test2 ( const char* name, ddf f )
{
    int     i;
    double  x;
    
    printf ( "\n%%%% %s\n\n", name );
    
    for ( i = -1000; i <= 1000; i++ ) {
        x = 1.e-3 * i;
	printf ( "%5d\t%12.8f\t%12.8f\t%12.8f\n", i, f(x), (f(x+5.e-5) - f(x-5.e-5))*1.e+4, (f(x+1.e-4) + f(x-1.e-4) - 2*f(x))*5.e+7 );
    }
    printf ( "%%%%\n" );
    fflush ( stdout );
}


int main ( int argc, char** argv )
{

#if 0

    test2 ( "Hann", hanning   );
    test2 ( "Hamm", hamming   );
    test2 ( "BM", blackman  );
    test2 ( "BM1",blackman1 );
    test2 ( "BM2",blackman2 );
    test2 ( "BMH N",blackmanharris_nuttall );
    test2 ( "MNH Min",blackmanharris_min4    );

#else

    init ();

    test ( 4, scalar04_float32       );
    test ( 4, scalar04_float32_i387  );
    test ( 4, scalar04_float32_3DNow );
    test ( 4, scalar04_float32_SIMD  );

    test ( 8, scalar08_float32       );
    test ( 8, scalar08_float32_i387  );
    test ( 8, scalar08_float32_3DNow );
    test ( 8, scalar08_float32_SIMD  );

    test ( 12, scalar12_float32       );
    test ( 12, scalar12_float32_i387  );
    test ( 12, scalar12_float32_3DNow );
    test ( 12, scalar12_float32_SIMD  );

    test ( 16, scalar16_float32       );
    test ( 16, scalar16_float32_i387  );
    test ( 16, scalar16_float32_3DNow );
    test ( 16, scalar16_float32_SIMD  );

    test ( 20, scalar20_float32       );
    test ( 20, scalar20_float32_i387  );
    test ( 20, scalar20_float32_3DNow );
    test ( 20, scalar20_float32_SIMD  );

    test ( 24, scalar24_float32       );
    test ( 24, scalar24_float32_i387  );
    test ( 24, scalar24_float32_3DNow );
    test ( 24, scalar24_float32_SIMD  );

    testn( scalar4n_float32       );
    testn( scalar4n_float32_i387  );
    testn( scalar4n_float32_3DNow );
    testn( scalar4n_float32_SIMD  );

#endif    
    
    return 0;
}

/* end of scalartest.c */