青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

Speex 一個開源的聲學回聲消除器(Acoustic Echo Cancellation)

轉載自:http://blog.csdn.net/chinabinlang/article/details/8086014

在一般的VOIP軟件或視頻會議系統中,假設我們只有A和B兩個人在通話,首先,A的聲音傳給B,B然后用喇叭放出來,而這時B的MIC呢則會采集到喇叭放出來的聲音,然后傳回給A,如果這個傳輸的過程中時延足夠大,A就會聽到一個和自己剛才說過的話一樣的聲音,這就是回聲,聲學回聲消除器的作用就是在B端對B采集到的聲音進行處理,把采集到聲音包含的A的聲音去掉再傳給A,這樣,A就不會聽到自己說過的話了。
聲學回聲消除的原理我就不說了,這在網上有很多文檔,網上缺少的是實現,所以,我在這把一個開源的聲學回聲消除器介紹一下,希望對有些有人用,如果有人知道怎么把這消除器用的基于實時流的VOIP軟件中,希望能一起分享一下。
這個聲學回聲消除器是一個著名的音頻編解碼器speex中的一部分,1.1.9版本后的回聲消除器才起作用,以前版本的都不行,我用的也是這個版本,測試表明,用同一個模擬文件,它有效果比INTEL IPP庫4.1版中的聲學回聲消除器的還要好。
先說編譯。首先,從www.speex.org上下載speex1.1.9的源代碼,解壓,打開speex/win32/libspeex中的libspeex.dsw,這個工作區里有兩個工程,一個是libspeex,另一個是libspeex_dynamic。然后,將libspeex中的mdf.c文件添加到工程libspeex中,編譯即可。
以下是我根據文檔封裝的一個類,里面有一個測試程序:
 //file name: speexEC.h
#ifndef SPEEX_EC_H
#define SPEEX_EC_H
#include 
<stdio.h>
#include 
<stdlib.h>
#include 
"speex/speex_echo.h"
#include 
"speex/speex_preprocess.h" 
class CSpeexEC
{
public:
CSpeexEC();
~CSpeexEC();
void Init(int frame_size=160int filter_length=1280int sampling_rate=8000); 
void DoAEC(short *mic, short *refshort *out);

protected:
void Reset();

private:
bool      m_bHasInit;
SpeexEchoState
*   m_pState;
    SpeexPreprocessState
* m_pPreprocessorState;
int      m_nFrameSize;
int      m_nFilterLen;
int      m_nSampleRate;
float*      m_pfNoise;
}
;

#endif

//fine name:speexEC.cpp
#include "SpeexEC.h"

CSpeexEC::CSpeexEC()
{
m_bHasInit   
= false;
m_pState   
= NULL;
m_pPreprocessorState  
= NULL;
m_nFrameSize   
= 160;
m_nFilterLen   
= 160*8;
m_nSampleRate   
= 8000;
m_pfNoise   
= NULL;
}


CSpeexEC::
~CSpeexEC()
{
Reset();
}


void CSpeexEC::Init(int frame_size, int filter_length, int sampling_rate)
{
Reset(); 

if (frame_size<=0 || filter_length<=0 || sampling_rate<=0)
{
  m_nFrameSize  
=160;
  m_nFilterLen  
= 160*8;
  m_nSampleRate 
= 8000;
}

else
{
  m_nFrameSize  
=frame_size;
  m_nFilterLen  
= filter_length;
  m_nSampleRate 
= sampling_rate;
}


m_pState 
= speex_echo_state_init(m_nFrameSize, m_nFilterLen);
m_pPreprocessorState 
= speex_preprocess_state_init(m_nFrameSize, m_nSampleRate);
m_pfNoise 
= new float[m_nFrameSize+1];
m_bHasInit 
= true;
}


void CSpeexEC::Reset()
{
if (m_pState != NULL)
{
  speex_echo_state_destroy(m_pState);
  m_pState 
= NULL;
}

if (m_pPreprocessorState != NULL)
{
  speex_preprocess_state_destroy(m_pPreprocessorState);
  m_pPreprocessorState 
= NULL;
}

if (m_pfNoise != NULL)
{
  delete []m_pfNoise;
  m_pfNoise 
= NULL;
}

m_bHasInit 
= false;
}


void CSpeexEC:DoAEC(short* mic, short* refshort* out)
{
if (!m_bHasInit)
  
return;

speex_echo_cancel(m_pState, mic, 
refout, m_pfNoise);
    speex_preprocess(m_pPreprocessorState, (__int16 
*)out, m_pfNoise);
    
}

可以看出,這個回聲消除器類很簡單,只要初始化一下就可以調用了。但是,要注意的是,傳給回聲消除器的兩個聲音信號,必須同步得非常的好,就是說,在B端,接收到A說的話以后,要把這些話音數據傳給回聲消除器做參考,然后再傳給聲卡,聲卡再放出來,這有一段延時,這時,B再采集,然后傳給回聲消除器,與那個參考數據比較,從采集到的數據中把頻域和參考數據相同的部分消除掉。如果傳給消除器的兩個信號同步得不好,即兩個信號找不到頻域相同的部分,就沒有辦法進行消除了。
測試程序:
#define NN 160
void main()
{
FILE
* ref_fd, *mic_fd, *out_fd;
short ref[NN], mic[NN], out[NN];
ref_fd 
= fopen ("ref.pcm""rb"); //打開參考文件,即要消除的聲音
mic_fd = fopen ("mic.pcm",  "rb");//打開mic采集到的聲音文件,包含回聲在里面
out_fd = fopen ("echo.pcm""wb");//消除了回聲以后的文件

CSpeexEC ec;
ec.Init();

while (fread(mic, 1, NN*2, mic_fd))
   
{
      fread(
ref1, NN*2, ref_fd);  
      ec.DoAEC(mic, 
refout);
      fwrite(
out1, NN*2, out_fd);
   }

  
   fclose(ref_fd);
   fclose(mic_fd);
   fclose(out_fd);
}
  以上的程序是用文件來模擬回聲和MIC,但在實時流中是大不一樣的,在一般的VOIP軟件中,接收對方的聲音并傳到聲卡中播放是在一個線程中進行的,而采集本地的聲音并傳送到對方又是在另一個線程中進行的,而聲學回聲消除器在對采集到的聲音進行回聲消除的同時,還需要播放線程中的數據作為參考,而要同步這兩個線程中的數據是非常困難的,因為稍稍有些不同步,聲學回聲消除器中的自適應濾波器就會發散,不但消除不了回聲,還會破壞原始采集到的聲音,使被破壞的聲音難以分辨。我做過好多嘗試,始終無法用軟件來實現對這兩個線程中的數據進行同步,導致實現失敗,希望有經驗的網友們一起分享一下這方面的經驗。

示例代碼:

Sample code

This section shows sample code for encoding and decoding speech using the Speex API. The commands can be used to encode and decode a file by calling:  
% sampleenc in_file.sw | sampledec out_file.sw 
where both files are raw (no header) files encoded at 16 bits per sample (in the machine natural endianness).

 

sampleenc.c

sampleenc takes a raw 16 bits/sample file, encodes it and outputs a Speex stream to stdout. Note that the packing used is NOT compatible with that of speexenc/speexdec.

#include <speex/speex.h>
#include 
<stdio.h>
/*The frame size in hardcoded for this sample code but it doesn't have to be*/
#define FRAME_SIZE 160
int main(int argc, char **argv)
{
char *inFile;
FILE 
*fin;
short in[FRAME_SIZE];
float input[FRAME_SIZE];
char cbits[200];
int nbBytes;
/*Holds the state of the encoder*/
void *state;
/*Holds bits so they can be read and written to by the Speex routines*/
SpeexBits bits;
int i, tmp;
/*Create a new encoder state in narrowband mode*/
state 
= speex_encoder_init(&speex_nb_mode);
/*Set the quality to 8 (15 kbps)*/
tmp
=8;
speex_encoder_ctl(state, SPEEX_SET_QUALITY, 
&tmp);
inFile 
= argv[1];
fin 
= fopen(inFile, "r");
/*Initialization of the structure that holds the bits*/
speex_bits_init(
&bits);
while (1)
{
/*Read a 16 bits/sample audio frame*/
fread(
insizeof(short), FRAME_SIZE, fin);
if (feof(fin))
break;
/*Copy the 16 bits values to float so Speex can work on them*/
for (i=0;i<FRAME_SIZE;i++)
input[i]
=in[i];
/*Flush all the bits in the struct so we can encode a new frame*/
speex_bits_reset(
&bits);
/*Encode the frame*/
speex_encode(state, input, 
&bits);
/*Copy the bits to an array of char that can be written*/
nbBytes 
= speex_bits_write(&bits, cbits, 200);
/*Write the size of the frame first. This is what sampledec expects but
it's likely to be different in your own application
*/

fwrite(
&nbBytes, sizeof(int), 1, stdout);
/*Write the compressed data*/
fwrite(cbits, 
1, nbBytes, stdout);
}

/*Destroy the encoder state*/
speex_encoder_destroy(state);
/*Destroy the bit-packing struct*/
speex_bits_destroy(
&bits);
fclose(fin);
return 0;
}

 

sampledec.c

sampledec reads a Speex stream from stdin, decodes it and outputs it to a raw 16 bits/sample file. Note that the packing used is NOT compatible with that of speexenc/speexdec.

#include <speex/speex.h>
#include 
<stdio.h>
/*The frame size in hardcoded for this sample code but it doesn't have to be*/
#define FRAME_SIZE 160
int main(int argc, char **argv)
{
char *outFile;
FILE 
*fout;
/*Holds the audio that will be written to file (16 bits per sample)*/
short out[FRAME_SIZE];
/*Speex handle samples as float, so we need an array of floats*/
float output[FRAME_SIZE];
char cbits[200];
int nbBytes;
/*Holds the state of the decoder*/
void *state;
/*Holds bits so they can be read and written to by the Speex routines*/
SpeexBits bits;
int i, tmp;
/*Create a new decoder state in narrowband mode*/
state 
= speex_decoder_init(&speex_nb_mode);
/*Set the perceptual enhancement on*/
tmp
=1;
speex_decoder_ctl(state, SPEEX_SET_ENH, 
&tmp);
outFile 
= argv[1];
fout 
= fopen(outFile, "w");
/*Initialization of the structure that holds the bits*/
speex_bits_init(
&bits);
while (1)
{
/*Read the size encoded by sampleenc, this part will likely be
different in your application
*/

fread(
&nbBytes, sizeof(int), 1, stdin);
fprintf (stderr, 
"nbBytes: %d/n", nbBytes);
if (feof(stdin))
break;
/*Read the "packet" encoded by sampleenc*/
fread(cbits, 
1, nbBytes, stdin);
/*Copy the data into the bit-stream struct*/
speex_bits_read_from(
&bits, cbits, nbBytes);
/*Decode the data*/
speex_decode(state, 
&bits, output);
/*Copy from float to short (16 bits) for output*/
for (i=0;i<FRAME_SIZE;i++)
out[i]=output[i];
/*Write the decoded audio to file*/
fwrite(
outsizeof(short), FRAME_SIZE, fout);
}

/*Destroy the decoder state*/
speex_decoder_destroy(state);
/*Destroy the bit-stream truct*/
speex_bits_destroy(
&bits);
fclose(fout);
return 0;
}

 

posted on 2013-01-11 00:24 楊粼波 閱讀(2159) 評論(0)  編輯 收藏 引用

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            免费欧美电影| 欧美成人a视频| 国产亚洲一区二区三区在线观看| 欧美四级在线观看| 欧美性片在线观看| 国产精品久久网站| 国产在线视频欧美一区二区三区| 国语对白精品一区二区| 亚洲福利视频在线| aa成人免费视频| 亚洲欧美国产高清| 浪潮色综合久久天堂| 亚洲国产精品成人综合| 亚洲国产精品成人精品| 亚洲淫片在线视频| 久久先锋资源| 国产精品九九久久久久久久| 精品白丝av| 亚洲色图制服丝袜| 老司机精品视频网站| 一区二区三区 在线观看视| 久久精品主播| 国产精品久久久久久久免费软件| 国产字幕视频一区二区| 一区二区三区国产精华| 久久综合色88| 亚洲伊人色欲综合网| 欧美激情一区二区三区不卡| 国产亚洲午夜高清国产拍精品| 一本久道久久综合中文字幕| 久久久水蜜桃av免费网站| 一本久久知道综合久久| 欧美1区视频| 韩国一区二区在线观看| 亚洲男女毛片无遮挡| 亚洲电影免费在线| 久久久久久色| 国产区日韩欧美| 亚洲影视综合| 亚洲精品视频中文字幕| 欧美jizz19性欧美| 亚洲电影av| 老司机午夜精品视频在线观看| 亚洲一区二区在线看| 欧美日韩午夜剧场| 亚洲美女视频网| 国产精品视频一区二区三区| 美女福利精品视频| 国产中文一区| 亚洲欧美日韩成人高清在线一区| 亚洲人妖在线| 欧美福利电影在线观看| 永久555www成人免费| 久久精品夜色噜噜亚洲a∨| 亚洲一区二区av电影| 欧美午夜片在线观看| 在线视频欧美日韩精品| 亚洲国产精品视频| 欧美激情一区二区三区| 亚洲久久一区| 亚洲欧洲日韩女同| 欧美另类一区| 亚洲无吗在线| 亚洲一区二区三区欧美| 国产精品久久精品日日| 亚洲欧美日韩在线高清直播| 亚洲一区国产一区| 国产亚洲欧美一区二区| 可以看av的网站久久看| 久久综合九色欧美综合狠狠| 亚洲国产一区在线| 亚洲日本一区二区| 国产精品video| 久久av一区二区三区| 久久精品色图| 亚洲精品韩国| 中文亚洲字幕| 国产一区二区三区电影在线观看| 狂野欧美性猛交xxxx巴西| 欧美成人免费全部| 亚洲影音一区| 久久久欧美一区二区| 99综合视频| 午夜精品福利视频| 91久久久亚洲精品| 亚洲香蕉成视频在线观看| 国产欧美日韩亚州综合| 女生裸体视频一区二区三区| 欧美日韩调教| 免费一级欧美片在线播放| 欧美精品日韩| 久久视频在线免费观看| 欧美日韩国产一区| 久久综合亚州| 欧美午夜一区| 欧美韩日一区二区三区| 国产精品推荐精品| 欧美成年人视频网站| 国产精品亚洲аv天堂网| 亚洲福利电影| 国产亚洲人成a一在线v站| 亚洲精品美女久久7777777| 国产一区二区三区在线观看视频| 欧美国产国产综合| 国产九九视频一区二区三区| 亚洲国产美女| 黄色日韩精品| 亚洲综合大片69999| 99国产精品久久久久久久成人热| 欧美日本一道本在线视频| 国产精品mv在线观看| 另类图片综合电影| 国产精品国产精品| 亚洲精品欧美激情| 亚洲福利视频二区| 欧美在线中文字幕| 亚洲欧美伊人| 欧美日韩精品福利| 亚洲国产91精品在线观看| 国内免费精品永久在线视频| 99精品免费视频| 亚洲伦理在线| 老司机aⅴ在线精品导航| 久久九九全国免费精品观看| 国产精品www色诱视频| 亚洲区在线播放| 最新热久久免费视频| 久久久夜夜夜| 女人色偷偷aa久久天堂| 激情五月婷婷综合| 久久精品国产清高在天天线| 久久精视频免费在线久久完整在线看| 国产精品免费看| 亚洲一区二区三区在线观看视频| 亚洲先锋成人| 欧美性色aⅴ视频一区日韩精品| 亚洲片区在线| 一区二区欧美日韩视频| 欧美精品一区三区在线观看| 亚洲精品美女在线| 一区二区毛片| 国产精品久久久久久久午夜| 亚洲曰本av电影| 羞羞答答国产精品www一本| 国产精品人人做人人爽| 亚洲欧美网站| 麻豆精品一区二区综合av| 亚洲第一天堂av| 欧美日本高清一区| 这里只有精品电影| 久久国产精品亚洲va麻豆| 红桃视频成人| 欧美成人精品| 一道本一区二区| 欧美中在线观看| 亚洲国产高清一区| 欧美日本一区二区三区| 亚洲小视频在线观看| 久久久综合免费视频| 亚洲国产高清一区二区三区| 欧美精品日韩精品| 亚洲一区日韩| 欧美成在线视频| 亚洲一区二区三区欧美| 国产一区二区三区免费观看| 免费看成人av| 亚洲免费影院| 亚洲成人在线免费| 一区二区在线观看视频| 免费观看亚洲视频大全| 99国内精品久久| 久久免费观看视频| 99这里只有精品| 国产一区免费视频| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 欧美在线在线| 亚洲精品欧美在线| 久久精品国产欧美激情| 亚洲美女av网站| 国产主播一区二区| 欧美天堂亚洲电影院在线播放| 久久激情视频久久| 在线视频你懂得一区二区三区| 久久最新视频| 先锋影音久久| 在线视频日韩精品| 91久久中文| 一区在线观看| 国产精品视频yy9099| 欧美激情影院| 久久亚洲精品一区二区| 午夜久久久久久| 日韩视频免费大全中文字幕| 欧美成人tv| 狼狼综合久久久久综合网| 欧美在线短视频| 午夜亚洲福利| 香蕉成人久久| 亚洲综合日本| 亚洲免费中文|