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

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

?? kiss_fft.c

?? speex 1.1.12 編碼 穩定版本
?? 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一区二区三区免费野_久草精品视频
欧美日韩综合在线免费观看| 99久久精品国产一区二区三区| 中文字幕中文乱码欧美一区二区| 精品日韩一区二区三区免费视频| 91精品啪在线观看国产60岁| 欧美日韩免费在线视频| 欧美日韩国产乱码电影| 欧美裸体一区二区三区| 欧美一二三在线| 日韩限制级电影在线观看| 日韩欧美一二三区| 中文字幕精品三区| 国产精品电影一区二区三区| 亚洲欧美日韩久久| 亚洲国产cao| 日韩精品欧美精品| 国产专区综合网| 成人教育av在线| 欧美色图12p| 精品国产在天天线2019| 欧美国产日韩精品免费观看| 亚洲欧美偷拍另类a∨色屁股| 亚洲精品国产精品乱码不99| 午夜激情综合网| 国产麻豆视频精品| 一本色道**综合亚洲精品蜜桃冫| 欧美亚洲一区二区在线观看| 4hu四虎永久在线影院成人| 日韩一区二区三免费高清| 精品奇米国产一区二区三区| 国产精品美女久久久久aⅴ| 亚洲一二三级电影| 国内精品免费在线观看| 91视频精品在这里| 日韩欧美久久一区| 17c精品麻豆一区二区免费| 日本三级韩国三级欧美三级| 丁香婷婷综合色啪| 在线成人午夜影院| 国产精品美女久久久久久久网站| 亚洲一区在线观看网站| 国产成人aaa| 欧美电影精品一区二区| 亚洲人成影院在线观看| 国产一区二区精品久久| 欧美日韩在线播放一区| 国产精品久久看| 精品一区二区三区欧美| 欧美色网一区二区| 国产精品久久毛片av大全日韩| 奇米888四色在线精品| 色老汉一区二区三区| 国产三级精品三级在线专区| 蜜臀国产一区二区三区在线播放| 亚洲午夜成aⅴ人片| 成人av网站在线观看| 亚洲曰韩产成在线| 中文字幕va一区二区三区| 56国语精品自产拍在线观看| 91久久精品网| 久久久不卡网国产精品一区| 日韩一区精品视频| 在线观看日韩高清av| 国产精品久久久久四虎| 国产美女主播视频一区| 欧美变态tickling挠脚心| 亚洲国产wwwccc36天堂| 91激情五月电影| 亚洲视频1区2区| 波多野结衣中文一区| 久久免费国产精品| 国产乱理伦片在线观看夜一区| 亚洲欧美一区二区视频| 国产成人免费视| 日本一区二区三级电影在线观看| 国产一区二区美女| 久久久久国产精品人| 黄色日韩三级电影| 亚洲精品一区在线观看| 国精产品一区一区三区mba桃花 | 欧美tickling网站挠脚心| 天天影视涩香欲综合网| 欧美日韩精品一区二区三区蜜桃| 亚洲一区自拍偷拍| 欧美高清一级片在线| 日韩有码一区二区三区| 欧美一区二区三区小说| 喷水一区二区三区| 欧美精品一区二区不卡 | 国产精品国产馆在线真实露脸| 国产一区激情在线| 中文字幕久久午夜不卡| 色婷婷av一区| 午夜精品一区二区三区三上悠亚| 欧美巨大另类极品videosbest | 国产成人丝袜美腿| 国产精品麻豆视频| 欧美在线观看视频在线| 秋霞影院一区二区| 国产三级三级三级精品8ⅰ区| 91在线播放网址| 婷婷激情综合网| 久久精品人人做人人综合| 不卡在线观看av| 亚洲成va人在线观看| 久久亚洲二区三区| 91蜜桃在线免费视频| 日韩va欧美va亚洲va久久| 欧美激情一区二区三区蜜桃视频| 91亚洲男人天堂| 精品一二三四在线| 亚洲视频一区二区在线| 日韩一区二区免费电影| 成人网在线免费视频| 亚洲123区在线观看| 久久伊99综合婷婷久久伊| 欧美专区亚洲专区| 国产精品一区二区在线观看不卡| 一区二区三区在线视频观看| 日韩免费在线观看| 色婷婷亚洲综合| 国产精品系列在线观看| 午夜精品久久久久久久| 国产精品久久看| 日韩精品一区二区三区四区| 色欧美88888久久久久久影院| 国产做a爰片久久毛片| 日韩精品91亚洲二区在线观看| 国产精品视频一二三| 日韩一级精品视频在线观看| 色综合夜色一区| 成人av网址在线| 国产精品亚洲视频| 日本欧美一区二区| 精品制服美女丁香| 天堂一区二区在线免费观看| 国产精品国产自产拍高清av王其| 精品精品国产高清一毛片一天堂| 欧美视频中文字幕| 色综合久久久久久久| 成人性视频免费网站| 国产激情偷乱视频一区二区三区| 秋霞影院一区二区| 奇米精品一区二区三区在线观看 | 粉嫩绯色av一区二区在线观看| 亚洲电影中文字幕在线观看| 亚洲伦理在线精品| 亚洲视频免费在线| 一区二区中文字幕在线| 欧美激情一区在线| 国产精品初高中害羞小美女文| 国产午夜精品在线观看| 欧美精品一区二区蜜臀亚洲| 精品免费一区二区三区| 日韩三级视频在线观看| 日韩欧美黄色影院| 欧美成人bangbros| 欧美sm极限捆绑bd| 亚洲精品一区二区三区在线观看| 日韩精品一区二区三区在线观看| 精品裸体舞一区二区三区| 久久综合中文字幕| 国产无一区二区| 中文字幕一区二区视频| 亚洲免费大片在线观看| 一区二区三区国产精华| 香蕉乱码成人久久天堂爱免费| 亚洲第一精品在线| 久久99久久久欧美国产| 高清免费成人av| 91网站黄www| 欧美一区二区三区日韩| 久久人人爽人人爽| 中文字幕一区二区三区四区| 一区二区三区欧美| 日韩高清欧美激情| 国产激情一区二区三区| 在线视频国产一区| 日韩精品一区在线观看| 国产精品无码永久免费888| 亚洲一区二区三区四区的| 麻豆91在线播放免费| 成人午夜激情片| 欧美老肥妇做.爰bbww视频| 精品福利在线导航| 亚洲精品中文在线影院| 日韩va亚洲va欧美va久久| 国产盗摄女厕一区二区三区| 91啦中文在线观看| 日韩免费高清视频| 亚洲麻豆国产自偷在线| 久久国产综合精品| 在线看不卡av| 国产欧美精品一区二区三区四区| 亚洲高清免费一级二级三级| 国产精品系列在线观看| 欧美一区二区三区小说| 中文字幕中文字幕一区二区| 久久电影网站中文字幕| 在线观看一区日韩|