《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 基于C語言的設計流優化語音識別芯片結構設計
基于C語言的設計流優化語音識別芯片結構設計
摘要: 本文從可復用和優化芯片空間的角度出發介紹語音識別芯片結構設計的種種考慮,其思路有利于開發一系列其它語音識別芯片。
關鍵詞: SOC 語音識別 ASIC C語言
Abstract:
Key words :

    據預測,市場對語音控制應用設備的需求將急劇增長,其推動力來自電話機市場。電話機將更多地采用語音命令進行控制。其他應用領域包括玩具和手持設備如計算器、語音控制的安全系統、家用電器及車載設備(立體聲、視窗、環境控制、車燈和導航控制)。本文從可復用和優化芯片空間的角度出發介紹語音識別芯片結構設計的種種考慮,其思路有利于開發一系列其它語音識別芯片。       

    新加坡Columns公司在便攜式語音控制產品應用中起步較早,其中一個產品是執行歐元與其他歐洲貨幣之間進行兌換的“語音控制歐洲貨幣兌換器”。歐元兌換器的設計要求包括:1. 功率小,電池壽命至少為1年;2. 價格低廉,產品零售價不超過9美元;3.具有很強的靈活性,能用多種語言精確地識別并合成與說話人相關的語音;4. 整個語音控制核產品應具備可復用的特性。 

    本文介紹利用Frontier Design公司設計工具來開發歐元兌換器ASIC產品的全過程。在ASIC中實現復雜DSP算法的要求通常極為苛刻,但采用Frontier的結構合成工具A|RT Designer工具能迅速優化RTL描述,該工具還允許自由選擇備用結構以優化應用設計。 

    通過應用基于C語言的設計流,能在結構設計階段對新特性進行設計和硬件優化,這能降低50%的硅片面積,通過加快 C語言原型硬件的設計,可以進一步擴展設計的性能以滿足用戶對產品規格的嚴格要求。 

    算法研究

    歐元兌換器的效率在一定程度上取決于語音命令與存儲數據庫的比較以及執行命令的能力。開發出滿足最終產品要求的算法對設計的成功至關重要,因為沒有人希望看到語音控制設備不能始終如一地識別命令,人們需要算法自始至終達到98%以上的識別精度。因此,目前面臨的難題包括檢測并清除背景噪聲、區分真實的命令字和其他噪聲(呼吸聲、微小靜電干擾聲及麥克風聲響)、確定命令字的起始和終止以及將輸入與存儲的“聲紋譜”數據庫及隨后的命令字識別(圖1)進行比較。 

命令字識別

    以下幾種先進的計算密集DSP算法適用于解決上述問題:1. Mel頻率聲譜(cepstral)系數(MFCC)算法,MFCC算法由快速傅立葉變換(FFT)功能譜、Mel定標和log ii構成;2. 反離散余弦變換(iDCT);3. 應用多重估計和選擇算法連續識別并估計背景聲音和語音噪聲的連續噪聲電平估計程序;4. 在命令字有效期間及其附近對聲音能級實施詳盡分析的不精確和精確命令字邊界檢測算法;5. 對一系列不等長度的向量進行比較并在這些向量間比較持續時間變化的動態時間扭曲算法(dynamic time warp)。 

    該算法用浮點C語言編程,為了調整并優化參數,浮點C代碼的編譯和仿真速度要足夠快以檢驗算法的性能。最后,C語言代碼必須能在傳統的PC機上運行,語音識別和合成算法的性能可在實際環境中進行測試。最終的語音識別算法在450MHz奔騰機上測試,當用該公司的內部語音記錄庫進行測試時,可得到99%的識別精度。 

    浮點算法向定點算法轉換

    芯片實現需要將浮點算法轉換為定點算法,要保證動態范圍和精度并防止轉換后超越動態極限。常規定點操作數的非優化范圍可能導致操作數繞回(wrap around, 如(max+1)得到(min)),并引發嚴重的削波和誤碼。定點的精確度同等重要,特別是在重復的信號處理運算中。當精確度不夠時,重復的信號處理算法將導致故障傳播和錯誤累積,最終信號可能逐漸退化成白噪聲,這對于語音控制產品來說無疑是災難性的錯誤。 

    Frontier工具擁有一個稱為A|RT庫的C++類庫,它是分析C代碼定點性能的工具。該類庫支持多種定點數據類型,對多重溢出行為(如飽和和繞回)提供位真建模(bit-true modeling),并提供截斷和舍入零等多重量化模型。原始的32位浮點語音識別算法支持數據以8 KHz輸入,其典型信號帶寬為32位,內存容量要求為幾千字節,典型語音用戶接口的輸出以每秒幾字節的速率測量。 

    代碼合并實現最終產品 

    分析表明,全局數據類型(global data-type)和數組只需16位(1個符號位,10個動態位,5個精度位)就足以保持算法的精度,而不會產生噪聲。但是,高度重復性的FFT子程序需要8個動態位、7個精度位以及1個符號位。通常這種分析可用全局使用的19位字寬滿足任何操作的動態位和精度位的最大要求。由于A|RT庫允許字寬動態改變,而全局數據類型定義了1個符號位、10個動態位和5個精度位,FFT的MAC結果分配了1個符號位、8個動態位和5個精度位,因此設計的字寬(包括總線)保持為16位。這樣可大大節省硅片面積。 

    完成定點C算法轉換后,就可用常規C++編譯器編譯C代碼,并在PC機上運行(也可在HP或SUN機器上運行)。所有信號的位真定義(bit-true definition)保證了硬件映射的正確索引以及到其他數字部件如HDL編譯器和仿真器的直接接口。將定點識別代碼與歐元兌換器應用程序的C代碼合并,就可得到完整的可執行最終代碼。 

    系統設計的考慮

  為了達到成本目標,單片SoC解決方案是唯一可行的方案。SoC必須將如下資源集成至不超過25,000門的芯片上:1. 語音識別與合成(SRS)識別核;2. 語音識別與合成(SRS)程序和歐元兌換器代碼(最大30KB);3. 語音合成實例(最大30KB);4. 用于存儲聲紋(voice print)并用作中間結果存儲器的RAM(最大30K字節);5. AD/DA轉換器;6. 麥克風接口;7. 揚聲器接口。 

    功耗也是要考慮的重要問題,電池壽命至少應為1年半。要滿足這些苛刻的功率要求,系統必須具備省電模式、在RAM中存儲聲紋、處理器具有較低的時鐘頻率以及高效率的音頻放大器。 

    SRS處理器結構

    要給定所必需的處理和低功耗約束條件,選擇目標時鐘頻率是首要任務。根據對初始功耗和處理計算的估計,我們認為2到4MHz時鐘頻率足以滿足要求。選擇3.579 MHz是因為該頻率是NTSC視頻系統的基礎,而石英成本低廉。 

    該算法需要檢測并去除背景噪聲。為了從奔騰機的450MHz時鐘得到3.5MHz時鐘,并保持芯片核門數小于25,000,SRS要采用專用結構。
 
    設計專用處理器費時費力,要用HDL語言重寫算法以獲得最佳方案。A|RT Designer工具綜合了基于控制器的結構,并直接以高效能的C語言算法為基礎。設計工程師通過分析和優化,然后轉化為Verilog或VHDL代碼。 

    設計工程師使用A|RT Designer工具為語音識別算法合成適當的結構,之后進行RTL描述。該工具分配必需的數據通路資源(乘法器、加法器、ALU、I/O、RAM、ROM等),為這些資源分配算術運算,并對運算過程進行調度。同時將自動生成一個控制器、微代碼(用來控制資源分配和調度)及寄存器、多路轉換器和總線。 

    將SRS算法映射到硬件結構的關鍵參數是:以3.5MHz目標時鐘頻率運行完整的SRS代碼,且不超過最大25,000門的約束條件。使用A|RT Designer的“負載視圖(load view)”,設計工程師識別出代表性能瓶頸的幾個多周期運算(multiple cycle operation)。視圖上出現瓶頸的位置將顯示相關C代碼,設計工程師因而能識別產生瓶頸的原因并試驗備選解決方案。 

    最明顯的瓶頸是MEL運算中的密集FFT計算,它占據了實時處理周期80%的時間。通過增加一個二級加法器和專用地址計算單元ACU (address calculation unit),FFT就能優化到只占原始運算周期的10%。這雖然增加了硬件設備,但付出的代價只是4,000個門,正好在硬件預算以內。即便如此改進,所用周期的總數目實在太高,難以達到3.5MHz的時鐘頻率。 

    進一步分析表明,可以改進對數函數的計算。當在RISC DSP (NSC CR16B)上運行C語言算法時,該運算占用大約1,000個周期,約為實時運算需求的15%。添加專用的特定應用單元ASU (application specific unit)進一步將這些功能的循環周期降至3個周期,而只增加200個門。上述結構上的改變使最小時鐘頻率為1.5MHz,少于目標頻率的一半。 

    對門電路數目和語音識別核功耗的優化可以降低寄存器觸發器的數目。觸發器的開銷很大(每個需要10個門電路),并消耗很大的功率。A|RT Designer的“壽命視圖(life-time view)”用來分析組成每個變量壽命的周期數目及變量被使用的頻率。通過在RAM中存儲不常使用但長期有效的變量,即可降低寄存器的總數,進一步減小所需的硅片面積和功率。該措施節約了50%的寄存器門電路,同時為運算周期預算留下充足的開銷空間。 

    RAM壓縮的實現

    在設計初期,我們已經明確30KB的RAM空間太緊張。參考SRS C代碼的每個聲紋譜(約為1秒鐘的語音)字占用大約1-2KB,相當于30條命令,這樣幾乎沒給中間結果SRAM留下任何空間。由于30KB的RAM占用了硅片相當大的面積,因此在硅片預算中無法添加更多的RAM(圖2)。 

    整個芯片使用標準的0.35μm CMOS工藝制造,解決RAM空間問題的唯一解決方案是采用某些形式的語音壓縮。 

    聲紋數據可用兩種方法壓縮:無損壓縮或有損壓縮。目前存在幾種以現有的標準C代碼源程序為基礎,用C語言實現的無損壓縮方法。聲紋采樣數據可用作參考,最佳的無損算法可得到30%的壓縮率。采用有損壓縮,還能再壓縮20%,并且不明顯降低識別質量。有損壓縮完全可以縮放,從而獲得依賴于實際聲紋長度或詞匯表大小的可變壓縮率。由此得到的C代碼算法共500行,并對聲紋得到50%的壓縮率。下一步就可以集成語音壓縮和語音識別IP塊了。 

    然后只需將這500行代碼與10,000行SRS代碼合并,得到一個新功能子程序,在存儲聲紋或讀取RAM中的聲紋時調用。但程序的計算量相當大,初始計算后約需要150萬個時鐘周期,這與SRS處理所需的時間相當。幸運地是,有效時鐘頻率留出的近2.5 MHz能解決這個進程問題,而無需進一步優化。此壓縮方案將RAM需求降低到20-25KB,留出至少5KB用于處理器的中間結果存儲器之用。

RAM壓縮的實現

    揚聲器接口的實現

    單電池電源管理偏置網絡、數模轉換器(DAC)和模擬放大器的要占用較大的芯片面積,而直接用C語言實現脈寬調制(PWM)揚聲器驅動程序可以解決這個問題。 

    揚聲器如何發音?C代碼可使用該公司的A|RT Builder “C-到-HDL”轉換工具直接轉換為VHDL。然后使用Exemplar的Leonardo Spectrum加以合成,并映射到Xilinx的Virtex FPGA,采用Xilinx FPGA主板,就能將揚聲器同2個數字輸出直接相連,啟動開關,即可測聽音效了。 

    RTL描述的生成

    當工程人員對語音識別SoC的性能和結構感到滿意時,就可使用A|RT Designer工具自動生成用于最終硅片的RTL VHDL語言描述。該工具自動為控制器生成RTL代碼及微代碼、RAM、ROM和數據通路功能。另外A|RT Designer工具在設計流的每個階段自動生成測試基準,因此原始的浮點算法仿真可與浮點C和HDL方案中的仿真媲美。VHDL仿真與原始的浮點C代碼嚴格對應,這意味著SoC具有與浮點算法相同的精度。 

    最終結構

    SRS ASIC所需的全部功能都集成在單芯片上(圖2)。另外所有為該SoC開發的IP都可復用。SRS算法目前應用于CR16B RISC核的DECT電話語音識別器上。數據壓縮功能也可復用,以進一步增強專用可變位率ADPCM音頻壓縮代碼(VADPCM)。VADPCM同樣可用于SRS核,在不利用模擬元件的條件下,PWM算法及方案仍然能實現高品質的音頻輸出。SRS實現方案本身在下一代產品中還可以修改。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          香蕉久久a毛片| 欧美日韩午夜在线视频| 欧美一级久久久久久久大片| 欧美黑人国产人伦爽爽爽| 欧美日韩国产精品专区| 黄色日韩网站视频| 一区二区三区四区五区视频| 巨胸喷奶水www久久久免费动漫| 欧美国产日韩精品免费观看| 国自产拍偷拍福利精品免费一| 亚洲精品在线免费| 亚洲国产美国国产综合一区二区| 欧美成人免费一级人片100| 欧美**字幕| 蜜桃伊人久久| 午夜日韩福利| 欧美亚洲系列| 亚洲欧洲一区| 国产精品一区久久| 欧美性大战久久久久久久| 亚洲精品日韩激情在线电影| 亚洲精品一区二区在线| 欧美在线免费观看亚洲| 久久九九99视频| 欧美日韩一区不卡| 欧美一区二区免费观在线| 亚洲欧美日韩视频二区| 亚洲青色在线| 老司机免费视频久久| 欧美日韩中文字幕日韩欧美| 美女国产精品| 这里只有精品视频在线| 国产一区 二区 三区一级| 黄色成人av网| 伊人成年综合电影网| 国产一区二区精品久久99| 欧美午夜不卡影院在线观看完整版免费| 久久嫩草精品久久久精品| 久久精品欧美| 国产精品中文字幕欧美| 好男人免费精品视频| 国产精品一区二区你懂的| 国产精品一区二区三区久久久| 欧美日韩视频免费播放| 亚洲电影激情视频网站| 欧美黄色一级视频| 欧美涩涩网站| 在线精品视频一区二区三四| 久久中文精品| 欧美在线视频全部完| 欧美jizz19hd性欧美| 欧美日韩综合在线免费观看| 黄色亚洲大片免费在线观看| 欧美激情1区| 久久久久久伊人| 黄色精品一区二区| 久久精品亚洲一区二区| 欧美久色视频| 久久精品中文字幕免费mv| 伊人成人在线| 欧美日韩国产成人在线免费| 麻豆久久久9性大片| 99pao成人国产永久免费视频| 亚洲第一精品久久忘忧草社区| 国产精品一二三| 国产精品美女久久久久久久| 男同欧美伦乱| 麻豆成人在线播放| 久久亚洲私人国产精品va| 亚洲国产成人在线视频| av不卡免费看| 欧美激情视频一区二区三区在线播放| 亚洲欧美另类在线| 国产在线观看精品一区二区三区| 国产欧美日韩高清| 欧美综合国产| 国产精品视频你懂的| 黄色工厂这里只有精品| 久久精品女人的天堂av| 欧美人与禽猛交乱配| 午夜亚洲伦理| 伊人成人在线视频| 亚洲欧美在线另类| 一本色道久久综合精品竹菊| 蜜臀av在线播放一区二区三区| 亚洲欧美精品中文字幕在线| 国产精品呻吟| 久久日韩精品| 久久婷婷国产综合国色天香| 国外成人网址| 在线中文字幕一区| 亚洲欧美激情一区| 国产亚洲一区二区三区在线播放| 国产精品色网| 欧美freesex交免费视频| 日韩亚洲视频在线| 欧美不卡一卡二卡免费版| 亚洲国产精品一区在线观看不卡| 激情六月综合| 国产老女人精品毛片久久| 国产伦理精品不卡| 亚洲国产日韩一区二区| 日韩一区二区电影网| 欧美午夜免费影院| 99国产精品久久久| 国产一区自拍视频| 欧美色视频在线| 免费成人在线视频网站| 欧美电影免费观看网站| 欧美.日韩.国产.一区.二区| 国产日韩欧美91| 亚洲乱码国产乱码精品精| 日韩一区二区免费看| 亚洲午夜一区| 久久福利一区| 9久re热视频在线精品| 国产欧美一区二区三区国产幕精品| 亚洲一区二区免费视频| 一区二区在线免费观看| 国产精品影视天天线| 久久久久久亚洲综合影院红桃| 国产一区二区按摩在线观看| 在线免费观看日韩欧美| 在线免费观看日本一区| 中文亚洲欧美| 久久精品一区四区| 中文一区二区在线观看| 欧美日韩精品一区二区三区| av不卡在线| 欧美三级资源在线| 欧美成人首页| 亚洲成色777777在线观看影院| 国产精品夜色7777狼人| 国产综合在线视频| 国产无一区二区| 久久亚洲私人国产精品va| 亚洲人成绝费网站色www| 国产亚洲精品bt天堂精选| 欧美电影免费网站| 亚洲欧美日韩网| 亚洲剧情一区二区| 久久久人成影片一区二区三区观看| 国产日韩精品一区二区三区| 欧美夜福利tv在线| 国产伦精品一区二区三区免费迷| 国产麻豆一精品一av一免费| 亚洲人永久免费| 狠狠入ady亚洲精品经典电影| 亚洲一区二区三区在线视频| 久久精品国产综合| 欧美日本亚洲| 亚洲在线观看| 欧美亚洲在线视频| 女女同性女同一区二区三区91| 久久精品国产清高在天天线| 国产亚洲永久域名| 国产精品欧美日韩| 久久久久久久久久看片| 欧美剧在线免费观看网站| 国内久久精品视频| 久久久久久国产精品mv| 欧美成人免费在线视频| 久久躁日日躁aaaaxxxx| 欧美伊人久久久久久久久影院| 国产精品久久久久高潮| 亚洲一区二区三区高清不卡| 久久久久久久网站| 久久精品久久99精品久久| 欧美中文在线观看| 性8sex亚洲区入口| 国内免费精品永久在线视频| 亚洲精品在线电影| 99re热这里只有精品免费视频| 中国亚洲黄色| 亚洲精品欧美在线| 黄色日韩在线| 99精品国产在热久久婷婷| 欧美国产日本高清在线| 亚洲欧美国产高清va在线播| 国产精品久久久久91| 欧美揉bbbbb揉bbbbb| 日韩午夜在线电影| 欧美在线视屏| 久久精品视频在线看| 欧美中文日韩| 欧美视频久久| 亚洲国产成人久久综合| 亚洲一区二区精品| 欧美视频日韩视频在线观看| 欧美日韩在线免费| 欧美一区视频在线| 久久大逼视频| 欧美日韩成人综合天天影院| 久久人人97超碰人人澡爱香蕉| 久久一区二区视频| 欧美在线观看天堂一区二区三区| 亚洲视频 欧洲视频| 亚洲性xxxx| 亚洲午夜91| 欧美国产在线电影| 亚洲一区二区三区激情| 日韩亚洲不卡在线| 久久精品成人一区二区三区| 91久久精品一区二区三区| 午夜精品久久久久久久99热浪潮| 99国产一区| 亚洲国产综合视频在线观看| 亚洲精品国产精品国自产观看浪潮| 免费观看成人www动漫视频| 国产精品爱啪在线线免费观看| 久久尤物电影视频在线观看| 99在线精品视频在线观看| 欧美绝品在线观看成人午夜影视| 亚洲激情国产精品| 国产欧美日韩综合| 欧美二区在线| 久久成人精品无人区| 日韩视频免费观看高清完整版| 亚洲成在线观看| 亚洲欧美制服另类日韩| 一区二区视频免费在线观看| 欧美一区二区三区在线视频| 欧美在线日韩| 欧美日韩午夜在线| 狠狠入ady亚洲精品经典电影| 国产拍揄自揄精品视频麻豆| 欧美区在线观看| 欧美日韩国产片| 国产日韩精品综合网站| 欧美人与性动交cc0o| 欧美视频在线免费| 日韩午夜在线电影| 香蕉免费一区二区三区在线观看| 欧美精品福利| 国产精品美女视频网站| 欧美黑人国产人伦爽爽爽| 国产嫩草一区二区三区在线观看| 欧美精品乱人伦久久久久久| 国产精品美女xx| 极品少妇一区二区三区| 亚洲国产成人久久综合一区| 亚洲视频在线观看| 亚洲综合欧美| 精品成人一区二区| 久久久久久午夜| 亚洲国产成人在线| 欧美在线看片| 国产亚洲欧美一区在线观看| 欧美日韩视频一区二区| 国内不卡一区二区三区| 在线成人av网站| 国产欧美精品在线播放| 欧美日韩国产一区| 国产精品久久久久久一区二区三区| 欧美精品1区| 欧美大片专区| 免费看的黄色欧美网站| 久久午夜羞羞影院免费观看| 欧美精品日韩综合在线| 校园春色综合网| 国产精品久久久久久一区二区三区| 亚洲福利视频一区二区| 国产精品影院在线观看| 国产精品国产三级国产普通话三级| 欧美一区二区视频网站| 国产欧美日本| 久久婷婷国产综合国色天香| 欧美日一区二区在线观看| 男人的天堂亚洲在线| 老司机成人在线视频| 亚洲激情社区| 亚洲一区二区三区免费观看| 欧美成人综合一区| 欧美精品二区三区四区免费看视频| 亚洲精品视频啊美女在线直播| 国产精品国产a级| 午夜精品网站| 久久xxxx| 最新亚洲电影| 狠久久av成人天堂| 9l国产精品久久久久麻豆| 亚洲一区美女视频在线观看免费| 欧美激情精品久久久久久大尺度| 久久一二三国产| 亚洲国产欧美国产综合一区| 欧美三级精品| 亚洲一区二区欧美| 国产精品网站在线观看| 午夜视频在线观看一区二区| 欧美亚洲自偷自偷| 久久精品在线观看| 欧美激情一区二区三级高清视频| 久久国内精品自在自线400部| 欧美一区二区三区免费在线看| 老司机一区二区| 久久精品99国产精品| 欧美多人爱爱视频网站| 欧美激情精品久久久久| 欧美成在线观看| 美女主播精品视频一二三四| 欧美国产日韩精品免费观看| 国产美女搞久久| 欧美福利电影网| 国产日韩一区| 久久综合给合久久狠狠狠97色69| 亚洲精品中文字幕有码专区| 欧美激情免费在线| 欧美激情精品久久久久久黑人| 亚洲影院一区| 国产精品性做久久久久久| 久久久久国产一区二区三区| 欧美日韩精品一区二区天天拍小说| 国产精品不卡在线| 美玉足脚交一区二区三区图片| 香港成人在线视频| 久久精品国产第一区二区三区| 欧美一区二区三区久久精品茉莉花| 国产精品极品美女粉嫩高清在线| 国产伦精品一区二区三区高清版| 国产亚洲一区二区三区在线观看| 老司机久久99久久精品播放免费| 久久久久国产精品麻豆ai换脸| 欧美专区18| 欧美日韩一区在线观看| 在线日韩av| 久久久人成影片一区二区三区观看| 久久精品国产一区二区三区| 黄色精品一二区|