音頻信號(hào)采集與AGC算法的DSP實(shí)現(xiàn)
出處:sxl_72 發(fā)布于:2007-05-24 11:36:04
電臺(tái)等由于其自辦頻道的廣告、新聞、廣播劇、歌曲和轉(zhuǎn)播節(jié)目等音頻信號(hào)電平大小不一,導(dǎo)致節(jié)目播出時(shí),音頻信號(hào)忽大忽小,嚴(yán)重影響用戶(hù)的收聽(tīng)效果。在轉(zhuǎn)播時(shí),由于傳輸距離等原因,在信號(hào)的輸出端也存在信號(hào)大小不一的現(xiàn)象。過(guò)去,對(duì)大音頻信號(hào)采用限幅方式,即對(duì)大信號(hào)進(jìn)行限幅輸出,小信號(hào)不予處理。這樣,仍然存在音頻信號(hào)過(guò)小時(shí),用戶(hù)自行調(diào)節(jié)音量,也會(huì)影響用戶(hù)的收聽(tīng)效果。隨著電子技術(shù),計(jì)算機(jī)技術(shù)和通信技術(shù)的迅猛發(fā)展,數(shù)字信號(hào)處理技術(shù)已廣泛地深入到人們生活等各個(gè)領(lǐng)域。其中語(yǔ)音處理是數(shù)字信號(hào)處理活躍的研究方向之一,在IP電話(huà)和多媒體通信中得到廣泛應(yīng)用。語(yǔ)音處理可采用通用數(shù)字信號(hào)處理器DSP和現(xiàn)場(chǎng)可編程門(mén)陣列(FPGA) 實(shí)現(xiàn),其中DSP實(shí)現(xiàn)方法具有實(shí)現(xiàn)簡(jiǎn)便、程序可移植行強(qiáng)、處理速度快等優(yōu)點(diǎn),特別是TI公司TMS320C54X系列在音頻處理方面有很好的性?xún)r(jià)比,能夠解決復(fù)雜的算法設(shè)計(jì)和滿(mǎn)足系統(tǒng)的實(shí)時(shí)性要求,在許多領(lǐng)域得到廣泛應(yīng)用。在DSP的基礎(chǔ)上對(duì)音頻信號(hào)做AGC算法處理可以使輸出電平保持在一定范圍內(nèi),能夠解決不同節(jié)目音頻不均衡等問(wèn)題。
TI公司DSP芯片TMS320VC5402具有獨(dú)特的6總線哈佛結(jié)構(gòu),使其能夠6條流水線同時(shí)工作,工作頻率達(dá)到100MHz。利用VC5402的2個(gè)多通道緩沖串行口(McBSP0和McBSP1)來(lái)實(shí)現(xiàn)與AIC23的無(wú)縫連接。VC5402的多通道帶緩沖的串行口在標(biāo)準(zhǔn)串口的基礎(chǔ)上加了一個(gè)2K的緩沖區(qū)。每次串口發(fā)送數(shù)據(jù)時(shí),CPU自動(dòng)將發(fā)送緩沖中的數(shù)據(jù)送出;而當(dāng)接收數(shù)據(jù)時(shí),CPU自動(dòng)將收到的數(shù)據(jù)寫(xiě)入接收緩存。在自動(dòng)緩沖方式下,不需每傳送一個(gè)字就發(fā)中斷,而是每通過(guò)緩沖器的邊界,才產(chǎn)生中斷至CPU,從而減少頻繁中斷對(duì)CPU的影響。
音頻芯片采用TLV320 AIC23,它是TI公司的一款高性能立體聲音頻A/D,D/A放大電路。AIC23的模數(shù)轉(zhuǎn)換和數(shù)模轉(zhuǎn)換部件高度集成在芯片內(nèi)部,采用了先進(jìn)的過(guò)采樣技術(shù)。AIC23的外部硬件接口分為模擬口和數(shù)字口。模擬口是用來(lái)輸入輸出音頻信號(hào)的,支持線路輸入和麥克風(fēng)輸入;有兩組數(shù)字接口,其一是由/CS、SDIN、SCLK和MODE構(gòu)成的數(shù)字控制接口。AIC23是一塊可編程的音頻芯片,通過(guò)數(shù)字控制口將芯片的控制字寫(xiě)入AIC23內(nèi)部的寄存器,如采樣率設(shè)置,工作方式設(shè)置等,共有12個(gè)寄存器。音頻控制口與DSP的通信主要由多通道緩沖串行口McBSP1來(lái)實(shí)現(xiàn)。
AIC23通過(guò)數(shù)字音頻口與DSP的McBSP0完成數(shù)據(jù)的通信,DSP做主機(jī),AIC23做從機(jī)。主機(jī)提供發(fā)送時(shí)鐘信號(hào)BCLKX0和發(fā)送幀同步信號(hào)BFSX0。在這種工作方式下,接收時(shí)種信號(hào)BCLKR0和接收幀同步信號(hào)BFSR0實(shí)際上都是由主機(jī)提供的。圖1是AIC23與VC5402的接口連接。
![]() |
圖2是音頻信號(hào)采集的具體電路圖。
使放大電路的增益隨信號(hào)強(qiáng)度的變化而自動(dòng)調(diào)整的控制方法,就是AGC-自動(dòng)增益控制。實(shí)現(xiàn)AGC可以是硬件電路,即AGC閉環(huán)電子電路,也可以是軟件算法。本文主要討論用軟件算法來(lái)實(shí)現(xiàn)音頻信號(hào)的AGC。
音頻AGC是音頻自動(dòng)增益控制算法,更為準(zhǔn)確的說(shuō)是峰值自動(dòng)增益控制算法,是一種根據(jù)輸入音頻信號(hào)水平自動(dòng)動(dòng)態(tài)地調(diào)整增益的機(jī)制。當(dāng)音量(無(wú)論是捕捉到的音量還是再現(xiàn)的音量)超過(guò)某一門(mén)限值,信號(hào)就會(huì)被限幅。限幅指的是音頻設(shè)備的輸出不再隨著輸入而變化,輸出實(shí)質(zhì)上變成了音量位置上的一條水平線;當(dāng)檢測(cè)到音頻增益達(dá)到了某一門(mén),它會(huì)自動(dòng)減小增益來(lái)避免限幅的發(fā)生。另一方面,如果捕捉到的音量太低時(shí),系統(tǒng)將自動(dòng)提高增益。當(dāng)然,增益的調(diào)整不會(huì)使音量超過(guò)用戶(hù)在調(diào)節(jié)向?qū)е性O(shè)置的值。圖3是音頻AGC算法的結(jié)構(gòu)框圖。
![]() |
首先從串口獲取音頻數(shù)據(jù),它是16位的整型數(shù),一般來(lái)說(shuō),這些數(shù)都是比較小的,通過(guò)AGC算法將輸入的音頻數(shù)據(jù)投影在一個(gè)固定區(qū)間內(nèi),從而使得不論輸入的數(shù)據(jù)點(diǎn)數(shù)值大小都會(huì)等比例地向這個(gè)空間映射。一方面將獲得的音頻數(shù)據(jù)值與原來(lái)的峰值進(jìn)行比較,如果有新的峰值出現(xiàn)就計(jì)算新的增益系數(shù);另一方面在一定的時(shí)間周期內(nèi)獲取一個(gè)新的峰值,這個(gè)峰值就具有檢測(cè)性能,又與原峰值比較,然后就計(jì)算新的增益系數(shù)。這個(gè)增益系數(shù)是相對(duì)穩(wěn)定的。當(dāng)音量加大時(shí),信號(hào)峰值會(huì)自動(dòng)增加,從而增益系數(shù)自動(dòng)下降;當(dāng)音量減小時(shí),新的峰值會(huì)減小并且取代原來(lái)的峰值,從而使峰值下降,使增益系數(shù)上升。輸出的數(shù)據(jù)乘以新增益系數(shù)后映射到音頻信號(hào)輸入的投影區(qū)間內(nèi)。
圖4是音頻信號(hào)AGC算法的程序流程圖。
![]() |
AGC_Coff是初始增益系數(shù),初始值為1;maxAGC_in是增益峰值,初始值為0;time是采樣點(diǎn)計(jì)數(shù),門(mén)限值為4096;AGC_in是新的音頻數(shù)據(jù),MAXArrIn是新的音頻增益峰值;映射區(qū)間【-20000,20000】。
整個(gè)系統(tǒng)的軟件部分為5人模塊。系統(tǒng)主函數(shù)main( )、CMD文件、中斷向量表、DSP5402頭文件和專(zhuān)為C語(yǔ)言開(kāi)發(fā)的庫(kù)函數(shù)rtdx.lib。其中主函數(shù)部分是,主要包括:DSP器件初始化、MCBSP1初始化、MCBSP0初始化、AIC23初始化(內(nèi)部12個(gè)可編程寄存器設(shè)置)及算法程序等。
在CCS2.0集成開(kāi)發(fā)環(huán)境下,采用*.c語(yǔ)言和*.asm語(yǔ)言相結(jié)合的方式編寫(xiě)程序。將編寫(xiě)的程序*.c、*.asm和鏈接程序*.cmd文件編譯鏈接后生成執(zhí)行目標(biāo)文件*.out,通過(guò)仿真器將執(zhí)行目標(biāo)文件*.out到系統(tǒng)板上,經(jīng)過(guò)調(diào)試、編譯并運(yùn)行,以音樂(lè)作為音頻信號(hào)源輸入到系統(tǒng)板上。
這套完整的音頻信號(hào)采集和處理系統(tǒng)已經(jīng)應(yīng)用于實(shí)際的音頻設(shè)備中。
版權(quán)與免責(zé)聲明
凡本網(wǎng)注明“出處:維庫(kù)電子市場(chǎng)網(wǎng)”的所有作品,版權(quán)均屬于維庫(kù)電子市場(chǎng)網(wǎng),轉(zhuǎn)載請(qǐng)必須注明維庫(kù)電子市場(chǎng)網(wǎng),http://www.hbjingang.com,違反者本網(wǎng)將追究相關(guān)法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明自其它出處的作品,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點(diǎn)或證實(shí)其內(nèi)容的真實(shí)性,不承擔(dān)此類(lèi)作品侵權(quán)行為的直接責(zé)任及連帶責(zé)任。其他媒體、網(wǎng)站或個(gè)人從本網(wǎng)轉(zhuǎn)載時(shí),必須保留本網(wǎng)注明的作品出處,并自負(fù)版權(quán)等法律責(zé)任。
如涉及作品內(nèi)容、版權(quán)等問(wèn)題,請(qǐng)?jiān)谧髌钒l(fā)表之日起一周內(nèi)與本網(wǎng)聯(lián)系,否則視為放棄相關(guān)權(quán)利。
- 單片機(jī)技術(shù)特性與嵌入式開(kāi)發(fā)實(shí)踐指南2026/1/7 10:00:02
- 單片機(jī)(MCU)與數(shù)字信號(hào)處理器(DSP)分類(lèi)及選型技術(shù)指南2025/12/30 10:02:37
- 工業(yè)級(jí)DSP信號(hào)處理系統(tǒng):硬件適配與抗干擾工程方案2025/12/15 14:41:00
- HOLTEK推出HT32F65533G/733G內(nèi)建N/N預(yù)驅(qū)電機(jī)專(zhuān)用SoC單片機(jī)2025/11/26 14:11:41
- 什么是C51數(shù)據(jù)類(lèi)型擴(kuò)充定義2025/10/27 13:59:22
- 編碼器的工作原理及作用1
- 超強(qiáng)整理!PCB設(shè)計(jì)之電流與線寬的關(guān)系2
- 三星(SAMSUNG)貼片電容規(guī)格對(duì)照表3
- 電腦藍(lán)屏代碼大全4
- 國(guó)標(biāo)委發(fā)布《電動(dòng)汽車(chē)安全要求第3部分:人員觸電防護(hù)》第1號(hào)修改單5
- 通俗易懂談上拉電阻與下拉電阻6
- 繼電器的工作原理以及驅(qū)動(dòng)電路7
- 電容單位8
- 跟我學(xué)51單片機(jī)(三):?jiǎn)纹瑱C(jī)串口通信實(shí)例9
- 一種三極管開(kāi)關(guān)電路設(shè)計(jì)10
- 高速PCB信號(hào)完整性(SI)設(shè)計(jì)核心實(shí)操規(guī)范
- 鎖相環(huán)(PLL)中的環(huán)路濾波器:參數(shù)計(jì)算與穩(wěn)定性分析
- MOSFET反向恢復(fù)特性對(duì)系統(tǒng)的影響
- 電源IC在惡劣環(huán)境中的防護(hù)設(shè)計(jì)
- 連接器耐腐蝕性能測(cè)試方法
- PCB電磁兼容(EMC)設(shè)計(jì)與干擾抑制核心實(shí)操規(guī)范
- 用于相位噪聲測(cè)量的低通濾波器設(shè)計(jì)與本振凈化技術(shù)
- MOSFET在高頻開(kāi)關(guān)中的EMI問(wèn)題
- 電源IC在便攜式設(shè)備中的設(shè)計(jì)要點(diǎn)
- 連接器結(jié)構(gòu)設(shè)計(jì)常見(jiàn)問(wèn)題分析












