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

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

?? scal.c

?? mediastreamer2是開源的網絡傳輸媒體流的庫
?? C
字號:
/* Copyright (C) 2006-2008 CSIRO, Jean-Marc Valin, Xiph.Org Foundation   File: scal.c   Shaped comb-allpass filter for channel decorrelation   Redistribution and use in source and binary forms, with or without   modification, are permitted provided that the following conditions are   met:   1. Redistributions of source code must retain the above copyright notice,   this list of conditions and the following disclaimer.   2. 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.   3. The name of the author may not be used to endorse or promote products   derived from this software without specific prior written permission.   THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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.*//*The algorithm implemented here is described in:* J.-M. Valin, Perceptually-Motivated Nonlinear Channel Decorrelation For   Stereo Acoustic Echo Cancellation, Accepted for Joint Workshop on   Hands-free Speech Communication and Microphone Arrays (HSCMA), 2008.  http://people.xiph.org/~jm/papers/valin_hscma2008.pdf*/#ifdef HAVE_CONFIG_H#include "config.h"#endif#include "speex/speex_echo.h"#include "vorbis_psy.h"#include "arch.h"#include "os_support.h"#include "smallft.h"#include <math.h>#include <stdlib.h>#define ALLPASS_ORDER 20struct SpeexDecorrState_ {   int rate;   int channels;   int frame_size;#ifdef VORBIS_PSYCHO   VorbisPsy *psy;   struct drft_lookup lookup;   float *wola_mem;   float *curve;#endif   float *vorbis_win;   int    seed;   float *y;      /* Per-channel stuff */   float *buff;   float (*ring)[ALLPASS_ORDER];   int *ringID;   int *order;   float *alpha;};EXPORT SpeexDecorrState *speex_decorrelate_new(int rate, int channels, int frame_size){   int i, ch;   SpeexDecorrState *st = speex_alloc(sizeof(SpeexDecorrState));   st->rate = rate;   st->channels = channels;   st->frame_size = frame_size;#ifdef VORBIS_PSYCHO   st->psy = vorbis_psy_init(rate, 2*frame_size);   spx_drft_init(&st->lookup, 2*frame_size);   st->wola_mem = speex_alloc(frame_size*sizeof(float));   st->curve = speex_alloc(frame_size*sizeof(float));#endif   st->y = speex_alloc(frame_size*sizeof(float));   st->buff = speex_alloc(channels*2*frame_size*sizeof(float));   st->ringID = speex_alloc(channels*sizeof(int));   st->order = speex_alloc(channels*sizeof(int));   st->alpha = speex_alloc(channels*sizeof(float));   st->ring = speex_alloc(channels*ALLPASS_ORDER*sizeof(float));      /*FIXME: The +20 is there only as a kludge for ALL_PASS_OLA*/   st->vorbis_win = speex_alloc((2*frame_size+20)*sizeof(float));   for (i=0;i<2*frame_size;i++)      st->vorbis_win[i] = sin(.5*M_PI* sin(M_PI*i/(2*frame_size))*sin(M_PI*i/(2*frame_size)) );   st->seed = rand();      for (ch=0;ch<channels;ch++)   {      for (i=0;i<ALLPASS_ORDER;i++)         st->ring[ch][i] = 0;      st->ringID[ch] = 0;      st->alpha[ch] = 0;      st->order[ch] = 10;   }   return st;}static float uni_rand(int *seed){   const unsigned int jflone = 0x3f800000;   const unsigned int jflmsk = 0x007fffff;   union {int i; float f;} ran;   *seed = 1664525 * *seed + 1013904223;   ran.i = jflone | (jflmsk & *seed);   ran.f -= 1.5;   return 2*ran.f;}static unsigned int irand(int *seed){   *seed = 1664525 * *seed + 1013904223;   return ((unsigned int)*seed)>>16;}EXPORT void speex_decorrelate(SpeexDecorrState *st, const spx_int16_t *in, spx_int16_t *out, int strength){   int ch;   float amount;      if (strength<0)      strength = 0;   if (strength>100)      strength = 100;      amount = .01*strength;   for (ch=0;ch<st->channels;ch++)   {      int i;      int N=2*st->frame_size;      float beta, beta2;      float *x;      float max_alpha = 0;            float *buff;      float *ring;      int ringID;      int order;      float alpha;      buff = st->buff+ch*2*st->frame_size;      ring = st->ring[ch];      ringID = st->ringID[ch];      order = st->order[ch];      alpha = st->alpha[ch];            for (i=0;i<st->frame_size;i++)         buff[i] = buff[i+st->frame_size];      for (i=0;i<st->frame_size;i++)         buff[i+st->frame_size] = in[i*st->channels+ch];      x = buff+st->frame_size;      beta = 1.-.3*amount*amount;      if (amount>1)         beta = 1-sqrt(.4*amount);      else         beta = 1-0.63246*amount;      if (beta<0)         beta = 0;         beta2 = beta;      for (i=0;i<st->frame_size;i++)      {         st->y[i] = alpha*(x[i-ALLPASS_ORDER+order]-beta*x[i-ALLPASS_ORDER+order-1])*st->vorbis_win[st->frame_size+i+order]                + x[i-ALLPASS_ORDER]*st->vorbis_win[st->frame_size+i]                - alpha*(ring[ringID]               - beta*ring[ringID+1>=order?0:ringID+1]);         ring[ringID++]=st->y[i];         st->y[i] *= st->vorbis_win[st->frame_size+i];         if (ringID>=order)            ringID=0;      }      order = order+(irand(&st->seed)%3)-1;      if (order < 5)         order = 5;      if (order > 10)         order = 10;      /*order = 5+(irand(&st->seed)%6);*/      max_alpha = pow(.96+.04*(amount-1),order);      if (max_alpha > .98/(1.+beta2))         max_alpha = .98/(1.+beta2);         alpha = alpha + .4*uni_rand(&st->seed);      if (alpha > max_alpha)         alpha = max_alpha;      if (alpha < -max_alpha)         alpha = -max_alpha;      for (i=0;i<ALLPASS_ORDER;i++)         ring[i] = 0;      ringID = 0;      for (i=0;i<st->frame_size;i++)      {         float tmp =  alpha*(x[i-ALLPASS_ORDER+order]-beta*x[i-ALLPASS_ORDER+order-1])*st->vorbis_win[i+order]                + x[i-ALLPASS_ORDER]*st->vorbis_win[i]                - alpha*(ring[ringID]               - beta*ring[ringID+1>=order?0:ringID+1]);         ring[ringID++]=tmp;         tmp *= st->vorbis_win[i];         if (ringID>=order)            ringID=0;         st->y[i] += tmp;      }   #ifdef VORBIS_PSYCHO      float frame[N];      float scale = 1./N;      for (i=0;i<2*st->frame_size;i++)         frame[i] = buff[i];   //float coef = .5*0.78130;      float coef = M_PI*0.075063 * 0.93763 * amount * .8 * 0.707;      compute_curve(st->psy, buff, st->curve);      for (i=1;i<st->frame_size;i++)      {         float x1,x2;         float gain;         do {            x1 = uni_rand(&st->seed);            x2 = uni_rand(&st->seed);         } while (x1*x1+x2*x2 > 1.);         gain = coef*sqrt(.1+st->curve[i]);         frame[2*i-1] = gain*x1;         frame[2*i] = gain*x2;      }      frame[0] = coef*uni_rand(&st->seed)*sqrt(.1+st->curve[0]);      frame[2*st->frame_size-1] = coef*uni_rand(&st->seed)*sqrt(.1+st->curve[st->frame_size-1]);      spx_drft_backward(&st->lookup,frame);      for (i=0;i<2*st->frame_size;i++)         frame[i] *= st->vorbis_win[i];#endif         for (i=0;i<st->frame_size;i++)      {#ifdef VORBIS_PSYCHO         float tmp = st->y[i] + frame[i] + st->wola_mem[i];         st->wola_mem[i] = frame[i+st->frame_size];#else         float tmp = st->y[i];#endif         if (tmp>32767)            tmp = 32767;         if (tmp < -32767)            tmp = -32767;         out[i*st->channels+ch] = tmp;      }            st->ringID[ch] = ringID;      st->order[ch] = order;      st->alpha[ch] = alpha;   }}EXPORT void speex_decorrelate_destroy(SpeexDecorrState *st){#ifdef VORBIS_PSYCHO   vorbis_psy_destroy(st->psy);   speex_free(st->wola_mem);   speex_free(st->curve);#endif   speex_free(st->buff);   speex_free(st->ring);   speex_free(st->ringID);   speex_free(st->alpha);   speex_free(st->vorbis_win);   speex_free(st->order);   speex_free(st->y);   speex_free(st);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区精品在线| 在线亚洲精品福利网址导航| 成人a免费在线看| 91麻豆精品国产91久久久久| 国产女同互慰高潮91漫画| 久久精品国产第一区二区三区| 91欧美一区二区| 国产欧美日韩久久| 午夜精品在线视频一区| 99精品视频一区二区三区| 精品久久久久久最新网址| 亚洲成av人片www| 色94色欧美sute亚洲线路一ni| 久久香蕉国产线看观看99| 日韩中文字幕91| 欧美在线制服丝袜| 自拍偷自拍亚洲精品播放| 国产精品一区二区你懂的| 日韩一区二区电影网| 亚洲一区二区三区四区在线免费观看| 国产69精品久久777的优势| 精品久久久久99| 美女尤物国产一区| 69久久99精品久久久久婷婷 | 国产乱对白刺激视频不卡| 欧美日韩国产综合久久| 亚洲一区二区三区四区五区黄| 国产99久久久国产精品| 国产日韩精品视频一区| 国产精品一线二线三线精华| 日韩欧美亚洲国产精品字幕久久久| 日韩激情av在线| 91麻豆精品国产自产在线| 午夜精品福利一区二区三区蜜桃| 欧美色精品天天在线观看视频| 亚洲主播在线观看| 欧美日本一道本| 免费观看日韩电影| 欧美精品一区二| 国产主播一区二区| 国产精品久久久一区麻豆最新章节| 国产成人精品综合在线观看 | 中文字幕一区二区三区四区不卡| 国产91精品免费| 综合激情成人伊人| 欧美在线不卡一区| 日韩国产欧美在线视频| 日韩三级在线观看| 国产精品一级在线| 日韩一区欧美小说| 欧美日本在线播放| 久久99精品国产麻豆不卡| 久久久国产午夜精品| 91在线免费视频观看| 午夜伊人狠狠久久| 久久这里只有精品6| 99久久国产综合精品麻豆| 亚洲国产成人av好男人在线观看| 欧美一级电影网站| 成人sese在线| 日韩精品乱码av一区二区| 精品入口麻豆88视频| zzijzzij亚洲日本少妇熟睡| 亚洲午夜免费视频| 国产日韩欧美亚洲| 欧美羞羞免费网站| 国产一区二区三区观看| 亚洲欧美激情一区二区| 欧美一区欧美二区| 高清在线成人网| 天堂一区二区在线| 国产精品无人区| 欧美日本高清视频在线观看| 国产精品一线二线三线| 亚洲在线免费播放| 国产亚洲短视频| 欧美视频在线一区| 成人美女视频在线看| 丝袜美腿高跟呻吟高潮一区| 欧美经典三级视频一区二区三区| 欧美亚洲一区二区在线| 国产一区二区三区综合| 亚洲福利一区二区三区| 国产女人aaa级久久久级| 欧美男人的天堂一二区| 成人av资源在线观看| 秋霞午夜鲁丝一区二区老狼| 最新国产の精品合集bt伙计| 精品国产区一区| 欧美日韩成人一区二区| 97se亚洲国产综合自在线不卡| 捆绑紧缚一区二区三区视频| 亚洲综合免费观看高清在线观看| 欧美国产日韩在线观看| 精品少妇一区二区三区在线播放| 欧美日韩一卡二卡三卡| 91视频免费播放| 国产+成+人+亚洲欧洲自线| 久久精工是国产品牌吗| 五月天激情综合网| 亚洲第一会所有码转帖| 亚洲猫色日本管| 国产精品久久久久久一区二区三区| 日韩欧美高清在线| 69精品人人人人| 欧美人动与zoxxxx乱| 91麻豆成人久久精品二区三区| 国产精品一区二区三区四区 | 91精品一区二区三区久久久久久| 91国内精品野花午夜精品| 成人黄色综合网站| 成人午夜私人影院| 成人激情av网| 99久久精品免费看国产免费软件| 国产精品亚洲一区二区三区在线 | 91精品国产91热久久久做人人| 国产欧美一区二区精品婷婷 | 色综合色综合色综合 | 国产精品免费av| 日本一区二区三区免费乱视频| 精品理论电影在线观看| 精品少妇一区二区三区在线视频| 精品国产成人系列| 国产情人综合久久777777| 国产欧美1区2区3区| 国产精品美日韩| 亚洲欧美激情一区二区| 亚洲午夜影视影院在线观看| 亚洲永久精品大片| 青青国产91久久久久久| 久久99久国产精品黄毛片色诱| 精品一区二区三区久久| 国产精品一区二区三区乱码| 成人丝袜视频网| 欧美在线一区二区| 日韩午夜小视频| 国产日本一区二区| 伊人婷婷欧美激情| 日韩中文欧美在线| 国产在线精品一区二区三区不卡| 国产suv精品一区二区6| 色国产综合视频| 日韩欧美三级在线| 欧美极品aⅴ影院| 亚洲午夜久久久久久久久久久| 日本亚洲免费观看| 懂色一区二区三区免费观看| 91成人网在线| 欧美sm美女调教| 亚洲男同1069视频| 日本少妇一区二区| 不卡av电影在线播放| 欧美唯美清纯偷拍| 久久久影视传媒| 一区二区三区加勒比av| 久久电影网电视剧免费观看| av在线一区二区| 日韩西西人体444www| 中文字幕一区二区三区不卡| 午夜视黄欧洲亚洲| 不卡视频一二三| 欧美大肚乱孕交hd孕妇| 国产精品超碰97尤物18| 日韩电影免费在线| 成人三级伦理片| 精品美女在线观看| 亚洲一区二区中文在线| 国产在线视频一区二区三区| 91久久线看在观草草青青| 精品国产露脸精彩对白| 亚洲一区二区三区美女| 国产成人亚洲精品青草天美| 在线播放欧美女士性生活| 亚洲国产经典视频| 精品中文字幕一区二区小辣椒| 色狠狠综合天天综合综合| 国产视频911| 激情综合色丁香一区二区| 欧美久久久久久蜜桃| 亚洲视频综合在线| 福利电影一区二区三区| 精品剧情在线观看| 日日夜夜精品免费视频| 色综合欧美在线视频区| 中文在线一区二区| 国内精品第一页| 欧美α欧美αv大片| 午夜不卡av在线| 欧美体内she精高潮| 中文字幕日本不卡| 成人国产在线观看| 国产精品视频一区二区三区不卡| 韩国av一区二区三区在线观看| 91精品国产欧美一区二区成人| 亚洲国产成人精品视频| 欧美在线视频日韩| 一区二区三区影院| 欧美自拍偷拍一区| 亚洲一区在线观看网站| 欧美艳星brazzers|