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

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

?? filters.c

?? 語音濾波源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* Copyright (C) 2002 Jean-Marc Valin    File: filters.c   Various analysis/synthesis filters   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#include "filters.h"#include "stack_alloc.h"#include "misc.h"#include "math_approx.h"#include "ltp.h"#include <math.h>#ifdef _USE_SSE#include "filters_sse.h"#elif defined (ARM4_ASM) || defined(ARM5E_ASM)#include "filters_arm4.h"#elif defined (BFIN_ASM)#include "filters_bfin.h"#endifvoid bw_lpc(spx_word16_t gamma, const spx_coef_t *lpc_in, spx_coef_t *lpc_out, int order){   int i;   spx_word16_t tmp=gamma;   for (i=0;i<order;i++)   {      lpc_out[i] = MULT16_16_P15(tmp,lpc_in[i]);      tmp = MULT16_16_P15(tmp, gamma);   }}#ifdef FIXED_POINT/* FIXME: These functions are ugly and probably introduce too much error */void signal_mul(const spx_sig_t *x, spx_sig_t *y, spx_word32_t scale, int len){   int i;   for (i=0;i<len;i++)   {      y[i] = SHL32(MULT16_32_Q14(EXTRACT16(SHR32(x[i],7)),scale),7);   }}void signal_div(const spx_sig_t *x, spx_sig_t *y, spx_word32_t scale, int len){   int i;   if (scale > SHL32(EXTEND32(SIG_SCALING), 8))   {      spx_word16_t scale_1;      scale = PSHR32(scale, SIG_SHIFT);      scale_1 = EXTRACT16(DIV32_16(SHL32(EXTEND32(SIG_SCALING),7),scale));      for (i=0;i<len;i++)      {         y[i] = SHR32(MULT16_16(scale_1, EXTRACT16(SHR32(x[i],SIG_SHIFT))),7);      }   } else {      spx_word16_t scale_1;      scale = PSHR32(scale, SIG_SHIFT-5);      scale_1 = DIV32_16(SHL32(EXTEND32(SIG_SCALING),3),scale);      for (i=0;i<len;i++)      {         y[i] = MULT16_16(scale_1, EXTRACT16(SHR32(x[i],SIG_SHIFT-2)));      }   }}#elsevoid signal_mul(const spx_sig_t *x, spx_sig_t *y, spx_word32_t scale, int len){   int i;   for (i=0;i<len;i++)      y[i] = scale*x[i];}void signal_div(const spx_sig_t *x, spx_sig_t *y, spx_word32_t scale, int len){   int i;   float scale_1 = 1/scale;   for (i=0;i<len;i++)      y[i] = scale_1*x[i];}#endif#ifdef FIXED_POINTspx_word16_t compute_rms(const spx_sig_t *x, int len){   int i;   spx_word32_t sum=0;   spx_sig_t max_val=1;   int sig_shift;   for (i=0;i<len;i++)   {      spx_sig_t tmp = x[i];      if (tmp<0)         tmp = -tmp;      if (tmp > max_val)         max_val = tmp;   }   sig_shift=0;   while (max_val>16383)   {      sig_shift++;      max_val >>= 1;   }   for (i=0;i<len;i+=4)   {      spx_word32_t sum2=0;      spx_word16_t tmp;      tmp = EXTRACT16(SHR32(x[i],sig_shift));      sum2 = MAC16_16(sum2,tmp,tmp);      tmp = EXTRACT16(SHR32(x[i+1],sig_shift));      sum2 = MAC16_16(sum2,tmp,tmp);      tmp = EXTRACT16(SHR32(x[i+2],sig_shift));      sum2 = MAC16_16(sum2,tmp,tmp);      tmp = EXTRACT16(SHR32(x[i+3],sig_shift));      sum2 = MAC16_16(sum2,tmp,tmp);      sum = ADD32(sum,SHR32(sum2,6));   }      return EXTRACT16(SHR32(SHL32(EXTEND32(spx_sqrt(1+DIV32(sum,len))),(sig_shift+3)),SIG_SHIFT));}#ifndef OVERRIDE_NORMALIZE16int normalize16(const spx_sig_t *x, spx_word16_t *y, spx_sig_t max_scale, int len){   int i;   spx_sig_t max_val=1;   int sig_shift;      for (i=0;i<len;i++)   {      spx_sig_t tmp = x[i];      if (tmp<0)         tmp = NEG32(tmp);      if (tmp >= max_val)         max_val = tmp;   }   sig_shift=0;   while (max_val>max_scale)   {      sig_shift++;      max_val >>= 1;   }   for (i=0;i<len;i++)      y[i] = EXTRACT16(SHR32(x[i], sig_shift));      return sig_shift;}#endif#elsespx_word16_t compute_rms(const spx_sig_t *x, int len){   int i;   float sum=0;   for (i=0;i<len;i++)   {      sum += x[i]*x[i];   }   return sqrt(.1+sum/len);}#endif#ifndef OVERRIDE_FILTER_MEM2#ifdef PRECISION16void filter_mem2(const spx_sig_t *x, const spx_coef_t *num, const spx_coef_t *den, spx_sig_t *y, int N, int ord, spx_mem_t *mem){   int i,j;   spx_word16_t xi,yi,nyi;   for (i=0;i<N;i++)   {      xi= EXTRACT16(PSHR32(SATURATE(x[i],536870911),SIG_SHIFT));      yi = EXTRACT16(PSHR32(SATURATE(ADD32(x[i], SHL32(mem[0],1)),536870911),SIG_SHIFT));      nyi = NEG16(yi);      for (j=0;j<ord-1;j++)      {         mem[j] = MAC16_16(MAC16_16(mem[j+1], num[j],xi), den[j],nyi);      }      mem[ord-1] = ADD32(MULT16_16(num[ord-1],xi), MULT16_16(den[ord-1],nyi));      y[i] = SHL32(EXTEND32(yi),SIG_SHIFT);   }}#elsevoid filter_mem2(const spx_sig_t *x, const spx_coef_t *num, const spx_coef_t *den, spx_sig_t *y, int N, int ord, spx_mem_t *mem){   int i,j;   spx_sig_t xi,yi,nyi;   for (i=0;i<N;i++)   {      xi=SATURATE(x[i],805306368);      yi = SATURATE(ADD32(xi, SHL32(mem[0],2)),805306368);      nyi = NEG32(yi);      for (j=0;j<ord-1;j++)      {         mem[j] = MAC16_32_Q15(MAC16_32_Q15(mem[j+1], num[j],xi), den[j],nyi);      }      mem[ord-1] = SUB32(MULT16_32_Q15(num[ord-1],xi), MULT16_32_Q15(den[ord-1],yi));      y[i] = yi;   }}#endif#endif#ifndef OVERRIDE_IIR_MEM2#ifdef PRECISION16void iir_mem2(const spx_sig_t *x, const spx_coef_t *den, spx_sig_t *y, int N, int ord, spx_mem_t *mem){   int i,j;   spx_word16_t yi,nyi;   for (i=0;i<N;i++)   {      yi = EXTRACT16(PSHR32(SATURATE(x[i] + SHL32(mem[0],1),536870911),SIG_SHIFT));      nyi = NEG16(yi);      for (j=0;j<ord-1;j++)      {         mem[j] = MAC16_16(mem[j+1],den[j],nyi);      }      mem[ord-1] = MULT16_16(den[ord-1],nyi);      y[i] = SHL32(EXTEND32(yi),SIG_SHIFT);   }}#elsevoid iir_mem2(const spx_sig_t *x, const spx_coef_t *den, spx_sig_t *y, int N, int ord, spx_mem_t *mem){   int i,j;   spx_word32_t xi,yi,nyi;   for (i=0;i<N;i++)   {      xi=SATURATE(x[i],805306368);      yi = SATURATE(xi + SHL32(mem[0],2),805306368);      nyi = NEG32(yi);      for (j=0;j<ord-1;j++)      {         mem[j] = MAC16_32_Q15(mem[j+1],den[j],nyi);      }      mem[ord-1] = MULT16_32_Q15(den[ord-1],nyi);      y[i] = yi;   }}#endif#endif#ifndef OVERRIDE_FIR_MEM2#ifdef PRECISION16void fir_mem2(const spx_sig_t *x, const spx_coef_t *num, spx_sig_t *y, int N, int ord, spx_mem_t *mem){   int i,j;   spx_word16_t xi,yi;   for (i=0;i<N;i++)   {      xi= EXTRACT16(PSHR32(SATURATE(x[i],536870911),SIG_SHIFT));

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美性做爰猛烈叫床潮| 亚洲色图丝袜美腿| 国产精品美女久久福利网站| 亚洲国产成人91porn| 国产一区欧美日韩| 欧美吻胸吃奶大尺度电影| 久久天堂av综合合色蜜桃网| 亚洲第一成年网| 91女厕偷拍女厕偷拍高清| 亚洲精品一区二区三区香蕉| 日韩精品五月天| 欧美午夜精品久久久久久孕妇| 久久久久久久网| 美日韩一级片在线观看| 日本伦理一区二区| 亚洲欧洲日韩在线| 国产黑丝在线一区二区三区| 欧美一卡二卡在线观看| 亚洲午夜激情网页| 在线一区二区三区四区五区| 亚洲婷婷国产精品电影人久久| 国产精品一区三区| 亚洲精品在线免费播放| 美女脱光内衣内裤视频久久影院| 欧美天天综合网| 亚洲色图19p| 94-欧美-setu| ●精品国产综合乱码久久久久| 激情深爱一区二区| 精品精品国产高清a毛片牛牛| 午夜精品久久久| 欧美剧情电影在线观看完整版免费励志电影 | 欧美日韩免费在线视频| 亚洲卡通欧美制服中文| 日本高清不卡视频| 亚洲人亚洲人成电影网站色| 色综合色综合色综合| 亚洲欧洲日韩在线| 日本久久一区二区三区| 亚洲国产视频网站| 91精品国产色综合久久| 免费观看日韩电影| 精品欧美乱码久久久久久1区2区| 日本不卡1234视频| 久久久精品影视| 成人看片黄a免费看在线| 成人免费在线播放视频| 色菇凉天天综合网| 日韩不卡手机在线v区| 日韩精品一区二区三区视频 | 日韩一区二区在线看| 日韩**一区毛片| 久久久www免费人成精品| 国产大陆a不卡| 成人欧美一区二区三区小说 | 成人黄动漫网站免费app| 亚洲美女一区二区三区| 欧美精品丝袜久久久中文字幕| 日韩av电影一区| 国产性色一区二区| 欧美性大战xxxxx久久久| 极品瑜伽女神91| 日韩av午夜在线观看| 精品少妇一区二区三区在线视频| 国产成人欧美日韩在线电影| 亚洲精品午夜久久久| 日韩西西人体444www| 成人午夜大片免费观看| 亚洲国产aⅴ天堂久久| 日韩视频免费观看高清完整版| 国产精品一区免费在线观看| 樱花影视一区二区| 久久影院午夜论| 色视频欧美一区二区三区| 麻豆专区一区二区三区四区五区| 国产精品理论片在线观看| 欧美日韩国产综合视频在线观看 | 亚洲成a人片在线不卡一二三区 | 亚洲视频电影在线| 欧美xxx久久| 在线精品视频免费播放| 国产乱码一区二区三区| 午夜久久久久久久久| 国产午夜久久久久| 日韩欧美国产1| 91在线看国产| 国产老妇另类xxxxx| 高清av一区二区| 麻豆精品一二三| 亚洲成人动漫一区| 日韩伦理av电影| 亚洲国产高清在线观看视频| 欧美xingq一区二区| 欧美精品日日鲁夜夜添| av不卡一区二区三区| 国产一区二区三区蝌蚪| 视频在线观看91| 亚洲二区在线观看| 亚洲日本欧美天堂| 亚洲国产电影在线观看| 久久久久久久性| 精品日韩99亚洲| 欧美一级免费观看| 欧美日韩另类国产亚洲欧美一级| 成人性视频网站| 国产成人精品免费| 国产精品主播直播| 久久国产视频网| 紧缚奴在线一区二区三区| 美女任你摸久久 | 亚洲免费观看高清| 国产精品每日更新在线播放网址| 久久综合色天天久久综合图片| 欧美乱妇23p| 在线播放91灌醉迷j高跟美女| 日本乱人伦一区| 欧美三区在线观看| 欧洲一区二区三区免费视频| 一本久久a久久精品亚洲| 99re热这里只有精品免费视频| aaa亚洲精品一二三区| av不卡一区二区三区| 色综合久久久久综合体| 91福利精品第一导航| 欧美日韩视频在线一区二区| 在线成人免费视频| 日韩久久久精品| 日本一区二区三区在线观看| 国产精品久久看| 亚洲永久免费视频| 天天色 色综合| 国内成人精品2018免费看| 国产成人精品影视| 91网站最新地址| 欧美日韩成人综合| 久久这里只有精品6| 中文字幕一区二区三区色视频| 亚洲视频一区二区在线观看| 亚洲午夜免费电影| 久久精品国产免费| 成人一区二区三区中文字幕| 色综合天天综合在线视频| 欧美精品黑人性xxxx| 久久久久久9999| 亚洲精品视频自拍| 久热成人在线视频| av福利精品导航| 欧美一区永久视频免费观看| 国产三级一区二区三区| 亚洲精品乱码久久久久| 久久精品国产亚洲5555| 99re视频精品| 欧美大片一区二区三区| 亚洲精品成人悠悠色影视| 美女脱光内衣内裤视频久久网站| 成人性生交大片免费看视频在线| 欧美人与禽zozo性伦| 国产三级欧美三级日产三级99| 伊人性伊人情综合网| 国产在线精品免费av| 在线观看免费亚洲| 久久蜜臀精品av| 日韩成人dvd| 91视频在线观看| 久久蜜桃av一区二区天堂| 亚洲综合色自拍一区| 成人国产一区二区三区精品| 91精品国产品国语在线不卡| 中文字幕一区视频| 国产一区二三区| 欧美日韩高清影院| 亚洲视频在线观看三级| 国产成人亚洲综合a∨婷婷图片 | 亚洲国产精品自拍| www.av亚洲| 久久久久久久久久久黄色| 五月天一区二区| 在线观看www91| 日韩伦理av电影| av在线不卡免费看| 久久久噜噜噜久噜久久综合| 美女脱光内衣内裤视频久久影院| 欧美性大战xxxxx久久久| 亚洲欧美在线高清| 丁香婷婷综合色啪| 久久综合九色综合欧美就去吻 | 亚洲精品国产一区二区精华液| 国产一区二区不卡| 日韩一区二区麻豆国产| 亚洲一区二区三区自拍| 一本到高清视频免费精品| 国产欧美日韩在线看| 国产成人亚洲综合a∨婷婷| 日韩午夜三级在线| 日韩成人精品在线观看| 欧美久久高跟鞋激| 日韩国产欧美在线播放| 欧美日韩精品欧美日韩精品一综合| 一区二区三区不卡视频| 91国内精品野花午夜精品|