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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? kiss_fft.c

?? 語音濾波源代碼
?? C
字號:
/*Copyright (c) 2003-2004, Mark BorgerdingAll rights reserved.Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:    * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.    * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.    * Neither the author nor the names of any contributors may be used to endorse or promote products derived from this software without specific prior written permission.THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.*/#ifdef HAVE_CONFIG_H#include "config.h"#endif#include "_kiss_fft_guts.h"#include "misc.h"/* The guts header contains all the multiplication and addition macros that are defined for fixed or floating point complex numbers.  It also delares the kf_ internal functions. */static kiss_fft_cpx *scratchbuf=NULL;static size_t nscratchbuf=0;static kiss_fft_cpx *tmpbuf=NULL;static size_t ntmpbuf=0;#define CHECKBUF(buf,nbuf,n) \    do { \        if ( nbuf < (size_t)(n) ) {\            free(buf); \            buf = (kiss_fft_cpx*)KISS_FFT_MALLOC(sizeof(kiss_fft_cpx)*(n)); \            nbuf = (size_t)(n); \        } \   }while(0)        static void kf_bfly2(        kiss_fft_cpx * Fout,        const size_t fstride,        const kiss_fft_cfg st,        int m        ){    kiss_fft_cpx * Fout2;    kiss_fft_cpx * tw1 = st->twiddles;    kiss_fft_cpx t;    Fout2 = Fout + m;    if (!st->inverse) {       int i;       kiss_fft_cpx *x=Fout;       for (i=0;i<2*m;i++)       {          x[i].r = SHR(x[i].r,1);          x[i].i = SHR(x[i].i,1);       }    }    do{        C_MUL (t,  *Fout2 , *tw1);        tw1 += fstride;        C_SUB( *Fout2 ,  *Fout , t );        C_ADDTO( *Fout ,  t );        ++Fout2;        ++Fout;    }while (--m);}static void kf_bfly4(        kiss_fft_cpx * Fout,        const size_t fstride,        const kiss_fft_cfg st,        const size_t m        ){    kiss_fft_cpx *tw1,*tw2,*tw3;    kiss_fft_cpx scratch[6];    size_t k=m;    const size_t m2=2*m;    const size_t m3=3*m;    tw3 = tw2 = tw1 = st->twiddles;    if (!st->inverse) {       int i;       kiss_fft_cpx *x=Fout;       for (i=0;i<4*m;i++)       {          x[i].r = PSHR16(x[i].r,2);          x[i].i = PSHR16(x[i].i,2);       }    }    if (st->inverse)    {       do {          C_MUL(scratch[0],Fout[m] , *tw1 );          C_MUL(scratch[1],Fout[m2] , *tw2 );          C_MUL(scratch[2],Fout[m3] , *tw3 );                    C_SUB( scratch[5] , *Fout, scratch[1] );          C_ADDTO(*Fout, scratch[1]);          C_ADD( scratch[3] , scratch[0] , scratch[2] );          C_SUB( scratch[4] , scratch[0] , scratch[2] );          C_SUB( Fout[m2], *Fout, scratch[3] );          tw1 += fstride;          tw2 += fstride*2;          tw3 += fstride*3;          C_ADDTO( *Fout , scratch[3] );          Fout[m].r = scratch[5].r - scratch[4].i;          Fout[m].i = scratch[5].i + scratch[4].r;          Fout[m3].r = scratch[5].r + scratch[4].i;          Fout[m3].i = scratch[5].i - scratch[4].r;          ++Fout;       } while(--k);    } else    {       do {          C_MUL(scratch[0],Fout[m] , *tw1 );          C_MUL(scratch[1],Fout[m2] , *tw2 );          C_MUL(scratch[2],Fout[m3] , *tw3 );                    C_SUB( scratch[5] , *Fout, scratch[1] );          C_ADDTO(*Fout, scratch[1]);          C_ADD( scratch[3] , scratch[0] , scratch[2] );          C_SUB( scratch[4] , scratch[0] , scratch[2] );          C_SUB( Fout[m2], *Fout, scratch[3] );          tw1 += fstride;          tw2 += fstride*2;          tw3 += fstride*3;          C_ADDTO( *Fout , scratch[3] );                    Fout[m].r = scratch[5].r + scratch[4].i;          Fout[m].i = scratch[5].i - scratch[4].r;          Fout[m3].r = scratch[5].r - scratch[4].i;          Fout[m3].i = scratch[5].i + scratch[4].r;          ++Fout;       }while(--k);    }}static void kf_bfly3(         kiss_fft_cpx * Fout,         const size_t fstride,         const kiss_fft_cfg st,         size_t m         ){     size_t k=m;     const size_t m2 = 2*m;     kiss_fft_cpx *tw1,*tw2;     kiss_fft_cpx scratch[5];     kiss_fft_cpx epi3;     epi3 = st->twiddles[fstride*m];     tw1=tw2=st->twiddles;     do{        if (!st->inverse) {         C_FIXDIV(*Fout,3); C_FIXDIV(Fout[m],3); C_FIXDIV(Fout[m2],3);	}         C_MUL(scratch[1],Fout[m] , *tw1);         C_MUL(scratch[2],Fout[m2] , *tw2);         C_ADD(scratch[3],scratch[1],scratch[2]);         C_SUB(scratch[0],scratch[1],scratch[2]);         tw1 += fstride;         tw2 += fstride*2;         Fout[m].r = Fout->r - HALF_OF(scratch[3].r);         Fout[m].i = Fout->i - HALF_OF(scratch[3].i);         C_MULBYSCALAR( scratch[0] , epi3.i );         C_ADDTO(*Fout,scratch[3]);         Fout[m2].r = Fout[m].r + scratch[0].i;         Fout[m2].i = Fout[m].i - scratch[0].r;         Fout[m].r -= scratch[0].i;         Fout[m].i += scratch[0].r;         ++Fout;     }while(--k);}static void kf_bfly5(        kiss_fft_cpx * Fout,        const size_t fstride,        const kiss_fft_cfg st,        int m        ){    kiss_fft_cpx *Fout0,*Fout1,*Fout2,*Fout3,*Fout4;    int u;    kiss_fft_cpx scratch[13];    kiss_fft_cpx * twiddles = st->twiddles;    kiss_fft_cpx *tw;    kiss_fft_cpx ya,yb;    ya = twiddles[fstride*m];    yb = twiddles[fstride*2*m];    Fout0=Fout;    Fout1=Fout0+m;    Fout2=Fout0+2*m;    Fout3=Fout0+3*m;    Fout4=Fout0+4*m;    tw=st->twiddles;    for ( u=0; u<m; ++u ) {        if (!st->inverse) {        C_FIXDIV( *Fout0,5); C_FIXDIV( *Fout1,5); C_FIXDIV( *Fout2,5); C_FIXDIV( *Fout3,5); C_FIXDIV( *Fout4,5);	}        scratch[0] = *Fout0;        C_MUL(scratch[1] ,*Fout1, tw[u*fstride]);        C_MUL(scratch[2] ,*Fout2, tw[2*u*fstride]);        C_MUL(scratch[3] ,*Fout3, tw[3*u*fstride]);        C_MUL(scratch[4] ,*Fout4, tw[4*u*fstride]);        C_ADD( scratch[7],scratch[1],scratch[4]);        C_SUB( scratch[10],scratch[1],scratch[4]);        C_ADD( scratch[8],scratch[2],scratch[3]);        C_SUB( scratch[9],scratch[2],scratch[3]);        Fout0->r += scratch[7].r + scratch[8].r;        Fout0->i += scratch[7].i + scratch[8].i;        scratch[5].r = scratch[0].r + S_MUL(scratch[7].r,ya.r) + S_MUL(scratch[8].r,yb.r);        scratch[5].i = scratch[0].i + S_MUL(scratch[7].i,ya.r) + S_MUL(scratch[8].i,yb.r);        scratch[6].r =  S_MUL(scratch[10].i,ya.i) + S_MUL(scratch[9].i,yb.i);        scratch[6].i = -S_MUL(scratch[10].r,ya.i) - S_MUL(scratch[9].r,yb.i);        C_SUB(*Fout1,scratch[5],scratch[6]);        C_ADD(*Fout4,scratch[5],scratch[6]);        scratch[11].r = scratch[0].r + S_MUL(scratch[7].r,yb.r) + S_MUL(scratch[8].r,ya.r);        scratch[11].i = scratch[0].i + S_MUL(scratch[7].i,yb.r) + S_MUL(scratch[8].i,ya.r);        scratch[12].r = - S_MUL(scratch[10].i,yb.i) + S_MUL(scratch[9].i,ya.i);        scratch[12].i = S_MUL(scratch[10].r,yb.i) - S_MUL(scratch[9].r,ya.i);        C_ADD(*Fout2,scratch[11],scratch[12]);        C_SUB(*Fout3,scratch[11],scratch[12]);        ++Fout0;++Fout1;++Fout2;++Fout3;++Fout4;    }}/* perform the butterfly for one stage of a mixed radix FFT */static void kf_bfly_generic(        kiss_fft_cpx * Fout,        const size_t fstride,        const kiss_fft_cfg st,        int m,        int p        ){    int u,k,q1,q;    kiss_fft_cpx * twiddles = st->twiddles;    kiss_fft_cpx t;    int Norig = st->nfft;    CHECKBUF(scratchbuf,nscratchbuf,p);    for ( u=0; u<m; ++u ) {        k=u;        for ( q1=0 ; q1<p ; ++q1 ) {            scratchbuf[q1] = Fout[ k  ];        if (!st->inverse) {            C_FIXDIV(scratchbuf[q1],p);	}            k += m;        }        k=u;        for ( q1=0 ; q1<p ; ++q1 ) {            int twidx=0;            Fout[ k ] = scratchbuf[0];            for (q=1;q<p;++q ) {                twidx += fstride * k;                if (twidx>=Norig) twidx-=Norig;                C_MUL(t,scratchbuf[q] , twiddles[twidx] );                C_ADDTO( Fout[ k ] ,t);            }            k += m;        }    }}staticvoid kf_work(        kiss_fft_cpx * Fout,        const kiss_fft_cpx * f,        const size_t fstride,        int in_stride,        int * factors,        const kiss_fft_cfg st        ){    kiss_fft_cpx * Fout_beg=Fout;    const int p=*factors++; /* the radix  */    const int m=*factors++; /* stage's fft length/p */    const kiss_fft_cpx * Fout_end = Fout + p*m;    if (m==1) {        do{            *Fout = *f;            f += fstride*in_stride;        }while(++Fout != Fout_end );    }else{        do{            kf_work( Fout , f, fstride*p, in_stride, factors,st);            f += fstride*in_stride;        }while( (Fout += m) != Fout_end );    }    Fout=Fout_beg;    switch (p) {        case 2: kf_bfly2(Fout,fstride,st,m); break;        case 3: kf_bfly3(Fout,fstride,st,m); break;         case 4: kf_bfly4(Fout,fstride,st,m); break;        case 5: kf_bfly5(Fout,fstride,st,m); break;         default: kf_bfly_generic(Fout,fstride,st,m,p); break;    }}/*  facbuf is populated by p1,m1,p2,m2, ...    where     p[i] * m[i] = m[i-1]    m0 = n                  */static void kf_factor(int n,int * facbuf){    int p=4;    double floor_sqrt;    floor_sqrt = floor( sqrt((double)n) );    /*factor out powers of 4, powers of 2, then any remaining primes */    do {        while (n % p) {            switch (p) {                case 4: p = 2; break;                case 2: p = 3; break;                default: p += 2; break;            }            if (p > floor_sqrt)                p = n;          /* no more factors, skip to end */        }        n /= p;        *facbuf++ = p;        *facbuf++ = n;    } while (n > 1);}/* * * User-callable function to allocate all necessary storage space for the fft. * * The return value is a contiguous block of memory, allocated with malloc.  As such, * It can be freed with free(), rather than a kiss_fft-specific function. * */kiss_fft_cfg kiss_fft_alloc(int nfft,int inverse_fft,void * mem,size_t * lenmem ){    kiss_fft_cfg st=NULL;    size_t memneeded = sizeof(struct kiss_fft_state)        + sizeof(kiss_fft_cpx)*(nfft-1); /* twiddle factors*/    if ( lenmem==NULL ) {        st = ( kiss_fft_cfg)KISS_FFT_MALLOC( memneeded );    }else{        if (mem != NULL && *lenmem >= memneeded)            st = (kiss_fft_cfg)mem;        *lenmem = memneeded;    }    if (st) {        int i;        st->nfft=nfft;        st->inverse = inverse_fft;        for (i=0;i<nfft;++i) {            const double pi=3.14159265358979323846264338327;            double phase = ( -2*pi /nfft ) * i;            if (st->inverse)                phase *= -1;            kf_cexp(st->twiddles+i, phase );        }        kf_factor(nfft,st->factors);    }    return st;}    void kiss_fft_stride(kiss_fft_cfg st,const kiss_fft_cpx *fin,kiss_fft_cpx *fout,int in_stride){    if (fin == fout) {        CHECKBUF(tmpbuf,ntmpbuf,st->nfft);        kf_work(tmpbuf,fin,1,in_stride, st->factors,st);        memcpy(fout,tmpbuf,sizeof(kiss_fft_cpx)*st->nfft);    }else{        kf_work( fout, fin, 1,in_stride, st->factors,st );    }}void kiss_fft(kiss_fft_cfg cfg,const kiss_fft_cpx *fin,kiss_fft_cpx *fout){    kiss_fft_stride(cfg,fin,fout,1);}/* not really necessary to call, but if someone is doing in-place ffts, they may want to free the    buffers from CHECKBUF */ void kiss_fft_cleanup(void){    free(scratchbuf);    scratchbuf = NULL;    nscratchbuf=0;    free(tmpbuf);    tmpbuf=NULL;    ntmpbuf=0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕字幕中文在线中不卡视频| 国产精品亚洲成人| 亚洲一区二区精品视频| 亚洲日穴在线视频| 亚洲精品美国一| 亚洲自拍偷拍综合| 亚洲成人1区2区| 水野朝阳av一区二区三区| 奇米影视在线99精品| 久久99精品国产.久久久久| 久久99久久精品| 国产一区二区三区蝌蚪| 不卡一区在线观看| 色播五月激情综合网| 欧美日韩不卡一区二区| 欧美一级生活片| 久久亚洲欧美国产精品乐播 | 久久99精品一区二区三区三区| 久久精品国产精品亚洲综合| 激情久久五月天| 成人免费福利片| 在线观看亚洲专区| 欧美电影免费观看高清完整版在线观看 | 欧美一区二区美女| 精品国产一区二区亚洲人成毛片 | 午夜视频久久久久久| 久久精品国产亚洲a| 国产很黄免费观看久久| 91蝌蚪porny| 91精品福利在线一区二区三区| 久久亚洲精华国产精华液| 日韩伦理av电影| 日韩国产一二三区| 成人性视频免费网站| 欧美性受xxxx黑人xyx性爽| 日韩欧美美女一区二区三区| 国产精品女同互慰在线看| 亚洲国产综合在线| 国产福利91精品一区二区三区| 色爱区综合激月婷婷| 日韩欧美一区二区免费| 亚洲欧洲性图库| 毛片av一区二区| 一本色道久久综合精品竹菊| 日韩一二三四区| 国产精品久久久久毛片软件| 91免费视频网| 精品国产伦一区二区三区免费 | 日本aⅴ精品一区二区三区| 国产 日韩 欧美大片| 欧洲精品视频在线观看| 国产日产欧产精品推荐色| 亚洲国产成人av网| 成人综合婷婷国产精品久久蜜臀| 欧美伊人久久久久久久久影院| 久久久.com| 午夜精品福利一区二区三区av | 精品免费视频.| 亚洲一区二区五区| 成人毛片视频在线观看| 日韩一区二区三区四区| 亚洲自拍偷拍图区| 成人av综合一区| 精品国产免费人成电影在线观看四季| 亚洲一区二区三区中文字幕在线| 国产精品99久久久久久有的能看| 欧美美女一区二区三区| 国产精品家庭影院| 国产专区综合网| 日韩一区二区免费电影| 一区二区三区四区不卡视频| 国产91精品久久久久久久网曝门| 3d动漫精品啪啪| 一区二区三区四区中文字幕| youjizz国产精品| 久久久久久免费毛片精品| 蜜桃视频免费观看一区| 欧美日韩国产综合久久| 一区二区国产盗摄色噜噜| av午夜一区麻豆| 国产精品视频线看| 国产成人一级电影| 国产婷婷色一区二区三区四区| 亚洲色图视频网站| 国产91精品精华液一区二区三区| 欧美一区二区私人影院日本| 亚洲a一区二区| 欧美一a一片一级一片| 亚洲精品欧美激情| 成人av在线影院| 国产精品美女www爽爽爽| 欧美一区二区三区性视频| 亚洲国产精品久久久久秋霞影院| 99免费精品在线| 国产精品白丝在线| 成人精品免费视频| 国产精品天干天干在观线| 国产成人亚洲综合a∨婷婷| 国产日韩精品久久久| 国产福利精品一区二区| 欧美经典一区二区| 国产suv精品一区二区三区| 国产夜色精品一区二区av| 国产精品99久久久久久久vr | 国产日韩欧美在线一区| 国产成人精品一区二| 一区二区三区在线视频免费| 日韩欧美资源站| 亚洲123区在线观看| 欧美日韩免费一区二区三区| 亚洲一区二区av在线| 欧美日韩一区高清| 男女性色大片免费观看一区二区 | 91看片淫黄大片一级在线观看| 亚洲欧洲www| 在线看国产日韩| 日韩电影一区二区三区四区| 欧美成人乱码一区二区三区| 国产高清成人在线| 国产精品视频一二| 色屁屁一区二区| 亚洲成av人片在线观看无码| 日韩小视频在线观看专区| 国产一区二区久久| 亚洲三级小视频| 欧美精品日韩精品| 国内精品伊人久久久久av一坑| 国产精品久久综合| 欧美日韩综合在线免费观看| 日日夜夜精品免费视频| 欧美精品一区二区三区蜜桃| 成人精品免费视频| 午夜一区二区三区视频| 精品少妇一区二区三区 | 成人欧美一区二区三区视频网页| 91国产精品成人| 激情图片小说一区| 17c精品麻豆一区二区免费| 欧美日本一区二区在线观看| 国产精品资源在线观看| 亚洲天堂2014| 日韩久久精品一区| 99精品一区二区三区| 美国十次综合导航| 中文字幕五月欧美| 欧美一级高清片在线观看| 成人毛片老司机大片| 日本伊人色综合网| **网站欧美大片在线观看| 91麻豆精品国产91久久久使用方法 | 美女爽到高潮91| 欧美国产在线观看| 欧美高清视频不卡网| 99久久久免费精品国产一区二区| 日本不卡在线视频| 亚洲欧洲精品一区二区精品久久久| 91精品免费观看| 色狠狠桃花综合| 国产精品1区二区.| 免费成人av在线播放| 一区二区三区中文免费| 国产色产综合色产在线视频| 91精品福利在线一区二区三区| 91麻豆精品在线观看| 国产一区二区在线看| 日本成人在线看| 一片黄亚洲嫩模| 国产精品欧美久久久久无广告| 日韩一区二区三区高清免费看看| 色综合久久中文综合久久牛| 国产精品一区二区三区乱码| 免费在线欧美视频| 亚洲午夜国产一区99re久久| 亚洲欧洲国产专区| 久久久久久久电影| 日韩欧美国产一区二区在线播放| 日本道在线观看一区二区| 波多野结衣精品在线| 国产一区二区福利| 麻豆国产精品视频| 五月天激情小说综合| 亚洲一区二区三区小说| 亚洲欧美一区二区在线观看| 亚洲国产精品精华液2区45| 日韩色视频在线观看| 777午夜精品免费视频| 欧美亚洲尤物久久| 91成人国产精品| 色综合视频一区二区三区高清| 成人看片黄a免费看在线| 国产成人在线视频网站| 激情久久久久久久久久久久久久久久| 婷婷综合五月天| 亚洲永久免费视频| 一区二区三区蜜桃| 一区二区三区四区亚洲| 亚洲一线二线三线视频| 亚洲一区二三区| 午夜免费久久看| 日韩福利视频导航|