# 國 立 交 通 大 學 電機與控制工程研究所

# 碩士論文

使用有限區間二次倒回最佳化控制 之全橋式D類放大器

A Full-Bridge Class-D Amplifier Using Finite Receding Horizon Quadratic Optimal Control

研究生:林岑思指導教授:胡竹生博士

中華民國九十四年七月

使用線性區間二次倒回最佳化控制之全橋式 D 類放大器

# A Full-Bridge Class-D Amplifier Using Finite Receding Horizon Quadratic Optimal Control

| 研究生:林  | 岑 | 思    | Student : Chen-Si, Lin        |
|--------|---|------|-------------------------------|
| 指導教授:胡 | 竹 | 生 博士 | Advisor : Prof. Jwu-Sheng, Hu |



Submitted to Institute of Electrical and Control Engineering College of Electrical Engineering and Computer Science National Chiao Tung University in partial Fulfillment of the Requirements for the Degree of Master in

Electrical and Control Engineering

July 2005

Hsinchu, Taiwan, Republic of China

中華民國九十四年七月

# 使用有限區間二次倒回最佳化控制 之全橋式 D 類放大器

研究生:林 岑 思 指導教授:胡 竹 生 博士

#### 國立交通大學電機與控制工程研究所碩士班



本論文以 Finite Receding Horizon Quadratic Optimal Control 為基礎設計 D 類音頻 放大器。D 類音頻放大器,相對於 A 類或 AB 類放大器,有效率高、功率級設計較易 的優勢。在數位訊號處理上有一個重要的量化誤差問題,所以在本論文中以量化誤差 為目標,訂定出其成本函數,然後使用有限區間二次倒回最佳化控制的方法去最小化 量化失真。以回授迴圈的方式實現一個 Multi-Step Optimal Converter,它以更一般的方 法來嵌入 Sigma-Delta Modulation 並且提供更好的效能。D 類放大器常以 Pulse-Width Modulator 產生切換式控制訊號,但產生的諧波問題較為嚴重。相對的,Multi-Step Optimal Converter 回授量化誤差,經過迴圈轉移函數,改變量化誤差能量分佈,得到 更高的訊號雜訊比。本論文將設計與實現穩定數位的 Multi-Step Optimal Converter、 USB 介面與切換式功率放大器,完成一全數位式音頻放大器。

# A Full-Bridge Class-D Amplifier Using Finite Receding Horizon Quadratic Optimal Control

Student : Chen-Si Lin

Advisor: Prof. Jwu-Sheng Hu

### Institute of Electrical and Control Engineering National Chiao-Tung University



The objective of this thesis is to design a Class D audio amplifier based on Finite Receding Horizon Quadratic Optimal Control. Comparing to the traditional Class A or Class AB amplifiers, audio amplifiers based on Class D topology are more efficient in terms of energy conversion and have low cost. An important aspect of digital signal processing is the impact of quantization errors. In this thesis, we focus on the topic about quantization errors and define a cost function, which is utilized to minimize a measure of the quantization distortion by using finite receding horizon quadratic optimal control. We propose a Multi-Step Optimal Converter, which can be implemented as a feedback loop. It embeds Sigma-Delta Modulation in a more general setting and typically provides better performance. Class D amplifiers commonly rely on Pulse-Width Modulation to generate the output switching waveforms which gives rise to more serious problems in unwanted harmonics . On the other hand, using Multi-Step Optimal Converter, it is possible to design the loop filter so that the harmonic distortion is reduced. This thesis will analyze and implement a stable digital Multi-Step Optimal Converter, USB interfaces, and a switching power stage to complete a full digital audio amplifier.

# 誌 謝

漫長的學生生涯即將隨著本論文的完成,暫時的劃下句點,或許往後仍有機會再 度成為學生。回首過去,在一路上幫忙我的人實在是族繁不急備載,在此首先感謝在 我過去的十八年學生生活裡面,曾經幫助我以及輔助過我的人,當然還有感謝上天讓 我一路走來很平順,使我可以如願的取得碩士學位。

很榮幸地我可以成為胡竹生教授所領導的實驗室的一份子,感謝老師兩年多來的 指導與栽培,讓我不只學習到學術上的專業知識,也了解到做事該有的態度以及研究 生就是該對自己負責,在此致上最崇高的謝意與敬意。

在 x-lab 的日子裡,因為有眾多的學長姐、同學以及學弟妹的相輔相成,才能使 我順利的畢業,也因為有大家,讓我的研究生生活充滿歡笑與樂趣。感謝本論文的先 驅順智學長,感謝他在下班之餘還要被我打攪;感謝宗敏學長不只在我課業上的輔助, 偶而還要當我的心理顧問;感謝生活智慧王的 Angel,解決了我很多生活上的問題; 還有機器人魔人立偉學長、史上最強的博士价呈、常找我去健身房的劉大人、超像吸 毒犯的天才鳥哥、常請我吃東西的康康、常幫我們訂便當的億如、吃素卻可以長得很 高的俊德、愛打棒球的家瑋、愛學我說話的興哥、皮膚有變好趨勢的士奇、有老師架 式的群棋、硬體天王的晏榮以及愛運動又可以吃很少的鏗元,另外也感謝學弟妹們, 朱木、螞蟻、恆嘉、佩靜、鳥蔥、耀賢和詠融,謝謝你們的陪伴以及協助。

最後我要感謝我的家人,對於我一路上的支持與鼓勵。感謝我的父母在我求學的 過程,提供了我良好的學習環境,以及生活上的衣食無缺;當我在碩二下生病的那段 日子,感謝你們對我無微不至的照顧與呵護,使我可以迅速的恢復並且回到學校完成 我的學業。感謝我的兩位哥哥對於我這個問題妹妹的照顧,謝謝你們對我在學業上的 指導以及當我的精神指標。僅以本論文向家人獻上最誠摯的謝意。

iii

| 目 錄 |
|-----|
| 日錄  |

| 摘             | 要    |                                                    | .i |
|---------------|------|----------------------------------------------------|----|
| AB            | STRA | ACT                                                | ii |
| 誌             | 謝    | i                                                  | ii |
| 目             | 錄    | i                                                  | V  |
| 表             | 列    |                                                    | vi |
| 圖             | 列    | V                                                  | ii |
| 5<br>5        | 帛一章  | : 序論                                               | 1  |
|               | 1.1  | 簡介                                                 | 1  |
|               | 1.2  | 目標                                                 | 3  |
|               | 1.3  | 章節概要                                               | 4  |
| <u>አ</u>      | 帛二章  | :訊號調變                                              | 5  |
|               | 2.1  | Pulse-Width Modulator                              | 5  |
|               | 2.2  | Sigma-Delta Modulator                              | 6  |
|               | 2.3  | Receding Horizon Quadratic Control with Constraint | 9  |
| <u>አ</u><br>5 | 帛三章  | : 設計 MULTI-STEP OPTIMAL CONVERTER1                 | 1  |
|               | 3.1  | 架構分析1                                              | 1  |
|               |      | 3.1.1 Define Quantizer. 1896                       | 2  |
|               |      | 3.1.2 Finite Horizon Formulation 1                 | 2  |
|               |      | 3.1.3 Solution and Implementation of the MSOC 1    | 4  |
|               | 3.2  | Relationship to the Noise Shaping Quantizer 1      | 8  |
|               | 3.3  | 設計範例2                                              | 1  |
| 5<br>5        | 第四章  | <b>二 量化器的設計實例與分析</b> 2                             | 9  |
|               | 4.1  | Horizon One and 1.5-Bit2                           | 9  |
|               | 4.2  | Horizon Two and One - Bit                          | 0  |
|               | 4.3  | Horizon Two and 1.5 - Bit                          | 2  |
| <u>አ</u><br>5 | 帛五章  | : 實現3                                              | 4  |
|               | 5.1  | USB 介面3                                            | 5  |
|               |      | 5.1.1 硬體介紹                                         | 7  |
|               |      | 5.1.2 軟體介紹                                         | 8  |
|               |      | 5.1.3 USB 實作                                       | 0  |
|               | 5.2  | FPGA4                                              | 6  |
|               |      | 5.2.1 硬體介紹:Altera FLEX10K Emulation Board 4        | .7 |
|               |      | 5.2.2 軟體介紹:Quartus II 4                            | .7 |
|               |      | 5.2.3 FPGA 實作                                      | -8 |
|               |      |                                                    |    |

| 5.3 | Power Stage                                       | 55 |
|-----|---------------------------------------------------|----|
|     | 5.3.1 硬體介紹: Digital Amplifier Power Stage TAS5121 | 55 |
|     | 5.3.2 Power Stage 實作                              | 56 |
| 5.4 | 實作結果                                              | 58 |
| 第六章 | 至結論                                               | 65 |
| 6.1 | 研究成果                                              | 65 |
| 6.2 | 未來展望                                              | 66 |



# 表 列

| 表 | 3.3.1. | 二階  | • • N=1 | , 1-BIT ∉ | 約 MSOC | 輸出  | 比較結果 |       | <br> |
|---|--------|-----|---------|-----------|--------|-----|------|-------|------|
| 表 | 3.3.2. | 二階  | • • N=2 | ,1-bit é  | 約 MSOC | 輸出  | 比較結果 |       | <br> |
| 表 | 5.1.1. | USB | 四種傳     | 輸模式と      | 上較     |     |      | ••••• | <br> |
| 表 | 5.1.2. | USB | 音效裝     | 置輸出貢      | 資料的時   | 間關係 | 条    |       | <br> |



| 圖 | 列 | J |
|---|---|---|
|---|---|---|

| 啚 | 1.1  | 類比音響系統                                                  | 1    |
|---|------|---------------------------------------------------------|------|
| 圖 | 1.2  | D 頻放大器                                                  | 2    |
| 啚 | 1.3  | 全數位化音頻擴大器                                               | 3    |
| 啚 | 2.1  | PULSE-WIDTH MODULATOR 示意圖                               | 5    |
| 啚 | 2.2  | DELTA MODULATOR 與 POWER STAGE 架構圖                       | 6    |
| 圖 | 2.3  | 一階類比 SIGMA-DELTA MODULATOR                              | 7    |
| 圖 | 2.4  | 一階數位 SIGMA-DELTA MODULATOR                              | 7    |
| 圖 | 2.5  | PWM 輸出頻譜響應圖(0~40K Hz)                                   | 8    |
| 圖 | 2.6  | SIGMA-DELTA MODULATION 輸出頻譜響應圖(0~40K Hz)                | 8    |
| 圖 | 2.7  | RECEDING HORIZON QUDRATIC CONTROL WITH CONSTRAINT 輸出頻譜響 | ĺ    |
|   |      | 應圖(0~40K Hz)                                            | . 10 |
| 圖 | 3.1  | GENERAL SINGLE-STAGE SIGMA-DELTA CONVERTER              | .11  |
| 啚 | 3.2  | MOVING HORIZON PRINCIPLE, N=3                           | .17  |
| 啚 | 3.3  | 以回授的方式(FEEDBACK LOOP)實現 MSOC                            | . 18 |
| 啚 | 3.4  | NOISE SHAPING QUANTIZER                                 | . 18 |
| 啚 | 3.5  | 化簡後的 N 階 SIGMA-DELTA MODULATOR 方塊圖                      | . 19 |
| 圖 | 3.6  | 以 ADDITIVE NOISE MODEL 線性化 N 階 SIGMA-DELTA MODULATOR    | . 19 |
| 啚 | 3.7  | NOISE SHAPING QUANTIZER, REDRAWN                        | . 20 |
| 啚 | 3.8  | 2-ORDER, N=1的 MSOC 架構圖                                  | . 22 |
| 啚 | 3.9  | 輸入為1KHZ的弦波訊號頻率響應圖                                       | . 23 |
| 啚 | 3.10 | 2-ORDER, N=2的 MSOC 架構圖                                  | . 24 |
| 啚 | 3.11 | 輸入為1KHZ的弦波訊號頻率響應圖                                       | . 25 |
| 啚 | 3.12 | ERROR VARIANCE 比較關係圖                                    | . 26 |
| 啚 | 3.12 | SNR 比較關係圖                                               | . 27 |
| 圖 | 3.13 | THD+N 比較關係圖                                             | . 27 |
| 啚 | 3.14 | 輸入不同振幅的訊號之 SNR 比較關係圖                                    | . 28 |
| 啚 | 3.15 | 輸入不同振幅的訊號之 THD+N 比較關係圖                                  | . 28 |
| 啚 | 4.1  | 一維量化器                                                   | . 29 |
| 啚 | 4.2  | 一維量化器之架構圖                                               | . 29 |
| 啚 | 4.3  | N=2的1-BIT 量化器之區域分割                                      | .31  |
| 啚 | 4.4  | N = 2 的 1-BIT 量化器之架構圖                                   | .31  |
| 啚 | 4.5  | N=2的1.5-BIT 量化器之區域分割                                    | . 33 |
| 圖 | 4.6  | N=2的1.5-BIT 量化器之架構圖                                     | . 33 |
| 圖 | 5.1  | 全數位化的音頻擴大器系統方塊圖                                         | . 34 |
| 啚 | 5.2  | USB 基本架構                                                | . 35 |

| 圖 | 5.3  | DMA-CYPRESS USB AN2131 控制單板                  |      |
|---|------|----------------------------------------------|------|
| 啚 | 5.4  | KEIL UVISION2 使用介面                           |      |
| 圖 | 5.5  | EZ-USB 使用介面                                  | . 39 |
| 圖 | 5.6  | USB AUDIO DESCRIPTOR 架構圖                     | .41  |
| 圖 | 5.7  | USB 單板以 USB AUDIO CLASS 描述元裝置列舉              | 42   |
| 圖 | 5.8  | 主程式流程圖                                       | 43   |
| 圖 | 5.9  | 中斷服務程式流程圖                                    | .44  |
| 啚 | 5.10 | USB 傳送資料速度與 FPGA 消耗資料速度                      |      |
| 啚 | 5.11 | FPGA 之基本架構圖                                  | .46  |
| 啚 | 5.12 | ALTERA FLEX10K EMULATION BOARD               | .47  |
| 圖 | 5.13 | QUARTUS II 4.1 使用介面                          | . 48 |
| 圖 | 5.14 | FIFO 內部基本方塊圖                                 | . 49 |
| 圖 | 5.15 | BUFFER 方塊的 I/O                               | . 50 |
| 圖 | 5.16 | 空、满的 BUFFER 方塊示意圖                            | . 50 |
| 圖 | 5.17 | 二階、N=2之 MSOC 實現方塊圖                           | . 51 |
| 圖 | 5.18 | 1 CHANNEL MSOC I/O 的方塊圖                      | . 52 |
| 圖 | 5.19 | FPGA 實現 2 CHANNEL MSOC 之 VHDL 架構圖            | . 53 |
| 圖 | 5.20 | QUARTUS II 之 COMPILER REPORT                 | . 54 |
| 圖 | 5.21 | TI TAS5121 接腳圖                               | . 56 |
| 圖 | 5.22 | TAS5121 特性圖                                  | . 57 |
| 圖 | 5.23 | 2-ORDER,N=1,1.5-BIT 的 MSOC 之 FPGA 的輸出訊號圖     | . 58 |
| 圖 | 5.24 | 2-ORDER,N=2,1-BIT 的 MSOC 之 FPGA 的輸出訊號圖       | . 59 |
| 啚 | 5.25 | 2-ORDER,N=2,1.5-BIT 的 MSOC 之 FPGA 的輸出訊號圖     | . 60 |
| 啚 | 5.26 | SNR                                          | . 61 |
| 圖 | 5.27 | THD+N                                        | . 63 |
| 圖 | 5.28 | 在 MODELSIM 中 BEHAVIOR 的 ERROR VARIANCE 比較關係圖 | . 64 |
| 圖 | 6.1  | 具備 USB 介面雙聲道之數位音頻擴大器                         | . 66 |

# 第一章 序論

#### 1.1 简介

隨著科技日新月異,電子產品的迅速發展、資訊網路的發達,可攜式產品的重要性 越來越高,而可攜式產品越來越重視效率以及耗功的問題,D 類音訊放大器在可攜式產 品的應用上,例如手機、PDA 以及 mp3 上已經有取代 AB 類放大器的趨勢。



圖 1.1. 類比音響系統

D 類放大放器最早是由 Baxandall 在 1959 年所提出,利用 PWM 調變,將輸入訊號 調變為開關控制訊號,以控制切換式功率放大器的導通與關閉,達到訊號放大的目的 [1]。D 類放大器的效率一般可達 90%[2],而 A 類放大器因為有偏壓電流,使得的最大 效率只有 25%,而 AB 類放大器一般效率在 40~60%之間。因此在輸出相同的功率下, D 類放大器較節省能源,另外體積小以及效率高,並且還可大幅減少散熱片所佔面積甚 至取消散熱片。 D 類放大器之所以效率高乃是因為在 H-Bridge 中,實際上的 MOSFET 在狀態為'ON'時, R<sub>DS(on)</sub>為極小,因此它上面幾乎沒有壓降;在狀態'OFF'時, R<sub>DS(on)</sub>值很大,因此幾乎沒有電流流過。所以從電源向負載提供了幾乎等量的功率,而相對的,AB 類放大器僅有極小的功率被 MOSFET 消耗,效率則非常低。下圖為 D 類放大器的示意圖,其中 MOSFET 以開關來表示。



將音響放大器全數位化,不需要經過數位類比轉換器,減少數位類比轉換過程造成 的失真,將調變(Modulation)後的訊號送至D類放大器藉以提高功率,再驅動喇叭。而 因為IC 製程的進步,元件的動態響應也越來越好,電晶體的切換速度越來越快,D類 數位放大器(Class D Amplifier)的切換速度也能提升到CD取樣頻率,甚至8倍、64倍 以上。因此要將音樂全數位化,硬體限制的問題,從不可能達成變成可能實現。下圖 1.3 為全數位化的音頻擴大器系統。



圖 1.3 全數位化音頻擴大器系統

#### 1.2 目標

本論文提的全數位化音響放大器,以數位儲存媒體作為音源(數位輸入),將數位訊 號調變為 one-bit 或是 1.5-bit 的數位訊號,再將此數位訊號以全橋式 D 類數位功率放大 器(Full Bridge Class-D Amplifier)放大,驅動喇叭。

研究目標,設計實現一個全數位化的音響放大器,利用 pulse 訊號,驅動音箱,聽 到音樂。關鍵在設計一個能將 multi-bit 數位訊調變成為 one-bit 或是 1.5-bit 數位訊號的 調變器(modulator),這樣的 modulator,應用在音頻領域,目前主要有 PWM(Pulse Width Modulation)與 SDM(Sigma Delta Modulation)。本論文將討論另一種 Modulation,是利用 Finite Receding Horizon Quadratic Optimal Control 的方法來對資料作 Modulate,將之稱 為 Multi- Step Optimal Converter(MSOC),而事實上 SDM 是它的一種特例。

Sigma Delta Modulation 是廣為人知的架構,但是它的設計的瓶頸在高階時,如何 求得穩定且符合規格要求的係數,而設計這些係數往往不是很容易的,所以在此採用 Finite Receding Horizon Quadratic Optimal Control 的方法,它比較有彈性,可以根據不 同的要求而定義出想要的成本函數(Cost Function),進而去求得輸出,而在濾波器的設 計上,採用最簡單的積分器,使得係數都很簡單。本論文引用[3],設計穩定且符合需 求的 MSOC, 實現全數位化的音響放大器。

## 1.3 章節概要

本論文的章節組織如下:

第二章將說明將 multi-bit 數位訊調變成為 1bit 數位訊號的 PWM、SDM 與 Receding Horizon Quadratic Control with Constraint 的調變原理、差別。第三章將分析 Multi-Step Optimal Converter 的系統,並說明它與雜訊整形量化器(Noise Shaping Quantizer)間的關係,並提出幾個實驗範例。第四章為設計量化器(Quantizer)的實例說明。第五章說明如 何實現全數位化的音響系統。第六章心得總結以及對本系統的未來展望。



## 第二章 訊號調變

應用在音頻領域,將 multi-bit 數位訊號調變為 single bit 或是 1.5-bit 數位訊號的 Modulation,目前主要有 PWM 與 SDM 二種方法,以及本論文將使用的 Receding Horizon Quadratic Control with Constraint,以下分別介紹其調變原理與差異。

#### 2.1 Pulse-Width Modulator

PWM 切換控制方塊如圖 2.1,其中三角波可以為正、上升、下降三角波等三種。



圖 2.1 Pulse-Width Modulator 示意圖

切換開關的控制信號 Vswitch 是由輸入訊號(參考波)Vinput 與頻率為 fs 的三角波(載波)Vt 比較而得,當輸入訊號 Vinput 的電壓大於三角波 Vt 時,則輸出為高準位,使開關 導通;反之則為低準位,使開關截止,而開關的切換頻率為 fs 。固定切換頻率,調整 脈波寬度,以改變輸出電壓的大小。PWM 輸出電壓的平均值之大小,正比於開闢之導 通截止時間[4]。

數位 PWM 與類比 PWM 原理相同。輸入的數位訊號,在有限的取樣頻率下,依取 樣(Sampling)方法的不同,有 Uniform Sampling 與 Direct Interpolation Sampling 等型態。 Natural Sampling 是以無限高的取樣頻率作 Sampling,即為類比訊號。數位 PWM 的三 角波的切換頻率為 $f_s$ ,而為了達到 n-bit 的解析度(resolution),內部時脈必須為 $2^n f_s$ 。 假設今天輸入為取樣頻率 44.1KHz 的音樂訊號,而三角波作 32 倍的過度取樣,所以  $f_s = 44.1K \times 32Hz$ ,若要達到 16-bit 的解析度,則內部所需時脈為 $44.1K \times 32 \times 2^{16}$ 約等於 92GHz,在實現上不僅是 timing constraint 無法達到,同時還會增加功率消耗的問題。

#### 2.2 Sigma-Delta Modulator

切換式電源轉換器的損失包含有:導通損失、切換損失以及週邊控制電路之耗損。 近年來,先進國家對於電器產品之低功率損耗要求日益嚴格,還針對待機時之功率耗損 訂定標準規範。因此,許多降低切換頻率以及功率損耗的技術也就孕育而生。而無須濾 波器的 D 類放大器解決了這項問題,此放大器可以充分的利用揚聲器的自身電感及低 頻響應特性,無須在訊號調變送入 D 類放大器後再加濾波器,但是基於 PWM 的 D 類 放大器,因為它的總諧波失真(Total Harmonics Distortion)較高,所以只能提供有限的頻 寬,無法支援多音調振鈴及 MP3 播放。爲了解決此頻率響應的問題,採用 Sigma-Delta 的調變方法並且無需要濾波器的 D 類放大器因此產生,它不但可以提供較廣的頻寬同 時也可以降低切換頻率,甚至不需要後級的濾波器。

Delta Modulator 最早由 Frank de Jager[5]於 1952 年提出的架構,應用在通訊領域。



圖 2.2 Delta Modulator 與 power stage 架構圖

上圖 2.2 為 Delta Modulator 與 power stage 的架構圖。圖中的「為 one-bit 量化器, 產生 1 或是-1 的切換訊號,積分則為類似三角波,與輸入訊號比較。當輸入訊號大於 三角波,即誤差大於零,量化為高準位(1),積分後三角波增大;輸入訊號小於三角波, 即誤差小於零,量化為低準位(-1),積分後三角波變小。如此的切換動作,使得三角波 得以近似輸入訊號。將切換訊號透過 power stage 功率放大後,積分為近似輸入訊號的 三角波,輸出,達到放大的目的。

Sigma-Delta Modulation 架構由 Inose 於 1962 年提出[6],從 Delta Modulator 演變而來,將 Delta Modulator 在 power stage 的類比積分器,換到 signal stage,成為一個 signal 積分器,使系統整體的轉移函數不變。下圖 2.3 可以看到一階類比的 Sigma-Delta Modulation 則是將積分器代換為數位累加器,如圖 2.4 為一階數位的 Sigma-Delta Modulation。



圖 2.3 一階類比 Sigma-Delta Modulator



圖 2.4 一階數位 Sigma-Delta Modulator

數位 Sigma-Delta Modulation 通常可以依二個重要特徵--階數、取樣頻率,作為比較、評估的基準。隨著超大型積體電路製程不斷的改良,電路的操作速度不斷的提昇且供應電壓逐漸地下降,可將 Sigma-Delta Modulation 應用在較高頻寬的系統。



圖 2.6 Sigma-Delta Modulation 輸出頻譜響應圖(0~40K Hz)

上圖 2.5 為 PWM 的輸出頻譜響應圖,其 switching frequency 為 44.1K\*16Hz,解析 度為 3bit;圖 2.6 為四階、oversampling 為 16 倍的 Sigma-Delta modulation 的輸出頻譜 響應圖,比較此二圖可以明顯的發現,PWM 的 Harmonics 問題很嚴重,而 Sigma-Delta Modulation 則能將 noise 推到約 5KHz 以上的頻帶,因此在 5KHz 內的雜訊比 PWM 小 很多。

## 2.3 Receding Horizon Quadratic Control with Constraint

於 2002 年由 Daniel E. Quevedo 等人提出了一種從有限制條件的最佳化控制 (constrained optimal control)為觀點的方法[7],此方法可以依據不同的需求而訂定出個別 的 Cost Function,例如:切換次數、量化誤差、狀態的大小或是參考輸入等,所以它比 Sigma-Delta Modulation 的設計更具彈性。

首先考慮一個系統其輸入為u(k),以及它的狀態向量為x(k)∈ ℝ<sup>n</sup>,在此假設 n=1, 可得到下列的狀態方程式:

$$x(k+1) = Ax(k) + Bu(k), \quad u(k) \in U$$
(2-1)

where U is a set representing input constraints.

選擇 Finite Horizon Quadratic Cost Function 如下

$$V_{N}(x(k), u(k)) = x^{T}(k+1)Px(k+1) + \{x^{T}(k)Qx(k) + u^{T}(k)Ru(k)\}$$
(2-2)

其中 $Q \ge 0, P > 0$  and R > 0

將(2-1)式帶入(2-2)式可得:

$$\mathbf{V}_{N}(x(k),u(k)) = \overline{\mathbf{V}}_{N}(x(k)) + u^{T}(k)Wu(k) + 2u^{T}(k)Fx(k)$$
(2-3)

其中  $W = B^T QB + R$ ,  $F = B^T QA$ ,  $\overline{V}_N(x(k))$ 為與u(k)無關的項。

設 $\tilde{u}(k) = W^{1/2}u(k)$ 代入(2-3)可化為

$$\mathbf{V}_{N}\left(x(k),u(k)\right) = \overline{\mathbf{V}}_{N}\left(x(k)\right) + \tilde{u}^{T}\left(k\right)\tilde{u}\left(k\right) + 2\tilde{u}^{T}\left(k\right)W^{-1/2}Fx(k)$$
(2-4)

將(2-4)對u(k)微分,可求得最佳解:

$$\tilde{u}(x(k)) = -W^{-1/2}Fx(k)$$

再將此最佳解經過量化,即可得到開關的切換訊號,如下所示

$$u^{*}(x(k)) = W^{-1/2}q_{\tilde{U}^{N}}(-W^{-1/2}Fx(k))$$
(2-5)



上圖 2.7 為 Receding Horizon Quadratic Control with Constraint 輸出頻譜響應,與 PWM 比起來,它的 Nosie Shaping 效果較佳且 Harmonics 問題較小。此方法在高階的穩 定性上仍有待證明,因為此最佳化方法的回授為非線性,無法依據線性系統中的穩定性 原則來判定。

# 第三章 設計 Multi-Step Optimal Converter

在數位的聲音處理上,面臨著一個重要的問題--量化誤差(quantization errors),將 multi-bit 數位訊號調變為 single bit 數位訊號的 modulation 時,難免會產生量化誤差,因 此經過量化後的資訊一定會有所損失,當訊號經由還原後會與原本的訊號有所差異,所 以一個好的轉換器(converter)是要使產生的訊號與原訊號最相似為原則,例如以均方誤 差(meansquare error)去量測時,當然對於處理聲音的轉換器來說,它的目標是要滿足人 類的聽覺。

Sigma-Delta Modulation 是一個廣為人知的轉換器,架構如圖 3.1 所示, r為輸入訊號, y 為輸出訊號, F 與 G 為線性的濾波器,而一般來說量化器(quantizer)為產生 1 或 -1 的切換訊號(single bit 數位訊號), Sigma-Delta Modulator 是以下要介紹的 MSOC(Multi-Step Optimal Converter) [3]的一個特例。



圖 3.1 General single-stage Sigma-Delta Converter

## 3.1 架構分析

整體架構大致上可以分為量化器(quantizer)、Finite Horizon Formulation 以及 Solution and Closed Loop Implementation 來闡述。

#### 3.1.1 Define Quantizer

首先,定義 Nearest Neighbor Vector Quantizer[8],如下:

Definition 1: 給定一個可數的集合〔不一定有限〕,包函不相等的向量

 $B = \{b_1, b_2, ...\} \subset \mathbb{R}^{n_B}$ , the nearest neighbor quantizer is defined as a mapping  $q_B : \mathbb{R}^{n_B} \to B$ which assigns to each vector  $c \in \mathbb{R}^{n_B}$  the closest element of B (as measured by the Euclidean norm),  $\mathring{R} \equiv \mathring{z} : q_B(c) = b \in B$  if and only if c satisfies:

$$\left\|c-b\right\| \le \left\|c-b_i\right\|, \quad \forall b_i \in B \tag{3-1}$$

較詳細的 vector quantizers 還有其特性可以參考[9]。這個量化器(quantizer)可以用來解決 Audio quantization 的問題。考慮一個經過取樣的聲音訊號序列,  $\{a(k)\}, t \in \mathbb{N}$ , 這個序 列的訊號必需被量化成 $\{u(t)\}, t \in \mathbb{N}$ , 其中u(t)的每個值, 被限制在一個有限的集合,  $U = \{s_1, \dots, s_n\}$ 此序列的訊號將被量化為最接近集合U裡的元素,當時間t = k時。  $u(k) = q_u(a(k)).$  (3-2)

#### **3.1.2 Finite Horizon Formulation**

我們的目的在於最佳化失真誤差(distortion errors)到一個適當的值,所以使轉換誤 差(conversion errors)通過一個穩定的、因果的、線性的以及非時變的濾波器 H,此濾波 器可以透過下列式子來表示:

$$H(\rho) = D + C(\rho I - A)^{-1}B,$$
(3-3)

其中 $A \in \mathbb{R}^{n \times n}, B \in \mathbb{R}^{n \times 1}, C \in \mathbb{R}^{1 \times n}, D \in \mathbb{R}^{1 \times 1}$ ,  $\rho v(k) = v(k+1)$ , 其中 $\{v(k)\}$ 是任意的序列。

此濾波器可以是典型的低通濾波器(low pass filter)並且使用過度取樣轉換(oversampled conversion),在聲音的應用上,選擇H為人耳的感知聲學模型(psycho-acoustic model)。

設計一個理想的量化器(quantizer)使經過濾波器後的誤差(filtered error)最小化,可將此概念經由下列式子表示之:

$$e(t) \triangleq H(\rho) \left( a(t) - u(t) \right)$$

其中a(t)為原輸入訊號,u(t)為量化後的訊號,在此將e(t)表示為狀態空間系統的輸出,而此狀態空間系統的表示式如下所示:

$$x(t+1) = Ax(t) + B(a(t) - u(t))$$
  

$$e(t) = Cx(t) + D(a(t) - u(t)),$$
(3-4)

其中 $\{C, A, B\}$ 與方程式(3-3)裡的相同,而 $x \in \mathbb{R}^n$ 為濾波器的狀態, $n \in \mathbb{N}$ 為狀態的維度 (dimension),也就是濾波器H的階數(order)。

根據設計的目的,以二次成本函數(quadratic cost function)為設計準則,並在有限的區間N內;在時間t = k時,將下列之二次成本函數最小化則可求得解:

$$V_{N}\left(\vec{u}(k)\right) = \sum_{t=k}^{k+N-1} \left(e(t)\right)^{2},$$
(3-5)

其中

$$\vec{u}(k) = \begin{bmatrix} u(k) & u(k+1) & \cdots & u(k+N-1) \end{bmatrix}^T \in \mathbf{U}^{\mathbf{N}}$$
(3-6)

集合 $U^{N} \subset \mathbb{R}^{N}$ 且定義為: U<sup>N</sup> ≜ U×···×U。

#### **3.1.3 Solution and Implementation of the MSOC**

最佳化的控制問題在上一小節已經描述過了,將方程式(3-5)求其最小的值可以得其 解:

$$\vec{u}^{*}(k) = \arg\min_{\vec{u}(k)\in U^{N}} V_{N}\left(\vec{u}(k)\right).$$
(3-7)

其中 $U^N$ 是非凸集合(non-convex set),所以此問題是一個非凸最佳化(non-convex optimization)問題。

<u>定理一</u>:假設 $U^{N} = \{v_{1}, v_{2}, ..., v_{r}\}, 其中 r = (n_{U})^{N}$ ,由方程式(3-7)、(3-3)、(3-5)以及(3-6) 可以得到最佳化序列 $\vec{u}^{*}(k)$ 如下:

$$\vec{a}(k) = \begin{bmatrix} a(k) \\ a(k+1) \\ \vdots \\ a(k+N-1) \end{bmatrix}, \quad \Gamma = \begin{bmatrix} C \\ CA \\ \vdots \\ CA^{N-1} \end{bmatrix}, \quad \Psi = \begin{bmatrix} 1 & 0 & \cdots & 0 \\ h_1 & 1 & \ddots & \vdots \\ \vdots & \ddots & \ddots & 0 \\ h_{N-1} & \cdots & h_1 & 1 \end{bmatrix}$$
(3-8)

$$h_i = CA^{i-1}B, \quad i = 1, 2, \dots, N-1.$$

非線性的  $q_{\tilde{U}^N}(\cdot)$  是Nearest Neighbor Vector Quantizer在3.1.1 Definition 1中描述過, $U^N$  被映射(mapping)到另一個集合上:

$$\widetilde{U}^{N} \triangleq \left\{ \widetilde{v}_{1}, \widetilde{v}_{2}, \dots \widetilde{v}_{r} \right\} \subset \mathbb{R}^{N}$$
(3-9)

其中:

其中:

$$\tilde{v}_i = \Psi v_i, v_i \in U^N.$$

<u>證明</u>:

設 
$$\vec{e}(k) = \left[ e(k) e(k+1) \cdots e(k+N-1) \right]^T$$

將(3-4)式代入上述向量中可得

$$\vec{e}(k) = \Psi \vec{a}(k) - \Psi \vec{u}(k) + \Gamma x(k)$$

#### (3-5)式可以表示為

$$V_{N}\left(\vec{u}(k)\right) = \vec{e}(k)^{T}\vec{e}(k)$$

$$= \left(\Psi\vec{a}(k) - \Psi\vec{u}(k) + \Gamma x(k)\right)^{T} \left(\Psi\vec{a}(k) - \Psi\vec{u}(k) + \Gamma x(k)\right)$$

$$= \overline{V}_{N}\left(x(k), \vec{a}(k)\right) + \vec{u}^{T}\left(k\right)\Psi^{T}\Psi\vec{u}(k) - 2\vec{u}^{T}\left(k\right)\Psi^{T}\left(\Psi\vec{a}(k) + \Gamma x(k)\right), \quad (3-10)$$

$$\nexists \Psi$$

 $\overline{V}_{N}(x(k), \vec{a}(k))$ 為與 $\vec{u}(k)$ 無關的項。

設 $\vec{\mu}(k) = \Psi \vec{u}(k)$ , 在(3-9)式中定義了將 $U^N$  映射到 $\tilde{U}^N$ 上, 代入(3-10)式可得

$$V_{N}\left(\vec{u}(k)\right) = \overline{V}_{N}\left(x(k),\vec{a}(k)\right) + \vec{\mu}^{T}\left(k\right)\vec{\mu}\left(k\right) - 2\vec{\mu}^{T}\left(k\right)\left(\Psi\vec{a}(k) + \Gamma x(k)\right),$$
(3-11)

將(3-7)式重新改寫如下

$$\vec{u}^{*}(k) = \Psi^{-1} \arg \min_{\vec{\mu} \in \vec{U}^{N}} J_{N}\left(\vec{\mu}(k)\right)$$
$$J_{N}\left(\vec{\mu}(k)\right) \triangleq \vec{\mu}(k)^{T} \vec{\mu}(k) - 2\vec{\mu}^{T}(k)\left(\Psi\vec{a}(k) + \Gamma x(k)\right)$$

水平集合(level sets) $J_{N}$ 是以 $\overline{\Psi a(k)}$ + $\Gamma x(k)$ 為中心的球面所構成的集合,且此集合在

ℝ<sup>N</sup>裡,因此可以得到

$$\arg \min_{\vec{\mu}\in\vec{U}^{N}} J_{N}\left(\vec{\mu}(k)\right) = q_{\vec{U}^{N}}\left(\Psi\vec{a}(k) + \Gamma x(k)\right)$$

由此可以證實(3-8)式。在(3-8)式中的 $q_{\bar{v}^N}(\cdot)$ 是一個N-維度的向量量化器(quantizer),而 隨著horizon length N的增加,實現上的複雜度也跟隨著增加,所以在各方面的應用上變 得有些不實際;但是相對的,當N越大時,所得到的效能(performance)也比較好,因為 在處理的過程中考慮了較多的資料(data)。MSOC在N=1時,它等於是Sigma-Delta Modulator,所以Sigma-Delta Modulator是MSOC的一個特例。

在時間t = k時,為了提高性能(performance), $\vec{u}^{*}(k)$ 只有第一個元素(element)將被使用來做為回授(feedback)以及輸出,如下所示:

$$u^{*}(k) \triangleq \begin{bmatrix} 1 & 0 & \cdots & 0 \end{bmatrix} \vec{u}^{*}(k)$$
  
=  $\begin{bmatrix} 1 & 0 & \cdots & 0 \end{bmatrix} \Psi^{-1} q_{\vec{u}^{N}} \left( \Psi \vec{a}(k) + \Gamma x(k) \right)$  (3-12)

在(3-12)式中, $u^*(k)$ 作為轉換器(converter)的輸出,於是將 $u(k) \leftarrow u^*(k)$ ;而 $u^*(k)$ 還 需要用來更新(update)狀態x(k),所以需要做回授(feedback),更新狀態如下所示:

$$x(k+1) = Ax(k) + B(a(k) - u^{*}(k)).$$
(3-13)

在下一個取樣時間點,新的狀態將被使用做為最小化成本(minimize the cost) $V_N(\hat{u}(k+1))$ ,得到u(k+1)。如圖3.2所示,為N=3的Moving Horizon。當取樣時間點向前移動,也 就是k遞增時, $V_N(\cdot)$ 也隨著向前移動,而 $V_N(\cdot)$ 移動的方法即是透過狀態 $x(\cdot)$ 。因為隨 著更新(update)後的狀態 $x(\cdot)$ ,過去的 $u^*(\cdot)$ 會被傳遞,如此重複遞回下去。



圖 3.2 Moving horizon principle, N=3

根據(3-12)式,必須要有現在的狀態(state)x(k)的資訊,可將(3-4)式改寫成

$$x(k) = (\rho I - A)^{-1} B(a(k) - u(k)), \qquad (3-14)$$

將(3-14)式代入(3-12)式中可以得到:

$$u(k) = [1 \ 0 \ \cdots \ 0] \Psi^{-1} q_{\widetilde{U}^{N}} \left( \left( \Psi + \Gamma(\rho I - A)^{-1} B[1 \ 0 \ \cdots \ 0] \right) \overline{a}(k) - \Gamma(\rho I - A)^{-1} Bu(k) \right)$$
(3-15)

將 $\vec{a}(k)$ 以a(k)表示,(3-15)式可以改寫為:

$$u(k) = [1 \ 0 \ \cdots \ 0] \Psi^{-1} q_{\widetilde{n}^{N}} \left( \operatorname{H}(\rho) a(k) - F(\rho) u(k) \right)$$
(3-16)

其中

$$\mathbf{H}(\rho) = \Psi \left[ 1 \rho \cdots \rho^{N-1} \right]^{T} + \Gamma \left( \rho I - A \right)^{-1} B, \quad F = \Gamma \left( \rho I - A \right)^{-1} B$$

圖3.3表示了(3-16)式的架構[3],是以回授的方式表示,其中粗線表示是向量的訊號路徑。



圖 3.3 以回授的方式(feedback loop)實現MSOC



Mannun .

# 3.2 Relationship to the Noise Shaping Quantizer

圖 3.4 是一個常見的雜訊整形量化器(noise shaping quantizer),包含了濾波器 $Y(\rho)$ ,此濾波器將u(k)與w(k)的差異回授(feeds back)。



圖 3.4 Noise Shaping Quantizer

而由上圖可以導出下列式子:

$$u(k) = a(k) + (1 - Y(\rho))(u(k) - w(k)), \qquad (3-17)$$

通常1-Y(ρ)為一個高通濾波器,它的目的是要把u(k)中發生的某些頻率的量化雜訊整型(shape),也就是說它將雜訊頻譜(spectrum)推到人耳比較聽不見的頻帶去,使輸出更為人耳所能接受。

將 n 階的 Sigma-Delta Modulator 化簡為如圖 3.5 所示[10],其中 $F(\rho)$ 為訊號的轉 移函數, $W(\rho)$ 為迴路濾波器(loop filter),「為量化器。



將圖 3.5 以 additive noise model 將量化器線性化,如圖 3.6 所示,其中 $\hat{e}[k]$ 為量化誤差, 而量化誤差的轉移函數即為 Sigma-Delta Modulator 的雜訊轉移函數(Noise Transform Function),其轉移函數如(3-18)式所示:



圖 3.6 以 additive noise model 線性化 n 階 Sigma-Delta Modulator

$$\mathrm{NTF}(\rho) = \frac{1}{1 + W(\rho)} \tag{3-18}$$

而在(3-17)式中,也可得到雜訊轉移函數:  $NTF(\rho) = 1 - Y(\rho);$ 而又可將(3-17)式改寫成:

$$w(k) = \frac{1}{1 - Y(\rho)} a(k) - \frac{Y(\rho)}{1 - Y(\rho)} u(k)$$
(3-19)

經由上列式子可將圖 3.4 的回授路徑改為如圖 3.7 所示。



圖 3.7 Noise Shaping Quantizer, redrawn

將圖 3.7 與圖 3.3 比較,在 N=1 時後的圖 3.3 的架構相當於圖 3.7,則可以得到
$$H(\rho) = \frac{1861}{1 - Y(\rho)}$$
(3-20)

而因為NTF $(\rho)$ =1- $Y(\rho)$ ,由(3-18)式以及(3-20)式可以得到:

NTF
$$(\rho) = \frac{1}{1 + W(\rho)} = 1 - Y(\rho) = H(\rho)^{-1}$$
 (3-21)

由此在設計 MSOC 的H(
ho)此濾波器時,即可以[3]的設計原則來設計。

## 3.3 設計範例

根據3.1節的架構分析,以下將設計二個MSOC的實例以供參考。首先先定義四個 量測上的標準。

訊號雜訊比(Signal to Noise Ratio)

$$SNR = 10\log_{10}(\frac{\sigma_x^2}{\sigma_e^2})$$

其中 $\sigma_x$ 是訊號的能量, $\sigma_e$ 是雜訊的能量。

總諧波失真(Total Harmonic Distortion)[11]



其中 $S_1$ 為基頻(fundamental frequency),  $S_2 \cdots S_n$ 為諧波頻率(harmonic frequencise)。

如果失真的量很小,則可以將(3-22)改寫為

$$\% THD = 100 \times \frac{\sqrt{S_2^2 + S_3^2 + \dots + S_n^2}}{\sqrt{S_1^2 + S_2^2 + S_3^2 + \dots + S_n^2}}$$

總諧波失真加雜訊(Total Harmonic Distortion plus Noise)

$$\% THD + N = 100 \times \frac{\sqrt{S_2^2 + S_3^2 + \dots + S_n^2 + N^2}}{S_1}$$
(3-23)

其中N為非諧波訊號(non-harmonically related signals)以外的雜訊來源。

如上當失真很小時可以改寫(3-23)為

$$\% THD + N = 100 \times \frac{\sqrt{S_2^2 + S_3^2 + \dots + S_n^2 + N^2}}{\sqrt{S_1^2 + S_2^2 + S_3^2 + \dots + S_n^2 + N^2}}$$

感知誤差的取樣標準差 (the sample variance of the perceived error)[4]

$$V^{2} \triangleq \frac{1}{T_{f}} \sum_{i=1}^{T_{f}} \left( e(i) \right)^{2} = \frac{1}{T_{f}} \sum_{i=1}^{T_{f}} \left( H(\rho) \left( a(i) - u(i) \right) \right)^{2}$$

在以下的範例中,因為失真並不算很小,所以皆採用原式。

#### <u>範例一</u>:

Sampling Frequency=1.4994MHz, Oversampling 為 34 倍。



圖 3.8 2-order, N=1的MSOC架構圖

因為目前是採用二階的濾波器,所以在設計上並不需要特別設計係數即可穩定, 所以上圖中的 $a_1 = a_2 = b_1 = b_2 = 1$ ,此架構即為二階的Sigma-Delta Modulator。

下列表格為不同頻率的數位訊號輸入,將輸出的 single bit 數位訊號取 FFT 後,藉 由上述的量測標準,比較可得。圖 3.9 為輸入 1K Hz 的數位弦波訊號所得到的輸出頻率 響應圖。

|        | %THD   | SNR(dB) | %THD+N | Switching<br>Number(times/100ms) | Error variance |
|--------|--------|---------|--------|----------------------------------|----------------|
| 1K Hz  | 0.0184 | 87.90   | 0.18   | 68440                            | 1.1056         |
| 2K Hz  | 0.0294 | 84.1152 | 0.28   | 68508                            | 1.1402         |
| 5K Hz  | 0.1092 | 76.9934 | 0.63   | 68222                            | 1.2044         |
| 10K Hz | 0.0927 | 71.2661 | 1.22   | 67783                            | 1.3286         |

表 3.3.1 二階, N=1, 1-bit 的 MSOC 輸出比較結果



圖 3.9 輸入為1K Hz的弦波訊號頻率響應圖

設計取樣頻率為1.4994MHz的二階、N=1的MSOC,能將量化誤差轉移到5KHz以上的高頻區域,降低5KHz以內的雜訊大小。

#### <u>範例二</u>:

Sampling Frequency=1.4994MHz, Oversampling 為 34 倍。

首先設計H(
$$\rho$$
)為純二階積分器,H( $\rho$ )= $\frac{1}{\left(1-z^{-1}\right)^2}$ 。

N=2,量化器(quantizer)為1-bit。

以下是此2-order,N=2的MSOC架構圖。



圖 3.10 2-order, N=2的MSOC架構圖

圖中的 $q_{\tilde{U}^2}(\cdot)$ 為1-bit量化器,但是它有兩個input,在下一章節中將會介紹此向量量化器(vector quantizer)的設計方法與內部結構。

由上圖可以看到在輸入訊號部分為u(k)與u(k-1),而在(3-6)式中  $\vec{u}(k) = [u(k) u(k+1)]^{T}$ ,因為在實際的系統中,是無法得到未來的輸入的,所以在實現 上是以delay的方式來表示。

下表格與上一個範例一樣,皆為輸入不同頻率的弦波信號所產生的輸出比較表, 而圖 3.11 為輸入 1K Hz 的數位弦波訊號所得到的輸出頻率響應圖。

|        | %THD   | SNR(dB) | %THD+N | Switching<br>Number(times/100ms) | Error variance |
|--------|--------|---------|--------|----------------------------------|----------------|
| 1K Hz  | 0.0167 | 88.2974 | 0.17   | 71550                            | 0.6390         |
| 2K Hz  | 0.0291 | 84.2978 | 0.27   | 71760                            | 0.6393         |
| 5K Hz  | 0.1124 | 77.0909 | 0.63   | 71757                            | 0.6601         |
| 10K Hz | 0.0913 | 71.2923 | 1.22   | 72085                            | 0.6842         |

表 3.3.2 二階, N=2, 1-bit 的 MSOC 輸出比較結果



圖 3.11 輸入為1K Hz的弦波訊號頻率響應圖

比較表格3.3.1與3.3.2發現,在%THD、SNR與%THD+N沒有相差很大,但是在N=2 時是有稍微好一些的;而在切換次數上(switch number),N=2略大於N=1;在感知誤差 的取樣標準差上,N=2明顯的比N=1小。

比較圖3.9與3.11,可以發現圖3.11中的量化誤差轉移的效果稍微好一些,約將量化誤差轉移到6KHz以上的高頻區域,降低6KHz以內的雜訊大小。

而在二階,1.5-bit的N=1與N=2的部份,分別與範例一與範例二的架構圖一樣,但 是在於 $q_{\tilde{n}^2}(\cdot)$ 部份,N=1為1.5bit的Quantizer,而N=2的部份為1.5-bit的Vector Quantizer。

下圖 3.12 、 3.13 以及 3.14 為 比較 2-order,N=1,1-bit 、 2-order,N=1,1.5-bit 、 2-order,N=2,1-bit以及2-order,N=2,1.5-bit的Error Variance、SNR及THD+N關係圖。由圖 中可以發現N=2的Error Variance比N=1的小,又1.5-bit的Error Variance比1-bit的小。在此 2-order,N=2,1.5-bit有最小的Error Variance;在SNR與THD+N的部份,當N=1與N=2的表 現上差異不大,而在1.5-bit與1-bit的結果上,發現當在較低頻率時候,1.5-bit的效果較好,而在較高頻率時則結果相近。圖3.15與3.16為輸入不同振幅訊號的SNR與THD+N的 比較關係圖,可以發現結果也如同圖3.13與3.14一樣,以1.5bit的效果較佳。



圖 3.12 Error Variance比較關係圖


圖 3.14 THD+N比較關係圖



圖 3.16 輸入不同振幅的訊號之THD+N比較關係圖

# 第四章 量化器的設計實例與分析

在圖3.10中出現向量的量化器,而其中量化器又包含了one bit與1.5-bit,所以在此節中將介紹在實作上所需要用到的各種量化器。

# 4.1 Horizon One and 1.5-Bit

選擇N=1且輸出為1.5-bit的量化器(quantizer),在(3-9)中 $\tilde{v}_i = \Psi v_i, v_i \in U^N$ ,在此使用 二階的MSOC,  $U = \{1, 0, -1\}$ ,  $\Psi = 1$ ,可以將之映射到 $\tilde{U} = \{1, 0, -1\}$ , 因為 $\tilde{U} \in \mathbb{R}^1$ , 所以可將 $d_1(k)$ 軸上的輸入分為三個值,可以由圖4.1中看到此量化器(quantizer)的分割 情形,而圖中的深灰色區段表示量化後的輸出為1;灰色表示為0;淺灰色表示為-1。而 圖4.2可以看到此量化器(quantizer)的架構圖。  $d_1(k) + 0.5 = 0$  $d_1(k) = 0$  $d_1(k) = 0$  $d_1(k) = 0$ 

圖 4.1 一維量化器



圖 4.2 一維量化器之架構圖

## 4.2 Horizon Two and One - Bit

選擇N=2且輸出為1-bit,  $U = \{1, -1\}$ ,可以得到:

$$U^{2} = \left\{ \begin{bmatrix} -1\\ -1 \end{bmatrix}, \begin{bmatrix} -1\\ 1 \end{bmatrix}, \begin{bmatrix} 1\\ -1 \end{bmatrix}, \begin{bmatrix} 1\\ 1 \end{bmatrix} \right\},$$
 將之映射到  
$$\widetilde{U}^{2} = \left\{ \begin{bmatrix} -1\\ -3 \end{bmatrix}, \begin{bmatrix} -1\\ 1 \end{bmatrix}, \begin{bmatrix} -1\\ 1 \end{bmatrix}, \begin{bmatrix} 1\\ -3 \end{bmatrix}, \begin{bmatrix} 1\\ 1 \end{bmatrix} \right\}$$

向量量化器(vector quantizer)  $q_{\tilde{U}^2}(\cdot)$ 依據nearest neighbor rule(3-1),分割了輸入空間 $\mathbb{R}^2$ 成四個區域。但是在(3-12)式中,我們僅對 $\vec{u}^*(k)$ 的第一個元素有興趣,所以只有兩個區域是有意義的。將(3-16)是寫成如下:

其中
$$d(k) = \begin{bmatrix} d_1(k) \\ d_2(k) \end{bmatrix}$$
,在圖3.10中可以看到。
$$(4-1)$$

由圖4.3可以看到如何分割此兩個有意義的區域。由圖中可以看到 $\tilde{U}^2$ 中的四個轉換後的 參考點(紅點),而根據nearest neighbor quantizer的方法,此座標平面上的任何點與此四 個參考點分別比較距離,也就是比較平方差,選取與之平方差最小的參考點為其量化 後的值,但是因為我們只在意 $d(k) = \begin{bmatrix} d_1(k) \\ d_2(k) \end{bmatrix}$ 的 $d_1(k)$ ,所以最後只會將座標平面分為

兩個區域 $D_1$ 與 $D_2$ ,其中 $D_1$ 為圖中淺灰色的區域; $D_2$ 為深灰色區域,因為在此是1-bit的量化器,所以

$$u(k) = \begin{cases} +1, \text{ if } d(k) \in D_1 \\ -1, \text{ if } d(k) \in D_2 \end{cases}$$

經由下列式子實現

$$u(k) = q_U \left( q_U \left( d_1(k) + 2d_2(k) - 2 \right) + q_U \left( d_1(k) + 2d_2(k) + 2 \right) + q_U \left( d_1(k) + d_2(k) \right) \right)$$
(4-2)

其中if  $(\cdot) \ge 0$ , then  $q_U = +1$ ;  $(\cdot) < 0$ , then  $q_U = -1$ .

而由圖 4.4 可以看到此量化器的架構圖。



圖 4.4 N=2的1-bit 量化器之架構圖

# 4.3 Horizon Two and 1.5 - Bit

選擇 N=2 且輸出為 1.5-bit, U = {1,0,-1},可以得到

$$U^{2} = \left\{ \begin{bmatrix} -1\\ -1 \end{bmatrix}, \begin{bmatrix} -1\\ 1 \end{bmatrix}, \begin{bmatrix} 1\\ -1 \end{bmatrix}, \begin{bmatrix} 1\\ 1 \end{bmatrix}, \begin{bmatrix} 0\\ 0 \end{bmatrix}, \begin{bmatrix} 1\\ 0 \end{bmatrix}, \begin{bmatrix} -1\\ 0 \end{bmatrix}, \begin{bmatrix} 0\\ 1 \end{bmatrix}, \begin{bmatrix} 0\\ -1 \end{bmatrix} \right\},$$
 #  $\geq$  映射 到  
$$\widetilde{U}^{2} = \left\{ \begin{bmatrix} -1\\ -3 \end{bmatrix}, \begin{bmatrix} -1\\ -1 \end{bmatrix}, \begin{bmatrix} 1\\ 1 \end{bmatrix}, \begin{bmatrix} 1\\ 3 \end{bmatrix}, \begin{bmatrix} 0\\ 0 \end{bmatrix}, \begin{bmatrix} 1\\ 2 \end{bmatrix}, \begin{bmatrix} -1\\ -2 \end{bmatrix}, \begin{bmatrix} 0\\ 1 \end{bmatrix}, \begin{bmatrix} 0\\ -1 \end{bmatrix} \right\}$$

向量量化器(vector quantizer) $q_{\tilde{u}^2}(\cdot)$ 分割了輸入空間 $\mathbb{R}^2$ 成九個區域,因為在此為 1.5-bit 的量化器(quantizer),又因為只取 $\tilde{u}^*(k)$ 中的第一個元素,所以將座標平面分成三個區 域,由圖 4.5 中可以看到九個轉換後的參考點(紅點),以及分割的三個區塊分別為  $D_1 \cdot D_2 與D_3$ ,其中 $D_1$ 為圖中淺灰色區塊; $D_2$ 為深灰色區塊; $D_3$ 為灰色區塊。而可以得 到輸出為

$$u(k) = \begin{cases} 1896 \\ -1, \text{ if } d(k) \in D_1 \\ +1, \text{ if } d(k) \in D_2 \\ 0, \text{ if } d(k) \in D_3 \end{cases}$$

經由下列式子實現

$$u(k) = sign \left\{ q_{U} \left[ q_{U} \left( d_{1}(k) + d_{2}(k) - 2 \right) + q_{U} \left( d_{1}(k) + 2d_{2}(k) - 0.5 \right) \right. \\ \left. + q_{U} \left( d_{1}(k) + 2d_{2}(k) - 4.5 \right) + q_{U} \left( d_{1}(k) - 0.5 \right) \right. \\ \left. + q_{U} \left( d_{1}(k) + d_{2}(k) + 2 d_{2}(k) - 1 \right) \right] \\ \left. + q_{U} \left[ q_{U} \left( d_{1}(k) + d_{2}(k) + 2 \right) + q_{U} \left( d_{1}(k) + 2d_{2}(k) + 0.5 \right) \right. \\ \left. + q_{U} \left( d_{1}(k) + 2d_{2}(k) + 4.5 \right) + q_{U} \left( d_{1}(k) + 0.5 \right) \right. \\ \left. + q_{U} \left( d_{1}(k) + d_{2}(k) + 1 \right) \right] \right\}$$

$$(4-3)$$

其中 if  $(\cdot)=0$ , then  $sign(\cdot)=0$ ; if  $(\cdot)>0$ , then  $sign(\cdot)=+1$ ; if  $(\cdot)<0$ , then  $sign(\cdot)=-1$ . 由(4-3)式發現,由於分割區域所呈現的狀態較複雜,在實現上會使用到較多硬體,在此 我採用了圖中有標示的十個方程式去趨近。而圖 4.6 可以看到實現此量化器的架構圖。



圖 4.6 N=2的 1.5-bit 量化器之架構圖

# 第五章 實現

要實現一個全數位化的音頻擴大器,其架構如圖 1.2 所示,而圖中的『Modulator』 與『Amplifier』方塊,要能即時(real time)地接收由 PC 端送出的 16bits 數位音樂訊號, 並將其調變為 one bit 或是 1.5-bit 的數位訊號,經由功率放大後將其輸出。因此,利用 USB 作為與 PC 端的介面、FPGA 實現數位的 Multi-Step Optimal Converter(MSOC)以及 power MOS 實作一個高速的切換式 power stage, 三個部分來實現全數位化的音頻放大 器。圖 5.1 顯示了實現此全數位化的音訊擴大器的方塊圖。



圖 5.1 全數位化的音頻擴大器系統方塊圖

以 FPGA 實現 1499.4KHz 的數位 two-step 的 MSOC,輸入訊號為雙聲道 16-bits、 44.1KHz 的 PCM 音樂訊號,經過調變後輸出為 one-bit 或是 1.5-bit 的數位訊號。因此此 雙聲道 44.1KHz、16-bits 的音樂訊號必須及時的從 PC 端送出,而 USB 就是 PC 端與 FPGA 之間的介面。但是因為 FPGA 的輸出電壓為 3.3V 的數位訊號,此電壓不足以推 動喇叭,所以需將輸出訊號經過一個 power stage 做功率放大,再將此輸出推動喇叭。

## 5.1 USB 介面

USB 為 Universal Series Bus(萬用串列匯流埠)的縮寫。因為 USB 允許把外界的設備 與 PC 連接,不需重新配置規劃系統,且有隨插即用的功能,所以在此選用 USB 當做 介面。USB 界面使用 7-bit 的定址欄位,扣掉 USB 主機預設給第一次接上的周邊設備 使用,還剩 127 個位址可以使用,因此一部電腦最多可以連接 127 個 USB 裝置。



圖 5.2 USB 基本架構

一般 USB 系統的基本架構可以分為三個主要部份[12]:

- 1. USB 主機控制器(Host controller)/根集線器(Root Hub)
- 2. USB 集線器(Hub)
- 3. USB 裝置(Device)

所有在 USB 系統上的溝通都是在軟體控制下由 PC 主機啟動的,而主機的硬體函括了 主機控制器與根集線器。但是光靠根集線器不可能同時連接上 127 個周邊,所以 USB 系統還支援額外的集線器,而 USB 裝置就是泛指 USB 的各類型的周邊,而整個 USB 連接裝置的方式是類似於金字塔型的架構。圖 5.2 顯示了 USB 的基本架構圖,其中 USB Host 端的角色是 master,所有 Device 都聽 Host 端控制。

USB 的傳輸類型共有四種:控制傳輸(Control Transfer)、中斷傳輸(Interrupt Transfer)、巨量傳輸(Bulk Transfer)及等時傳輸(Isochronous Transfer)[13]。

- 控制傳輸:用來配置以及送出命令給裝置的,為雙向傳輸。控制型傳輸包含三種控制傳輸型態:控制讀取、控制寫入與無資料控制。運用 CRC(Cyclic Redundancy Check)
   來檢查資料之正確性,若此錯誤無法恢復,則要求重新傳送。
- • <u>中斷傳輸</u>:在 USB1.1 中定義為雙向傳輸。由於 USB 不支援硬體的中斷方式運行, 所以必須靠主機以週期性的方式來輪詢(Polling),故於 USB 的中斷傳輸意即是一種 輪詢的過程。對於 12Mbps 的裝置而言,可以訂定 1ms 至 255ms 之間的輪詢週期, 所以最快的輪詢速度為 1kHz。適用設備為鍵盤、搖桿或滑鼠。
- · <u>巨量傳輸</u>:一種突發性的傳輸模式,可為雙向或是單向的傳輸。適用於傳送大量的 資料,且沒有固定的傳輸速率,適用設備為印表機或掃描器等。
- <u>等時傳輸</u>:用來傳送高頻寬、以及對時間有嚴格要求的資料,可為單向或雙向的傳輸。此種傳輸需要維持一定的傳輸速度,且不具有錯誤檢測的能力。它事先與主機協議好固定的頻寬,以確保發送端及接收端的傳送速度。適用設備為 USB 麥克風、喇叭或是 MPEG-1 的裝置。

|      | 封包大小(Byte)       | 時間      | 資料檢查 | 應用       |
|------|------------------|---------|------|----------|
| 巨量傳輸 | 8 · 16 · 32 · 64 | 盡快完成    | 有    | 儲存裝置、印表機 |
| 中斷傳輸 | 1~64             | 1~255ms | 有    | 滑鼠、鍵盤    |
| 等時傳輸 | 1~1024           | 1ms     | 沒有   | 影像、聲音    |
| 控制傳輸 |                  | 盡快完成    | 有    | 命令       |

表 5.1.1 USB 四種傳輸模式比較

### 5.1.1 硬體介紹

Cypress AN2131Q USB 專用晶片(與 8051 Core 相容)

台灣長高科技公司 DMA- Cypress USB AN2131 控制單板

- ·符合 USB1.1 版, 12Mbps 高速傳輸博定標準
- ·提供 31 個可使用的端點
- ·支援等時、巨量、控制和中斷四種傳輸模式
- ·可另外接 D0~D7 資料匯流排與 A0~A15 位址匯流排
- ·ROM 可擴充至 32K RAM
- ·提供偵錯與發展的環境(Keil C Compiler)

・使用與 8051 Core 相容的 Cypress AN2131Q USB 專用晶片。包含 8051 與
 相容的 P0、P1 與 P3 週邊 port,可直接執行一般 8051 的 I/O 控制。



圖 5.3 DMA- Cypress USB AN2131 控制單板

# 5.1.2 軟體介紹

1.Keil  $\mu$  Vision 2

| 10 [I]                                                                    |                                                                                                                                                                                                                                                                            |                     |  |
|---------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--|
| Eile Edit View Project Debug                                                                                  | Pe <u>r</u> ipherals <u>T</u> ools <u>S</u> VCS <u>W</u> indow <u>H</u> e                                                                                                                                                                                                  | elp _ <b></b>       |  |
| 📲 🏜 🖬 🍠 🛛 🖧 🛍                                                                                                 | 2 🗅 卓 卓 🤞 🏷 🎘 🐂                                                                                                                                                                                                                                                            | main 🔽 🚧            |  |
| 🔯 🎒 🍳 🖪 🔽 🖑 🚸 🗾 🐏 🕨 🕨                                                                                         |                                                                                                                                                                                                                                                                            |                     |  |
| 🗍 🅸 🏝 🏙 👗   🌋 HID                                                                                             |                                                                                                                                                                                                                                                                            |                     |  |
| HID<br>HID<br>Source Group 1<br>FwHID.c<br>USB_LED.c<br>dscr.a51<br>Usbjmptb.obj<br>Ezusb.lib                 | // CH25 USB HID LED周邊檔案(<br>#pragma NOIV<br>#include <ezusb.h><br/>#include <ezregs.h><br/>#include <intrins.h><br/>#include <fx.h><br/>extern BOOL GotSUD;<br/>extern BOOL Sleep;<br/>extern BOOL Rwuen;<br/>extern BOOL Selfpwr;</fx.h></intrins.h></ezregs.h></ezusb.h> | 修改PERIPH.C)01/08/02 |  |
| Files 🖓 🚇 B                                                                                                   | //DMORD test:                                                                                                                                                                                                                                                              | ×                   |  |
| <pre>assembling dscr.a51 linking creating hex file from "usb_led" "usb_led" - 0 Error(s), 0 Warning(s).</pre> |                                                                                                                                                                                                                                                                            |                     |  |
| Build Command Find in Files                                                                                   |                                                                                                                                                                                                                                                                            |                     |  |
| Moves to the next bookmark                                                                                    |                                                                                                                                                                                                                                                                            | L:1 C:1             |  |

圖 5.4 Keil µ Vision 2使用介面

經由此Keil µ Vision 2的發展軟體,執行 AN2131Q USB 晶片程式編輯、編 譯動作,進而產生.hex 檔,在此為將 C code 編成 for Cypress AN2131Q USB 專用 晶片的 hex 檔。 2.EZ-USB

| 🚭 EZ-USB Control Panel - [Ezusb-0]                                                                                                                                                            |            |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--|--|
| 🔄 File Edit View Options Tools Window Help 📃 🗗 🗙                                                                                                                                              |            |  |  |
| Image: Second state     Image: Second state     Image: Second state     Image: Second state       Image: Second state     Image: Second state     Image: Second state     Image: Second state |            |  |  |
| Get Pipe Info                                                                                                                                                                                 |            |  |  |
| Get Dev     Get Conf     Get Pipes     Get String     Download     Re-Load     EEPROM     URB Stat     HOLD     RUN                                                                           |            |  |  |
| Vend Req Req OxA2 Value Ox0000 Index OxBEEF Length 16 Dir 1 IN V Hex B:                                                                                                                       |            |  |  |
| Iso Trans Pipe Packets 128 Size 16 Buffers 2                                                                                                                                                  | Frames     |  |  |
| Bulk / Int Pipe Length 64 Hex Bytes 5                                                                                                                                                         |            |  |  |
| ResetPipe Abort Pipe FileTrans Pipe Set IFace Interface 0                                                                                                                                     | AltSetting |  |  |
| EZ-USB Control Panel - built 11:31:58 Sep 17 2002<br>Get PipeInfo<br>Interface Size 16                                                                                                        |            |  |  |
| For Help, press F1 NUM                                                                                                                                                                        |            |  |  |

圖 5.5 EZ-USB 使用介面

當正確的進入 EZ-USB Control panel 後,即可進行對 DMA-USB 2131 控制 單板測試,下載(download)以及燒錄 EEPROM 等等的動作。在此為以 EZ-USB 將編譯完成的.hex 檔 download 到控制單板,重新裝置列舉後,單板由 Cypress EZ-USB (2131Q)的 USB 裝置,轉型為一個.hex 檔指定式樣的 USB 裝置。 可以將工作分為二部分,USB 描述元-讓 PC 的作業系統能使用此 USB 裝置;8051 I/O 控制程式-將資料傳送給 FPGA。

#### 1.USB 描述元

在USB 規格中定義了一些裝置群組,有 Audio、Communication、Display、 以及 Printer 等等,而在此是要即時地傳送 44.1KHz、16-bits 的音樂資料,所以 裝置群組應為 Audio 類型,且傳輸模式為等時傳輸。而等時傳輸,時間的最小單 位是 1ms,即最快每 1ms 將資料送出一次,因此,每一次的資料應該為 44 或 45 筆 16bit 的資料。



將控制單板宣告為 USB audio 裝置,需要寫 USB 描述元。USB 描述元是記錄關於裝置的各種訊息與其相關設定。宣告一個 USB audio 描述元,其架構圖如圖 5.6 所示。其每個 Descriptor 都是填寫一份表格[14]。

USB audio 描述元完成後,接上 PC 端,會辨識新連接的 USB 描述元,新增 加一個可用硬體-USB audio 音效裝置。此時,啟動應用程式,音樂訊號就會從 PC 送到 USB 的端點暫存區。只要是符合 USB Class 規定的裝置,其驅動程式已 包含在作業系統,而不用另外再寫其驅動程式,應用程式就可以直接使用裝置。 在圖 5.7 中可以看到在 PC 端上的硬體裝置管理員新增 EZ-USB 2131,以及將此 控制單板裝置列舉的狀況。 **Device Descriptor** 

Configuration Descriptor

Audio Control Interface Descriptors

Standard AC Interface Descriptor

Class-specific AC Interface Descriptor

Input Terminal Descriptor

**Output Terminal Descriptor** 

Audio Streaming Interface Descriptors

Standard AS Interface Descriptor (Alternate Setting 0)

Standard AS Interface Descriptor (Alternate Setting 1)

Class-specific AS General Interface Descriptor

Format Type Descriptor

Standard Endpoint Descriptor

Class-specific Isochronous Audio Data Endpoint Descriptor



圖 5.6 USB Audio Descriptor 架構圖

| 🔒, 풍월양객員                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                               |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 檔案 图 執行(▲) 檢視(⊻) 脱明(曲)                                                                                                                                                                                                                                                   | 檔案(E) 執行(Δ) 檢視(V) 説明(H)                                                                                                                                                                                                                                                                       |
| ← → 🗉 🖆 😫 😤 🕱 💆                                                                                                                                                                                                                                                          | ← → 📧 🖆 😫 🙁 🥆 🗷 🛃                                                                                                                                                                                                                                                                             |
| <ul> <li>● 音效,親訊及遊戲控制器</li> <li>● Altera ByteBlaster</li> <li>● Altera ByteBlaster</li> <li>● Legacy 音訊驅動程式</li> <li>● Legacy 荷訊驅動程式</li> <li>● Legacy 視訊顯取裝置</li> <li>● SoundMAX Integrated Digital Audio</li> <li>● 音訊轉碼器</li> <li>● 成混轉碼器</li> <li>● 成混轉碼器</li> </ul> | <ul> <li>● 音效,親訳及達戲控制器</li> <li>● Altera ByteBlaster</li> <li>● Altera ByteBlaster</li> <li>● Legacy 音訊驅動程式</li> <li>● Legacy 荷訊驅動程式</li> <li>● SoundMAX Integrated Digital Audio</li> <li>● SoundMAX Integrated Digital Audio</li> <li>● 首訳尊碼器</li> <li>● 旗體控制裝置</li> <li>● 親訊尊碼器</li> </ul> |
| <ul> <li>● 軟碟換</li> <li>● 軟碟決控制卡</li> <li>● 通用序列匯流排控制器</li> <li>● Cypress EZ-USE (21310/21315/21358) - EEPROM missing</li> <li>● Standard Enhanced PCI to USB Host Controller</li> <li>● Standard OnenHCD USB Host Controller</li> </ul>                                 | <ul> <li>● 處理器</li> <li>● 軟碟機控制卡</li> <li>● 軟碟機控制卡</li> <li>● 通用序列匯流排控制器</li> <li>● Standard Enhanced PCI to USB Host Controller</li> <li>● Standard OpenHCD USB Host Controller</li> <li>● Standard OpenHCD USB Host Controller</li> </ul>                                                   |
|                                                                                                                                                                                                                                                                          | <i>5</i> 入                                                                                                                                                                                                                                                                                    |

Download .hex to USB2131

圖 5.7 USB 單板以 USB audio Class 描述元裝置列舉

### 2.8051 I/O 控制程式

等時傳輸最快以每 1ms 的速度傳輸一次資料,資料傳完後,會發出一次等時中斷。而利用等時中斷機制,來知道端點暫存區是否有資料可以輸出到 I/O PORT。端點暫存區有個 count 機制,記錄目前暫存區內有多少 Byte 資料,每當暫存區被讀出 1Byte 資料, count 會減 1。利用 count 機制,來知道端點暫存區是否已經空了,如果空了,即可結束搬運。

Cypress USB 專用晶片與 8051 Core 相容,是 Enhanced 8051。寫 C code 指 定端點暫存區,利用等時中斷與暫存區的 count 機制,將資料搬移到指定 I/O PORT。8051 是八位元單晶片,所以必須利用二個 OUTPUT PORT 送出 16bit 的 音樂資料,分別輸出 high byte 與 low byte。規劃第三個 PORT 的二個腳位,當做 單版與 FPGA 的控制訊號(ch1/ch2 write enable),這樣就能夠在單版上的 I/O PORT 得到 44.1KHz、16bit 的 PCM 音樂訊號。圖 5.8 可以看到此主程式的流程 圖[15];圖 5.9 為中斷服務程式流程圖[15]。



圖 5.8 主程式流程圖



圖 5.9 中斷服務程式流程圖

由下表 5.1.2 可以看到分別為 USB Device 接收由 PC 端傳送的音訊資料、8051 的 OUTPUT PORTA 與 PORTB,以及 USB Device 傳送資料到 FPGA 的情形。USB 等時傳 輸時間最小單位為 1ms,由圖 5.10 可知,在此設定此傳輸時間為 1ms,而 USB Device 傳輸完資料的時間約為 0.8ms,此資料速率與 FPGA 需要的 44.1KHz 數位訊號並不相 符,所以資料在 USB 端送往 FPGA 處理時,需要先經由一個 buffer,而此 buffer 在此 為 FIFO 的型態。

| ₩左聲道 low byte, 左聲道 high byte, 右聲道 low byte, 右聲道 high byte |                     |              |  |
|-----------------------------------------------------------|---------------------|--------------|--|
| 等時傳輸                                                      | 第 1~9ms             | 第 10ms       |  |
| USB Device 收到資料                                           | *44                 | *45          |  |
| PORTB<br>PORTA                                            | *44                 | *45          |  |
| USB Device 傳送資料                                           | *44=0.7876ms        | *45=0.8055ms |  |
| (I Channel)                                               | → <b> </b> ← 17.9us | →            |  |

表 5.1.2 USB 音效裝置輸出資料的時間關係



圖 5.10 USB 傳送資料速度與 FPGA 消耗資料速度

# 5.2 **FPGA**

FPGA 全名為 Field Programmable Gate Array,是由許多各邏輯單元胞(Logic Cell) 經由可程式的垂直通道(Vertical Channel)以水平通道(Horizontal Channel)的連線所構成,圖 5.11 可以看到其基本架構。FPGA 根據其物理架構可分為兩類,一為 SRAM 型, 一為 Anti-fuse 型。在此選用 SRAM 型,因為它具有可重複程式化的優點,適合用來作 邏輯設計的測試與功能性驗證。



圖 5.11 FPGA 之基本架構圖

# 5.2.1 硬體介紹: Altera FLEX10K Emulation Board

#### ALTERA 10K-ARC240

- 10K Gates
- $\cdot$  work frequency over then 30MHz
- $\cdot$  supply voltage 5V regulated to 3.3V
- ・3.3V 的 I/O
- $\cdot$  with EPPROM



圖 5.12 Altera FLEX10K Emulation Board

# 5.2.2 軟體介紹: Quartus II

Quartus II 4.1:一個發展 FPGA 的環境,能夠編譯 VHDL code、simulation 看時序 圖檢驗 logic、規劃 FPGA 的輸入輸出腳位、將編譯好的 code 程式化 FPGA 或 EPPROM。 在 FPGA 的實現上採用此軟體,而沒有使用較早期的 MAX+PLUS II,乃因 Quartus II 的 complier 比 MAX+PLUS II 的更進化,因為它能提供一個 timing 效率更高的 P&R (Placement and Routing),但也因為如此,所以它在 complier 後會使用到較多的 resource, 所以 resource usage 會較 MAX+PLUS II compiler 後的多一些。下圖可以看到此軟體的使 用介面。



圖 5.13 Quartus II 4.1 使用介面

#### 5.2.3 FPGA 實作

#### 1. buffer 方塊

圖 5.1 因為 USB 送出資料的速度,與 FPGA 需要的 44.1KHz 數位訊號,速 率不相配,因此 FPGA 除了 MSOC 方塊之外,需要設計一個16×16 bit 的 FIFO(First In First Out)作資料緩衝。

FIFO 電路共有二個資料埠,一端資料寫入,一端資料讀出。其指向暫存器

的指標有二個,一為資料寫入指標,另一為資料讀出指標。資料寫入指標每寫入 一筆資料後其值應自動加一,以便下次資料寫入時能依序地將資料寫入。FIFO 電路有資料先進先出的特性,資料在 FIFO 中應該由排隊的方式來寫入與讀取。 當資料自 FIFO 讀出時,其讀出指標應自動加一,以便下次能依序將資料讀出。 FIFO 的輸入輸出腳位,應有資料 input port、資料 output port、wr\_enable、 rd\_enable、full、empty 與 reset[16]。由圖 5.14 可以看到此 FIFO 的內部基本方塊, 其中資料寫入與資料讀出部份皆為 16-bits 的資料;而控制電路部份,Full 與 Empty 分別控制資料寫入指標計數器與資料讀出指標計數器。



圖 5.14 FIFO 內部基本方塊圖

圖 5.15 為此 Buffer 的 I/O 方塊圖, 而圖 5.16 為此資料暫存器組中的資料 Full 與 Empty 的狀況。



圖 5.16 空、满的 buffer 方塊示意圖

由(3-12)式可知
$$u(k) = \begin{bmatrix} 1 & 0 & \cdots & 0 \end{bmatrix} \Psi^{-1} q_{\widetilde{U}^N} \left( \Psi \widetilde{a}(k) + \Gamma x(k) \right) , 以及(3-13)$$
式

$$x(k+1) = Ax(k) + B(a(k) - u^*(k))$$
., 實現上大致可以分為下列五個步驟:

- step1 從 FIFO 將輸入資料a(k)取進來
- step2 將 a(k) 經過一個 Delay
- step3 計算 $\Psi \vec{a}(k) + \Gamma x(k)$
- step4 將 step3 的輸出經過 Vector Quantizer

• step5 更新 
$$x(k)$$
,  $x(k+1) = Ax(k) + B(a(k) - u(k))$   
在實現上是使用二階的積分器且 N=2,所以可以得到:  $A = \begin{bmatrix} 0 & 1 \\ -1 & 2 \end{bmatrix}$ ,  $B = \begin{bmatrix} 0 \\ 1 \end{bmatrix}$ ,  
 $C = \begin{bmatrix} -1 & 2 \end{bmatrix}$ ,  $D = 1$ ,  $\Psi = \begin{bmatrix} 1 & 0 \\ CB & 1 \end{bmatrix} = \begin{bmatrix} 1 & 0 \\ 2 & 1 \end{bmatrix}$ ,  $\Gamma = \begin{bmatrix} C \\ CA \end{bmatrix} = \begin{bmatrix} -1 & 2 \\ -2 & 3 \end{bmatrix}$ 。而下圖 5.17 可以看  
到實現的方塊圖,其中 step5 的部份可以化為:  
 $\begin{bmatrix} x_1(k+1) \\ x_2(k+1) \end{bmatrix} = A \begin{bmatrix} x_1(k) \\ x_2(k) \end{bmatrix} + B(a(k) - u(k)) = \begin{bmatrix} x_2(k) \\ d_1(k) - u(k) \end{bmatrix}$ 



圖 5.17 二階、N=2 之 MSOC 實現方塊圖

若是實現二階的積分器且 N=1 時,其實現步驟與上相同只是省略 step2 的步驟,而 其架構圖則為上圖 5.17 中去掉虛線部份,並且 quantizer 為純量的而非向量的 quantizer。

因為是以16bit 精確度去實現的,所以將係數乘以32768,小數點以下無條件捨去。 而在此因為是採用純積分器,所以係數沒有小數點,故在做乘法運算時可以採用 shift 取代,如此可以節省使用的 gate count 以及所須的 timing。在整個運算過程中有使用到 加法器、减法器、位移器,以及比較器。

1 channel MSOC 腳位有 rd、empty、16bit input、clock、reset、output1+與 output1-, 如圖 5.18。其中 rd 每 <u>1</u> 44.1K 秒送一個 pulse,向 buffer 拿一筆新資料。output1+是左聲道 的 bit stream,output1-是與 output1+反相的 bit stream。output1+與 output1-為 MOSFET 的 控制訊號。圖 5.19 可以看到實現上的整體 VHDL 架構圖,實作上是採用雙聲道。



圖 5.181 channel MSOC I/O 的方塊圖



以 10K Gates 的 FPGA 實作雙聲道的二階 MSOC,採用頻率為 12MHz 的石英震盪 器作為 clock,而 oversampling rate 為 34 倍,在此採用 12M Hz 與 34 倍乃是因為它幾乎 可以被 44.1K Hz 整除, 12M÷44.1K = 272.1, 12M  $\approx$  (44.1K Hz)×(34×8)。其中 FPGA 的部份必須在 8 個 clock cycle 之內完成所有的動作。圖 5.20 是 Quartus II 4.1 中的 Compiler Report,實現上共實現了三種 case,第一為 2-order、N=1、1.5-bit 的;第二為 2-order、N=2、one-bit;第三為 2-order、N=2、1.5-bit 的。由圖中可以看到三種 case 的 logic element 使用率不同,原因一是因為 step 數不同造成的,N=2 在 MSOC 所使用的 硬體幾乎是 N=1 的兩倍;原因二是因為 quantization 的 bit 數不同,1.5-bit 的 quantizer 設計上較為複雜,所以也會使用較多的硬體。

| Compilation Report                                                                                                                                                                                                                                  | Flow Summary                                                                                                                                                                |                                                                                                                                                                                                                                       |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <ul> <li>Legal Notice</li> <li>Flow Summary</li> <li>Flow Settings</li> <li>Flow Lapsed Time</li> <li>Flow Log</li> <li>Analysis &amp; Synthesis</li> <li>Fitter</li> <li>Assembler</li> <li>Timing Analyzer</li> <li>EDA Netlist Writer</li> </ul> | Flow Status<br>Quartus II Version<br>Revision Name<br>Top-level Entity Name<br>Family<br>Device<br>Timing Models<br>Total logic elements<br>Total pins<br>Total memory bits | Successful - Tue Jul 05 16:52:36 2005<br>4.1 Build 181 06/29/2004 SJ Full Version<br>zoh2_1_5_34_two<br>zoh2_1_5_34_two<br>FLEX10KA<br>EPF10K100ARC240-1<br>Production<br>1,478 / 4,992 (29 %)<br>27 / 189 (14 %)<br>0 / 24,576 (0 %) |  |

## (a) 2-order、N=1、1.5-bit MSOC 的 Compiler Report

| 🗣 zoh4_1_34usefifo32 Compilation Report                                                                                                                                  |                                                                                                                                                                                             |                                                                                                                                                                                                                                             |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Compilation Report<br>Legal Notice<br>Flow Summary<br>Flow Settings<br>Flow Lapsed Time<br>Flow Log<br>Analysis & Synthesis<br>Fitter<br>Assembler<br>EDA Netlist Writer | Flow Summary<br>Flow Status<br>Quartus II Version<br>Revision Name<br>Top-level Entity Name<br>Family<br>Device<br>Timing Models<br>Total logic elements<br>Total pins<br>Total memory bits | Successful - Tue Jul 05 15:56:41 2005<br>4.1 Build 181 06/29/2004 SJ Full Version<br>zoh4_1_34usefifo32<br>zoh4_1_34usefifo32<br>FLEX10KA<br>EPF10K100ARC240-1<br>Production<br>1,959 / 4,992 (39 %)<br>28 / 189 (14 %)<br>0 / 24,576 (0 %) |  |

## (b) 2-order、N=2、one-bit MSOC 的 Compiler Report

| 🗣 zoh4_1_5_34usefifo32 Compilation Report 📃 🗖 🔀                                                                                                                                                                                                                      |                                                                                                                                                                             |                                                                                                                                                                                                                                                 |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 🞒 🔄 Compilation Report                                                                                                                                                                                                                                               | Flow Summary                                                                                                                                                                |                                                                                                                                                                                                                                                 |  |
| <ul> <li>Legal Notice</li> <li>Flow Summary</li> <li>Flow Settings</li> <li>Flow Elapsed Time</li> <li>Flow Log</li> <li>Analysis &amp; Synthesis</li> <li>Fitter</li> <li>Fitter</li> <li>Assembler</li> <li>Timing Analyzer</li> <li>EDA Netlist Writer</li> </ul> | Flow Status<br>Quartus II Version<br>Revision Name<br>Top-level Entity Name<br>Family<br>Device<br>Timing Models<br>Total logic elements<br>Total pins<br>Total memory bits | Successful - Sat Jul 16 23:42:10 2005<br>4.1 Build 181 06/29/2004 SJ Full Version<br>zoh4_1_5_34usefifo32<br>zoh4_1_5_34usefifo32<br>FLEX10KA<br>EPF10K100ARC240-1<br>Production<br>2,541 / 4,992 (50 %)<br>27 / 189 (14 %)<br>0 / 24,576 (0 %) |  |

(c) 2-order、N=2、1.5-bit MSOC 的 Compiler Report

## 圖 5.20 Quartus II 之 Compiler Report

# 5.3 Power Stage

FPGA 輸出為 3.3V 的低電壓數位訊號,且電流限制在 500mA 內,若是將此輸出直接輸入喇叭,不但會推不動喇叭,而且可能會造成 FPGA 版子的損壞,所以中間必須先經過一個 Power Stage,將輸出功率放大,在將放大後的訊號送至喇叭。此 Power Stage 裡面包含 Gate Driver 進而去驅動 Power MOS。在此採用德州儀器(TI)推出的 TAS5121 數位音訊放大器[17]。

### 5.3.1 硬體介紹: Digital Amplifier Power Stage TAS5121

- 特性 · 100-W RMS Power Into 4  $\Omega$  with Less Than 10% THD+N
  - 80-W RMS Power Into  $4 \Omega$  with Less Than 0.2% THD+N
  - 0.05% THD+N at 1W Into 4  $\Omega$
  - Power Stage Efficiency Greater Than 90% Into  $4 \Omega$  Load
  - Self-Protecting Design
  - 36-Pin PSOP3 Package
  - 3.3-V Digital Interface
- <u>應用</u> · DVD Receiver
  - Home Theater
  - Internet Music Appliance
  - Mini/Micro Component System

下圖 5.21 為 TAS5121 的接腳圖。



圖 5.21 TI TAS5121 接腳圖

## 5.3.2 Power Stage 實作



德州儀器(TI)推出的 TAS5121 數位音訊放大器是採用全橋式的功率放大器,所以在 放大級部份只需要供應正電壓,因為此功率放大晶片內部已經含蓋了 Gate Driver,所以 並不需要另外接此驅動器,整個硬體就是此顆晶片以及其周邊的電路。

此顆功率放大晶片共需要三種直流電壓源,其一為供應給接收開關切換訊號用的電源, 另兩個為 Power Device 所需的電源。

- <u>DVDD</u>: Digital supply。其電壓值可在 3V~3.6V 間,通常為 3.3V。其相對的接地為DGND。
- GVDD: Supply for internal Gate Driver and Logic Regulator。其電壓值可在 10.8V~
   13.2V間,通常為 12V。其相對的接地為 GND。
- <u>PVDD</u>: Half-Bridge supply。其電壓值可在 0V~32V 間,通常為 30.5V。其相對的接 地為 GND。此電壓源的大小與輸出負載跟輸出功率有關,而輸出功率又會 影響效率,由下圖 5.22(a)可以看到 PVDD 以及負載大小與輸出功率的關係

圖,5.22(b)可以看到輸出功率以及系統效率的關係圖。在實作上採用 PVDD 為 20V,而選用負載為4Ω的揚聲器。



如圖 1.2 為 D 類放大器的操作示意圖,而在實際運作上,兩個 MOSFET 是無法同 時導通或是截止的,故在 FPGA 的輸出變換為 10 轉變為 01 時,需要先將 10 轉便為 00 再轉為 01 才可以送入 Power Stage,所以還需額外的控制硬體。而在此 TAS5121 中還 有  $\overline{RESET}$  訊號需要由 FPGA 來控制,RESET 訊號在此有兩個功用,一為在發生 latched error 時重新致能操作,二為 disabling Output Stage switching。 $\overline{RESET}$ 為 Low 時, error latch 會被清除,而 $\overline{RESET}$  需在 GVDD 輸入的 1ms 之後設為 High 才可正常操作,而在 power down 的 1ms 以前,  $\overline{RESET}$  必須設為 Low。

# 5.4 實作結果

本節將介紹全數位式音頻擴大器的實作結果。實作上分別為 2-order,N=1,1.5-bit、 2-order,N=2,1-bit 以及 2-order,N=2,1.5-bit,將上述此三種 MSOC 分別與 2-order,N=1,1-bit 也就是二階的 SDM 相比較。輸入訊號為 16bit 的數位訊號,在此採用的 FPGA 時脈為 12M Hz, oversampling 為 34 倍, FPGA 的輸出時脈為 1.4994M Hz。



圖 5.23 2-order,N=1,1.5-bit 的 MSOC 之 FPGA 的輸出訊號圖

上圖 5.23 為 2-order,N=1,1.5-bit 的 MSOC 的輸出訊號波形圖以及頻率響應圖。5.23(a) 為 FPGA 的輸出波形圖,(b)為輸入為 1KHz 週期波的輸出 Power Spectrum 圖,(c)為輸

入為 10KHz 週期波的輸出 Power Spectrum 圖,(d)為輸入為 1KHz 週期波的 Power Spectrum 圖,但是 X 軸為 log scale。在上圖的(a)中可以看到輸出有三種狀態,分別為 1、 0 與-1,因為此為 1.5-bit 的 quantizer。在(c)中可以看到當輸入為 10KHz 的訊號時有 Harmonics 產生,圖中的一格表示為 20KHz,所以可以發現那些 Harmonics 皆在 20KHz 以外,所以人耳對於此諧波並不會有感覺。



圖 5.24 2-order,N=2,1-bit 的 MSOC 之 FPGA 的輸出訊號圖

圖 5.24 為 2-order,N=2,1-bit 的 MSOC 的輸出訊號波型圖以及頻率響應圖。其順序 與圖 5.23 同。在上圖的(a)中可以看到輸出只有<u>兩</u>種狀態,為1與-1,因為此為 1-bit 的 quantizer。而(c)的 Harmonics 問題也與之前同,都是發生在 20KHz 以外。



圖 5.25 2-order,N=2,1.5-bit 的 MSOC 之 FPGA 的輸出訊號圖

圖 5.25 為 2-order,N=2,1.5-bit 的 MSOC 的輸出訊號波形圖以及頻率響應圖。其順序 與圖 5.23 同。(a)中的輸出有三種狀態,1、0 與-1,因為此為 1.5-bit 的 Quantizer。(c) 的 Harmonics 狀態與圖 5.23、5.24 同。







圖 5.26 SNR。(a) 2-order,1-bit 的 N=1 與 N=2 的 SNR 比較圖(b) 2-order,N=1 的 1-bit 與 1.5-bit 的 SNR 比較圖(c) 2-order,N=1 的 1-bit 與 N=2 的 1.5-bit 的 SNR 比較圖

由圖 5.26 可以發現(a)的 2-order,N=2,1-bit 普遍的時候 SNR 較好,除了在 2K 以及 4K 的地方稍差之外。(b)的 2-order,N=1,1.5-bit 則是幾乎都比二階的 SDM 好。而(c)則是 在 4KHz 的時候比稍差,而其他頻率都較佳。由圖可以發現,在頻率較高時候的 SNR 普遍都降低,與在 Matlab 模擬時的結果一樣;而也可以映證 1.5-bit 的 SNR 的確比 one-bit 的高。






(c)

圖 5.27 THD+N。(a) 2-order,1-bit 的 N=1 與 N=2 的 THD+N 比較圖

(b) 2-order,N=1 的 1-bit 與 1.5-bit 的 THD+N 比較圖 (c) 2-order,N=1 的 1-bit 與 N=2 的 1.5-bit 的 THD+N 比較圖

由圖 5.27 也可以發現與圖 5.26 一樣的結果,而在此是比較 THD+N 的結果。

而下圖 5.28 是經由 ModelSim 中的 behavior 模擬的 Error Variance 的比較結果,如同圖 3-12 中的結果一樣,以 2-order,N=2,1.5-bit 的 Error Variance 最小,其次為 2-order,N=1,1-5-bit,然後 one-bit 的 N=1 與 N=2 都較大,但是 N=2 還是稍小一點。



# 第六章 結論

### 6.1 研究成果

本論文提出以 Finite Receding Horizon Quadratic Optimal Control 為方法來實現訊號 的調變,而將此轉換器稱之為 Multi-Step Optimal Converter。 再將此經過調變後的訊號 送入 D 類放大器中,以之驅動喇叭。由於近來可攜式產品的蓬勃發展,所以功率問題 特別被重視,目前在行動電話、平面電視、LCD 顯示器以及可攜式設備等消費性電子 產品中,已經有越來越多採用效率高的 D 類放大器的趨勢。

#### and the second

本論文已完成以 USB1.1 為介面和數位的 Multi-Step Optimal Converter,實現全橋 式數位音頻放大器。下圖 6.1 為具備 USB 介面之雙聲道全數位音頻擴大器。

1896

在模擬上, step 較高確實是可以降低 Error Variance, 並且 1.5-bit 的效果又比 one-bit 的佳;而在實作上,雖然無法計算 Error Variance 的量,但是在 Signal to Noise ratio 上, 1.5-bit 的確有比較好。



## 6.2 未來展望

在實現上發現大部分的 logic element 是消耗在 Vector Quantizer 上面,所以在 Vector Quantizer 的實現上,期許可以採用其他的方法,進而提高速度與減少所使用的 logic element。

在高階的 MSOC 上的穩定性問題尚未獲得證實,在實作上必須採用[10]所提的設計方法來設計濾波器,此會增加實現上的困難度,因此在未來期望可以找出此 MSOC 的高階穩定性,進而較容易去實現之。

近年來先進國家對電器產品之低功率損耗的要求日益嚴格,有些甚至針對待機時之

功率損耗訂定標準規範,因此降低切換頻率的技術也就孕育而生。不過在本論文中乃是 以最小化量化雜訊為目標,而去發展訊號調變轉換器的;若是日後能以最小化切換頻率 為目標,進而去發展調變轉換器,則將可以有效地降低切換所造成的功率損失。



## Reference

- F. H. Raab, "Analysis of Idealized Class-D Power Amplifiers," Green Mountain Radio Research Company Continuing Education Seminar, Vermont, 1982.
- [2] H. Nakagaki, N. Amada, S. Inouc, "A High Efficiency Audio Amplifier," J.Audio Eng. Soc., Vol. 31, No. 6, pp. 984-993, June 1983.
- [3] Daniel E. Quevedo and Graham C. Goodwin, "Multi-Step Optimal Analog-to-Digital Conversion, " Circuits and Systems I: Regular Papers, IEEE, Volume: 52, pp503-505, March 2005
- [4] Ned Mohan, Tore M. Undeland, and William P. Robbins, *Power electronics: converters, application, and design*, Translated by 江炫樟, 台北, 1975.
- [5] J. F. Schouten, F. de Jager, and J. A. Greefkes, "Delta modulation, a new modulation system for telecommunication," Philips Technical Review, vol. 13, no. 9, pp. 257-266, March 1952.
- [6] H. Inose and Y. Yasuda, "A unity bit coding method by negative feedback," Proceeding of the IEEE, pp. 1524-1535, November 1963.
- [7] Daniel E. Quevedo, Jose A.De Dona, and Graham C. Goodwin, "Receding Horizon Linear Quadratic Control With Finite Input Constraint,"IFAC 15<sup>th</sup> Triennial World Congress, Barcelona, Spain, 2002
- [8] Quevedo, D.E. and Goodwin, G.C, "Audio quantization from a receding horizon control perspective," American Control Conference, 2003. Proceedings of the 2003, Volume 5, Page(s):4131 4136 vol.5, 4-6 June 2003.
- [9] A.Gersho and R.M.Gray, "Vector Quantization and Signal Compression, "Kluwer Academic, 1992.
- [10] Shiang-Hwua Yu and Jwu-Sheng Hu, "Sigma-Delta modulators operated in optimization mode," IEEE International Symposium on Circuits and Systems, May 2004.
- [11] (.). "Testing DDX ®Digital Amplifier" Apogee Technology, [Online]. Available: http://www.apogeeddx.com/AN-03.pdf
- [12] 許永和, 8051 微處理機程式設計, 長高出版社, 台南, 2003.
- [13] (2002,October). "USB 設計規格資料" NTHU CS [Online]. Avaiable: http://super.cs.nthu.edu.tw/jerry/dream/usb/USB.htm
- [14] Geer Knapen. (1998, March). "Universal Serial Bus Device Class Definition for Audio Devices," USB Implementers Forum,

[Online]. Available:http://www.usb.org/developers/devclass\_docs/audio10.pdf

[15] 葉順智, 具備 USB 介面之雙聲道全數位式音頻放大器設計, 國立交通大學電機與 控制工程研究所, 新竹 2004

- [16] 林傳生, 使用 VHDL 電路設計語言之數位電路設計, 儒林圖書有限公司, 新竹, 1998.
- [17] (2003,November). "Digital Amplifier Power Stage" TEXAS INSTRUMENTS[Online]. Avaiable: http://focus.ti.com/lit/ds/symlink/tas5121.pdf

