新型聲碼器CMX638及其應用設計
2.3 與AMBE2000相比較
與同類競爭產品語音壓縮編解碼器件AMBE2000相比CMX638具有以下特點:采用RALCWI算法,速度快,質量好且結構簡單;片內集成增益放大器,A/D和D/A轉換器,低通濾波器,能夠直接處理模擬信號,提高信噪比;可選用外部語音CODEC,具有靈活性;壓縮速率雖無AMBE2000的選項多,但配合壓縮包時間長度和FEC功能,可應用于DMR TDMA和DMR FDMA及其他場合;封裝引腳數少,易于使用和布線,且成本低。表1列出CMX638與AMBE2000的異同點。
3 CMX638工作原理
3.1 編解碼過程
3.1.1 不帶FEC的簡單幀格式編解碼
CMX638提供簡單的編解碼數據幀格式,其壓縮速率包括2 050 b/s,2 400 b/s,2 750 b/s,此過程不帶FEC,STD和DTMF功能。CMX638每隔20 ms采集160個16位數據(A/D轉換器的采樣率為8 kHz),當第一個20 ms結束后,開始編碼運算,由于信號的異同會產生不同抖動延時,主機在40 ms的時刻讀取第一幀數據。以后每隔20 ms操作一次,形成流水線作業。在解碼過程中,在0 ms時刻主機向CMX638輸入一幀數據后,CMX638開始解碼運算,與編碼相似也會出現算法抖動延時,第一個樣本的輸出時刻由內部寄存器IDD決定,其延時應確保輸出連續有效的數據。圖2為CMX638簡單幀格式編解碼過程。
3.1.2 帶FEC的復雜幀格式編解碼
CMX638可提供帶前向糾錯的編解碼數據幀格式,其數據包長度為60 ms,包括3幀數據,其壓縮速率為3 600 b/s。CMX638在0時刻開始采樣,每隔20 ms進行編碼運算,會出現抖動延時,每隔60 ms插入一次FEC編碼(圖3黑色部分),在80 ms時刻一個數據包穩定有效,主機讀出數據,以后每隔60 ms操作一次。在解碼過程中,主機向CMX638輸入數據包后,開始對每一幀數據解碼運算,并會出現抖動延時,設置適當的內部寄存器IDD,可在延時后輸出連續有效的數據。圖3是帶FEC的復發幀格式編解碼過程,其數據包壓縮時間為60 ms。
3.2 數據幀格式
CMX638編碼后輸出的數據幀格式較簡單,無幀頭和其他控制標志信息,直接輸出有效數據。當壓縮速率為2 050b/s時,每隔20 ms產生一幀數據,有效數據位為41 bit,占用6字節,主機必須以字節為單位與CMX638交換數據,所以應該輸入/輸出6字節,其中最高字節先進先出,7個無效比特位不影響編解碼。當壓縮速率為2 400 b/s時,其工作原理與2 050 b/s壓縮速率相同,有效數據為48 bit,恰好占用6字節,無無效比特位。當壓縮速率為2 750 b/s,有效數據為55bit,占用7字節,1個無效比特位,必須輸入/輸出7字節。當壓縮速率為3 600 b/s,帶FEC功能,每隔60 ms產生包括3幀的數據包,有效數據為216 bit,采用硬比特格式,占用27字節。而采用軟比特格式時,則占用108字節。
3.3 主機與片外CODEC接口
主機通過C-BUS串行接口與CMX638交換數據。寫操作時,CSN為低,先寫入要訪問的寄存器地址,再寫入有效數據,以字節為單位,結束時CSN拉高;讀操作時,先寫入地址,接著讀取數據。在CLK上升沿采樣,最大時鐘頻率為5 MHz;每兩次CSN操作應至少相隔1μs。
當CMX638選用外部CODEC時,利用SSP接口與外部CODEC交換數據。當STRB同步脈沖到達,如果是寫操作,SDI輸入16 bit數據;如果是讀操作,SDO輸出16 bit數據。SCLK的最大時鐘頻率為6.6 MHz,時鐘沿采樣輸入數據方式取決于內部寄存器EXCODECCONT($0B)。
評論