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

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

?? aec.cxx

?? MiniSip Client with DomainKeys Authentication, Sip, Audio communications, Echo Cancel
?? CXX
字號:
/* aec.cxx * Acoustic Echo Cancellation NLMS-pw algorithm * Author: Andre Adrian, DFS Deutsche Flugsicherung * <Andre.Adrian@dfs.de> * * Version 1.1 */#include<config.h>#ifdef _MSC_VER#define _USE_MATH_DEFINES#endif#include <stdio.h>#include <stdlib.h>#include <math.h>#include <string.h>#include<libminisip/aec/aec.h>#ifdef _WIN32_WCE# define M_PI           3.14159265358979323846  /* pi */#endif/* ================================================================ *//* Exponential Smoothing or IIR Infinite Impulse Response Filter */IIR6::IIR6(){  memset(this, 0, sizeof(IIR6));}float IIR6::lowpass(float in){  const float AlphaLp = 0.15f;	/* controls Transfer Frequence */  /* Lowpass = Exponential Smoothing */  lowpassf[0] = in;  int i;  for (i = 0; i < 2*POL; ++i) {    lowpassf[i+1] += AlphaLp*(lowpassf[i] - lowpassf[i+1]);  }  return lowpassf[2*POL];   }/* ================================================================ *//* * Algorithm:  Recursive single pole FIR high-pass filter * * Reference: The Scientist and Engineer's Guide to Digital Processing */FIR1::FIR1(){  float x = (float) exp(-2.0 * M_PI * PreWhiteTransferFreq/8000.0f);    a0 = (1.0f + x) / 2.0f;  a1 = -(1.0f + x) / 2.0f;  b1 = x;  last_in = 0.0f;  last_out = 0.0f;}/* ================================================================ *//* Vector Dot Product */float dotp(float a[], float b[]) {  float sum0 = 0.0, sum1 = 0.0;  int j;    for (j = 0; j < NLMS_LEN; j+= 2) {    // optimize: partial loop unrolling    sum0 += a[j] * b[j];    sum1 += a[j+1] * b[j+1];  }  return sum0+sum1;}AEC::AEC(){  max_max_x = 0.0f;  hangover = 0;  memset(max_x, 0, sizeof(max_x));  dtdCnt = dtdNdx = 0;    memset(x, 0, sizeof(x));  memset(xf, 0, sizeof(xf));  memset(w, 0, sizeof(w));  j = NLMS_EXT;  lastupdate = 0;  dotp_xf_xf = 0.0f;}/* Normalized Least Mean Square Algorithm pre-whitening (NLMS-pw) * The LMS algorithm was developed by Bernard Widrow * book: Widrow/Stearns, Adaptive Signal Processing, Prentice-Hall, 1985 * * in mic: microphone sample (PCM as floating point value) * in spk: loudspeaker sample (PCM as floating point value) * in update: 0 for convolve only, 1 for convolve and update  * return: echo cancelled microphone sample */float AEC::nlms_pw(float mic, float spk, int update){  float d = mic;      	      	  // desired signal  x[j] = spk;  xf[j] = Fx.highpass(spk);       // pre-whitening of x  // calculate error value (mic signal - estimated mic signal from spk signal)  float e = d - dotp(w, x + j);    if (update) {        float ef = Fe.highpass(e);    // pre-whitening of e        if (lastupdate) {      // optimize: iterative dotp(xf, xf)      dotp_xf_xf += (xf[j]*xf[j] - xf[j+NLMS_LEN-1]*xf[j+NLMS_LEN-1]);    } else {      dotp_xf_xf = dotp(xf+j, xf+j);    }           // calculate variable step size    float mikro_ef = 0.5f/dotp_xf_xf * ef;        // update tap weights (filter learning)    int i;    for (i = 0; i < NLMS_LEN; i += 2) {      // optimize: partial loop unrolling      w[i] += mikro_ef*xf[i+j];      w[i+1] += mikro_ef*xf[i+j+1];    }  }  lastupdate = update;    if (--j < 0) {    // optimize: decrease number of memory copies    j = NLMS_EXT;    memmove(x+j+1, x, (NLMS_LEN-1)*sizeof(float));        memmove(xf+j+1, xf, (NLMS_LEN-1)*sizeof(float));      }    return e;}/* Geigel Double-Talk Detector * * in d: microphone sample (PCM as floating point value) * in x: loudspeaker sample (PCM as floating point value) * return: 0 for no talking, 1 for talking */int AEC::dtd(float d, float x){  // optimized implementation of max(|x[0]|, |x[1]|, .., |x[L-1]|):  // calculate max of block (DTD_LEN values)  x = fabsf(x);  if (x > max_x[dtdNdx]) {    max_x[dtdNdx] = x;    if (x > max_max_x) {      max_max_x = x;    }  }  if (++dtdCnt >= DTD_LEN) {    dtdCnt = 0;    // calculate max of max    max_max_x = 0.0f;    for (int i = 0; i < NLMS_LEN/DTD_LEN; ++i) {      if (max_x[i] > max_max_x) {        max_max_x = max_x[i];      }    }    // rotate Ndx    if (++dtdNdx >= NLMS_LEN/DTD_LEN) dtdNdx = 0;    max_x[dtdNdx] = 0.0f;  }  // The Geigel DTD algorithm with Hangover timer Thold  if (fabsf(d) >= GeigelThreshold * max_max_x) {    hangover = Thold;  }      if (hangover) --hangover;    if (max_max_x < UpdateThreshold) {    // avoid update with silence    return 1;  } else {    return (hangover > 0);  }}int AEC::doAEC(int d, int x) {  float s0 = (float)d;  float s1 = (float)x;    // Mic and Spk signal remove DC (IIR highpass filter)  s0 = dc0.highpass(s0);  s1 = dc1.highpass(s1);  // Mic Highpass Filter - telephone users are used to 300Hz cut-off  s0 = hp0.highpass(s0);  // Double Talk Detector  int update = !dtd(s0, s1);  // Acoustic Echo Cancellation  s0 = nlms_pw(s0, s1, update);  // Acoustic Echo Suppression  if (update) {    // Non Linear Processor (NLP): attenuate low volumes    s0 *= NLPAttenuation;  }    // Saturation  if (s0 > MAXPCM) {    return (int)MAXPCM;  } else if (s0 < -MAXPCM) {    return (int)-MAXPCM;  } else {    return (int)floorf( ( float)(s0+0.5) );  }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91麻豆精品国产91久久久久久久久 | 欧美极品美女视频| 91网站最新地址| 日本不卡免费在线视频| 国产精品久久久久久久久果冻传媒| 欧美日韩一区二区在线观看| 国产白丝精品91爽爽久久| 日韩精品一区第一页| 1000部国产精品成人观看| 日韩欧美第一区| 欧美日韩中文字幕精品| 成人理论电影网| 激情av综合网| 日本中文字幕不卡| 亚洲一级片在线观看| 欧美国产日韩一二三区| 日韩精品一区在线观看| 欧美理论电影在线| 欧洲一区二区av| 91网站黄www| 成人中文字幕电影| 国产一二三精品| 韩国中文字幕2020精品| 亚洲成人黄色小说| 亚洲欧美一区二区在线观看| 久久精品亚洲精品国产欧美kt∨| 91精品国产91热久久久做人人| aa级大片欧美| 成人免费看视频| 国产成+人+日韩+欧美+亚洲| 麻豆高清免费国产一区| 日本女优在线视频一区二区| 亚洲一区二区三区免费视频| 亚洲欧洲色图综合| 国产精品久久三区| 国产日产欧美一区二区三区| 久久影院午夜论| 日韩久久久精品| 欧美成人一区二区三区在线观看| 欧美人伦禁忌dvd放荡欲情| 日本韩国欧美在线| 欧美无乱码久久久免费午夜一区| 91视频在线观看免费| 91蜜桃免费观看视频| 99久久精品一区二区| 91一区二区三区在线观看| 99久久精品免费观看| 99精品欧美一区二区三区小说| 不卡一区二区在线| 一本色道亚洲精品aⅴ| 在线观看一区日韩| 欧美午夜宅男影院| 69p69国产精品| 日韩一区二区三区免费看| 欧美大胆一级视频| 久久综合国产精品| 久久精品亚洲精品国产欧美kt∨| 国产女人18水真多18精品一级做 | www.欧美色图| 97久久超碰国产精品| 成人精品免费网站| av午夜一区麻豆| 在线亚洲免费视频| 91精品国产免费| 欧美sm美女调教| 欧美极品少妇xxxxⅹ高跟鞋 | 久久精品99国产精品| 国产一区二区三区在线观看精品| 成人一区二区三区在线观看| 91蝌蚪国产九色| 欧美一个色资源| 国产精品天美传媒| 有码一区二区三区| 成人高清免费在线播放| 色就色 综合激情| 91精品一区二区三区久久久久久| 26uuu精品一区二区三区四区在线| 国产精品蜜臀av| 亚洲电影视频在线| 国产精一区二区三区| 91视视频在线直接观看在线看网页在线看 | 无码av中文一区二区三区桃花岛| 精品亚洲成a人| 91麻豆精东视频| 精品美女被调教视频大全网站| 亚洲国产精品激情在线观看| 亚洲激情成人在线| 国产一区二区在线看| 一本大道av一区二区在线播放| 欧美日韩精品高清| 国产日本欧洲亚洲| 日本中文在线一区| 99精品视频免费在线观看| 日韩网站在线看片你懂的| 亚洲人成在线播放网站岛国 | 色哟哟一区二区| 日韩欧美亚洲一区二区| 亚洲欧美二区三区| 久久er99热精品一区二区| 欧美吞精做爰啪啪高潮| 国产香蕉久久精品综合网| 天天综合天天做天天综合| 99免费精品视频| 精品国产乱码久久久久久久久 | 成人小视频在线| 在线成人免费视频| 国产精品美女一区二区三区| 日本美女一区二区| 91精彩视频在线观看| 国产欧美精品一区aⅴ影院| 蜜乳av一区二区| 欧美午夜电影网| 亚洲欧美成人一区二区三区| 国产成人精品影视| 欧美一区二区三区免费在线看 | 在线观看亚洲精品视频| 久久久久久久综合色一本| 日韩av电影一区| 欧美女孩性生活视频| 亚洲国产精品久久人人爱| 91色porny蝌蚪| 国产精品国产三级国产普通话蜜臀| 麻豆成人91精品二区三区| 69成人精品免费视频| 亚洲国产精品久久久男人的天堂| 99国产精品国产精品毛片| 国产日产欧美一区二区三区 | 成人影视亚洲图片在线| 精品国产伦理网| proumb性欧美在线观看| 国产剧情av麻豆香蕉精品| 色综合久久综合中文综合网| 国产精品天干天干在观线| 国产成人av一区| 久久久国产精品不卡| 国产精品66部| 国产欧美日韩一区二区三区在线观看| 精品伊人久久久久7777人| 91麻豆精品久久久久蜜臀| 国产亚洲污的网站| 国产成人免费视频一区| 亚洲电影欧美电影有声小说| 成人18视频日本| 久久婷婷久久一区二区三区| 亚洲一区二区五区| 99在线精品观看| 日本一区二区成人| 精品一区二区三区久久| 51久久夜色精品国产麻豆| 亚洲精品日韩一| 成人av在线影院| 久久影音资源网| 国精品**一区二区三区在线蜜桃| 欧美在线视频日韩| 亚洲免费伊人电影| 91亚洲精品乱码久久久久久蜜桃| 国产亚洲一区二区三区| 久久国产精品色婷婷| 欧美va亚洲va在线观看蝴蝶网| 无吗不卡中文字幕| 在线播放亚洲一区| 日日噜噜夜夜狠狠视频欧美人 | 不卡视频在线观看| 国产欧美精品一区二区色综合| 国产一区二区三区蝌蚪| 久久天天做天天爱综合色| 另类成人小视频在线| 欧美一区二区三区视频| 三级成人在线视频| 91 com成人网| 日韩有码一区二区三区| 91精品国产高清一区二区三区| 首页国产欧美久久| 56国语精品自产拍在线观看| 日本美女视频一区二区| 日韩精品在线一区二区| 韩国欧美国产一区| 久久久噜噜噜久久人人看| 国产91精品精华液一区二区三区| 久久精品亚洲麻豆av一区二区 | 91精品国产免费久久综合| 奇米综合一区二区三区精品视频| 欧美日本一区二区在线观看| 日韩电影在线观看电影| 日韩精品一区二区三区swag| 国内偷窥港台综合视频在线播放| 中文字幕欧美激情| 91视频.com| 水野朝阳av一区二区三区| 精品少妇一区二区三区视频免付费 | 91国内精品野花午夜精品 | 亚洲三级在线播放| 91国偷自产一区二区三区观看| 午夜欧美2019年伦理| 日韩欧美另类在线| 国产裸体歌舞团一区二区| 亚洲三级在线看| 日韩一二三区不卡| 成人精品国产福利| 亚洲成人自拍偷拍|