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

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

?? fftwrap.c

?? speech echo cancellation library
?? C
字號:
/* Copyright (C) 2005 Jean-Marc Valin    File: fftwrap.c   Wrapper for various FFTs    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 name of the Xiph.org Foundation nor the names of its   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 FOUNDATION 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#define USE_SMALLFT/*#define USE_KISS_FFT*/#include "arch.h"#include "os_support.h"#ifdef FIXED_POINTstatic int maximize_range(spx_word16_t *in, spx_word16_t *out, spx_word16_t bound, int len){   int i, shift;   spx_word16_t max_val = 0;   for (i=0;i<len;i++)   {      if (in[i]>max_val)         max_val = in[i];      if (-in[i]>max_val)         max_val = -in[i];   }   shift=0;   while (max_val <= (bound>>1) && max_val != 0)   {      max_val <<= 1;      shift++;   }   for (i=0;i<len;i++)   {      out[i] = in[i] << shift;   }      return shift;}static void renorm_range(spx_word16_t *in, spx_word16_t *out, int shift, int len){   int i;   for (i=0;i<len;i++)   {      out[i] = (in[i] + (1<<(shift-1))) >> shift;   }}#endif#ifdef USE_SMALLFT#include "smallft.h"#include <math.h>void *spx_fft_init(int size){   struct drft_lookup *table;   table = celt_alloc(sizeof(struct drft_lookup));   spx_drft_init((struct drft_lookup *)table, size);   return (void*)table;}void spx_fft_destroy(void *table){   spx_drft_clear(table);   celt_free(table);}void spx_fft(void *table, float *in, float *out){   if (in==out)   {      int i;      celt_warning("FFT should not be done in-place");      float scale = 1./((struct drft_lookup *)table)->n;      for (i=0;i<((struct drft_lookup *)table)->n;i++)         out[i] = scale*in[i];   } else {      int i;      float scale = 1./((struct drft_lookup *)table)->n;      for (i=0;i<((struct drft_lookup *)table)->n;i++)         out[i] = scale*in[i];   }   spx_drft_forward((struct drft_lookup *)table, out);}void spx_ifft(void *table, float *in, float *out){   if (in==out)   {      celt_warning("FFT should not be done in-place");   } else {      int i;      for (i=0;i<((struct drft_lookup *)table)->n;i++)         out[i] = in[i];   }   spx_drft_backward((struct drft_lookup *)table, out);}#elif defined(USE_KISS_FFT)#include "kiss_fftr.h"#include "kiss_fft.h"struct kiss_config {   kiss_fftr_cfg forward;   kiss_fftr_cfg backward;   kiss_fft_cpx *freq_data;   int N;};void *spx_fft_init(int size){   struct kiss_config *table;   table = speex_alloc(sizeof(struct kiss_config));   table->freq_data = speex_alloc(sizeof(kiss_fft_cpx)*((size>>1)+1));   table->forward = kiss_fftr_alloc(size,0,NULL,NULL);   table->backward = kiss_fftr_alloc(size,1,NULL,NULL);   table->N = size;   return table;}void spx_fft_destroy(void *table){   struct kiss_config *t = (struct kiss_config *)table;   kiss_fftr_free(t->forward);   kiss_fftr_free(t->backward);   speex_free(t->freq_data);   speex_free(table);}#ifdef FIXED_POINTvoid spx_fft(void *table, spx_word16_t *in, spx_word16_t *out){   int i;   int shift;   struct kiss_config *t = (struct kiss_config *)table;   shift = maximize_range(in, in, 32000, t->N);   kiss_fftr(t->forward, in, t->freq_data);   out[0] = t->freq_data[0].r;   for (i=1;i<t->N>>1;i++)   {      out[(i<<1)-1] = t->freq_data[i].r;      out[(i<<1)] = t->freq_data[i].i;   }   out[(i<<1)-1] = t->freq_data[i].r;   renorm_range(in, in, shift, t->N);   renorm_range(out, out, shift, t->N);}#elsevoid spx_fft(void *table, spx_word16_t *in, spx_word16_t *out){   int i;   float scale;   struct kiss_config *t = (struct kiss_config *)table;   scale = 1./t->N;   kiss_fftr(t->forward, in, t->freq_data);   out[0] = scale*t->freq_data[0].r;   for (i=1;i<t->N>>1;i++)   {      out[(i<<1)-1] = scale*t->freq_data[i].r;      out[(i<<1)] = scale*t->freq_data[i].i;   }   out[(i<<1)-1] = scale*t->freq_data[i].r;}#endifvoid spx_ifft(void *table, spx_word16_t *in, spx_word16_t *out){   int i;   struct kiss_config *t = (struct kiss_config *)table;   t->freq_data[0].r = in[0];   t->freq_data[0].i = 0;   for (i=1;i<t->N>>1;i++)   {      t->freq_data[i].r = in[(i<<1)-1];      t->freq_data[i].i = in[(i<<1)];   }   t->freq_data[i].r = in[(i<<1)-1];   t->freq_data[i].i = 0;   kiss_fftri(t->backward, t->freq_data, out);}#else#error No other FFT implemented#endifint fixed_point = 1;#ifdef FIXED_POINT#include "smallft.h"void spx_fft_float(void *table, float *in, float *out){   int i;#ifdef USE_SMALLFT   int N = ((struct drft_lookup *)table)->n;#elif defined(USE_KISS_FFT)   int N = ((struct kiss_config *)table)->N;#else#endif   spx_word16_t _in[N];   spx_word16_t _out[N];   for (i=0;i<N;i++)      _in[i] = (int)floor(.5+in[i]);   spx_fft(table, _in, _out);   for (i=0;i<N;i++)      out[i] = _out[i];   if (!fixed_point)   {      struct drft_lookup t;      spx_drft_init(&t, ((struct kiss_config *)table)->N);      float scale = 1./((struct kiss_config *)table)->N;      for (i=0;i<((struct kiss_config *)table)->N;i++)         out[i] = scale*in[i];      spx_drft_forward(&t, out);      spx_drft_clear(&t);   }}void spx_ifft_float(void *table, float *in, float *out){   int i;#ifdef USE_SMALLFT   int N = ((struct drft_lookup *)table)->n;#elif defined(USE_KISS_FFT)   int N = ((struct kiss_config *)table)->N;#else#endif   spx_word16_t _in[N];   spx_word16_t _out[N];   for (i=0;i<N;i++)      _in[i] = (int)floor(.5+in[i]);   spx_ifft(table, _in, _out);   for (i=0;i<N;i++)      out[i] = _out[i];   if (!fixed_point)   {      int i;      struct drft_lookup t;      spx_drft_init(&t, ((struct kiss_config *)table)->N);      for (i=0;i<((struct kiss_config *)table)->N;i++)         out[i] = in[i];      spx_drft_backward(&t, out);      spx_drft_clear(&t);   }}#elsevoid spx_fft_float(void *table, float *in, float *out){   spx_fft(table, in, out);}void spx_ifft_float(void *table, float *in, float *out){   spx_ifft(table, in, out);}#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日日摸夜夜添夜夜添精品视频| 久久99久国产精品黄毛片色诱| 亚洲成人第一页| 国产精品一级二级三级| 欧美综合天天夜夜久久| 国产亚洲精品7777| 偷拍亚洲欧洲综合| 色先锋资源久久综合| 久久综合久久综合久久综合| 亚洲国产精品久久久男人的天堂| 丰满少妇在线播放bd日韩电影| 欧美美女激情18p| 亚洲人成精品久久久久久| 国产一区二区三区在线观看精品| 欧美丰满一区二区免费视频| 亚洲欧美日韩久久| 成人黄色av网站在线| 久久亚洲免费视频| 日本在线不卡视频| 欧美日韩卡一卡二| 依依成人精品视频| 97se亚洲国产综合自在线观| 久久久久久久久久美女| 久久99久久99| 91精品国产一区二区| 亚洲国产裸拍裸体视频在线观看乱了 | 精品久久久久99| 三级在线观看一区二区| 欧美日本乱大交xxxxx| 亚洲一区二区视频在线| 欧美亚一区二区| 亚洲欧美日韩国产成人精品影院| 成人听书哪个软件好| 国产欧美日韩另类一区| 国产成人在线影院| 久久久亚洲精华液精华液精华液| 久久激五月天综合精品| 精品国产乱码久久久久久牛牛 | 国产精品久久久久7777按摩| youjizz国产精品| 久久九九久久九九| 国产91精品一区二区麻豆网站| 久久精品男人天堂av| 国产suv一区二区三区88区| 久久久久久**毛片大全| 成人精品一区二区三区四区| 国产精品国产三级国产| 色婷婷综合久久久| 亚洲成人av免费| 91精品国产乱| 国产一区二区三区黄视频 | 欧美调教femdomvk| 丝袜美腿亚洲综合| 日韩欧美第一区| 国产一区二区三区最好精华液| 欧美激情一区二区在线| 一本色道a无线码一区v| 亚洲第一搞黄网站| 精品国产制服丝袜高跟| 国产99久久精品| 亚洲电影第三页| 久久综合九色综合欧美98| 丁香啪啪综合成人亚洲小说 | 日韩成人一级片| 久久久久久久电影| 色婷婷综合久久久久中文一区二区 | 99久久夜色精品国产网站| 夜夜爽夜夜爽精品视频| 欧美变态tickle挠乳网站| 成人免费看视频| 午夜激情久久久| 国产日本欧洲亚洲| 欧美午夜片在线观看| 韩国一区二区三区| 亚洲最大成人综合| 久久综合色综合88| 色综合一个色综合亚洲| 另类调教123区| 亚洲天堂免费在线观看视频| 日韩欧美中文字幕一区| 成人18精品视频| 蜜臀av性久久久久蜜臀aⅴ流畅| 中文字幕国产一区二区| 91麻豆精品国产91久久久久久 | 成人av免费网站| 青青草精品视频| 一区二区三区欧美在线观看| 2020国产精品| 69久久夜色精品国产69蝌蚪网| 成人福利电影精品一区二区在线观看| 午夜婷婷国产麻豆精品| 国产精品黄色在线观看| 精品国产乱子伦一区| 欧美日韩高清影院| 91美女在线看| zzijzzij亚洲日本少妇熟睡| 国产一区二区三区在线看麻豆| 午夜精品福利一区二区蜜股av | 日本中文在线一区| 亚洲第一狼人社区| 亚洲乱码日产精品bd| 国产精品免费看片| 久久久无码精品亚洲日韩按摩| 日韩一区国产二区欧美三区| 欧美日韩一区高清| 欧美日韩一级大片网址| 一本色道久久加勒比精品| www.66久久| hitomi一区二区三区精品| 国产成人精品影视| 国产精品资源在线看| 激情综合网最新| 国产在线不卡视频| 国产美女视频91| 国产精品一区在线观看乱码| 久久99精品久久久久久国产越南| 免费在线视频一区| 久久99久久精品欧美| 乱一区二区av| 激情六月婷婷久久| 国产综合一区二区| 国产精品亚洲第一| 国产91在线|亚洲| www.欧美精品一二区| 99国产精品久久久| 色婷婷综合视频在线观看| 久久免费偷拍视频| 国产人伦精品一区二区| 国产精品久久久久久福利一牛影视| 国产精品久久午夜| 亚洲精品免费播放| 五月激情综合色| 另类小说欧美激情| 成人一道本在线| 色综合天天综合网国产成人综合天| 色婷婷av一区二区三区软件 | 亚洲精品乱码久久久久久 | 日韩激情av在线| 国产专区欧美精品| av男人天堂一区| 欧美日韩国产免费| 精品福利在线导航| 中文字幕制服丝袜一区二区三区| 一区二区三区精品视频| 免费成人av资源网| 不卡av在线免费观看| 欧美最猛性xxxxx直播| 日韩欧美国产1| 日本一区二区视频在线观看| 一区二区三区中文字幕精品精品 | 4438成人网| 中文字幕精品—区二区四季| 亚洲综合视频在线| 黄一区二区三区| 欧美影院一区二区三区| 久久影院午夜论| 亚洲动漫第一页| 国产成人免费9x9x人网站视频| 欧美日韩亚洲另类| 国产欧美综合在线观看第十页| 亚洲一二三专区| 国产成人三级在线观看| 欧美日韩成人高清| 中文幕一区二区三区久久蜜桃| 亚洲国产欧美日韩另类综合| 国产不卡在线一区| 欧美一区二区三区视频| 亚洲色图欧美激情| 国产在线播放一区二区三区| 欧美色手机在线观看| 国产欧美精品一区aⅴ影院| 视频一区欧美日韩| 99国产精品99久久久久久| 久久综合五月天婷婷伊人| 午夜久久福利影院| 99久久精品国产一区| 久久综合九色综合久久久精品综合| 亚洲国产综合91精品麻豆| heyzo一本久久综合| 久久精品视频免费| 老汉av免费一区二区三区| 色94色欧美sute亚洲线路一久 | 国产成人精品亚洲午夜麻豆| 欧美一区二区三区免费观看视频| 亚洲精品一卡二卡| 99视频在线观看一区三区| 久久精品人人爽人人爽| 久久国产精品99久久久久久老狼| 欧美日韩大陆一区二区| 亚洲综合激情网| 91福利小视频| 亚洲老司机在线| 91日韩在线专区| 亚洲视频一区二区在线| 99综合电影在线视频| 欧美国产1区2区| 成人丝袜18视频在线观看| 欧美国产精品一区| 成人高清免费在线播放| 国产精品护士白丝一区av|