亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? fftbench.c

?? 任意混合基的FFT
?? C
字號:

/************************************************************************
  fftbench
 ------------------------------------------------------------------------
  Function:
      The FFT routine under test is characterized in terms of speed and
      accuracy. The routine is tested at different FFT lengths and the
      test results are saved in the file FFTBENCH.TXT.
      
      The FFT benchmark program is distributed with the mixed radix FFT
      routine. If you want to test another FFT routine, you probably anly
      have to modify the make file, the FFT routine declaration and the 
      fftio routine below.
 ------------------------------------------------------------------------
  Compile options:
      The huge memory model is used.
 ------------------------------------------------------------------------
  Benchmarks:                   
      As an example the mixed radix FFT routine was tested and the 
      results are shown below. The Microsoft Visual C++ compiler was used 
      with the following compile options:
      /nologo /Gs /G2 /W4 /AH /Ox /D "NDEBUG" /D "_DOS" /FR
      and the test executed on a 50MHz 486DX :
      
      Length  Time [s]  Accuracy [dB]

         128   0.0054     -314.8   
         256   0.0116     -309.8   
         512   0.0251     -290.8   
        1024   0.0567     -313.6   
        2048   0.1203     -306.4   
        4096   0.2600     -291.8   
        8192   0.5800     -305.1   
         100   0.0040     -278.5   
         200   0.0099     -280.3   
         500   0.0256     -278.5   
        1000   0.0540     -278.5   
        2000   0.1294     -280.6   
        5000   0.3300     -278.4   
       10000   0.7133     -278.5   
 ------------------------------------------------------------------------
  Author:
      Jens Joergen Nielsen            For non-commercial use only.
      Bakkehusene 54                  A $100 fee must be paid if used
      DK-2970 Hoersholm               commercially. Please contact.
      DENMARK

      E-mail : jjn@get2net.dk   All rights reserved. October 2000.
      Homepage : http://home.get2net.dk/jjn
*************************************************************************/

#include <math.h>
#include <float.h>
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
#include <time.h>
#include <sys\timeb.h>

#define  maxIndex  10000L


/* Declaration of FFT routine under test.
 */
void fft(int n,double are[],double aim[],double bre[],double bim[]);

/* The purpose of this routine, which is called from the benchmark  
 * program, is to convert between the data formats used in the      
 * benchmark routine and the formats used in the FFT routine under  
 * test.                                                            
 */
int fftio(long n,double are[],double aim[],double bre[],double bim[])
{
    fft((int)n, are, aim, bre, bim);
    return(0);
}

/* Calculate time in seconds from start. Resolution 1/1000 second.
 */
double timeUsed(struct _timeb *start)
{                               
    double seconds;
    struct _timeb   finish;

    _ftime(&finish);
    seconds = (double) finish.millitm;
    seconds = seconds - start->millitm;
    seconds = seconds / 1000;
    seconds = seconds + finish.time - start->time;
    
    return(seconds);
}


/* Measure the time taken to perform an FFT. The test signal is a 
 * linear sweep from 0 to fs/2. At least 2 seconds of test time is
 * used and output is the average time for one FFT in seconds.
 */
double fftTime(long fftLength, 
               double xre[], double xim[], double yre[], double yim[])
{
    long            i, k, n, m, q;  
    double          w, pi;
    double          elapsed_time;
    struct _timeb   start;
                             
    n = fftLength;                             
    pi = 4 * atan(1); 
    k  = 1;
    w  = k*pi/n/n;
    for (i=0; i<n; i++) {
        xre[i] = cos(i*i*w);
        xim[i] = sin(i*i*w);
    }                    
    
    m = 0;
    q = 1;            
    _ftime(&start);
    while (timeUsed(&start) < 2.0)
    {
        for (i=0; i<q; i++)
            fftio(n, xre, xim, yre, yim);
        m = m + q;
        q = q + q;
    }
    elapsed_time = timeUsed(&start)/(double)m;
    return(elapsed_time);
}

/* Measure the difference between the theoretical FFT output and the
 * actual FFT output. The power leak is measured in terms of error 
 * to signal power ratio. The value is returned in dB.
 */
double fftLeak(long fftLength, 
               double xre[], double xim[], double yre[], double yim[])
{
    long            i, k, n;  
    double          w, pi;
    double          sqr, sqrsum, sqrmax;
                             
    n = fftLength;                             
    pi = 4 * atan(1); 
    k = 3;
    w = 2*k*pi/n;
    for (i=0; i<n; i++) {
        xre[i] = cos(i*w);
        xim[i] = sin(i*w);
    }                    
                     
    fftio(n, xre, xim, yre, yim);

    sqrsum = (yre[k]-n)*(yre[k]-n) + yim[k]*yim[k];
    sqrmax = 0;         
    for (i=0; i<n; i++)
        if (i != k)
        {
            sqr = yre[i]*yre[i] + yim[i]*yim[i];
            sqrsum = sqrsum + sqr;
            if (sqr > sqrmax) sqrmax = sqr;
        }
    sqrsum = sqrsum/n;    /* division by n*n in two stages to avoid */
    sqrsum = sqrsum/n;    /* integer overflow !!!!                  */
    sqrmax = sqrmax/n;
    sqrmax = sqrmax/n;
             
    if (sqrsum > 0)
        sqrsum = 10*log10(sqrsum);
    else                                
        sqrsum = -1000;
    if (sqrmax > 0)
        sqrmax = 10*log10(sqrmax);
    else
        sqrmax = -1000;
        
    return(sqrsum);
}

/* FFT benchmark main program.
 */
void main()
{                
    double          t, p;
    long            i, n;
    long            nmax, nfft[100];  

    double   *are, *aim, *bre, *bim;             
    
    FILE *txtFile;

    are = (double  *) calloc(maxIndex, sizeof(double));                        
    aim = (double  *) calloc(maxIndex, sizeof(double));                        
    bre = (double  *) calloc(maxIndex, sizeof(double));
    bim = (double  *) calloc(maxIndex, sizeof(double));

    if( bim == NULL )
    {
       printf( "Insufficient memory available\n" );
       exit(2);
    }                 
      
    printf("\nFFT Benchmark Test");        
    txtFile = fopen("fftbench.txt", "w");
    fprintf(txtFile,"\nResults from FFT benchmark test:");
    fprintf(txtFile,"\n\nLength  Time [s]  Accuracy [dB]\n");
              
    do {        
        printf("\n\n");
        printf("(0)  End FFT benchmark test.\n");
        printf("(1)  FFT lengths : 128, 256, 512, ... , 8192.\n");
        printf("(2)  FFT lengths : 100, 200, 500, ... , 10000.\n");
        printf("(3)  User selectable FFT length.\n\n");
        printf("Enter selection, 0-3 : ");
        scanf( "%ld", &n );
        nmax = 0;
        switch(n) {
            case 0 : nmax = 0; break;
            case 1 : 
                nmax = 7;
                nfft[0]  =  128;
                nfft[1]  =  256;
                nfft[2]  =  512;
                nfft[3]  = 1024;
                nfft[4]  = 2048;
                nfft[5]  = 4096;
                nfft[6]  = 8192;
                break;
            case 2 : 
                nmax = 7;
                nfft[0]  =   100;
                nfft[1]  =   200;
                nfft[2]  =   500;
                nfft[3]  =  1000;
                nfft[4]  =  2000;
                nfft[5]  =  5000;
                nfft[6]  = 10000;
                break;
            case 3 : 
                printf(     "\nEnter FFT length, N<=%5ld, maxPrime <= 37     : ", maxIndex);
                scanf( "%ld", &n );
                if ((n > 0) && (n <= maxIndex)) {
                    nfft[0] = n;
                    nmax = 1;
                }
                break;
        }
                
        for (i=0; i<nmax; i++) {
            t = fftTime( nfft[i], are, aim, bre, bim);
            p = fftLeak( nfft[i], are, aim, bre, bim);
            printf(         "\n %5ld %8.4f s %8.1f dB", nfft[i], t, p);
            fprintf(txtFile,"\n %5ld %8.4f   %8.1f   ", nfft[i], t, p);
        }                    
    } while(n > 0);

    fclose(txtFile);   

    free(bim);
    free(bre);
    free(aim);
    free(are);
    printf("\n");
    printf("\nFFT test terminated.");
    printf("\nCopyright 2000, Jens Joergen Nielsen, jjn@get2net.dk.");
    printf("\n");
    
 }



?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品毛片无遮挡高清| 日本v片在线高清不卡在线观看| 日韩中文字幕区一区有砖一区| 97se亚洲国产综合在线| 奇米精品一区二区三区在线观看一| 在线一区二区观看| 亚洲精品国产a| 欧美少妇xxx| 看国产成人h片视频| 欧美丝袜自拍制服另类| 亚洲伦理在线精品| 欧美日韩在线免费视频| 免费在线一区观看| 国产精品三级电影| 欧美日韩激情在线| 国产精品一区二区x88av| 亚洲日本在线a| 久久综合丝袜日本网| 99这里都是精品| 午夜视频在线观看一区二区| 精品美女一区二区| 在线观看一区二区精品视频| 另类小说色综合网站| 国产精品久久福利| 日韩一区二区电影| 在线观看日韩国产| 成人在线一区二区三区| 午夜精品久久久久久久久久久| 99国产一区二区三精品乱码| 亚洲国产一区二区三区| 精品福利一二区| 欧美日韩在线一区二区| eeuss鲁一区二区三区| 狠狠色丁香婷综合久久| 日本午夜精品视频在线观看| 亚洲精品日韩一| 视频一区二区国产| 亚洲一卡二卡三卡四卡五卡| 国产精品欧美一区二区三区| 精品国产一区二区在线观看| 欧美一级日韩不卡播放免费| 色婷婷精品久久二区二区蜜臀av| 成人免费福利片| 福利一区福利二区| 粉嫩av亚洲一区二区图片| 国产一区 二区| 国产成人精品1024| 成人高清av在线| 99久久国产免费看| 在线精品视频小说1| 欧美图片一区二区三区| 欧美色图一区二区三区| 欧美精品日韩综合在线| 日韩一级欧美一级| 亚洲精品在线电影| 国产网站一区二区| 亚洲摸摸操操av| 日日噜噜夜夜狠狠视频欧美人| 蓝色福利精品导航| 日韩中文欧美在线| 国产一区二区精品久久91| 粉嫩av一区二区三区粉嫩| 色欧美片视频在线观看在线视频| 在线日韩国产精品| 日韩免费电影网站| 亚洲男人的天堂在线aⅴ视频| 日本不卡的三区四区五区| 中文字幕日韩精品一区| 亚洲不卡av一区二区三区| 精品午夜一区二区三区在线观看| 成人自拍视频在线观看| 69堂国产成人免费视频| 欧美激情综合五月色丁香| 午夜精品久久久久久久久| 懂色av中文字幕一区二区三区| 在线免费视频一区二区| 国产欧美一区二区在线观看| 婷婷久久综合九色综合伊人色| 国产在线精品一区二区夜色| 在线观看区一区二| 日韩理论片一区二区| 久久精品国内一区二区三区| 欧美亚洲尤物久久| 亚洲视频在线一区二区| 国产成人在线网站| 欧美大片在线观看一区二区| 亚洲成人av一区二区| 91免费看视频| 亚洲人成人一区二区在线观看| 成人综合在线网站| 国产欧美日韩另类视频免费观看| 激情综合色播激情啊| 欧美视频日韩视频在线观看| 久久综合久久鬼色中文字| 精品一区二区三区在线播放视频 | 9i在线看片成人免费| 国产性色一区二区| 国产精品一品二品| 国产精品色哟哟| 91亚洲永久精品| 亚洲免费视频成人| 欧美精三区欧美精三区| 青青草国产成人av片免费| 欧美一级国产精品| 国产一区二区三区国产| 日韩美女视频一区二区| 色网站国产精品| 免费成人结看片| 中文无字幕一区二区三区| 91亚洲精华国产精华精华液| 亚洲一区二区在线免费观看视频 | 综合久久久久久久| 欧美军同video69gay| 日本亚洲一区二区| 国产一区二区三区电影在线观看 | 亚洲午夜久久久久久久久电影网| 91麻豆精品国产无毒不卡在线观看| 激情av综合网| 亚洲人亚洲人成电影网站色| 欧美高清精品3d| 国产成人亚洲精品狼色在线| 亚洲h动漫在线| 国产日韩欧美a| 欧美一级在线免费| 欧洲一区二区三区免费视频| 国产一区二区三区在线观看免费| 亚洲色图在线播放| 国产性做久久久久久| 欧美嫩在线观看| 一本久久综合亚洲鲁鲁五月天| 国产成人欧美日韩在线电影| 蜜臀精品一区二区三区在线观看 | 天天综合日日夜夜精品| 国产精品视频一二三| 精品国产91乱码一区二区三区 | 欧美一区二区三区日韩视频| 在线观看日韩av先锋影音电影院| 七七婷婷婷婷精品国产| 欧美一区三区二区| 欧美日免费三级在线| 色天使久久综合网天天| 91在线高清观看| 91亚洲国产成人精品一区二区三| 成人性生交大片免费看在线播放| 国产精品一二三四| 国产在线播放一区二区三区| 美日韩一区二区| 国产一区二区三区蝌蚪| www.在线成人| 在线区一区二视频| 欧美日韩高清一区二区不卡| 欧美日韩电影在线播放| 欧美成人女星排名| 国产日韩欧美a| 一区二区三区在线观看网站| 日韩中文字幕区一区有砖一区| 美洲天堂一区二卡三卡四卡视频| 久热成人在线视频| www.日韩精品| 制服丝袜中文字幕一区| 久久午夜免费电影| 日韩毛片一二三区| 麻豆精品视频在线| 91丨九色丨尤物| 日韩一级二级三级精品视频| 国产欧美一区二区精品性色超碰 | 51午夜精品国产| 久久精品日韩一区二区三区| 亚洲女与黑人做爰| 精品一区二区三区免费观看 | 精品一二三四区| 色综合久久88色综合天天免费| 制服丝袜亚洲网站| 日韩毛片一二三区| 国产精品一二三四区| 日韩视频一区二区在线观看| 中文字幕一区二区日韩精品绯色| 狠狠v欧美v日韩v亚洲ⅴ| 日本韩国一区二区三区| 国产精品伦理在线| 国产黄色精品视频| 精品日韩一区二区三区| 亚洲一区日韩精品中文字幕| fc2成人免费人成在线观看播放 | 色哟哟国产精品免费观看| 精品人在线二区三区| 久色婷婷小香蕉久久| 91精品久久久久久蜜臀| 性欧美疯狂xxxxbbbb| 色欧美88888久久久久久影院| 国产无一区二区| 国产成人在线视频免费播放| 国产片一区二区| 成人污污视频在线观看| 国产精品视频免费看| 99视频精品在线| 亚洲人成小说网站色在线| 欧美午夜视频网站| 日韩国产在线观看| 久久网这里都是精品|