

### Wojciech Kołodziejski



Optymalizacja parametrów cyfrowych linearyzowanych modulatorów szerokości impulsów LPWM dla akustycznych wzmacniaczy klasy D

Wydawnictwa Państwowej Wyższej Szkoły Zawodowej w Tarnowie

Optymalizacja parametrów cyfrowych linearyzowanych modulatorów szerokości impulsów LPWM dla akustycznych wzmacniaczy klasy D

## Optymalizacja parametrów cyfrowych linearyzowanych modulatorów szerokości impulsów LPWM dla akustycznych wzmacniaczy klasy D



Wydawnictwa Państwowej Wyższej Szkoły Zawodowej w Tarnowie Tarnów 2021 Publikacja ukazała się nakładem Państwowej Wyższej Szkoły Zawodowej w Tarnowie

Recenzent dr hab. inż. Zbigniew Rymarski

© Copyright by Wojciech Kołodziejski & Państwowa Wyższa Szkoła Zawodowa w Tarnowie Tarnów 2021

Publikacja udostępniana na podstawie licencji Creative Commons Uznanie autorstwa – Użycie niekomercyjne – Bez utworów zależnych 3.0 Polska (CC BY-NC-ND 3.0 PL)

Wydawca Wydawnictwa Państwowej Wyższej Szkoły Zawodowej w Tarnowie ul. Mickiewicza 8, 33-100 Tarnów, www.pwsztar.edu.pl tel. +48 14 631 65 67, e-mail: wydawnictwa@pwsztar.edu.pl

ISBN 978-83-959880-7-3

Redakcja techniczna i projekt okładki Jadwiga Popowska

Opracowanie graficzne, skład i łamanie Jadwiga Popowska

## Spis treści

| Lista skrótów                  |                                                                                             |  |  |
|--------------------------------|---------------------------------------------------------------------------------------------|--|--|
| Wykaz stosowanych symboli    9 |                                                                                             |  |  |
| Wstęp                          |                                                                                             |  |  |
| 1. Wp                          | rowadzenie                                                                                  |  |  |
| 1.1<br>1.2<br>1.3              | <ul> <li>Bezfiltrowe wzmacniacze klasy D</li></ul>                                          |  |  |
| 2. Por<br>pró                  | ównanie cyfrowych modulacji UPWM z równomiernym<br>bkowaniem z naturalnymi modulacjami NPWM |  |  |
| 2.1                            | <ul> <li>Analogowe (naturalne) modulacje szerokości<br/>impulsów NPWM</li></ul>             |  |  |
| 3. Cyf                         | rowe, linearyzowane modulacje szerokości impulsów                                           |  |  |
| 3.1                            | Ogólne metody linearyzacji cyfrowych modulatorówDPWM                                        |  |  |

| 3.2.<br>3.3.                                     | <ul> <li>3.1.2. Algorytmy obliczania położenia początków i końców czasu trwania impulsów DPWM w linearyzowanych modulacjach LPWM</li></ul>      |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Hyb<br>mod                                       | rydowe konwertery cyfrowo-czasowe DTC w cyfrowych<br>Iulatorach LPWM dla akustycznych wzmacniaczy klasy D 70                                    |
| <ul><li>4.1.</li><li>4.2.</li><li>4.3.</li></ul> | <ul> <li>Metody kwantyzacji cyfrowo-czasowej DTC stosowane</li> <li>w cyfrowych modulatorach DPWM</li></ul>                                     |
| lmp<br>o mi                                      | lementacja hybrydowego modulatora LBDD PWM w oparciu<br>krokontroler STM32 i programowaną linię opóźniającą (PTDL)87                            |
| 5.1.                                             | Ogólna koncepcja hybrydowego modulatora LBDD PWM 87<br>5.1.1. Dobór częstotliwości zegara i synchronizacja<br>uzależnień czasowych              |
|                                                  | <ul> <li>3.2.</li> <li>3.3.</li> <li>Hyb mod</li> <li>4.1.</li> <li>4.2.</li> <li>4.3.</li> <li>Implo mi</li> <li>5.1.</li> <li>5.2.</li> </ul> |

|              | 5.3.<br>5.4. | Wyniki symulacji hybrydowego modulatora LBDD PWM<br>w programie Matlab i badania eksperymentalne praktycznie<br>wykonanego modulatora10<br>Ocena uzyskanych wyników10 | )0<br>)5 |
|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| 6.           | Wzn<br>w tr  | nacniacze akustyczne klasy BD ze zrównoważonym wyjściem<br>ybie wspólnym CM10                                                                                         | )8       |
|              | 6.1.<br>6.2. | Wprowadzenie                                                                                                                                                          | 8        |
|              | 6.3.         | modulatory LBDD PWM lub LPSC PWM11<br>Wyniki symulacji w programie SPICE i badania<br>eksperymentalne wzmacniaczy audio klasy DB                                      | .2       |
|              | 6.4.         | ze zrównoważonym wyjściem wspólnym w trybie CM11<br>Ocena uzyskanych wyników 12                                                                                       | .7<br>!4 |
| 7.           | Wni          | oski końcowe                                                                                                                                                          | :6       |
| Bibliografia |              |                                                                                                                                                                       |          |
| Do           | datk         | <b>i</b> 13                                                                                                                                                           | 5        |
| Do           | Dodatek A1   |                                                                                                                                                                       |          |
| Doualek A2   |              |                                                                                                                                                                       |          |
| Dodatek A4   |              |                                                                                                                                                                       |          |
| Do           | odate        | ek A5                                                                                                                                                                 | 55       |

## Lista skrótów

| AD C     | Analog to Digital Converter                       |
|----------|---------------------------------------------------|
| Class-D  | Systems using a digital PWM topology              |
| СМ       | Common Mode                                       |
| DAC      | Digital to Analogue Converter                     |
| DM       | Differential Mode                                 |
| DPWM     | Digital Pulse Width Modulation                    |
| DSP      | Digital Signal Processing                         |
| DTC      | Digital to Time Converter                         |
| FFT      | Fast Fourier Transform                            |
| FIR      | Finite Impulse Response                           |
| IC       | Integrated Circuit                                |
| IIR      | Infinite Impulse Response                         |
| IM       | Intermodulation Components                        |
| LBDD     | Linearized Double-Edge BD Class Modulation        |
| LPWM     | Linearized PWM                                    |
| LSB      | Least Significant Bit                             |
| MOSFET   | Metal-Oxide Semiconductor Field Effect Transistor |
| MSB      | Most Significant Bit                              |
| NBDD PWM | Natural sampling Class-BD Double sided modulation |
| NPWM     | Natural Pulse Width Modulation                    |
| РСМ      | Pulse Code Modulation                             |
| PLL      | Phase Lock Loop                                   |
| PNPWM    | Pseudo Natural Pulse Width Modulation             |
| PSC PWM  | Phase Shifted Carrier PWM                         |
| PSD      | Power Spectral Density                            |
| PTDL     | Programmable Tapped Delay Line                    |
| PWM      | Pulse Width Modulation                            |
| SNR      | Signal to Noise Ratio                             |
| SDM      | Sigma-Delta Modulation                            |
| THD+N    | Total Harmonic Distortion plus Noise              |
| UPWM     | Uniform Pulse Width Modulation                    |

## Wykaz stosowanych symboli

| Pulsacja kluczowania                                                                                     |
|----------------------------------------------------------------------------------------------------------|
| Okres kluczowania                                                                                        |
| Pulsacja sygnału modulującego                                                                            |
| Częstotliwość zegara przetwornika DTC przy metodzie<br>licznikowej                                       |
| Częstotliwość zegara przetwornika DTC przy metodzie<br>hybrydowej                                        |
| Częstotliwość oscylatora na magistralach AHB<br>mikrokontrolera STM32                                    |
| Częstotliwość zegara sterującego PTDL                                                                    |
| Okres próbkowania i przetwarzania sygnału audio<br>w przetworniku ADC                                    |
| Czas opóźnienia okresu $T_{\scriptscriptstyle CLKh}$ przez jeden segment PTDL                            |
| Chwila początku impulsu PWM (zbocza narastającego) w $n$ -tym okresie $T_c$                              |
| Chwila końca impulsu PWM (zbocza opadającego) w <i>n</i> -tym okresie $T_c$                              |
| <i>n</i> -ty okres częstotliwość kluczowania $f_c$                                                       |
| Próbka sygnału audio w $n$ -tym okresie próbkowania $nT_c$                                               |
| Próbka opadającego przebiegu trójkątnego w <i>n</i> -tym<br>półokresie próbkowania <i>nT<sub>c</sub></i> |
| Próbka narastającego przebiegu trójkątnego w <i>n</i> -tym<br>półokresie próbkowania <i>nT</i> c         |
| Indeks modulacji                                                                                         |
| Funkcja Bessel'a I-go rodzaju, rzędu <i>n</i>                                                            |
| Indeks harmonicznych sygnału modulującego                                                                |
| Indeks harmonicznych sygnału kluczującego                                                                |
| Współczynnik nadpróbkowania, częstotliwość<br>nadpróbkowania <i>QF<sub>c</sub></i>                       |
| $Q$ dodatkowych próbek w okresie kluczowania $T_c$                                                       |
| Długość przetwarzanego słowa w bitach przed rekwantyzacją                                                |
| Długość przetwarzanego słowa w bitach po rekwantyzacji                                                   |
|                                                                                                          |

| H(z)           | Dyskretna transmitancja                                |
|----------------|--------------------------------------------------------|
| NTF(z)         | Dyskretna transmitancja szumów                         |
| $V_{OUT}^L$    | Napięcie na wyjściu lewej gałęzi mostka H              |
| $V_{OUT}^R$    | Napięcie na wyjściu prawej gałęzi mostka H             |
| $V_{OUT}^{DM}$ | Napięcie na wyjściu różnicowym mostka H (w trybie DM)  |
| $V_{OUT}^{CM}$ | Napięcie na wyjściu sumacyjnym mostka H (w trybie CM)  |
| $i_D(t)$       | Chwilowa wartość prądu drenu                           |
| η              | Sprawność energetyczna wzmacniacza                     |
| $P_L$          | Moc wydzielona w rezystancji obciążenia R, wzmacniacza |

Wstęp

W niniejszej książce<sup>1</sup> przedstawiono algorytmy przetwarzania sygnałów niezbędnych do konwersji cyfrowych danych audio, uzyskanych ze źródła, na cyfrowy sygnał o modulowanej szerokości impulsów do sterowania tranzystorów MOSFET stopnia końcowego akustycznego wzmacniacza klasy D. Skoncentrowano się na linearyzowanych, rozbudowanych modulatorach szerokości impulsów LBDD PWM z kompensacją wstępną, umożliwiających możliwie jak najwierniejszą emulację naturalnych modulacji NBDD PWM lub PSC PWM.

Algorytmy kompensacji wstępnej, składające się z bloków modułowych: interpolacji, obliczenia położenia początków i końców czasu trwania impulsu LBDD PWM w n-tych okresach kluczowania i kształtowania szumów kwantyzacji zostały zdefiniowane w teorii, zaprojektowane i przesymulowane w programie Matlab, a następnie zaimplementowane w oparciu o metodę hybrydową z wykorzystaniem mikrokontrolera STM32 i programowaną linię opóźniającą z odczepami PTDL.

W publikacji przedstawiono oryginalne architektury hybrydowych modulatorów LBDD PWM, które konwertują rekwantyzowane dane cyfrowe określające położenie początków  $t_p(n)$  (zboczy narastających) i końców  $t_k(n)$ (zboczy opadających) impulsów DPWM w kolejnych *n*-tych okresach przełączania  $T_c$  w dwa fizyczne ciągi 1-bitowych sygnałów LBDD DPWM, sterujących stopniem wyjściowym wzmacniacza klasy BD.

Zaproponowano nowe architektury i implementacje cyfrowych wzmacniaczy akustycznych klasy BD z otwartą pętlą, charakteryzujących się zrównoważonym wyjściem dla sygnałów wspólnych, tj. posiadających stałe napięcie na wyjściu sumacyjnym.

<sup>&</sup>lt;sup>1</sup> Podstawą publikacji jest doktorat obroniony 26 października 2021 r. przed Komisją Rady Dyscypliny Automatyki, Elektroniki i Elektrotechniki na Akademii Górniczo-Hutniczej w Krakowie. Promotorem pracy był prof. dr hab. inż. Stanisław Kuta.

Stopień wyjściowy proponowanych wzmacniaczy audio klasy BD zawiera typowy mostek H z czterema tranzystorami MOSFET oraz cztery dodatkowe przełączniki MOSFET, które równoważą i utrzymują stałą wartość napięcia na wyjściu sumacyjnym w trybie wspólnym.

Obszerne badania symulacyjne w programie SPICE oraz badania eksperymentalne wykazały, że proponowane wzmacniacze klasy BD mają podobne parametry jak prototypowy wzmacniacz klasy BD z optymalną modulacją NBDD, a jednocześnie mają zrównoważone wyjście dla sygnałów wspólnych o stałym napięciu, umożliwiając tym samym realizację bezfiltrowych wzmacniaczy klasy D, przy równoczesnej eliminacji lub znacznym ograniczeniu zakłóceń elektromagnetycznych radiacyjnych (EMI). Wprowadzenie

### 1.1. Bezfiltrowe wzmacniacze klasy D

Pierwsze wzmacniacze klasy D sięgają lat pięćdziesiątych XX wieku [1-2]. Od tego czasu znalazły szerokie zastosowanie w elektronice użytkowej ze względu na ciągłe ulepszanie technologii półprzewodników mocy.

Stopnie końcowe wzmacniaczy klasy D skonfigurowane są w struktury półmostkowe lub mostkowe, w których tranzystory mocy MOSFET pełnia rolę przełączników (kluczy), sterowanych od stanu zamknięcia do stanu otwarcia. Charakterystyki statyczne tych elementów w granicznych stanach przewodzenia powinny być zbliżone do charakterystyk przełącznika w stanach zamknięcia i otwarcia, a czasy przełączania możliwie jak najkrótsze. Maksymalna moc obciążenia limitowana jest przez graniczne wartości prądów i napięć zastosowanych tranzystorów, a nie przez ich dopuszczalną moc strat. Straty mocy w tego typu wzmacniaczach składają się głównie z dwóch składników: strat mocy przewodzenia związanych ze spadkiem napięcia na załączonym tranzystorze oraz strat mocy związanych z procesem przełączania tranzystora, gdy jego punkt pracy przemieszcza się przez obszar aktywny i jednocześnie mogą wystąpić duże chwilowe wartości napięcia i prądu tranzystora. O sprawności energetycznej tych układów w dużym stopniu decyduje właściwy dobór elementów ze wzglądu na ich szybkość działania, jak również dobór odpowiednich układów sterowania tranzystorów w celu zminimalizowania strat mocy związanych z procesami przełączania, bowiem ten składnik może być dominujący w ogólnym bilansie strat mocy.

Szybki rozwój technologii półprzewodników wywołał ponowne zainteresowanie wykorzystaniem wzmacniaczy mocy audio klasy D, zwłaszcza w aplikacjach mniejszej mocy, poniżej 50W na kanał [3-30]. Dzięki dużej sprawności energetycznej, małym rozmiarom, małym stratom mocy, a tym samym zmniejszeniu rozpraszania ciepła, wzmacniacze klasy D znalazły szerokie zastosowanie w wielu konsumenckich systemach elektronicznych, takich jak telewizja, systemy nagłośniające, zestawy i systemy kina domowego, telefonia komórkowa, systemy radiokomunikacji ruchomej i inne, ponieważ czas między ładowaniami akumulatora może być dłuższy [3-7]. Wymagało to jednak rozwiązania wielu problemów w celu ulepszenia parametrów elektroakustycznych, energetycznych i kompatybilności elektromagnetycznej (EMI) oraz filtracji sygnału wyjściowego [3-30]. Ostatnio, bardzo popularnymi rozwiązaniami stały się tzw. bezfiltrowe wzmacniacze klasy D [3-18], w których wyjście wzmacniacza jest bezpośrednio podłączone do obciążenia, a samo obciążenie (głośnik) zapewnia filtrację, a tym samym demodulację sygnału dźwiękowego, przy znacznym ograniczeniu zakłóceń elektromagnetycznych i zapewnieniu kompatybilności elektromagnetycznej EMI.

### 1.2. Osiągnięcia i kierunki rozwoju wzmacniaczy klasy D oraz stosowane techniki modulacji PWM

W wielu komercyjnych instalacjach Audio-Video, sieciowe odtwarzacze przetwarzają pliki audio zapisane w formatach dźwiękowych: A/52 (*Dolby Digital*), ASF (*Advanced Systems Format*), MP3, WMA (*Windows Media Au-dio*), a powszechną tendencją jest, aby odtwarzanie wszelkich typów plików multimedialnych obsługiwane było przez różne wersje programu Windows Media Player [31]. We wspomnianych i innych systemach audio, najczęściej wielokanałowych, sygnały audio są zapamiętywane, przesyłane i przetwa-rzane w dziedzinie cyfrowej. Implementacja koncepcji wzmacniacza klasy D w takich systemach stwarza możliwość przetwarzania i wzmacniania sygnałów audio w dziedzinie cyfrowej, aż do stopnia końcowego mocy. W stopniu końcowym, najczęściej w konfiguracji mostka H, tranzystory mocy MOSFET pracują jako klucze, dzięki czemu uzyskuje się wysoką sprawność energetyczną wzmacniacza, a po filtracji dolnoprzepustowej wzmocniony sygnał akustyczny dołączony jest do głośników.

Architektury wzmacniaczy klasy D można ogólnie podzielić na dwie kategorie:

- Wzmacniacze klasy D w otwartej pętli z analogową modulacją szerokości impulsu APWM (*Analog Pulse Width Modulation*), z próbkowaniem naturalnym NPWM (*Natural Sampled* PWM) lub jej cyfrową wersją DPWM (*Digital* PWM) z równomierną modulacją szerokości impulsu UPWM (*Uniform Sampled* PWM).
- 2. Wzmacniacze w zamkniętej pętli z modulacją Sigma Delta ( $\Sigma$ - $\Delta$ ), stanowiącej odmianę modulacji gęstości impulsów.

Na rys. 1.1 pokazano sposoby próbkowania wejściowego sygnału modulującego stosowane w modulacjach APWM i DPWM we wzmacniaczach klasy D w otwartej pętli.

W modulacjach analogowych APWM stosuje się naturalne próbkowanie sygnału modulującego (NPWM), tzn. czasy trwania impulsów zmodulowanych PWM otrzymywane są w wyniku porównania analogowego sygnału modulującego z przebiegiem trójkątnym lub piłokształtnym.

W modulacjach cyfrowych DPWM, zamiast analogowego sygnału ciągłego, wykorzystywany jest dyskretny sygnał modulujący, otrzymywany po wcześniejszym skwantowaniu sygnału analogowego. Szerokości zmodulowanych impulsów prostokątnych są proporcjonalne do dyskretnych wartości sygnału modulującego i przy próbkowaniu ze stałym okresem sygnału modulowanego otrzymujemy równomierną modulację UPWM.



Rys. 1.1. Różnice pomiędzy modulacjami: NPWM, UPWM i LPWM [32]

Stosując dodatkowe próbkowanie sygnału w okresie przełączania  $T_{c'}$  otrzymujemy dyskretny sygnał skwantowany bardziej zbliżony kształtem do pierwotnego sygnału analogowego, a zmodulowany sygnał DPWM jest bardziej zbliżony do zmodulowanego sygnału NPWM przy modulacji naturalnej. Ten rodzaj modulacji może być realizowany jako modulacja pseudonaturalna PNPWM (*Pseudo-Natural Pulse Width Modulation*) lub linearyzowana – LPWM (*Linearized Pulse Width Modulation*).

W każdej z wyszczególnionych wyżej metod modulacji PWM, zarówno analogowych jak i cyfrowych, można wyróżnić modulację jednobrzegową

(*Single sided modulation* – S) lub dwubrzegową (*Doule sided modulation* D). Sygnał PWM z modulacją dwubrzegową niesie więcej informacji o sygnale modulującym, przy tej samej częstotliwości przebiegu modulowanego [32-39].

Wzmacniacze klasy D w zamkniętej pętli, zamiast opisanego wyżej modulatora PWM, wykorzystują modulację Sigma-Delta (Σ-Δ) z nadpróbkowaniem, kształtującym charakterystykę szumów kwantyzacji [40-44]. Na rys. 1.2.a przedstawiono standardowy, jednostopniowy modulator Σ-Δ zawierający: integrator, strobowany komparator, który w istocie jest układem kwantyzatora sterowanym częstotliwością próbkowania  $f_s$ . Przetwornik cyfrowo analogowy C/A zasilany jest cyfrowym sygnałem, który pojawia się na wyjściu układu komparatora. Wprowadzone w układzie ujemne sprzężenie zwrotne wymusza śledzenie wartości sygnału wejściowego modulatora. Różnice sygnałów: wejściowego modulatora oraz wyjściowego kwantyzatora są korygowane w integratorze. Modulator jednostopniowy Σ-Δ daje redukcję szumów kwantyzacji o około 9 dB przy wzroście dwukrotnym częstotliwości próbkowania  $f_s$ .



Rys. 1.2. Schematy blokowe: a) standardowego, jednostopniowego modulatora  $\Sigma$ - $\Delta$ b) wzmacniacza klasy D z modulatorem  $\Sigma$ - $\Delta$  drugiego rzędu

Współczesne rozwiązania wzmacniaczy klasy D z modulatorem  $\Sigma$ - $\Delta$  używają pętli sprzężenia zwrotnego pracującej w trybie ciągłym, a nie pętli cyfrowej, jak w opisanym wcześniej modulatorze na rys. 1.2.a. Dzięki temu, informacja z wyjścia dostępna jest na wejściu, umożliwiając porównanie z sygnałem wejściowym i poprzez ujemne sprzeżenia zwrotne korygujemy zniekształcenia tranzystorów MOSFET stopnia końcowego mostka H, które pojawiają się podczas ich przełączania. Zniekształcenia wynikające ze zjawiska aliasingu są minimalizowane na skutek ciągłej pracy układu, który zawiera filtr antyaliasingowy, uniemożliwiając przedostanie sie na wejście modulatora wyższych harmonicznych sygnałów generowanych na wyjściu modulatora niż dopuszczalna częstotliwość sygnału wejściowego. Na rys. 1.2.b przedstawiono jedno z wielu możliwych rozwiązań wzmacniacza klasy D z modulatorem  $\Sigma$ - $\Delta$ , 2-go rzędu, które łączy w sobie opisywane wyżej techniki [40-44]. W wielu pracach opisano różne modyfikacje rozwiązań układowych wzmacniaczy klasy D z modulatorami  $\Sigma$ - $\Delta$ , zarówno 2-go, jak i 3-go rzedu, w których wprowadzono sprzeżenie "w przód", emulujące sprzężenie zwrotne i poprawiające zakres dynamiczny integratorów, a także dodatkowe petle selektywnego sprzeżenia zwrotnego pomiedzy wyjściem komparatora a wejściami integratorów, zapewniając w niektórych petlach cyfrowe sprzężenie zwrotne poprzez konwerter C/A obok sprzężenia ciągłego w pozostałych pętlach [22-30], [40-44], [59-60].

Cyfrowe wzmacniacze klasy D małej mocy najczęściej używają modulatora opartego na wielobitowym modulatorze  $\Sigma$ - $\Delta$ . Algorytmiczna transformacja cyfrowego sygnału PCM na sygnał PWM jest przenoszona do zamkniętej pętli modulatora  $\Sigma$ - $\Delta$ , dzięki czemu szum i zniekształcenia generowane podczas transformacji są tłumione przez duże wzmocnienie pętli sprzężenia zwrotnego "w przód". W porównaniu do LPWM, modulacja  $\Sigma$ - $\Delta$  wymaga znacznie wyższej częstotliwości przełączania tranzystorów MOSFET w stopniu wyjściowym, co powoduje obniżenie sprawności energetycznej wzmacniacza [7, 23, 35].

Zastosowanie klasycznych, analogowych wzmacniaczy klasy D w cyfrowych systemach audio, z wejściowym sygnałem cyfrowym PCM, wiąże się z koniecznością każdorazowego przetworzenia sygnału cyfrowego na sygnał analogowy w precyzyjnym przetworniku C/A, aby następnie przekształcić go na sygnał zmodulowany NPWM. To przekształcenie jest często nazywane konwersją PCM na PWM.

Aby wyeliminować konieczność stosowania w konwerterach PCM na PWM dość skomplikowanych układów, precyzyjnych przetworników C/A – proces modulacji PWM można zrealizować bezpośrednio przy zastosowaniu algorytmów cyfrowej modulacji szerokości impulsów DPWM, gdzie wejściowy sygnał PCM jest przetwarzany bezpośrednio w ciąg 1-bitowych impulsów PWM [32-39], [45-49]. Standardowa DPWM z równomiernym próbkowaniem UPWM (ang. *Uniform PWM*), chociaż bardzo prosta, nie może być wykorzystana we wzmacniaczach akustycznych ze względu na jej wrodzoną naturalną nieliniowość [32-35].

Algorytmy DPWM stosowane w akustycznych wzmacniaczach klasy D są dość złożone, a ponadto muszą być realizowane w czasie rzeczywistym, przy dość wysokiej częstotliwości kluczowania stopnia końcowego (zależnie od rodzaju modulacji DPWM,  $F_c \ge 250$  kHz). Z tego powodu, w praktycznych rozwiązaniach cyfrowych wzmacniaczy klasy D rozwinęły się główne dwie metody realizacji modulatorów DPWM: 1) modulacja DPWM realizowana w oparciu o wielobitową modulację sigma-delta ( $\Sigma$ - $\Delta$ ) z układem kształtowania szumów kwantyzacji (cześciej stosowana w praktyce ze względu na łatwiejsze kompromisy pomiędzy parametrami układu dla uzyskania zadanych parametrów wyjściowych) oraz 2) standardowe modulacje DPWM z kompensacją wstępną, charakteryzujące się próbkowaniem sygnału modulującego najbardziej zbliżonym do próbkowania przy modulacjach naturalnych NPWM i układem kształtowania szumów rekwantyzacji. Poprzez interpolacje wejściowego sygnału PCM otrzymujemy dyskretny sygnał skwantowany bardziej zbliżony kształtem do pierwotnego sygnału analogowego, a zmodulowany sygnał DPWM jest bardziej zbliżony do zmodulowanego sygnału NPWM przy modulacji naturalnej. Ten rodzaj modulacji nazywany jest modulacją pseudonaturalną PNPWM (ang. Pseudo-Natural Pulse Width Modulation) lub linearyzowaną LPWM (Linearized Pulse Width Modulation).

Standardowe modulacje DPWM z kompensacją wstępną stwarzają możliwość emulacji wszystkich czterech podstawowych metod modulacji NPWM w cyfrowych aplikacjach wzmacniaczy klasy D (tj. NADS, NADD, NBDS, NBDD), a w szczególności dwubrzegowej modulacji klasy BD (NBDD), (*Natural sampled Class-BD Doule sided*) uznawanej jako optymalna modulacja PWM, ze względu na łatwość filtracji sygnałów różnicowych na wyjściu stopnia końcowego wzmacniacza klasy D. Spośród czterech podstawowych rodzajów modulacji NPWM, modulacja NBDD, która jest odpowiednikiem trzypoziomowej wersji modulacji PSCPWM (*Phase Shifted Carrier Pulse Width Modulation*) i jest najlepsza pod względem wyjścia różnicowego DM (*Differential Mode*) i ma zdecydowanie najbardziej atrakcyjną charakterystykę widmową, która zawiera znacznie mniej niepożądanych składowych widmowych niż wszystkie inne metody PWM [32-32], [36-39]. Modulator NBDD posiada jednak pewną wadę, ponieważ na jego wyjściu sumacyjnym CM (*Common Mode*) pojawia się sygnał sumacyjny, obecny w pełnej skali nawet przy bardzo niskim poziomie sygnału modulującego, o szerokim widmie zawierającym nieparzyste harmoniczne częstotliwości przełączania i ich parzyste składowe intermodulacyjne (IM). Szybkie przełączanie tranzystorów wyjściowych MOSFET, duże skoki napięć wyjściowych w zakresie napięć na szynach zasilających stopień końcowy wzmacniacza, szerokie spektrum częstotliwości sygnałów PWM mogą prowadzić do emisji zakłóceń o wysokiej częstotliwości RF ze stopnia wyjściowego, ścieżek na płytce drukowanej, filtrów i kabli głośnikowych, które stają się przypadkowymi antenami [3-10].

Cyfrowa modulacja PNPWM jest atrakcyjna z punktu widzenia możliwości ograniczenia zniekształceń nieliniowych w paśmie podstawowym sygnału modulującego do dowolnie niskiego poziomu, a dla jej realizacji wykorzystywane są powszechnie znane i ugruntowane numeryczne metody obliczeń, ale trudne do realizacji w czasie rzeczywistym, ponieważ wymagają zbyt dużych nakładów obliczeniowych.

Linearyzowane modulacje LPWM są prostsze w realizacji i wymagają mniejszych nakładów obliczeniowych, dlatego w badaniach skoncentrowano się na tych sposobach modulacji, tym bardziej, że głównym celem badań była implementacja hybrydowego, linearyzowanego 9-bitowego lub 10-bitowego modulatora LBDD do sterowania stopniem wyjściowym akustycznego wzmacniacza klasy BD, w oparciu o mikrokontroler STM32 i programowaną linię opóźniającą z odczepami PTDL (*Programmable Tapped Delay Line*) [45-52]. Zadaniem modulatora jest możliwie jak najwierniejsze odwzorowanie dwubrzegowej modulacji NBDD, która charakteryzuje się najbardziej złożonym algorytmem obliczeniowym i wymaga największych nakładów obliczeniowych w czasie rzeczywistym.

Cyfrowy modulator LBDD, emulujący optymalny modulator NBDD, posiada tę samą wadę co jego prototyp, tj. na jego wyjściu sumacyjnym CM pojawia się sygnał sumacyjny, obecny w pełnej skali nawet przy bardzo niskim poziomie sygnału modulującego, o szerokim widmie zawierającym nieparzyste harmoniczne częstotliwości przełączania i ich parzyste składowe intermodulacyjne.

Dla rozwiązania tego problemu, opracowano rozszerzone układy cyfrowych modulatorów LBDD PWM oraz LPSC PWM (*Linearized Phase Shifted Carrier Pulse Width Modulation*), przystosowanych do sterowania nowych oryginalnych wzmacniaczy akustycznych klasy BD w otwartej pętli ze zrównoważonym wyjściem w trybie wspólnym, posiadającym stałe napięcia na wyjściu CM [9-10], [45-52].

### 1.3. Cele badawcze

Niniejsza publikacja dotyczy algorytmów przetwarzania sygnałów niezbędnych do konwersji cyfrowych danych audio, uzyskanych ze źródła, na cyfrowy sygnał o modulowanej szerokości impulsów, który steruje tranzystory MOSFET stopnia końcowego akustycznego wzmacniacza klasy D. Głównym celem badań była implementacja hybrydowego, linearyzowanego modulatora LBDD z kompensacją wstępną do sterowania stopniem wyjściowym akustycznego wzmacniacza klasy BD, ze zrównoważonym wyjściem dla sygnałów wspólnych CM, o stałej wartości napięcia na tym wyjściu.

Algorytmy kompensacji wstępnej stosowane w cyfrowym przetwarzaniu sygnałów DSP, składające się z następujących bloków modułowych:

- interpolacja,
- obliczenia z dużą dokładnością położenia początków i końców czasu trwania impulsu LBDD PWM w n-tych okresach kluczowania,
- kształtowania szumów kwantyzacji.

Algorytm obliczeniowy położenia początków i końców czasu trwania impulsu PWM w każdym okresie przełączania wymaga dwuetapowej interpolacji wejściowego sygnału PCM. W pierwszym etapie interpolacja realizowana jest ze współczynnikiem nadpróbkowania *K*, dzięki której odstęp pomiędzy dwoma sąsiednimi próbkami jest równy okresowi kluczowania  $T_{c'}$  natomiast w drugim etapie interpolacji wprowadza się *Q* dodatkowych próbek sygnału PCM równomiernie rozłożonych w okresie kluczowania  $T_c$  i aproksymuje się sygnał modulujący w tym przedziale odcinkami prostoliniowymi, przechodzącymi przez interpolowane próbki PCM.

Obliczone z dużą dokładnością wartości położenia początków i końców czasu trwania impulsu PWM w *n*-tych okresach kluczowania, wymagałyby bardzo dużej rozdzielczości czasowej kwantyzatora na wyjściu modulatora, transformującego obliczone czasy na ciąg fizycznie generowanych impulsów PWM, co z kolei wymagałoby zastosowania bardzo wysokich (nieakceptowalnych w praktyce) częstotliwości generatora taktującego kwantyzator. Zastosowanie procesu rekwantyzacji pozwala z jednej strony na redukcję (obcięcie) długości słowa bitowego  $N_q$  obliczonej wartości położenia początków i końców czasu trwania impulsu PWM do mniejszej rozdzielczości  $N_{rq'}$  tym samym ograniczenie rozdzielczości kwantyzatora, ale z drugiej strony, pozwala na kształtowanie generowanych szumów rekwantyzacji. Rekwantyzowany sygnał cyfrowy, po przejściu przez układ kształtowania szumów kwantyzacji zawierający pętle sprzężenia zwrotnego z filtrem, zachowuje niezmienione składowe widma sygnału PWM w paśmie podstawowym sygnału modulującego, zaś szum kwantyzacji zostaje przesunięty poza to pasmo, do zakresu wyższych częstotliwości, odfiltrowywanych w procesie demodulacji.

Celem badań było również opracowanie rozszerzonych układów cyfrowych modulatorów LBDD PWM oraz LPSC PWM, przystosowanych do sterowania nowych oryginalnych wzmacniaczy akustycznych klasy BD w otwartej pętli ze zrównoważonym wyjściem w trybie wspólnym, posiadających stałe napięcia na wyjściu CM.

## Porównanie cyfrowych modulacji UPWM z równomiernym próbkowaniem z naturalnymi modulacjami NPWM

### 2.1. Analogowe (naturalne) modulacje szerokości impulsów NPWM

W tabeli 2.1 wprowadzono skrócone nazwy czterech podstawowych modulacji z naturalnym próbkowaniem, zgodne z nazwami często stosowanymi w literaturze [32-38].

| Metoda próbkowania    | Modulowane<br>zbocza                 | llość poziomów | Skrót modulacji PWM |
|-----------------------|--------------------------------------|----------------|---------------------|
| Próbkowanie naturalne | Jednobrzegowa<br><i>Single sided</i> | 2 (AD)         | NADS                |
| (NPWM)                |                                      | 3 (BD)         | NBDS                |
|                       | Dwubrzegowa<br><i>Double sided</i>   | 2 (AD)         | NADD                |
|                       |                                      | 3 (BD)         | NBDD                |

Tabela 2.1. Skrócone nazwy modulacji PWM z próbkowaniem naturalnym

Zasadę tworzenia naturalnych modulacji PWM, wyszczególnionych w tabeli 2.1, tj.: NADS, NBDS, NADD, NBDD, przedstawiono na rys. 2.1. Wyznaczone przebiegi czasowe ilustrują proces tworzenia sygnałów PWM o częstotliwości kluczowania  $F_c$ , modulowanych sygnałem sinusoidalnym:

$$u_m(t) = M\sin(\omega_m t) \tag{2.1}$$

o częstotliwości 8-krotnie mniejszej od częstotliwości  $F_c$ , tj.  $f_m/F_c = 1/8$ . Na rysunku k oznacza kolejny numer okresu kluczowania  $T_c$ , gdzie:  $T_c = 1/F_c$ .

Znormalizowaną częstotliwość (lub pulsację) można zdefiniować jako stosunek pulsacji sygnału modulującego  $\omega_m$  do pulsacji kluczowania  $\Omega_c$ :

$$f_r = \omega_r = \frac{\omega_m}{\Omega_c} = \frac{2\pi f_m}{2\pi F_c}$$
(2.2)

Zgodnie z kryterium Nyquista, znormalizowana częstotliwość musi spełniać warunek:  $f_r < (1/2)$ , jednak obserwując na rys. 2.1 szybkości narastania przebiegów piłokształtnych (lub trójkątnych) oraz sygnału modulującego (o jednostkowych amplitudach), otrzymujemy:

Ila jednobrzegowej PWM

 $SR_c = 2F_c$  oraz  $SR_m = 2\pi f_m$ , co prowadzi do warunku:

$$SR_c > SR_m \iff f_m < \frac{F_c}{\pi} \iff f_r < \frac{1}{\pi}$$
 (2.3)

Ila dwubrzegowej PWM

$$SR_c = 4F_c \qquad \Leftrightarrow \qquad f_m < \frac{2F_c}{\pi} \qquad \Leftrightarrow \qquad f_r < \frac{2}{\pi} \qquad (2.4)$$

#### 2.1.1. Analityczne widma częstotliwościowe sygnałów z modulacją NPWM

Widma częstotliwościowe sygnałów z modulacją NPWM mają postać podwójnych szeregów Fouriera i w oparciu o literaturę [32-38], widma te przedstawiono niżej dla różnicowych sygnałów NPWM, tj. zmodulowanych sygnałów na wyjściach różnicowych modulatorów w trybie DM, zgodnie z zasadami tworzenia naturalnych modulacji NPWM.



Rys. 2.1. Zasady tworzenia naturalnych modulacji PWM: NADS, NBDS, NADD, NBDD [32]

#### Jednobiegunowa (klasa AD), dwubrzegowa NADD PWM – wyjście różnicowe DM

$$F_{NADD}(t) = M \cos(\omega_m t) + + 2\sum_{m=1}^{\infty} \left\{ \frac{J_0\left(\frac{m\pi M}{2}\right)}{\frac{m\pi}{2}} \sin\left(\frac{m\pi}{2}\right) \cos(m\Omega_c t) \right\} + + 2\sum_{m=1}^{\infty} \sum_{n=\pm 1}^{\infty} \left\{ \frac{J_0\left(\frac{m\pi M}{2}\right)}{\frac{m\pi}{2}} \sin\frac{(m+n)\pi}{2} \cos[(m\Omega_c + n\omega_m)t] \right\}$$
(2.7)

#### Dwubiegunowa (klasa BD), dwubrzegowa NBDD PWM – wyjście różnicowe

$$\begin{aligned} F_{NBDD}^{DM}(t) &= M \cos(\omega_{m} t) - \\ &- 4 \sum_{m=1}^{\infty} \sum_{n=\pm 1}^{\infty} \left\{ \frac{J_{n} \left( \frac{m \pi M}{2} \right)}{m \pi} \sin\left( \frac{(m+n)\pi}{2} \right) \sin\left( \frac{n \pi}{2} \right) \sin\left[ m \,\Omega_{c} + n \,\omega_{m} \right) t - \frac{n \pi}{2} \right] \right\} = \\ &= M \cos(\omega_{m} t) + \\ &+ 4 \sum_{m=1}^{\infty} \sum_{n=0}^{\pm \infty} \left\{ \frac{J_{n} \left( \frac{2m \pi M}{2} \right)}{2m \pi} \sin\left( \frac{[2m + (2n+1)]\pi}{2} \right) \sin\left[ \{2m \,\Omega_{c} + (2n+1)\omega_{m} \} t + \frac{\pi}{2} \right] \right\} \end{aligned}$$

We wzorach (2.5 ÷ 2.8) zastosowano oznaczenia:

 $\Omega_c = 2\pi F_c$  pulsacja kluczowania,

- $\omega_m = 2\pi f_m$  pulsacja sygnału modulującego,
- M indeks modulacji,  $M \in [0;1]$
- *J*<sup>*n*</sup> funkcja Bessel'a I-go rodzaju, rzędu *n*,
- n indeks harmonicznych sygnału modulującego,
- *m* indeks harmonicznych sygnału kluczującego.

Przedstawione na rys. 2.1 przebiegi czasowe ilustrują zasadę tworzenia dwubiegunowych (w klasie BD) modulacji NBDS i NBDD, w których wyjściowy sygnał różnicowy w trybie DM jest różnicą sygnałów wyjściowych

z dwóch modulatorów jednobiegunowych (odpowiednio NADS i NADD), sterowanych prostym i odwróconym w fazie o 180° sygnałem modulującym. Rysunek ten ilustruje również proces powstawania sygnałów wspólnych CM (Common Mode signal) przy naturalnych modulacjach NPWM.

Widma częstotliwościowe tych sygnałów określone są zależnościami:

$$F_{NADS,C} = 0 \tag{2.9}$$

$$F_{NBDS,C}(t) = 2\sum_{m=1}^{\infty} \frac{1 - J_0(m\pi M)\cos(m\pi)}{m\pi} \sin(n\Omega_c t) - 2\sum_{m=1}^{\infty} \sum_{n=\pm 1}^{\infty} \left\{ \frac{J_n(m\pi M)}{m\pi} \sin[(m\Omega_c + n\omega_m)t - m\pi]\cos\left(\frac{n\pi}{2}\right) \right\}$$
(2.10)

$$F_{NADD,C} = 0 \tag{2.11}$$

$$F_{NBDD}^{CM}(t) = 2\sum_{m=1}^{\infty} \frac{J_0\left(\frac{m\pi M}{2}\right)}{\frac{m\pi}{2}} \sin\left(\frac{m\pi}{2}\right) \cos\left(m\Omega_c t\right) + 2\sum_{m=1}^{\infty} \sum_{n=\pm 1}^{\infty} \left\{ \frac{J_n\left(\frac{m\pi M}{2}\right)}{\frac{m\pi}{2}} \sin\left(\frac{(m+n)\pi}{2}\right) (1+\cos n\pi) \cos\left[(m\Omega_c+n\omega_m)t\right] \right\}$$
(2.12)

#### 2.1.2. Porównanie widm częstotliwościowych sygnałów z modulacją NPWM

2

W tabeli 2.2 dokonano zbiorczego porównania widm częstotliwościowych wszystkich rozważanych naturalnych modulacji NPWM. Widma te charakteryzują się tym, że zawierają składową podstawową o częstotliwości sygnału modulującego i amplitudzie równej indeksowi modulacji, składową o częstotliwości kluczowania i jej harmoniczne oraz wiele składowych intermodulacyjnych o częstotliwościach będących liniową kombinacją częstotliwości kluczowania  $F_c$  i modulującej  $f_m$ . We wszystkich modulacjach NPWM, tj. zarówno w klasie AD i BD, zmodulowany sygnał różnicowy na wyjściu różnicowym nie zawiera składowej stałej.

Przy dostatecznie dużym odstępie częstotliwości kluczowania  $F_c$  od maksymalnej częstotliwości  $f_{m max}$  sygnału modulującego, amplitudy prążków intermodulacyjnych, dla takich wartości n, dla których częstotliwości  $(F_c - nf_{m max})$  pokrywają się z pasmem podstawowym sygnału modulującego, zanikają praktycznie do zera, zatem w procesie demodulacji, za pomocą odpowiedniego filtru dolnoprzepustowego, sygnał modulujący zostanie wydzielony bez żadnych zniekształceń nieliniowych.

Na szczególne wyróżnienie zasługuje dwubrzegowa modulacja klasy BD (NBDD), w której nie występują składowe z nieparzystym indeksem częstotliwości kluczowania, ani ich składowe boczne. Brak w widmie częstotliwościowym składowej o częstotliwości kluczowania, ani jej prążków bocznych jest równoważne podwojeniu częstotliwości próbkowania. Zatem, przy zastosowaniu modulacji NBDD znacznie łatwiej jest odfiltrować wszystkie niepożądane składowe widma sygnału różnicowego lub możliwe jest dwukrotne obniżenie częstotliwości kluczowania (zwiększenie sprawności energetycznej wzmacniacza). Z tego względu modulację NBDD należy uznać za optymalną.

| Rodzaj<br>modulacji | Składowa widma                                                 | Amplituda                                                               |
|---------------------|----------------------------------------------------------------|-------------------------------------------------------------------------|
| 1                   | 2                                                              | 3                                                                       |
|                     | Podstawowa                                                     | М                                                                       |
| NADS                | $m$ -ta harmoniczna pulsacji kluczowania $\Omega_c = 2\pi F_c$ | $2\left(\frac{1-J_0(m\pi M)\cos(m\pi)}{m\pi}\right)$                    |
|                     | Składowe intermodulacyjne IM: $(m\Omega_c\pm narnothing_m)$    | $2\left(\frac{J_n(m\pi M)}{m\pi}\right)$                                |
|                     | Podstawowa                                                     | М                                                                       |
|                     | Skład. IM: ( $m\Omega_{_c}\pm n\omega_{_m})$ (Różnicowe)       | $2\left(\frac{J_n(m\pi M)}{m\pi}\right)\sin\left(\frac{n\pi}{2}\right)$ |
| NBDS                | $m$ -ta harmoniczna pulsacji $\Omega_c$ (Sygnał wspólny)       | $2\left(\frac{1-J_0(m\pi M)\cos(m\pi)}{m\pi}\right)$                    |
|                     | Składowe IM: $(m\Omega_c\pm n\omega_m)$<br>(Sygnał wspólny)    | $2\left(\frac{J_n(m\pi M)}{m\pi}\right)\cos\left(\frac{n\pi}{2}\right)$ |

Tabela 2.2. Porównanie naturalnych modulacji NPWM

| 1    | 2                                                                           | 3                                                                                                                  |
|------|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
|      | Podstawowa                                                                  | М                                                                                                                  |
| NADD | $m$ -ta harmoniczna pulsacji $\Omega_c$                                     | $\frac{4J_0\left(\frac{m\pi M}{2}\right)}{m\pi}\sin\left(\frac{m\pi}{2}\right)$                                    |
| 1    | Składowe IM: ( $m\Omega_{c}\pm n\omega_{m}$ )                               | $\frac{4J_n\left(\frac{m\pi M}{2}\right)}{m\pi}\sin\left((m+n)\frac{\pi}{2}\right)$                                |
|      | Podstawowa                                                                  | М                                                                                                                  |
|      | Składowe IM: ( $m\Omega_c \pm n\omega_m$ )<br>(Różnicowe)                   | $\frac{4J_n\left(\frac{m\pi M}{2}\right)}{m\pi}\sin\left(\frac{(m+n)\pi}{2}\right)\sin\left(\frac{n\pi}{2}\right)$ |
| NBDD | $m$ -ta harmoniczna pulsacji $\Omega_c$ (Sygnał wspólny)                    | $\frac{4J_0\left(\frac{m\pi M}{2}\right)}{m\pi}\sin\left(\frac{m\pi}{2}\right)$                                    |
|      | Składowe IM: ( $m {f \Omega}_c \pm n {m arnothing}_m$ )<br>(Sygnał wspólny) | $\frac{4J_n\left(\frac{m\pi M}{2}\right)}{m\pi}\sin\left(\frac{(m+n)\pi}{2}\right)(1+\cos n\pi)$                   |

Przy dwubiegunowych modulacjach NBDS i NBDD występują sygnały wspólne, co stanowi niewątpliwą wadę tych modulacji, bowiem wiąże się z koniecznością dodatkowej filtracji tych sygnałów. Potrzeba filtracji sygnałów wspólnych przy modulacji NBDD obniża nieco jej zalety jako modulacji optymalnej.

## 2.1.3. Analiza spektralna sygnałów z modulacją NPWM w programie Matlab

Widma częstotliwościowe sygnałów zmodulowanych PWM wyznaczono metodą estymacyjną opisaną w dodatkach A.1, A.2, przy założeniu, że sygnał modulujący jest periodyczny. Kod programu zostały opracowany w oparciu o literaturę [33, 35, 75-78]. Na rys. 2.2 przedstawiono przykładowe wyniki symulacji w programie Matlab przebiegów czasowych sygnałów: różnicowego i wspólnego dla optymalnej modulacji NBDD, z następującymi parametrami:  $f_m = 9,8$  kHz,  $F_c = 352,8$  kHz, A = 0,95.

Sygnał kluczujący – <br/>, $F_c$  = 352,8 kHz, $f_{\rm m}$  = 9,8 kHz, sygnał prosty – <br/>i sygnał odwrócony –



Rys. 2.2. Przebiegi czasowe sygnału różnicowego i wspólnego przy modulacji NBDD, dla:  $F_c = 352,8$  kHz,  $f_m = 9,8$  kHz, A = 0,95

Dla tych samych parametrów co wyżej, na rys. 2.3 i 2.4 przedstawiono odpowiednio widma częstotliwościowe dla sygnału różnicowego i wspólnego (kod programu w dodatku A.2), przy czym analiza spektralna przeprowadzona jest z rozdzielczością d f = 9,8 kHz.



Rys. 2.3. Widmo częstotliwościowe sygnału różnicowego przy modulacji NBDD, dla:  $F_c$  = 352,8 kHz,  $f_m$  = 9,8 kHz, Am = 0,95, df = 0,98 kHz



Rys. 2.4. Widmo częstotliwościowe sygnału wspólnego przy modulacji NBDD, dla:  $F_c$  = 352,8 kHz,  $f_m$  = 9,8 kHz, Am = 0,95, df = 0,98 kHz

Analizę spektralną sygnału różnicowego NBDD przeprowadzono w szerokim zakresie, aż do częstotliwości  $2F_c$  = 705,6 kHz, aby pokazać najważniejszą właściwość tej modulacji, że w widmie sygnału różnicowego nie występują składowe z nieparzystym indeksem częstotliwości kluczowania, ani ich składowe boczne. Brak w widmie częstotliwościowym składowej o częstotliwości kluczowania, ani jej prążków bocznych, jest równoważne podwojeniu częstotliwości próbkowania, co bardzo efektownie pokazuje rys. 2.3.

Jednak widmo częstotliwościowe sygnału wspólnego NBDD, jak pokazano na rys. 2.4, zawiera składowe nieparzyste częstotliwości kluczowania  $m^*F_c$ , dla m=1,3,5..., tj. 352,8 kHz, 1058,4 kHz itd. i szeroką gamę ich intermodulacyjnych prążków bocznych.



Rys. 2.5. Widma częstotliwościowe sygnałów różnicowych PWM: NADS, NBDS, NADD, NBDD, dla:  $F_c$  = 352,8 kHz,  $f_m$  = 9,8 kHz, Am = 0,95, df = 0,98 kHz



Rys. 2.6. Widma częstotliwościowe sygnałów różnicowych PWM: NADS, NBDS, NADD, NBDD, dla:  $F_c = 352,8$  kHz,  $f_m = 19,6$  kHz, Am = 0,95, df = 0,98 kHz

W celu porównanie wszystkich czterech naturalnych modulacji PWM: NADS, NBDS, NADD, NBDD, na rysunkach 2.5 i 2.6 przedstawiono zbiorcze wyniki symulacji widm częstotliwościowych ich sygnałów różnicowych, w paśmie od 0 do  $F_c$ , dla:  $F_c$  = 352,8 kHz, Am = 0,95, df = 0,98 kHz, przy różnych częstotliwościach sygnału modulującego, odpowiednio:  $f_m$  = 9,8 kHz (rys. 2.5) oraz  $f_m$  = 19,6 kHz (rys. 2.6).

Z porównania tych widm widać, że przy modulacji NADS powstaje najwięcej składowych harmonicznych  $m F_c$  częstotliwości kluczowania i ich intermodulacyjnych prążków bocznych o częstotliwościach ( $mF_c \pm nf_m$ ). W miarę zwiększania stosunku częstotliwości sygnału modulującego do częstotliwości kluczowania (rys. 2.6), przy modulacji NADS prążki intermodulacyjne o częstotliwościach ( $F_c - nf_m$ ) najwcześniej dotrą do pasma podstawowego sygnału modulującego, zniekształcając sygnał modulujący. Jednak w praktyce, stosunek maksymalnej częstotliwości sygnału modulującego do częstotliwości kluczowania dobiera się znacznie mniejszy niż ten, przy którym wystąpiłoby to zjawisko, aby ułatwić konstrukcję filtru LC wydzielającego sygnał modulujący ze zmodulowanego przebiegu. Tym niemniej, z pośród wszystkich czterech modulacji NPWM, modulacja NADS wymaga zastosowania najbardziej złożonego filtru LC.

Porównując widma częstotliwościowe sygnałów różnicowych NBDS i NADD widzimy, że są one bardzo podobne. Podobieństwo to pozwala na stwierdzenie, że nie ma żadnych przesłanek dla praktycznego wykorzystania modulacji NBDS, bowiem jej realizacja jest bardziej skomplikowana niż modulacja NADD, a ponadto przy modulacji NBDS powstają sygnały wspólne, co wiąże się z koniecznością ich filtracji.

Opisane wcześniej, w oparciu o rys. 2.4, właściwości widma częstotliwościowego sygnału różnicowego przy modulacji NBDD, pozwalają na zakwalifikowanie jej jako optymalnej modulacji PWM, umożliwiającej najprostszą konstrukcję filtru LC dla wydzielenia różnicowego sygnału modulującego z przebiegu PWM (dzięki nieobecności w widmie częstotliwościowym składowej o częstotliwości kluczowania i jej intermodulacyjnych prążków bocznych). Wzmacniacze akustyczne klasy BD z modulacją NBDD często w literaturze są wyróżniane jako "bezfiltrowe", przez co należy rozumieć, że nie ma potrzeby stosowania dodatkowego filtru LC, a wydzielenie sygnału modulującego zapewnia samo obciążenie o charakterze rezystancyjno-indukcyjnym (głośnik).

Aby dołączyć sygnał różnicowy z wyjścia wzmacniacze do głośnika, przewody dołączające (najczęściej długie), a także ścieżki połączeniowe obwodu montażowego, przenoszą nie tylko sygnał różnicowy, ale również powstające przy modulacji NBDD sygnały wspólne. Ze względu na szerokie spektrum częstotliwości sygnałów wspólnych, przewody i ścieżki połączeniowe przenoszące sygnały wspólne stają się anteną promieniującą zakłócenia elektromagnetyczne. Dla ich eliminacji lub znacznego ograniczenia konieczna jest filtracja sygnałów wspólnych. Zagadnienie to zostanie omówione w rozdz. 6.

# 2.2. Cyfrowe modulacje szerokości impulsów UPWM z równomiernym próbkowaniem

W cyfrowych modulacjach DPWM, zamiast analogowego sygnału ciągłego wykorzystywany jest dyskretny sygnał modulujący, otrzymywany po wcześniejszym skwantowaniu sygnału analogowego. Wejściowy sygnał modulujący x(n) jest ograniczonym w paśmie dyskretnym sygnałem próbkowanym z częstotliwością Nyquista  $f_s = 1/T_s \ge 2B$ . W przetwarzaniu sygnałów akustycznych stosujemy standardowe częstotliwości próbkowania o różnych wartościach 44.1 kHz, 48 kHz, 96 kHz oraz 192 kHz. Biorąc pod uwagę dwie najniższe, widzimy że zachodzi koniczność zmiany częstotliwości próbkowania  $F_s$  sygnału dyskretnego już spróbkowanego, do wyższej wartości  $F_c$  odpowiadającej częstotliwości modulacji DPWM. Oznacza to, że spróbkowany sygnał x(n) należy przekształcić w dyskretny sygnał y(m) o wyższej częstotliwości próbkowania  $F_c = 1/T_c$ , przy czym m reprezentuje indeks dyskretnego czasu o wyższej szybkości. Zakładając:

$$T_{c}/T_{s} = 1/K$$
 (2.14)

nowa częstotliwość próbkowania wynosi:  $F_c = K f_s$ 

gdzie: K – współczynnik nadpróbkowania pierwszej interpolacji.

#### 2.2.1. Analityczne widma częstotliwościowe sygnałów z modulacją UPWM

Podobnie jak dla naturalnych modulacji NPWM, istnieją cztery podstawowe metody cyfrowych modulacji szerokości impulsów UPWM (ang. *Uniform Sampled* PWM) z równomiernym próbkowaniem (ze stałym okresem sygnału modulowanego), których skrócone nazwy podano w tabeli 2.3, a na rys. 2.7 przedstawiono zasadę tworzenia tych modulacji w dziedzinie czasu. Przebiegi czasowe wyznaczono dla sinusoidalnego sygnału referencyjnego o częstotliwości 8-krotnie mniejszej od częstotliwości kluczowania ( $f_m / F_c = 1/8$ ).

| Metoda próbkowania    | Modulowane<br>zbocza        | llość poziomów | Skrót modulacji PWM |
|-----------------------|-----------------------------|----------------|---------------------|
| Równomierne           | Jednobrzegowa               | 2 (AD)         | UADS                |
| próbkowanie<br>(UPWM) | Single sided                | 3 (BD)         | UBDS                |
|                       | Dwubrzegowa<br>Double sided | 2 (AD)         | UADD                |
|                       |                             | 3 (BD)         | UBDD                |

Tabela 2.3. Skrócone nazwy modulacji PWM z równomiernym próbkowaniem UPWM

Podobnie jak w przypadku modulacji NPWM, widma częstotliwościowe sygnałów z modulacją UPWM można wyznaczyć w oparciu o podwójne szeregi Fouriera. Na podstawie literatury [33-38], niżej przedstawiono te widma dla różnicowych sygnałów UPWM wyszczególnionych w tabeli 2.3. Zasady tworzenia cyfrowych modulacji UPWM: UADS, UBDS, UADD, UBDD przedstawia rys. 2.7. Zachowano te same oznaczenia i poziomy znormalizowanych amplitud sygnałów, co w przypadku modulacji NPWM.

#### Jednobiegunowa (klasa AD), jednobrzegowa modulacja UADS PWM – wyjście różnicowe

$$F_{UADS}(t) = -\sum_{n=1}^{\infty} \frac{J_n \left( n\pi M \frac{\omega_m}{\Omega_c} \right)}{\left( n\pi \frac{\omega_m}{\Omega_c} \right)} \sin \left( n\omega_m t - n\pi \frac{\omega_m}{\Omega_c} - n\frac{\pi}{2} \right) +$$

$$+ \sum_{m=1}^{\infty} \frac{1}{m\pi} \left[ \sin (m\Omega_c t) - J_0 (m\pi M) \sin (m\Omega_c t - m\pi) \right] -$$

$$- \sum_{m=1}^{\infty} \sum_{n=\pm 1}^{n=\pm \infty} \left\{ \frac{J_n \left[ \left( m + n\frac{\omega_m}{\Omega_c} \right) \pi M \right]}{\left( m + n\frac{\omega_m}{\Omega_c} \right) \pi} \sin \left[ m\Omega_c t + n\omega_m t - m\pi \right] \right\}$$

$$(2.15)$$



Rys. 2.7. Zasady tworzenia cyfrowych modulacji UPWM: UADS, UBDS, UADD, UBDD [32]
#### Dwubiegunowa (klasa BD), jednobrzegowa modulacja UBDS PWM – wyjście różnicowe

$$F_{UBDS}(t) = \sum_{n=1}^{\infty} \frac{J_n \left( n\pi M \frac{\omega_m}{\Omega_c} \right)}{\left( n\pi \frac{\omega_m}{\Omega_c} \right)} \cos \left( n\omega_m t - n\pi \frac{\omega_m}{\Omega_c} \right) \sin \left( \frac{n\pi}{2} \right) +$$

$$+ \sum_{m=1}^{\infty} \sum_{n=-\pm 1}^{n=\pm\infty} \left\{ \frac{J_n \left[ \left( m + n \frac{\omega_m}{\Omega_c} \right) \pi M \right]}{\left( m + n \frac{\omega_m}{\Omega_c} \right) \pi} \cos \left[ (m\Omega_c + n\omega_m) t \right] \sin \left( \frac{n\pi}{2} \right) \right\}$$
(2.16)

#### Jednobiegunowa (klasa AD), dwubrzegowa modulacja UADD PWM – wyjście różnicowe

$$F_{UADD}(t) = \sum_{n=1}^{\infty} \frac{J_n \left( n\pi \frac{\omega_m}{\Omega_c} \frac{M}{2} \right)}{\left( n\pi \frac{\omega_m}{\Omega_c} \right)} \sin \left[ \left( 1 + \frac{\omega_m}{\Omega_c} \right) \frac{n\pi}{2} \right] \cos(n\omega_m t) + \\ + \sum_{m=1}^{\infty} \frac{J_0 \left( n\pi \frac{M}{2} \right)}{m\pi} \cos\left( \frac{m\pi}{2} \right) \cos(m\Omega_c t) + \\ + \sum_{m=1}^{\infty} \sum_{n=\pm 1}^{n=\pm\infty} \frac{J_n \left[ \left( m + n \frac{\omega_m}{\Omega_c} \right) \frac{\pi}{2} \right]}{\left( m + n \frac{\omega_m}{\Omega_c} \right) \pi} \sin \left\{ \left[ m + n \left( 1 + \frac{\omega_m}{\Omega_c} \right) \right] \frac{\pi}{2} \right\} \cos \left[ (m\Omega_c + n\omega_m) t \right] \right\}$$

$$(2.17)$$

#### Dwubiegunowa (klasa BD), dwubrzegowa modulacja UADD PWM – wyjście różnicowe

$$F_{UBDD}(t) = -4\sum_{n=1}^{\infty} \frac{J_n \left(n\pi \frac{\omega_m}{\Omega_c} \frac{M}{2}\right)}{\left(n\pi \frac{\omega_m}{\Omega_c}\right)} \sin\left[\left(1 + \frac{\omega_m}{\Omega_c}\right) \frac{n\pi}{2}\right] \sin\left(\frac{n\pi}{2}\right) \sin\left(n\omega_m t - \frac{n\pi}{2}\right) - \sum_{n=1}^{\infty} \left[\left(1 - \frac{\omega_m}{\Omega_c}\right) \frac{n\pi}{\Omega_c}\right] \sin\left(\frac{n\pi}{2}\right) \sin\left(\frac{n\pi}{2}\right) \sin\left(\frac{n\pi}{2}\right) \sin\left(\frac{n\pi}{2}\right) \right] \sin\left(\frac{n\pi}{2}\right) \sin\left(\frac{n\pi}{2}\right) \sin\left(\frac{n\pi}{2}\right) - \sum_{n=1}^{\infty} \left[\left(1 - \frac{\omega_m}{\Omega_c}\right) \frac{n\pi}{\Omega_c}\right] \sin\left(\frac{n\pi}{2}\right) \sin\left(\frac{n\pi}{2}\right) \sin\left(\frac{n\pi}{2}\right) \sin\left(\frac{n\pi}{2}\right) \sin\left(\frac{n\pi}{2}\right) - \frac{\pi}{2} \sin\left(\frac{n\pi}{2}\right) \sin\left$$

$$-4\sum_{m=1}^{\infty}\sum_{n=\pm 1}^{n=\pm \infty} \frac{J_n \left[ \left[ m+n\frac{\omega_m}{\Omega_c} \right]^{n-\frac{1}{2}} \right]}{\left( m+n\frac{\omega_m}{\Omega_c} \right) \pi} \sin \left\{ \left[ m+n\left(1+\frac{\omega_m}{\Omega_c}\right) \right]^{\frac{1}{2}} \right\} \sin \left( \frac{n\pi}{2} \right) \sin \left[ (m\Omega_c + n\omega_m)t - \frac{n\pi}{2} \right]$$

W tabeli 2.4 dokonano zbiorczego porównania widm częstotliwościowych wszystkich rozważanych cyfrowych modulacji UPWM. Widma te zawierają składową podstawową o częstotliwości sygnału modulującego i jej wyższe harmoniczne, składową o częstotliwości kluczowania i jej harmoniczne oraz wiele składowych intermodulacyjnych ( $mF_s - n f_{m \max}$ ). Obecne w sygnałach z modulacją UPWM wyższe harmoniczne sygnału modulującego leżą w pasmie podstawowym sygnału i nie jest możliwe ich odfiltrowanie.

Stosując dużo wyższą częstotliwość kluczowania  $F_c$  od maksymalnej częstotliwości  $f_{m \max}$  sygnału modulującego, sygnał wyjściowy po demodulacji będzie zniekształcony tylko przez wyższe harmoniczne sygnału, których amplitudy silnie zależą od indeksu modulacji i znormalizowanej częstotliwości  $f_r = f_m / F_c$ .

Korzystając z tabeli 2.4, łatwo możemy wyznaczyć współczynnik zniekształceń nieliniowych *THD* sygnału po demodulacji jako stosunek średniokwadratowej wartości np. 10-ciu wyższych harmonicznych do harmonicznej podstawowej.

| Rodzaj<br>UPWM | n-ta harmoniczna sygnału                                                                                                                                                                   | m-ta harmoniczna częstotł. kluczowania $m \Omega_c$                                                               | Składowe IM $(m\Omega_c \pm n\omega)$                                                                                                                                                                                   |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UADS           | $\frac{J_n\left(n\pi M\frac{\boldsymbol{\omega}_m}{\boldsymbol{\Omega}_c}\right)}{\left(n\pi\frac{\boldsymbol{\omega}_m}{\boldsymbol{\Omega}_c}\right)}$                                   | $\frac{1-J_0(m\pi M)\cos(m\pi)}{m\pi}$                                                                            | $\frac{J_n\left[\left(m+n\frac{\omega_m}{\Omega_c}\right)\pi M\right]}{\left(m+n\frac{\omega_m}{\Omega_c}\right)\pi}$                                                                                                   |
| UBDS           | $\frac{J_n\left(n\pi M\frac{\omega_m}{\Omega_c}\right)}{\left(n\pi\frac{\omega_m}{\Omega_c}\right)}\sin\left(\frac{n\pi}{2}\right)$                                                        | -                                                                                                                 | $\frac{J_n\left[\left(m+n\frac{\omega_m}{\Omega_c}\right)\pi M\right]}{\left(m+n\frac{\omega_m}{\Omega_c}\right)\pi}\sin\left(\frac{n\pi}{2}\right)$                                                                    |
| UADD           | $\frac{J_n\left(n\pi\frac{\omega_m}{\Omega_c}\frac{M}{2}\right)}{\left(n\pi\frac{\omega_m}{\Omega_c}\right)}\sin\left[\left(1+\frac{\omega_m}{\Omega_c}\right)\frac{n\pi}{2}\right]$       | $\frac{J_0\left(n\pi\frac{M}{2}\right)}{m\pi}\cos\left(\frac{m\pi}{2}\right)$                                     | $\frac{J_n\left[\left(m+n\frac{\omega_m}{\Omega_c}\right)\frac{\pi M}{2}\right]}{\left(m+n\frac{\omega_m}{\Omega_c}\right)\pi}\sin\left\{\left[m+n\left(1+\frac{\omega_m}{\Omega_c}\right)\right]\frac{\pi}{2}\right\}$ |
| UBDD           | $4\frac{J_{n}\left(n\pi\frac{\omega_{m}}{\Omega_{c}}\frac{M}{2}\right)}{\left(n\pi\frac{\omega_{m}}{\Omega_{c}}\right)}\sin\left[\left(1+\frac{\omega_{m}}{\Omega_{c}}\right)n\pi\right]s$ | $\sin\left(\frac{n\pi}{2}\right) - \frac{J_n\left[\left(m+\frac{1}{2}\right)\right]}{\left(m+\frac{1}{2}\right)}$ | $ \frac{n\frac{\omega_{m}}{\Omega_{c}}\frac{\pi M}{2}}{n\frac{\omega_{m}}{\Omega_{c}}\pi} \sin\left\{\left[m+n\left(1+\frac{\omega_{m}}{\Omega_{c}}\right)\right]\frac{\pi}{2}\right\}\sin\left(\frac{n\pi}{2}\right) $ |

Tabela 2.4. Porównanie cyfrowych modulacji UPWM z równomiernym próbkowaniem

## 2.2.2. Analiza spektralna sygnałów z modulacją UPWM z wykorzystaniem programu Matlab. Współczynniki zawartości harmonicznych *THD*

Na rys. 2.8 przedstawiono wyniki symulacji w programie Matlab (kod programu w dodatku A.3) widma częstotliwościowego różnicowego sygnału z jednobrzegową modulacją UADS, z następującymi parametrami:  $f_m = 9,8$  kHz,  $F_c = 352,8$  kHz, M = 0,95, analiza spektralna z rozdzielczością  $df_m = 0,98$  kHz.

W analizowanym zakresie częstotliwości, widmo to zawiera składową podstawową i jej wyższe harmoniczne (leżące w paśmie podstawowym sygnału modulującego), składową o częstotliwości kluczowania i jej intermodulacyjne prążki boczne o częstotliwościach ( $F_c - n f_m$ ). Amplitudy sygnałów modulujących i ich harmonicznych silnie zależą od indeksu modulacji M i stosunku częstotliwości sygnału modulującego do częstotliwości kluczowania  $f_r = f_m/F_c$ .

Występujące w sygnale z modulacją UPWM wyższe harmoniczne sygnału modulującego są źródłem zniekształceń tego sygnału. W celu porównania wszystkich czterech cyfrowych modulacji z równomiernym próbkowaniem, wyznaczono dla nich współczynniki zniekształceń nieliniowych *THD* sygnału różnicowego po demodulacji jako stosunek średniokwadratowej wartości 10-ciu wyższych harmonicznych do harmonicznej podstawowej. Na rys. 2.9 przedstawiono wyniki symulacji współczynników *THD* dla modulacji UADS i UADD, a na rys. 2.10 dla modulacji UBDS i UBDD. Amplitudy poszczególnych harmonicznych wyznaczono na podstawie zależności zestawionych w tabeli 2.4.





Rys. 2.8. Widmo częstotliwościowe sygnału różnicowego przy modulacji UADS, dla:  $F_c$  = 352,8 kHz,  $f_m$  = 9,8 kHz, Am = 0,95, df = 0,98 kHz

W celu weryfikacji przeprowadzonych analiz, a w szczególności analiz widm częstotliwościowych, charakterystyki współczynników *THD* dla wszystkich czterech rodzajów modulacji cyfrowych: UADS, UADD, UBDS, UBDD wyznaczono bezpośrednio na podstawie bardzo pracochłonnych analiz spektralnych sygnałów zmodulowanych (jako stosunek średniokwadratowej wartości 10-ciu wyższych harmonicznych do harmonicznej podstawowej), przy tych samych wartościach wskaźników modulacji M, otrzymując dokładnie te same charakterystyki, co przedstawione na rys. 2.9 i 2.10.



Rys. 2.9 Współczynniki THD dla modulacji UADS i UADD, przy F<sub>c</sub> = 352,8 kHz



Rys. 2.10. Współczynniki THD dla modulacji UBDS i UBDD, przy F = 352,8 kHz

Z porównania przedstawionych na rys. 2.9 i rys. 2.10 symulacji wynika, że cyfrowe modulacje UPWM z równomiernym próbkowaniem nie są odpowiednie do zastosowań w akustycznych wzmacniaczach klasy D o małych zniekształceniach nieliniowych. Nawet dwubrzegowa modulacja UBDD, która charakteryzuje się najniższymi watrościami współczynników *THD*, przy maksymalnej częstotliwości sygnału modulującego  $f_{m \max}$  = 20 kHz. (zakładając, że jest to pasmo wzmacniacza akustycznego) oraz zastosowaniu wysokiej częstotliwości kluczowania  $F_c$  = 352,8 kHz, dla wskaźnika modulacji M = 0,95, *THD* osiąga wartość ok. 0,25%.

Ze względu na bardzo prosty sposób wytwarzania modulacji UPWM znajdują one szerokie zastosowanie w sterownikach falowników i różnego rodzaju przekształtników z modulacją szerokości impulsów, w których dopuszczalny poziom zniekształceń nieliniowych jest wyższy niż we wzmacniaczach akustycznych. W tych zastosowaniach modulację UBDD można uznać za optymalną, chociaż przy tej modulacji występują sygnały wspólne, co wiąże się z koniecznością dodatkowej filtracji tych sygnałów (rozdz. 6).

## Cyfrowe, linearyzowane modulacje szerokości impulsów

# **3.1. Ogólne metody linearyzacji cyfrowych modulatorów DPWM**

Ogólne metody linearyzacji cyfrowych modulatorów PWM są szeroko reprezentowane w literaturze [15, 17, 20, 21, 23, 30, 33, 35, 41] i można je zakwalifikować do trzech kategorii:

- Metody kompensacji wstępnej, charakteryzujące się próbkowaniem sygnału modulującego najbardziej zbliżonym do próbkowania przy modulacjach naturalnych NPWM (metody te są najbardziej rozwinięte).
- Metody bezpośredniej kompensacji efektów nieliniowych, w której modulator UPWM traktuje się jako zależną od sygnału, nieliniową funkcję przejścia, której efekty nieliniowe mogą być kompensowane przez odwrotną funkcję przejścia.
- Metody wykorzystujące cyfrowe ujemne sprzężenia zwrotne w pętli samego modulatora lub obejmującej modulator i cyfrowy sygnał UPWM stopnia końcowego.

Na rys. 3.1 przedstawiono ogólny schemat blokowy cyfrowego wzmacniacza klasy D ze standardową, linearyzowaną modulacją cyfrową LPWM z kompensacją wstępną stwarzającą możliwość emulacji wszystkich czterech podstawowych metod modulacji NPWM. Algorytmy konwersji PCM--DPWM z kompensacją wstępną starają się jak najlepiej emulować sygnał z próbkowaniem naturalnym NPWM, wykorzystując ulepszone metody próbkowania, takie jak modulacja pseudo-naturalną PNPWM lub linearyzowaną LPWM [30, 33], [45-49], [53, 54]. Dzięki prostemu algorytmowi LPWM można osiągnąć znaczną poprawę liniowości modulatora, stwarzając szerokie możliwości aplikacji systemów DPWM.



Rys. 3.1. Ogólny schemat blokowy cyfrowego wzmacniacza klasy D

Algorytm obliczeniowy położenia początków i końców czasu trwania impulsu PWM w każdym okresie przełączania wymaga dwuetapowej interpolacji wejściowego sygnału PCM. W pierwszym etapie interpolacja realizowana jest ze współczynnikiem nadpróbkowania *K*, dzięki której odstęp pomiędzy dwoma sąsiednimi próbkami jest równy okresowi kluczowania  $T_c$ , natomiast w drugim etapie interpolacji wprowadza się *Q* dodatkowych próbek sygnału PCM równomiernie rozłożonych w okresie kluczowania  $T_c$  i aproksymuje się sygnał modulujący w tym przedziale odcinkami prostoliniowymi, przechodzącymi przez interpolowane próbki PCM. Obliczone z dużą dokładnością wartości położenia początków i końców czasu trwania impulsu PWM w *n*-tych okresach kluczowania, wymagałyby bardzo dużej rozdzielczości czasowej kwantyzatora na wyjściu modulatora, transformującego obliczone czasy na ciąg fizycznie generowanych impulsów DPWM, co z kolei wymagałoby zastosowania bardzo wysokich (nieakceptowalnych w praktyce) częstotliwości generatora taktującego kwantyzator.

#### 3.1.1. Interpolacja

#### **3.1.1.1.** Rekonstrukcja sygnału ciągłego $x_i(t)$ na podstawie ciągu jego próbek dyskretnych

Rekonstrukcja sygnału ciągłego  $x_a(t)$  na podstawie ciągu jego próbek dyskretnych, jak również zwiększenie szybkości próbkowania sygnału analogowego o rzeczywisty współczynnik *K* należą do podstawowych metod cyfrowego przetwarzania sygnałów [75-78].

Po spróbkowaniu wejściowego, analogowego sygnału akustycznego  $x_a(t)$  o częstotliwości  $f_s$ , z okresem próbkowania  $T_s$ , gdzie:  $T_s = 1/f$ , otrzymujemy cyfrowy sygnał akustyczny PCM, czyli dyskretną sekwencję sygnału spróbkowanego x[n], gdzie n jest indeksem czasu dyskretnego:

$$x[n] = x_a(Tn_s) - \infty < n < \infty, \qquad (3.1)$$

Jak pokazano na rys. 3.2, widmo sygnału dyskretnego jest identyczne z widmem sygnału analogowego w podstawowym przedziale częstotliwości, ale ze współczynnikiem skalowania  $f_s$ :



Rys. 3.2. Próbkowanie sygnału analogowego i jego widmo: a) sygnał analogowy  $x_a(t)$ ; b) sygnał dyskretny x[n]

Rekonstrukcję sygnału ciągłego  $x_a(t)$  na podstawie ciągu próbek dyskretnych  $x[n] = x_a(nT_s)$ , gdzie  $T_s = 1/f_s = 1/2B$ , otrzymujemy w postaci ważonych sum idealnej funkcji interpolacyjnej:

$$g(t) = \frac{\sin\left[\left(\frac{\pi}{T_s}t\right]}{\left(\frac{\pi}{T_s}t\right)}$$
(3.3)

i jej składowych z przesuniętym czasem  $g[t - nT] = x_a (nT_s)$ , dla  $-\infty < n$ , zaś współczynnikami wagowymi są próbki  $x[nT_s]$ :

$$x_{a}(t) = \sum_{n=\infty}^{\infty} x[nT_{s}] \frac{\sin\left[\frac{\pi}{T_{s}}(t-nT_{s})\right]}{\frac{\pi}{T_{s}}(t-nT_{s})}$$
(3.4)

Idealna funkcja interpolacyjna g(t) (3.3) jest odpowiedzią impulsową idealnego, dolnoprzepustowego filtru analogowego, nazywanego filtrem rekonstruującym, o transmitancji w dziedzinie częstotliwości:

$$H(f) = \begin{cases} T_s, & |f| \le \frac{1}{2T_s} \\ 0, & |f| > \frac{1}{2T_s} \end{cases}$$
(3.5)

Na rys. 3.3 przedstawiono idealną rekonstrukcję sygnału analogowego w dziedzinie częstotliwości, gdzie rekonstruowany sygnał w dziedzinie czasu jest równoważny splotowi sygnałów czasowych, tj.  $x(nT_s)\delta(t-nT_s \text{ oraz } g(t))$ .



Rys. 3.3. Reprezentacja idealnej rekonstrukcji sygnału analogowego w dziedzinie częstotliwości

Wejściowy sygnał x(n) jest ograniczonym w paśmie dyskretnym sygnałem próbkowanym z częstotliwością Nyquista  $f_s = 1/T_s \ge 2B$  i zostanie przekształcony w wyjściowy sygnał y(m) o wyższej częstotliwości próbkowania,  $F_c = 1/T_c = Kf_s$ , przy czym m reprezentuje indeks dyskretnego sygnału o wyższej częstotliwości próbkowania (rys. 3.4).



Rys. 3.4. Schemat blokowy intepolatora cyfrowego K-tego rzędu

Na wejściu interpolatora znajduje się ekspander, który dodaje *K*–1 próbek o wartościach zerowych pomiędzy każde dwie próbki sygnału, a następnie wygładza się tak "utworzony" sygnał filtrem interpolującym.

Dzięki tej operacji sygnał dyskretny x(n) zostaje przekształcony w dyskretny sygnał w(m):

$$w(m) = \begin{cases} x(m/K) & m = 0, \pm 1, \pm K, \pm 2K, ... \\ 0, & \text{w przeciwnym razie} \end{cases}$$
(3.6)

Stosując transformatę z do powyższego równania, otrzymujemy:

$$W(z) = \sum_{n = -\infty}^{\infty} w(m) z^{-m} = \sum_{n = -\infty}^{\infty} x(m) z^{-mK} = X(z^{K})$$
(3.7)

Podstawiając:  $z = e^{j \Omega_c}$ , otrzymujemy transformatę sygnału w(m) wyrażoną w zależności od widma sygnału wejściowego x(n):

$$W\left(e^{j\,\Omega_c}\right) = X\left(e^{j\,K\Omega_c}\right) \tag{3.8}$$

gdzie:  $\Omega_c = 2\pi fT_c$  oraz  $\omega_s = 2\pi fT_c$  są unormowanymi częstotliwościami próbkowania, przy:  $K = \frac{F_c}{f_s}$ ;  $F_c = 1/T_c = Kf_s$   $K = \frac{F_c}{F_s}$ 

Jak widać na rys. 3.5, widmo w(m) zawiera nie tylko pasmo podstawowe w zakresie częstotliwości od: –  $\pi/K$  do  $\pi/K$ , ale również pasma skupione wokół harmonicznych oryginalnych częstotliwości próbkującej:  $\pm 2 \pi/K$ ,  $\pm 4 \pi/K$ ,.....





Rys. 3.5. Reprezentacja w dziedzinie czasu i w dziedzinie częstotliwości sygnału analogowego przy zwiększeniu szybkości próbkowania o współczynnik "*K*"

Aby wyeliminować niepożądane składowe widma w zakresie wysokich częstotliwości, potrzebny jest dolnoprzepustowy filtr aproksymujący idealną charakterystykę:

$$H(e^{j\Omega_c}) = \begin{cases} G = K, & |\Omega_c| \le \frac{2\pi fT_c}{2} = \frac{\pi}{K} \\ 0, & \text{w przeciwnym razie} \end{cases}$$
(3.9)

Filtr interpolujący jest filtrem dolnoprzepustowym o unormowanej pulsacji granicznej  $\pi/K$  i wzmocnieniu w pasmie przepustowym *G* = *K*.

*K*-krotnie wzmocniona odpowiedź impulsowa dolnoprzepustowego filtru interpolującgo określona jest zależnością:

$$h(n) = K \left( \frac{1}{K} \frac{\sin(\pi n/K)}{\pi n/K} \right), \qquad -\infty < n < \infty$$
(3.10)

Równanie to opisuje dyskretny sygnał w postaci sin(x)/x, który się zeruje dla n = pK (p – dowolna liczba całkowita), za wyjątkiem n = 0, dla którego przyjmuje wartość h(0) = 1. Powoduje to, że w wyniku filtracji nie są modyfikowane znane ("stare") próbki sygnału. Cała operacja interpolacji cyfrowej jest szczególnym przypadkiem rekonstrukcji sygnału analogowego na podstawie jego próbek.

Jednak w tym przypadku interesuje nas nie "cały", ciągły fragment sygnału, leżący pomiędzy dowolnymi dwoma jego próbkami, tylko dodatkowe *K*-1 równoodległe wartości.

W praktyce występuje konieczność ograniczenia długości filtra, dlatego odpowiedź impulsową wymnaża się z wybranym oknem w(n), mającym określone właściwości widmowe.

$$h_w(n) = w(n)h(n), \qquad -\infty \le n < \infty \tag{3.11}$$

Zakres dynamiczny sygnału nadpróbkowanego K-krotnie wynosi [75-78]:

$$D = 6,20 b + 10\log K + 1,76 \tag{3.12}$$

Wejściowy, cyfrowy sygnał akustyczny PCM (16 bitów,  $F_s$  = 44,1 kHz) posiada zakres dynamiczny 98,5 dB.

## 3.1.2. Algorytmy obliczania położenia początków i końców czasu trwania impulsów DPWM w linearyzowanych modulacjach LPWM

Spośród wszystkich linearyzowanych modulacji DPWM, tzw. modulacje pseudo-naturalne PNPWM charakteryzują się próbkowaniem sygnału modulującego najbardziej zbliżonym do próbkowania przy modulacjach naturalnych NPWM, a tym samym redukcją harmonicznych sygnału modulującego w paśmie podstawowym sygnału.

Główna idea modulacji pseudonaturalnej [35] polega na interpolacji dyskretnego sygnału modulującego, spróbkowanego z częstotliwością  $f_s$ , w dyskretny sygnał y(m) o wyższej częstotliwości próbkowania  $f_{s2} = K f_s = F_c = 1/T$ , a następnie n równomiernie rozłożonych próbek PCM aproksymuje się wielomianem n-tego rzędu. Mając analityczną postać sygnału modulującego oraz przebiegu piłokształtnego (przy modulacji jednobrzegowej), metodami numerycznymi należy wyznaczyć punkty przecięcia tych przebiegów w kolejnych n okresach kluczowania. Szerokość impulsu PNPWM w n-tym okresie kluczowania wyznacza punkt przecięcia tych przebiegów oraz koniec okresu kluczowania (rys. 3.6).



Rys. 3.6. Aproksymacja *n* próbek PCM wielomianem *n*-tego rzędu i analityczne wyznaczenie punktu przecięcia

Cyfrowa modulacja PNPWM jest atrakcyjna z punktu widzenia możliwości ograniczenia zniekształceń nieliniowych w paśmie podstawowym sygnału modulującego do dowolnie niskiego poziomu, a dla jej realizacji wykorzystywane są powszechnie znane i ugruntowane numeryczne metody obliczeń, ale trudne do realizacji w czasie rzeczywistym, ponieważ wymagają zbyt dużych nakładów obliczeniowych.

Linearyzowane modulacje LPWM (*Linearized Pulse Width Modulation*) są prostsze w realizacji i wymagają mniejszych nakładów obliczeniowych, a ich zadaniem jest możliwie jak najwierniejsze odwzorowanie naturalnych modulacji NPWM. Algorytm obliczeniowy położenia początków i końców czasu trwania impulsu LPWM w każdym okresie przełączania wymaga dwuetapowej interpolacji wejściowego sygnału PCM. W pierwszym etapie interpolacja realizowana jest ze współczynnikiem nadpróbkowania K, dzięki któremu odstęp pomiędzy dwoma sąsiednimi próbkami jest równy okresowi kluczowania  $T_c$ , natomiast w drugim etapie interpolacji wprowadza się Q dodatkowych próbek sygnału PCM równomiernie rozłożonych w okresie kluczowania  $T_c$  i aproksymuje się sygnał modulujący w tym przedziale odcinkami prostoliniowymi, przechodzącymi przez interpolowane próbki PCM.

Obliczone z dużą dokładnością wartości położenia początków i końców czasu trwania impulsu PWM w *n*-tych okresach kluczowania, wymagałyby bardzo dużej rozdzielczości czasowej kwantyzatora na wyjściu modulatora, transformującego obliczone czasy na ciąg fizycznie generowanych impulsów LPWM, co z kolei wymagałoby zastosowania bardzo wysokich (nieakceptowalnych w praktyce) częstotliwości generatora taktującego kwantyzator. Zastosowanie procesu rekwantyzacji pozwala z jednej strony na redukcję (obcięcie) długości słowa bitowego  $N_a$  obliczonych wartości położenia początków i końców czasu trwania impulsu LPWM do mniejszej rozdzielczości N<sub>ra</sub>, tym samym ograniczenie rozdzielczości kwantyzatora, ale z drugiej strony, pozwala na kształtowanie generowanych szumów rekwantyzacji. Rekwantyzowany sygnał cyfrowy, po przejściu przez układ kształtowania szumów kwantyzacji zawierający pętle sprzężenia zwrotnego z filtrem, zachowuje niezmienione składowe widma sygnału PWM w paśmie podstawowym sygnału modulującego, zaś szum kwantyzacji zostaje przesunięty poza to pasmo, do zakresu wyższych częstotliwości, odfiltrowywanych w procesie demodulacji.

#### 3.1.2.1. Linearyzowana modulacja LADS PWM

Jak zaznaczono na rys. 3.7, w wyniku dodatkowej interpolacji sygnału cyfrowego w przedziale czasu  $nT_c \le t \le (n + 1)T_c$ , pomiędzy próbkami

 $y_0(n)$ ,  $y_0(n + 1)$ , wprowadzono Q dodatkowych próbek równomiernie rozłożonych w tym przedziale, które wraz z brzegowymi próbkami two-rzą ciąg Q+2 elementów:

$$y_0(n), y_1(n), y_2(n), \dots, y_{O-1}(n), y_O(n), y_0(n+1)$$
 (3.13)

Jak wynika z rys. 3.7 oraz jak opisano w Dodatku A.1, w kolejnych okresach kluczowania ciągły czas *t* możemy zapisać:

$$t = nT_c + \bar{t}; \text{ dla } n = 0,1,2,..., (N - 1) \text{ gdzie: } 0 \le \bar{t} < T_c$$
 (3.14)

 $N = (T_m/T_c)$  jest liczbą impulsów PWM jednym okresie sygnału modulującego. Przebieg piłokształtny w *n*-tym okresie kluczowania opisuje równanie:

$$s(t) = \frac{2}{T_c} (nT_c + \bar{t}) - (1 + 2n); \ 0 \le \bar{t} < T_c$$
(3.15)  
dla:  $n = 0, 1, 2, ..., (N - 1)$ 



Rys. 3.7. Modulacja LADS przy Q=5 dodatkowych próbkach w okresie kluczowania T<sub>c</sub>

W pierwszym okresie kluczowania, dla: n = 0, przebieg ten opisuje równanie:

$$s(\bar{t}) = \frac{2}{T_c} \bar{t} - 1$$
 (3.16)

Przy modulacji NADS, początek impulsu PWM w *n*-tym okresie kluczowania wynosi  $nT_c$ , natomiast koniec impulsu wyznacza punkt przecięcia aproksymowanego odcinkami prostoliniowymi przebiegu modulującego z przebiegiem piłokształtnym  $t = s(nT_c + \bar{t})$ .

Algorytm wyznaczania tego punktu będzie bardziej przejrzysty, gdy przebieg piłokształtny będzie zapisany zawsze dla pierwszego okresu kluczowania (rów. 3.16), zaś przesuwany będzie tylko przebieg modulujący.

Przy wprowadzeniu Q dodatkowych próbek w drugiej interpolacji, okres kluczowania  $T_c$  zostaje podzielony na Q+1 równych odstępów czasowych:

$$T_{\mathcal{Q}} = \frac{T_c}{Q+1} \tag{3.17}$$

Aby zmniejszyć sumaryczną ilość potrzebnych obliczeń arytmetycznych wykonywanych w algorytmie, w punktach podziału okresu kluczowania  $T_c$  (w których leżą próbki interpolowanego sygnału PCM), należy obliczyć i zapamiętać wartości przebiegu piłokształtnego:

$$s_0 = -1, \ s_1 = \frac{2}{Q+1} - 1, \ s_2 = \frac{4}{Q+1} - 1, \ \dots, \ s_{Q-1} = \frac{2(Q-1)}{Q+1} - 1, \ s_Q = \frac{2Q}{Q+1} - 1, \ s_{Q+1} = 1$$
(3.18)

W celu znalezienia punktu przecięcia przebiegu piłokształtnego z przebiegiem aproksymowanym, metodą kilku kolejnych porównań należy znaleźć *i*-ty przedział otrzymany w wyniku podziału, w którym:

$$y_i(n) > s_i \text{ oraz } y_{i+1}(n) < s_{i+1}$$
 (3.19)

Prowadząc prostą przez punkty o współrzędnych:

$$\frac{i T_c}{Q+1}, y_i(n);$$
 oraz  $\frac{(i+1)T_c}{Q+1}, y_{i+1}(n):$ 

$$\frac{T_c}{Q+1}[y-y_i(n)] = [y_{i+1}(n) - y_i(n)] \left(\bar{t} - \frac{i T_c}{Q+1}\right)$$
(3.20)

i rozwiązując układ równań (3.16), (3.20), kolejno dla wszystkich wartości otrzymujemy n = 0,1,2,... (N - 1) punkty przecięcia w kolejnych n-tych okresach kluczowania:

$$\bar{t}_{k}(n) = \frac{T_{c}[1 + (i+1)y_{i}(n) - iy_{i+1}(n)]}{2 + [y_{i}(n) - y_{i+1}(n)](Q+1)}$$
(3.21)

Ostatecznie, otrzymujemy początek i koniec impulsu PWM z modulacją LADS w *n*-tym okresie kluczowania:

$$t_p(n) = nT_c; \ t_k(n) = nT_c + \bar{t}_k(n)$$
 (3.22)

#### 3.1.2.2. Linearyzowana modulacja LADD PWM

Jak pokazano na rys. 3.8, przy modulacji NADD, początek i koniec impulsu PWM w *n*-tym okresie kluczowania wyznaczają punkty przecięcia aproksymowanego odcinkami prostoliniowymi przebiegu modulującego, odpowiednio z opadającą częścią  $s_f(nT_c + \bar{t}_k)$  (*n*) w pierwszym półokresie przebiegu trójkątnego i narastającą częścią  $s_f(nT_r + \bar{t}_k)$  w drugim półokresie tego przebiegu.

W dowolnym *n*-tym okresie kluczowania, symetryczny przebieg trójkątny opisują równania:

$$s_{f}(t) = -\frac{4}{T_{c}} (nT_{c} + \bar{t}) + 4n + 1; \text{ dla} : nT_{c} \le \bar{t} < nT_{c} + \frac{T_{c}}{2}$$
(3.23)

$$s_r(t) = \frac{4}{T_c} \left( nT_c + \bar{t} \right) - 4n - 3; \text{ dla} : nT_c + \frac{T_c}{2} \le \bar{t} < (n+1)T_c \quad (3.24)$$

przy czym ciągły czas t opisuje równanie (3.14).



Rys. 3.8. Modulacja LADD przy Q=5 dodatkowych próbkach w okresie kluczowania  $T_c$ 

Podobnie jak w punkcie 3.1.2.1, symetryczny przebieg trójkątny będzie zapisany zawsze dla pierwszego okresu kluczowania, zaś przesuwany będzie tylko przebieg modulujący:

$$s_f(t) = -\frac{4}{T_c}\bar{t} + 1; \text{ dla}: \ 0 \le \bar{t} < \frac{T_c}{2}$$
 (3.25)

$$s_r(t) = \frac{4}{T_c} \bar{t} - 3$$
; dla:  $0 \le \bar{t} < T_c$  (3.26)

Wprowadzenie Q dodatkowych próbek w drugiej interpolacji, zgodnie z zależnością (3.17), dzieli okres kluczowania  $T_c$  na Q+1 równych odstępów czasowych, przy czym dla parzystych Q, w obu półokresach przebiegu trójkątnego wystąpi Q/2 próbek, zaś przy nieparzystym Q, (Q-1)/2 próbek i jedna próbka w środku okresu  $T_c/2$ .

Aby nie powtarzać tych samych obliczeń w każdym następnym okresie kluczowania, na samym początku należy obliczyć i zapamiętać wartości przebiegu trójkątnego w punktach podziału okresu kluczowania  $T_c$ , w których leżą próbki interpolowanego sygnału PCM: Dla parzystych Q:

$$s_{f,0} = 1, \ s_{f,1} = \frac{-4}{Q+1} + 1, \ s_{f,2} = \frac{-8}{Q+1} + 1, \dots, s_{f,(Q/2)} = \frac{-4(Q/2)}{Q+1} + 1, \ s_f\left(\frac{T_c}{2}\right) = -1$$

$$s_r\left(\frac{T_c}{2}\right) = -1, \ s_{r,(Q/2)+1} = \frac{4[(Q/2)+1]}{Q+1} - 3, \ s_{r,(Q/2)+2} = \frac{4[(Q/2)+2]}{Q+1} - 3, \dots, \quad (3.27)$$

$$s_{r,Q} = \frac{4Q}{Q+1} - 3, \ s_{r,(Q+1)} = 1,$$

Dla nieparzystych Q:

$$s_{f,0} = 1, \ s_{f,1} = \frac{-4}{Q+1} + 1, \ s_{f,2} = \frac{-8}{Q+1} + 1, \dots, s_{f,(Q-1)/2} = \frac{-4((Q-1)/2)}{Q+1} + 1, \ s_{f,(Q-1)/2)+1} = -1$$

$$s_{r,(Q-1)/2)+1} = -1, \ s_{r,(Q-1)/2)+2} = \frac{4[(Q-1)/2+2]}{Q+1} - 3, \ s_{r,(Q-1)/2)+3} = \frac{4[(Q-1)/2+3]}{Q+1} - 3, \dots,$$

$$s_{r,Q} = \frac{4Q}{Q+1} - 3, \quad s_{r,(Q+1)} = 1,$$
(3.28)

W celu znalezienia punktu przecięcia opadającej części  $s_f(t)$  przebiegu trójkątnego z przebiegiem aproksymowanym, metodą kilku kolejnych porównań należy znaleźć *i*-ty przedział otrzymany w wyniku podziału, w którym:

► dla nieparzystych Q: 
$$y_i(n) < s_{f,i}$$
 oraz  $y_{i+1}(n) > s_{f,i+1}$  dla  $0 \le i < \frac{Q-1}{2} + 1$   
(3.29)

► dla parzystych Q:  $y_i(n) < s_{f,i}$  oraz  $y_{i+1}(n) > s_{f,i+1}$  dla  $0 \le i < \frac{Q}{2} + 1$ 

Prowadząc prostą przez punkty  $\frac{iT_c}{Q+1}$ ,  $y_i(n)$ ; oraz  $\frac{(i+1)T_c}{Q+1}$ ,  $y_{i+1}(n)$ 

$$\frac{T_c}{Q+1} [y - y_i(n)] = [y_{i+1}(n) - y_i(n)] \left(\bar{t} - \frac{iT_c}{Q+1}\right)$$
(3.30)

0 1

i rozwiązując układ równań (3.25), (3.30), kolejno dla wszystkich wartości n = 0,1,2,..., (N - 1), otrzymujemy punkt przecięcia  $\overline{t_p}(n)$ .

$$\bar{t}_{p}(n) = \frac{T_{c}[1+iy_{i+1}(n)-(i+1)y_{i}(n)]}{4+[y_{i+1}(n)-y_{i}(n)](Q+1)}$$
(3.31)

Początek czasu trwania impulsu PWM z modulacją LADS w *n*-tym okresie kluczowania wynosi:

$$t_p(n) = nT_c + \bar{t}_p(n)$$
 (3.32)

W przedstawionym opisie wyznaczania czasu  $\bar{t}_p(n)$  może się jednak zdarzyć, że dla parzystej wartości Q i dużej wartości indeksu modulacji M nie znajdziemy takiego i, przy którym będą spełnione wszystkie trzy nierówności (3.29), co pokazano na rys. 3.9 (dla Q = 6). Spowodowane to jest tym, że prostoliniowy odcinek aproksymujący sygnał dyskretny przebiega przez wierzchołki dwóch sąsiednich wektorów próbek leżących w rozdzielnych obszarach: opadającej i narastającej części przebiegu trójkątnego.



Rys. 3.9. Modulacja LADD przy parzystej liczbie Q dodatkowych próbkach w okresie kluczowania Tc (przykład Q = 6) i dużej wartości indeksu modulacji M

W tym przypadku aproksymujący odcinek prostoliniowy prowadzimy przez punkty o współrzędnych:

$$\frac{(Q/2)T_c}{Q+1}, y_{(Q/2)}(n); \quad \text{oraz} \quad \frac{[(Q/2)+1]T_c}{Q+1}, y_{(Q/2)+1}(n):$$

$$\frac{T_c}{Q+1} \left[ y - y_{(Q/2)}(n) \right] = \left[ y_{(Q/2)+1}(n) - y_{(Q/2)}(n) \right] \left( \bar{t} - \frac{(Q/2)T_c}{Q+1} \right) \quad (3.33)$$

i rozwiązując układ równań (4.21) i (4.29), dla wszystkich wartości *n*, w których rozpatrywany przypadek ma miejsce, otrzymujemy graniczny punkt przecięcia  $\bar{t}_{pg}(n)$ .

$$\bar{t}_{pg}(n) = \frac{T_c \left\{ 1 + (Q/2) y_{(Q/2)+1}(n) - \left[ (Q/2) + 1 \right] y_{Q/2}(n) \right\}}{4 + \left[ y_{(Q/2)+1}(n) - y_{Q/2}(n) \right] (Q+1)}$$
(3.34)

$$\bar{t}_{pg}(n) = nT_c + \bar{t}_{pg}(n)$$
 (3.35)

W podobny sposób do opisanego wyżej, wyznaczymy koniec czasu trwania impulsu PWM w *n*-tym okresie kluczowania, wykorzystując tym razem równanie (3.26) opisujące narastającą część przebiegu trójkątnego  $s_r(nT_c + \bar{t})$ w drugim półokresie.

W kilku kolejnych porównaniach należy znaleźć j-ty przedział otrzymany w wyniku podziału, w którym

• dla nieparzystych Q:

$$y_j(n) > s_{f,j}$$
 oraz  $y_{j+1}(n) < s_{f,j+1}$  dla  $\frac{Q-1}{2} + 1 \le j < Q+1$ 

 $\sim$ 

► dla parzystych Q:  

$$y_j(n) > s_{f,j}$$
 oraz  $y_{j+1}(n) < s_{f,j+1}$  dla  $\frac{Q}{2} + 1 \le j < Q + 1$ 
  
(3.36)

Prowadząc prostą przez punkty

o współrzędnych: 
$$\frac{jT_c}{Q+1}$$
,  $y_j(n)$ ; oraz  $\frac{(j+1)T_c}{Q+1}$ ,  $y_{j+1}(n)$ :

$$\frac{T_c}{Q+1} [y - y_j(n)] = [y_{j+1}(n) - y_j(n)] \left(\bar{t} - \frac{jT_c}{Q+1}\right)$$
(3.37)

i rozwiązując układ równań (3.26), (3.37), kolejno dla wszystkich wartości *n* = 0,1,2,..., (*N* – 1), otrzymujemy punkt przecięcia  $\overline{t}_k(n)$ .

$$\bar{t}_{k}(n) = \frac{T_{c}\left[jy_{j+1}(n) - (j+1)y_{j}(n) - 3\right]}{\left[y_{j+1}(n) - y_{j}(n)\right](Q+1) - 4}$$
(3.38)

Koniec czasu trwania impulsu PWM z modulacją LADS w n-tym okresie kluczowania wynosi:

$$t_k(n) = nT_c + \bar{t}_k(n) \tag{3.39}$$

Podobnie jak to miało miejsce w półokresie z opadającą częścią przebiegu trójkątnego, również w tym przypadku może się zdarzyć, że dla parzystej wartości Q i dużej wartości in-deksu modulacji M nie znajdziemy takiego j, przy którym będą spełnione wszystkie trzy nie-równości (3.36), co również pokazuje rys. 3.9.

Wtedy, graniczny punkt przecięcia  $t_{kq}(n)$ . wyznaczamy z rozwiązania układu równań (3.33) i (3.26), otrzymując:

$$\bar{t}_{kg}(n) = \frac{T_c \left\{ (Q/2) y_{(Q/2)+1}(n) - [(Q/2)+1] y_{Q/2}(n) - 3 \right\}}{\left[ y_{(Q/2)+1}(n) - y_{Q/2}(n) \right] (Q+1) - 4}$$

$$t_{kg}(n) = nT_c + \bar{t}_{kg}(n)$$
(3.40)
(3.41)

oraz

#### 3.1.3. Rekwantyzacja. Algorytmy rekwantyzacji szumów

Analiza czasów trwania impulsów zmodulowanych musi być przeprowadzona z dużą dokładnością, aby zlinearyzowane modulacje LPWM z dużą dokładnością emulowały naturalne modulacje NPWM. Analizy spektralne (opisane w Dodatku A.1) pozwalają na porównanie wszystkich składowych widm częstotliwościowych, w różnych modulacjach PWM, na tle minimalnego poziomu szumów (ang. *noise floor*). Analiz takich nie można przeprowadzić np. w programie Matlab przy wykorzystaniu standardowej metody DFT.

Obliczone z dużą rozdzielczością bitową  $N_q$  czasy początków i końców trwania impulsu PWM w *n*-tych okresach kluczowania wymagałyby bardzo dużej rozdzielczości czasowej kwantyzatora na wyjściu modulatora, transformującego obliczone czasy na ciąg fizycznie generowanych impulsów LPWM, co z kolei wymagałoby zastosowania bardzo wysokich (nieakceptowalnych w praktyce) częstotliwości generatora taktującego kwantyzator. Zależności te zestawiono w tabeli 3.1, przy założeniu, że częstotliwość kluczowania  $F_c$  = 352,8 kHz, natomiast częstotliwość generatora taktującego określa zależność [35, 45]:

$$F_{clock}(b) = F_{c}(2^{b} - 1)$$
(3.42)

| Rozdzielczość bitowa<br>szerokości impulsów – N <sub>g</sub> | Częstotliwość generatora taktującego – F <sub>cuk</sub> |     |
|--------------------------------------------------------------|---------------------------------------------------------|-----|
| 24                                                           | 5919,00                                                 | GHz |
| 18                                                           | 93,9                                                    | GHz |
| 16                                                           | 23,12                                                   | GHz |
| 12                                                           | 1,445                                                   | GHz |
| 10                                                           | 360,9                                                   | MHz |
| 8                                                            | 89,83                                                   | MHz |
| 4                                                            | 5,29                                                    | MHz |

Tabela 3.1. Częstotliwości generatorów taktujących w zależności od rozdzielczości bitowej szerokości impulsów

Zastosowanie procesu rekwantyzacji pozwala z jednej strony na redukcję (obcięcie) długości słowa bitowego  $N_q$  obliczonej wartości położenia początków i końców czasu trwania impulsu PWM do mniejszej rozdzielczości  $N_{rq}$ , tym samym ograniczenie rozdzielczości kwantyzatora, ale z drugiej strony, pozwala na kształtowanie generowanych szumów rekwantyzacji. Rekwantyzowany sygnał cyfrowy, po przejściu przez układ kształtowania szumów kwantyzacji zachowuje niezmienione składowe widma sygnału PWM w paśmie podstawowym sygnału modulującego, zaś szum kwantyzacji zostaje przesunięty poza to pasmo, do zakresu wyższych częstotliwości odfiltrowywanych w procesie demodulacji.

Na rys. 3.10 przedstawiono schemat funkcjonalny rekursywnego układu kształtowania szumów kwantyzacji [33], [35], [44-47], zaś na rys. 3.11 przedstawiono jego model z kwantyzatorem traktowanym jako addytywne niezależne źródło szumu.



Rys. 3.10. Schemat funkcjonalny rekursywnego układu kształtowania szumów kwantyzacji [34]



Rys. 3.11. Model rekursywnego układu kształtowania szumów kwantyzacji z kwantyzatorem traktowanym jako addytywne źródło szumu [34]

W tabeli 3.2 zestawiono wszystkie zmienne występujące w przedstawionym modelu i ich reprezentacje w postaci odpowiadających im: gęstości widmowej mocy *S* (ang. *power spectral density*) i średniokwadratowej wartości, czyli mocy sygnału  $\sigma^2$ .

| Zmienna               | Reprezentacja           | Rodzaj zmiennej                                  |
|-----------------------|-------------------------|--------------------------------------------------|
| x (n)                 | $S_x$ , $\sigma_x^2$    | Niekwantyzowany sygnał wejściowy                 |
| <i>q</i> ( <i>n</i> ) | $S_q$ , $\sigma_q^2$    | Błąd kwantyzacji na wejściu                      |
| $e_{rq}(n)$           | $S_{rq}, \sigma_{rq}^2$ | Rekwantyzowane źródło szumów                     |
| $e_n(n)$              | $S_n$ , $\sigma_n^2$    | Sygnał błędu na wyjściu (związany z kwantyzacją) |
| $e_{nb}(n)$           | $S_{nb}, \sigma_{nb}^2$ | Szum kwantyzacji na wyjściu w paśmie podstawowym |

Tabela 3.2. Nazwy zmiennych w analizie układu kształtowania szumów kwantyzacji i ich reprezentacje

Zasadniczym uproszczeniem dla tego modelu jest przyjęcie założenia, że źródło szumów kwantyzacji jest stochastycznym stacjonarnym procesem, niezależnym od sygnału wejściowego. O ile słuszność tego założenia można kwestionować w przypadku ciągów jednobitowych, to w przypadku kwantyzacji dokładnych wielobitowych ciągów, założenie to jest uzasadnione i nie wnosi istotnych ograniczeń [44].

Zakładając, że X(z),  $D_q(z)$ ,  $E_{rq}(z)$ ,  $E_n(z)$  są Z- transformatami funkcji dyskretnych x(n),  $d_q(n)$ ,  $e_{rq}(n)$ ,  $e_n(n)$ , na podstawie modelu na rys. 3.11 otrzymujemy równania:

$$E_{rq}(z) = X(z) + E_n(z) - \left[X(z) - E_{rq}(z)H(z)\right]$$
(3.43)

$$D_q(z) = X(z) + E_n(z) = E_q(z) + \left[X(z) - E_{rq}(z)H(z)\right]$$
(3.44)

Z równania (3.43) otrzymujemy funkcję transmitancji szumów *NTF* (*z*) (ang. *noise transfer function*), jako stosunek *Z*-transformat sygnału błędu na wyjściu układu (związanego z rekwantyzacją) do rekwantyzowanego źródła szumów:

$$NTF(z) = \frac{E_n(z)}{E_{ra}(z)} = 1 - H(z)$$
(3.45)

Natomiast z równania (3.44) możemy wyznaczyć sygnał  $D_q(z)$  na wyjściu kwantyzatora:

$$D_{q}(z) = X(z) + E_{q}(z) \left[ 1 - H(z) \right]$$
(3.46)

Równanie (3.46) bezpośrednio wyjaśnia, że cyfrowy sygnał PWM na wyjściu kwantyzatora w paśmie podstawowym nie ulega żadnej zmianie, natomiast szum kwantyzacji w tym paśmie przenoszony jest zgodnie z funkcją transmitancji szumów *NTF* (*z*) (równanie 3.45).

Wykorzystując równanie (3.45), możemy wyznaczyć gęstość widmową sygnału błędu na wyjściu układu (szumu po rekwantyzacji), w zależności od gęstości widmowej rekwantyzowanego źródła szumów:

$$S_n(z) = |NTF(z)|^2 S_{rq}(z) \propto |NTF(z)|^2$$
 (3.47)

Układ kształtowania szumów kwantyzacji nie jest w stanie całkowicie zredukować mocy sygnału błędu na wyjściu (szumu po rekwantyzacji) związanej z ograniczoną długością  $b_{rq}$  słowa, czyli zmniejszoną rozdzielczością bitową.

W konsekwencji, w procesie kwantyzacji z rozdzielczością bitową  $N_{rq}$ , moc sygnału błędu  $\sigma_n^2$  na wyjściu układu (szumu po rekwantyzacji), w rzeczywistości przewyższa moc sygnału rekwantyzowanego źródła szumów $\sigma_{rq}^2$ . W przypadku realizacji funkcji *NTF*(*z*), rzędu *N*-tego, w postaci nierekursywnego filtru FIR definiuje się współczynnik wzmocnienia szumów kwantyzacji [33, 44]:

$$G_{N} = \frac{\sigma_{n}^{2}}{\sigma_{rq}^{2}} = \sum_{n=0}^{N-1} \left| ntf(n) \right|^{2} = 1 + \sum_{n=0}^{N-1} \left| h(n) \right|^{2} \ge 1$$
(3.48)

gdzie: ntf(n) i h(n) są odpowiednio odpowiedziami impulsowymi funkcji transmitancji szumów i filtru w pętli ujemnego sprzężenia zwrotnego w układzie kształtowania szumów kwantyzacji, przy czym:

$$ntf(n) = \begin{cases} 1 & (n = 0) \\ -h(n) & (n \in \{1, 2, ..., N - 1\}) \\ 0 & \text{w przeciwnym razie} \end{cases}$$
(3.49)

Tewksbury i Hallock udowodnili w swojej pracy [74], że optymalną funkcję transmitancji szumów *NTF*(*z*), *N*-tego rzędu, może zapewnić kaskadowe połączenie *N* cyfrowych układów różniczkujących, o wypadkowej transmitancji opisanej zależnością:

$$NTF(z) = 1 - H(z) = \left(\frac{z - 1}{z}\right)^{N}$$
 (3.50)

Transmitancja ta zapewnia największe nachylenie charakterystyki amplitudowej w dziedzinie częstotliwości, wnosząc przy tym największe tłumienie szumów kwantyzacji w paśmie podstawowym sygnału. Podstawiając do równania (3.50):  $z = e^{j2\pi (f/F_c)}$ , możemy wyznaczyć moduł funkcji transmitancji szumów *NTF(f)* w dziedzinie częstotliwości, zależnie od rzędu *N* tej funkcji.

$$NTF(f) = \left[2\sin\left(\frac{\pi f}{F_c}\right)\right]^N$$
(3.51)

Zależności te przedstawiono na rys. 3.12, dla N = 1,...,10 [35].



Rys. 3.12. Moduł funkcji transmitancji szumów NTF(f), zależnie od rzędu N tej funkcji [34]

Wszystkie charakterystyki przecinają się w punkcie o współrzędnych  $\{f = F_c/6, NTF = 1 \text{ (0DB)}\}$  tak, że redukcja szumów kwantyzacji występuje tylko dla  $f < F_c/6$ , natomiast w przedziale częstotliwości są one wzmacniane, osiągając wartość maksymalną równą 2<sup>N</sup>, dla  $f < F_c/2$ .

Przeprowadzona analiza pokazuje, że w procesie kształtowania szumów kwantyzacji możemy wpływać na zniekształcenia w paśmie podstawowym, jednak przy założeniu, że w paśmie tym występują tylko harmoniczne sygnału modulującego generowane w skutek odstępstwa modulacji LPWM od NPWM, natomiast nie występują żadne intermodulacyjne składowe widma (prążki boczne) dzięki zastosowaniu dostatecznie wysokiej częstotliwości kluczowania.

Transmitancję filtru H(z) możemy wyznaczyć na podstawie optymalnej funkcji transmitancji szumów NTF(z) (równanie 3.50). Rozważmy dwa przy-

kłady, gdy funkcja ta jest 5-tego lub 8-go rzędu, co zgodnie z charakterystykami na rys. 3.12, zapewnia tłumienie szumów kwantyzacji  $NTF_{\alpha}(z)$  w paśmie podstawowym o szerokości 20 kHz, co najmniej na poziomie, odpowiednio: – 60 dB lub – 90 dB.

a) Funkcja  $NTF_5(z)$  5-tego rzędu:

$$NTF_5(z) = 1 - H_5(z) = \left(\frac{z-1}{z}\right)^5 = a_0 + a_1 z^{-1} + a_2 z^{-2} + a_3 z^{-3} + a_4 z^{-4} + a_5 z^{-5}$$
(3.52)

Z porównania współczynników wielomianów po obu stronach równania (3.52), otrzymujemy:

$$a_0 = 1, a_1 = -5, a_2 = 10, a_3 = -10, a_4 = 5, a_5 = -1$$
 (3.52a)

b) Funkcja  $NTF_{8}(z)$  8-go rzędu:

$$NTF_{8}(z) = 1 - H_{8}(z) = \left(\frac{z-1}{z}\right)^{9} = a_{0} + a_{1}z^{-1} + a_{2}z^{-2} + a_{3}z^{-3} + a_{4}z^{-4} + (3.53) + a_{5}z^{-5} + a_{6}z^{-6} + a_{7}z^{-7} + a_{8}z^{-8}$$

Z porównania współczynników wielomianów po obu stronach równania (3.53), otrzymujemy:

$$a_0 = 1, a_1 = -8, a_2 = 28, a_3 = -56, a_4 = 70, a_5 = -56, a_6 = 28,$$
 (3.53a)  
 $a_7 = -8, a_8 = -1$ 

Z zależności (3.52 i 3.53) możemy również wydzielić transmitancje H(z) rekursywnych filtrów cyfrowych FIR, odpowiednio 5-tego i 8-go rzędu:

$$H_5(z) = -\left(a_1 z^{-1} + a_2 z^{-2} + a_3 z^{-3} + a_4 z^{-4} + a_5 z^{-5}\right)$$
(3.54)

$$H_{8}(z) = -\left(a_{1}z^{-1} + a_{2}z^{-2} + a_{3}z^{-3} + a_{4}z^{-4} + a_{5}z^{-5} + a_{6}z^{-6} + a_{7}z^{-7} + a_{8}z^{-8}\right)$$
(3.55)

## 3.2. Analiza spektralna sygnałów z modulacją LPWM w programie Matlab

Na rys. 3.13, 3.14, 3.15, 3.16 przedstawiono wyniki symulacji w programie Matlab (kody programu w dodatku A.4) widm częstotliwościowych wszystkich czterech rodzajów linearyzowanych modulacji: LADS, LADD, LBDS i LBDD. Dla każdej z tych modulacji, na kolejnych rysunkach przedstawiono pary przebiegów czasowych sygnałów różnicowych i sumacyjnych oraz ich widma częstotliwościowe, odpowiednio dla częstotliwości sygnału modulującego  $f_m$  = 9,8 kHz i  $f_m$  = 19,8 kHz, przy: Q = 0;  $F_c$  = 352,8 kHz; M = 0,95, z rozdzielczością  $df_m$  = 0,98 kHz.



Modulacja LADS

Rys. 3.13. Przebiegi czasowe i widmo sygnału różnicowego DM przy modulacji LADS dla:  $f_m$  = 9,8 kHz;  $f_m$  = 19,8 kHz;  $F_c$  = 352,8 kHz



#### Modulacja LADD

Rys. 3.14. Przebiegi czasowe i widmo sygnału różnicowego DM przy modulacji LADD dla:  $f_m = 9,8$  kHz;  $f_m = 19,8$  kHz;  $F_c = 352,8$  kHz



#### **Modulacja LBDS**

Rys. 3.15. Przebiegi czasowe i widmo sygnału różnicowego DM i sumacyjnego CM przy modulacji LBDS dla:  $f_m$  = 9,8 kHz;  $f_m$  = 19,8 kHz;  $F_c$  = 352,8 kHz



#### Modulacja LBDD

Rys. 3.16. Przebiegi czasowe i widmo sygnału różnicowego DM i sumacyjnego CM przy modulacji LBDD dla:  $f_m = 9,8$  kHz;  $f_m = 19,8$  kHz;  $F_c = 352,8$  kHz

#### 3.3. Współczynniki zawartości harmonicznych *THD*. Porównanie cyfrowych modulacji LPWM z naturalnymi modulacjami NPWM

Występujące w sygnale zmodulowanym LPWM wyższe harmoniczne sygnału modulującego, których amplitudy i fazy zależą od stosunku częstotliwości  $f_m / F_c$ , ilości Q wprowadzonych dodatkowych próbek w drugiej interpolacji, a także wartości indeksu modulacji M, są źródłem zniekształceń tego sygnału.

W celu porównanie wszystkich czterech linearyzowanych modulacji LPWM, dla każdej z nich wyznaczono rodziny charakterystyk współczynników zniekształceń nieliniowych *THD* sygnału różnicowego DM po demodulacji, jako stosunek średniokwadratowej wartości składowych widma zawartych w paśmie podstawowym w zakresie do 50 kHz do harmonicznej podstawowej sygnału modulującego. Zależności współczynników *THD* w funkcji częstotliwości  $f_m / F_c$  zostały wyznaczone każdorazowo na podstawie pełnej analizy spektralnej sygnałów na wyjściach różnicowych DM rozważanych modulacji LPWM, dla zadanego zestawu parametrów:  $f_m / F_c$ ; Q; M.

Na rys. 3.17 przedstawiono wyniki symulacji współczynników *THD* dla modulacji jednobrzegowych LADS i LBDS, a na rys. 3.18 dla modulacji dwubrzegowych LADD i LBDD.





Rys. 3.17. Zniekształcenia nieliniowe dla jednobrzegowych modulacji LADS oraz LBDS





Rys. 3.18. Zniekształcenia nieliniowe dla dwubrzegowych modulacji LADD oraz LBDD

Charakterystyki *THD* zostały wyznaczone w funkcji stosunku częstotliwości  $f_m / F_c$  (w 20-tu punktach), dla parametrów: Q = 0;1;2;3;...;7 oraz M = 0,95;0,5;0,1.

Dla 4  $\leq$  Q  $\leq$  7 charakterystyki *THD* =  $f_m / F_c$  prawie pokrywają się z charakterystykami dla Q = 3, dla wszystkich rodzajów modulacji LPWM i nie zostały naniesione na rysunkach.

Z analizy przedstawionych charakterystyk *THD* wynika, że modulacja LBDD charakteryzuje się najmniejszymi zniekształceniami nieliniowymi na wyjściu różnicowym w trybie DM (podobnie jak w przypadku naturalnych modulacji NPWM). Wprowadzenie nawet jednej dodatkowej próbki w drugiej interpolacji (Q = 1) zapewnia *THD* < 0,05% w paśmie podstawowym ( $f_m < 20$  kHz, przy  $F_c = 352,8$  kHz) i maksymalnej wartości indeksu modulacji M, także praktycznie, nie ma potrzeby przy modulacji LBDD stosowanie w drugiej interpolacji większej liczby dodatkowych próbek niż Q = 1.

## Hybrydowe konwertery cyfrowo-czasowe DTC w cyfrowych modulatorach LPWM dla akustycznych wzmacniaczy klasy D

# 4.1. Metody kwantyzacji cyfrowo-czasowej DTC stosowane w cyfrowych modulatorach DPWM

Po obliczeniu początku  $t_p(n)$  i końca  $t_k(n)$  czasu trwania impulsu LPWM w *n*-tym okresie kluczowania oraz rekwantyzacji, czyli redukcji rozdzielczości bitowej obliczonych wartości z  $N_q$  do  $N_{rq'}$ , należy fizycznie wygenerować przebieg impulsowy o szerokości  $\tau_{PW}$ , który steruje tranzystorami stopnia końcowego wzmacniacza klasy D:

$$\tau_{PW} = t_k(n) - t_p(n) \tag{4.1}$$

#### 4.1.1. Kwantyzacja cyfrowo-czasowa oparta na metodzie licznikowej

Najbardziej znaną metodą wyznaczania szerokości impulsu przy modulacjach cyfrowych DPWM jest metoda licznikowa oparta na liczniku i cyfrowym układzie porównującym [53-59], [61, 62]. Przy modulacji jednobrzegowej, licznik zliczający w naturalnym kodzie wprzód lub wstecz impulsy zegara o częstotliwości:

$$F_{CLK}(N_{rq}) = F_c \times 2^{N_{rq}} = K f_s \times 2^{N_{rq}}$$
(4.2)

gdzie:  $N_{rq}$  – rozdzielczość bitowa obliczonych wartości, a częstotliwość kluczowania  $F_c$  jest wynikiem *K*-krotnego zwiększenia częstotliwości próbkowania  $f_m$  w pierwszej interpolacji, pełni rolę kwantyzatora czasowego o narastającej lub opadającej charakterystyce schodkowej, odpowiadającej przebiegowi piłokształtnemu lub trójkątnemu przy modulacjach analogowych.

Jak pokazano na rys. 4.1, przy modulacji jednobrzegowej LADS szerokość impulsu  $\tau_{PW}$  w każdym *n*-tym okresie kluczowania  $T_c$  jest wynikiem porównania obliczonej wartości końca czasu trwania impulsu  $t_k$  (*n*-1) w (*n*-1)-ym okresie kluczowania  $T_c$  ze stanem licznika zliczającego w naturalnym kodzie wprzód impulsy zegara o częstotliwości określonej zależnością (4.2). Maksymalna szerokość impulsu  $\tau_{PW max}$  wystąpi przy maksymalnym stanie

Maksymalna szerokość impulsu  $\tau_{PW \max}$  wystąpi przy maksymalnym stanie 11.1 licznika:

$$\tau_{PW \max} = T_c = NT_{CLK}$$
, gdzie:  $N = (2^{N_{rq}} - 1),$  (4.3)

zapewniając minimalną rozdzielczość czasową wygenerowanego impulsu:

$$\frac{\Delta t_{\min}}{T_c} = \frac{T_{CLK}}{T_c} = \frac{1/F_{CLK}}{T_c} = \frac{1}{N}$$
(4.4)

Ponieważ w akustycznych wzmacniaczach klasy D stosowana jest dość wysoka częstotliwość kluczowania  $F_{cr}$  dlatego w bieżącym, *n*-tym okresie kluczowania, obliczana jest wartość końca czasu trwania impulsu  $t_k(n)$  (oraz rekwantyzacja szumów), natomiast układ wyznaczania szerokości impulsu przetwarza wartość końca czasu trwania  $t_k(n - 1)$  impulsu z poprzedniego, czyli (n - 1)-go okresu kluczowania  $T_c$ . Takie rozwiązanie wprowadza wprawdzie niewielkie opóźnienie wygenerowanego ciągu impulsów DPWM o czas  $t_d = T_c = 1/F_c$ , ale pozwala na obliczenie szerokości impulsu i jego fizyczne wygenerowanie w czasie rzeczywistym, dla pełnego zakresu indeksu modulacji.



Rys. 4.1. Kwantyzator cyfrowo-czasowy przy modulacji jednobrzegowej LADS

W podobny sposób można zrealizować kwantyzator czasowy modulatora dwubrzegowego LADD, wykorzystując w tym celu licznik rewersyjny.



Rys. 4.2. Kwantyzator cyfrowo-czasowy przy modulacji dwubrzegowej LADD

Jak wyjaśnia rys. 4.2, szerokość impulsu  $\tau_{PW}$  w każdym *n*-tym okresie kluczowania  $T_c$  jest wynikiem porównania obliczonej wartości początku czasu trwania impulsu  $t_p$  (n - 1) ze stanem licznika zliczającego wstecz i końca czasu trwania impulsu  $t_k$  (n - 1) ze stanem licznika zliczającego wprzód.

Przy modulacji dwubrzegowej częstotliwość zegara  $F_{\rm CLK}$  jest dwukrotnie wyższa niż przy modulacji jednobrzegowej:

$$F_{CLK}(N_{rg}) = F_c \times 2^{N_{rq}+1}$$
(4.5)

Również w tym przypadku wystąpi opóźnienie wygenerowanego ciągu impulsów LPWM o czas  $t_d = T_c = 1/F_c$ , ale dzięki temu, wszystkie algorytmy obliczeniowe mogą być zrealizowane w czasie rzeczywistym dla pełnego zakresu indeksu modulacji  $0 \le M \le 1$ . Należy przy tym nadmienić, że konieczność wyznaczenia zarówno początku, jak i końca czasu trwania impulsu, zwiększa prawie dwukrotnie wymagania dotyczące szybkości obliczeń w czasie rzeczywistym, w porównaniu do modulacji LADS.

Z porównania rys. 4.1 i 4.5 widzimy, że przy równych okresach kluczowania  $T_c$ , okres impulsów zegara  $T_{CLK}$  przy modulacji LADD jest dwa razy krótszy, zapewniając tym samym dwa razy większą rozdzielczość czaso-
wą, równą  $T_{CLK}$  /2, zarówno przy wyznaczaniu początku  $t_p$  (n), jak i końca  $t_k$  (n) czasu trwania impulsu. Do przełączania kierunkiem zliczenia licznika rewersyjnego można wykorzystać przerzutnik RS, który ustawiany jest w stan 1 (liczenie wprzód) po zdekodowaniu stanu 00..0 licznika, natomiast w stan 0 (liczenie wstecz), po zdekodowaniu stanu FF..F. Ponieważ przy zliczaniu wstecz i wprzód powtarzają się te same stany licznika, dlatego komparatory cyfrowe, porównujące aktualne stany licznika z obliczonymi, muszą być uaktywniane sygnałem ENABLE = Q przerzutnika sterującego kierunkiem zliczania licznika rewersyjnego.

Metody licznikowe są niezbyt skomplikowane układowo, charakteryzują się idealną liniowością charakterystyki przetwarzania cyfrowej wartości szerokości impulsu na wartość w dziedzinie czasu, jednak ich główną wadą jest konieczność stosowania bardzo wysokich (nieakceptowalnych w praktyce) częstotliwości generatora taktującego kwantyzator, co wiąże się z dużym poborem mocy przez cały układ i z tego powodu, jak pokazano w tabeli 3.1 w rozdz. 3, przy rozdzielczościach powyżej 10 bitów, czyste metody licznikowe nie są praktycznie stosowane w akustycznych wzmacniaczach klasy D.

## 4.1.2. Kwantyzacja cyfrowo-czasowa w oparciu o programowaną linię opóźniającą z odczepami PTDL

Alternatywnym rozwiązaniem kwantyzatora cyfrowo-czasowego stosowanego w cyfrowych modulatorach DPWM, które w przeciwieństwie do metody licznikowej nie wymaga stosowania bardzo wysokich częstotliwości zegara, jest układ zrealizowany w oparciu o linię opóźniającą z odczepami PTDL [53-59].

Na rys. 4.3a przedstawiono ogólny schemat blokowy takiego układu, a na rys. 4.3b przebiegi czasowe w układzie, wyjaśniające jego zasadę działania. Najważniejszą właściwością tego układu, wyróżniającą go od modulatora licznikowego, jest niska częstotliwość zegara sterującego, równa częstotliwości kluczowania ( $F_{CLK} = F_c$ ).

Dyskretną charakterystykę schodkową kwantyzatora czasowego, uzyskiwaną w metodzie licznikowej w postaci kolejnych stanów licznika zliczającego wprzód lub wstecz impulsy zegara o dużej częstotliwości, w układzie na rys. 4.3a realizuje się w odmienny sposób, przy pomocy linii opóźniającej z odczepami i dokonaniu wyboru skwantowanej szerokości impulsu, równej opóźnieniu czasowemu impulsu wejściowego na wyselekcjonowanym odczepie linii opóźniającej. Kaskadowe połączenia  $N = (2^{N_{rq}} - 1)$ identycznych komórek opóźniających, z których każda opóźnia przenoszony impuls o czas:

$$t_d = \frac{T_c}{2^{N_{rq}}} \tag{4.6}$$

pozwala na realizację charakterystyki kwantyzatora czasowego o rozdzielczości czasowej równej opóźnieniu pojedynczej komórki.



Rys. 4.3. Implementacja kwantyzatora cyfrowo-czasowego DTC w oparciu o programowaną linię opóźniającą z odczepami PTDL: a) Architektura układu; b) Przebiegi czasowe w układzie

Na rys. 4.3b przedstawiono przebiegi czasowe na wszystkich odczepach linii opóźniającej utworzonej dla przejrzystości tylko z siedmiu komórek opóźniających. Stan zerowy kwantyzatora czasowego odpowiada wejściu linii opóźniającej, stąd potrzebna liczba komórek opóźniających wynosi  $N = (2^{N_{rq}} - 1)$ , a nie  $N = 2^{N_{rq}}$ .

Wyboru skwantowanej szerokości impulsu, równej opóźnieniu czasowemu impulsu wejściowego na wyselekcjonowanym odczepie linii opóźniającej, dokonuje się przy pomocy multipleksera o  $2^{N_{rq}}$  wejściach i 1 wyjściu. Wyselekcjonowane wejście multipleksera, w przypadku modulatora jednobrzegowego LADS, adresowane jest obliczoną w poprzednim okresie kluczowania wartością cyfrową końca czasu trwania  $t_k$  (n - 1) impulsu DPWM.

Jak widać na rys. 4.3a, zmodulowany przebieg DPWM otrzymujemy na wyjściu Q przerzutnika D wyzwalanego dodatnim zboczem. Synchroniczne przepisanie 1 z wejścia D na wyjście Q dodatnim zboczem impulsu zegara (o okresie kluczowania  $T_c$ ) ustawia Q = 1 (generowanie początku czasu trwania impulsu DPWM), zaś podanie na wejście asynchroniczne RESET wyselekcjonowanego impulsu z wyjścia multipleksera ustawia Q = 0 (generuje koniec czasu trwania impulsu DPWM, praktycznie na samym początku dodatniego zbocza impulsu sterującego).

Dla uzyskania liniowej charakterystyki kwantyzatora konieczne jest, aby każda komórka opóźniająca wnosiła taki sam kwant opóźniania (zależność 4.5) oraz aby opóźnienia na poszczególnych wejściach multipleksera były identyczne z opóźnieniami na odpowiadających im odczepach linii opóźniającej.

Praktyczna realizacja opisanego modulatora z linią opóźniającą, nawet przy niezbyt wygórowanych wymaganiach dotyczących rozdzielczości czasowej kwantyzatora (wyrażonej rozdzielczością bitową  $N_{rr}$ ), może być bardzo trudna, a nawet nierealna. Wiąże się to z koniecznością zastosowania bardzo dużej ilości (2<sup>brq</sup> – 1) identycznych komórek opóźniających, jak również problem realizacji multipleksera o tak dużej ilości wejść. Duża liczba komórek opóźniających powoduje niesymetrię ich rozmieszczenia względem wejść multipleksera, posiadającego także duże wymiary, w skutek czego każda ścieżka łacząca odczep linii opóźniającej z odpowiadającym mu wejściem multipleksera wprowadza dodatkowe i różne opóźnienie, zależne od jej długości i geometrii, a także wszelkiego rodzaju pojemności pasożytniczych pomiędzy rozważaną ścieżką a innymi elementami układu. Istnieje wiele innych czynników, takich jak: wszelkie niedopasowania powstające w procesach technologicznych przy wytwarzaniu komórek opóźniających, niestałość napięć zasilających, zmiana temperatury pracy układu, niedopasowania pojemności w węzłach wyjściowych komórek, a także niedopasowania prądów przeładowujących te pojemności, będących przyczyną niejednakowych opóźnień wnoszonych przez poszczególne komórki. Ponadto, przy przenoszeniu przebiegów impulsowych przez elementy opóźniające, realizowanych w postaci różnych modyfikacji bramek CMOS, opóźniania zboczy narastających i opadających są różne, wskutek czego przenoszony przebieg impulsowy ulega znacznej degradacji, szczególnie przy długim łańcuchu elementów opóźniających (występują nie tylko różne opóźnienia na poszczególnych odczepach linii, ale przebiegi impulsowe różnią się także kształtem). Wszystkie wymienione wyżej czynniki powodują, że charakterystyka kwantyzatora czasowego zawierającego dużą liczbę komórek opóźniających jest nierównomierna (lokalnie może być nawet niemonotoniczna), będąc źródłem zniekształceń przetwarzanego sygnału cyfrowego w postaci wygenerowania impulsu DPWM o szerokości różniącej się od wartości obliczonej.

## 4.2. Hybrydowy konwerter cyfrowo-czasowy DTC w dwubrzegowych modulatorach linearyzowanych LADD

Hybrydowe modulatory szerokości impulsów DPWM wykorzystują obydwie, wcześniej omówione metody kwantyzacji cyfrowo-czasowej DTC i zostały opisane w wielu pracach [53-59] dotyczących jednobrzegowych modulato-rów DPWM.

Każda z obliczonych wartości binarnych początków  $t_p(n)$  i końców  $t_k(n)$ czasów trwania impulsów zmodulowanych  $\tau(n)$ , wyrażona w słowie o długości  $N_{ra}$  bitów, dzielona jest na dwie części. Pierwsza, zawierająca starsze bity MSB:  $d(N_{rq} - 1 : m)$ , przetwarzana jest metodą licznikową, zaś druga, zawierająca młodsze bity LSB: d(m - 1: 0), przetwarzana jest metodą z linią opóźniającą z odczepami. Ponieważ charakterystyka statyczna kwantyzatora czasowego w metodzie licznikowej jest idealnie liniowa, to podziału należy tak dokonać, aby grupa starszych bitów MSB zawierała maksymalną liczbę bitów  $(N_{ra}-m)_{max}$ , przy której częstotliwość zegara  $F_{CLK}$  jest jeszcze akceptowalna, a która będzie niższa 2<sup>m</sup> razy niż w przypadku, gdyby modulator LPWM był realizowany w całości w oparciu o metodę licznikową. Z kolei niewielka liczba *m* pozostałych młodszych bitów LSB sprawia, że realizacja drugiej części modulatora z linią opóźniającą z odczepami jest prosta, bowiem taki modulator zawiera niezbyt dużą liczbę komórek opóźniających, multiplekser o niewielkiej liczbie wejść, dzięki czemu charakterystyka kwantyzatora czasowego będzie monotoniczna, utworzona prawie z równomiernych schodków.

Przykładowo, realizacja modulatora LADD o rozdzielczości  $N_{rq}$  = 10 bitów (przy częstotliwości kluczowania  $F_c$  = 384 kHz) byłaby bardzo trudna przy pomocy samej metody licznikowej, wymagałaby bowiem zastosowania zegara o częstotliwości  $F_{clk}$  = 786,432 MHz.

Wykonanie modulatora metodą hybrydową, przy przetwarzaniu 6 starszych bitów MSB metodą licznikową i 4 młodszych bitów LSB metodą z linią opóźniającą z odczepami, częstotliwość zegara  $F_{\rm CLK}$  = 49,152 MHz, a liczba elementów opóźniających wynosi 16, co pozwala na łatwą implementację takiego modulatora we współczesnych technologiach CMOS.

Na rys. 4.4a przedstawiono architekturę hybrydowego konwertera cyfrowo-czasowego DTC w dwubrzegowych modulatorach linearyzowanych LADD, a na rys. 4.4b – sygnały sterujące i przebiegi czasowe w układzie wyjaśniające jego działanie, przy czym dla przejrzystości rysunku przyjęto, że linia opóźniająca utworzona jest z siedmiu komórek opóźniających. Układ zawiera w sobie bloki funkcjonalne wykorzystywane w obu metodach, które wcześniej były przedstawione i objaśnione na rys. 4.2 i 4.3.

Zmodulowany impuls DPWM generowany jest na wyjściu Q przerzutnika RS, który ustawiany jest w stan Q = 1 impulsem wyselekcjonowanym przez LSB bity d(m - 1: 0) czasu początku trwania impulsu  $t_p(n - 1)$  na wyjściu multipleksera. Linia opóźniająca przenosi impuls generowany na wyjściu dekodera stanu 00..0 licznika zliczającego wstecz, który na samym początku pierwszej połowy okresu T<sub>c</sub> został załadowany do cyfrowej wartości początku czasu trwania impulsu  $t_p(n-1)$ , określonej przez MSB  $d(b_{ra})$ - 1 : *m*). Generacja początku czasu trwania impulsu DPWM następuje po sumarycznym czasie:  $t_p(n-1) = t_{p1} + t_{p2}$ . Podobnie generowany jest koniec czasu trwania impulsu DPWM:  $t_k(n - 1) = t_k + t_{k2}$ . Przerzutnik RS ustawiany jest w stan Q = 0 impulsem wyselekcjonowanym przez LSB d(m - 1: 0)czasu końca impulsu  $t_k$  (n - 1) na wyjściu multipleksera. Linia opóźniająca przenosi impuls generowany na wyjściu dekodera stanu 00..0 licznika zliczającego wstecz, który na samym początku drugiej połowy okresu  $T_c$  został załadowany do cyfrowej wartości czasu końca impulsu  $t_k(n - 1)$ , określonej przez starsze bity  $d(b_{rq} - 1 : m)$ .



Rys. 4.4. Hybrydowy konwerter cyfrowo-czasowych DTC w dwubrzegowych modulatorach linearyzowanych LADD: a) Architektura układu; b) Przebiegi czasowe sterujące układem

Czas trwania impulsu na wyjściu dekodera wynosi  $T_{CLK}/2$  i taki impuls z wyjścia dekodera stanu 00..0 jest przenoszony przez linię opóźniającą w każdym półokresie kluczowania  $T_c$ .

W celu rozróżnienia pierwszej i drugiej połowy okresu  $T_c$  służy przerzutnik RS,  $T_c/2$  (ustawiany w stan 1 sygnałem SET $T_c$ , a w stan 0 sygnałem SET  $T_c/2$ ), którego wyjścia Q i  $\overline{Q}$  bramkują odpowiednio sygnał ustawiający S i zerujący R przerzutnika wyjściowego.

## 4.3. Projekt hybrydowego konwertera cyfrowo-czasowego DTC w dwubrzegowych modulatorach linearyzowanych LADD z pętlą synchronizacji opóźnienia DLL

Zdecydowanie bardziej liniową charakterystykę kwantyzatora czasowego, ze znacznie większą równomiernością schodków, można uzyskać przez zastąpienie linii opóźniającej działającej w systemie bez sprzężenia zwrotnego, jak w przedstawionym układzie na rys. 4.4a, układem ze sprzężeniem zwrotnym w postaci pętli synchronizacji opóźnienia DLL (*Delay-Locked Loop*). W kwantyzatorze czasowym, zbudowanym w oparciu o pętlę synchronizacji DLL, sumaryczne opóźnienie wnoszone przez kaskadę  $2^{N_{rq}}$  komórek o regulowanym opóźnieniu (a nie  $2^{N_{rq}} - 1$ , jak z linią opóźniającą bez sprzężenia zwrotnego) jest równe okresowi kluczowania  $T_c$ . Na wyjściu pętli DLL otrzymujemy przebieg zegara opóźniony dokładnie o 1 okres, a ujemne sprzężenie zwrotne w pętli utrzymuje zgodność faz przebiegów zegara na wejściu i wyjściu pętli. Dzięki temu kwant opóźnienia pojedynczej komórki opóźniającej jest stabilizowany i nie zmienia się wraz ze zmianami czynników destabilizujących, wymienionych wcześniej w porozdz. 4.1.2.

Przy budowie kwantyzatorów o niewielkich rozdzielczościach bitowych, znajdujących praktyczne zastosowanie w modulatorach hybrydowych, ze względu na stosunkowo małą ilość komórek opóźniających tworzących linię opóźniającą, pojedyncza komórka może być nieco bardziej rozbudowana. W szczególności w komórce takiej można wprowadzić zgrubną i dokładną regulację czasów opóźnienia, stabilizować opóźnienie zbocza narastającego i opadającego zegara w każdej komórce [50-52], co zapobiega deformacjom przebiegu czasowego zegara na wszystkich odczepach linii opóźniającej. Kwantyzator czasowy zbudowany w oparciu o takie komórki, przy niezbyt dużych rozdzielczościach bitowych, posiada wystarczającą dla celów praktycznych liniową charakterystykę przetwarzania cyfrowej wartości szerokości impulsu na fizycznie wygenerowaną szerokość impulsu DPWM (równomierna charakterystyka schodkowa).

Wykorzystując opisane wyżej koncepcje hybrydowych modulatorów, opracowano najbardziej złożony modulator dla wzmacniacza klasy BD częstotliwości akustycznych z dwubrzegową, różnicową modulacją cyfrową LDBD [47, 48], [50, 51].

W porównaniu do opisanych wcześniej modulatorów dla wzmacniaczy w klasie AD, modulator taki jest najtrudniejszy do realizacji w czasie rzeczywistym, zarówno ze względu na wymagania dotyczące nakładów obliczeniowych dla wyznaczenia początków i końców czasów trwania impulsów DPWM, jak i jego sprzętowej implementacji. Wiąże się to z koniecznością wygenerowania oddzielnych dwóch przebiegów zmodulowanych LADD sterujących lewą i prawą gałęzią mostka H stopnia końcowego wzmacniacza klasy BD, odpowiednio dla prostego i odwróconego w fazie o 180° sygnału modulującego.

W celu złagodzenia wymagań dotyczących realizacji w czasie rzeczywistym cyfrowego modulatora dla wzmacniacza klasy BD z optymalną, dwubrzegową modulacją różnicową LBDD można obniżyć częstotliwość kluczowania  $F_c$ , bowiem widmo częstotliwościowe sygnału zmodulowanego przy tej modulacji nie zawiera składowych nieparzystych częstotliwości kluczowania i ich prążków bocznych, co jest równoważne podwojeniu częstotliwości próbkowania.

Implementacja hybrydowego modulatora z cyfrową modulacją LBDD o rozdzielczości 12-bitowej z częstotliwością kluczowania  $F_c = 176,4$  kHz wymaga zastosowania zegara o częstotliwości  $F_{CLK} = 80$  MHz, przy przetwarzaniu 9-MSB bitów metodą licznikową i 3LSB bitów metodą wykorzystującą linię opóźniającą lub zegara o częstotliwości  $F_{CLK} = 40$  MHz, przy przetwarzaniu 8-MSB bitów metodą licznikową i 4-LSB bitów metodą wykorzystującą linię opóźniającą.

W badaniach przyjęto częstotliwość kluczowania równą pięciokrotnej wartości częstotliwości próbkowania sygnału analogowego, tj.  $F_c = 5 \times f_s = 5 \times 44,1 \text{ kHz} = 220,5 \text{ kHz}$ , co w procesie interpolacji wymaga pięciokrotnego nadpróbkowania wejściowego sygnału PCM.

Dla tej częstotliwości kluczowania  $F_c$  = 220,5 kHz został opracowany modulator hybrydowy z cyfrową modulacją LBDD o rozdzielczości 12-bitowej, przetwarzający 8-MSB bitów metodą licznikową i 4-LSB bitów metodą wykorzystującą linię opóźniającą. Przy takiej implementacji modulatora, wymagana częstotliwość zegara wynosi  $F_{CLK}$  = 56,2275 MHz. W celu zwiększenia dokładności 4-bitowego kwantyzatora z linią opóźniającą, zastosowano układ z pętlą synchronizacji opóźnienia DLL, przy czym ta sama pętla DLL została wykorzystana w obydwu modulatorach sterujących lewą i prawą gałęzią mostka H stopnia końcowego wzmacniacza, ale dwoma, niezależnie programowanymi multiplekserami selekcjonującymi impulsy wyjściowe. Dla zapewnienia liniowości charakterystyki kwantyzatora z linią opóźniającą, zastosowano analogową pętlę DLL z podwójną, tj. zgrubną i dokładną regulacją opóźnienia. Linia opóźniająca składa się z 16 identycznych segmentów, utworzonych przez pojedyncze elementy opóźniające o zgrubnym i dokładnym opóźnieniu, sterowane przez dwie niezależne pętle sprzężenia zwrotnego. Ponadto w każdej pętli sprzężenia zwrotnego, tj. zarówno sterowania zgrubnego, jak i dokładnego, zastosowano niezależną synchronizację zboczy narastających i opadających przenoszonych impulsów przez linię opóźniającą.

W stanie synchronizacji, pętla DLL utrzymuje stałe opóźnienie pomiędzy impulsami na jej wejściu i wyjściu, równe jednemu okresowi  $T_{CLK} = 1/F_{CLK} = 1/56,2275$  MHz = 17,7849 nsec. Przy szesnastu identycznych elementach opóźniających, wymagane średnie opóźnienie, przypadające na jeden element, wynosi  $t_d = 17,7849/16 = 1,1115$  nsec.

Przetwarzanie ośmiu starszych bitów MSB metodą licznikową, oddzielnie dla lewej i prawej gałęzi mostka H stopnia końcowego, dokonywane jest w identyczny sposób, jak we wcześniej opisanym hybrydowym konwerterze cyfrowo-czasowych DTC w podrozdz. 4.2, przy częstotliwości zegara  $F_{_{CLK}}$  = 56,2275 MHz. Architekturę tej części układu, wraz z oznaczeniem blokowym układu przedstawiono na rys. 4.5.

Pełny schemat blokowy opracowanego hybrydowego konwertera cyfrowo-czasowego DTC w dwubrzegowych modulatorach linearyzowanych LADD z pętlą synchronizacji opóźnienia DLL przedstawiono na rys. 4.6.

W celu wyjaśnienia zasady generacji początku i końca czasu trwania impulsu w układzie, na rys. 4.7 a przedstawiono przebiegi czasowe w jednej gałęzi sterującej modulatora LBDD z rys. 4.6, a na rys. 4.7.b przedstawiono sekwencję przenoszonych impulsów w linii opóźniającej na wejściach multipleksera, gdy sygnał wyboru multipleksera Enable = 1.

W układzie na rys. 4.6 indeksem L oznaczono bloki, wejścia, wyjścia i sygnały wchodzące w skład modulatora sterującego lewą częścią mostka H stopnia końcowego, zaś indeksem R, sterującego prawą częścią tego mostka. Część wspólna, wykorzystywana przez modulatory, sterujące zarówno lewą, jak i prawą część mostka H, zawiera pętlę synchronizacji opóźnienia DLL z linią opóźniającą i przerzutnik RS sterowany impulsami SET  $T_c$  oraz SET  $T_c/2$ , generujący symetryczny przebieg prostokątny o okresie  $T_c$  i współczynniku wypełnienia równym 1/2.



Rys. 4.5. Układ przetwarzający 8 starszych bitów MSB:  $d(b_{rq}-1:m)$ : a) Architektura układu; b) Oznaczenie blokowe układu



Rys. 4.6. Architektura hybrydowego konwertera cyfrowo-czasowego DTC w dwubrzegowych modulatorach linearyzowanych LADD z pętlą synchronizacji opóźnienia DLL

Zasada generacji początku i końca czasu trwania impulsu DPWM zostanie wyjaśniona w oparciu o przebiegi czasowe w modulatorze sterującym lewą częścią mostka H stopnia końcowego. Pojawiający się impuls, o czasie trwanie  $T_{CLK}/2$ , generowany na wyjściu dekodera stanu 00..0 licznika zliczającego wstecz, który na samym początku pierwszej połowy okresu  $T_c$  został naładowany do cyfrowej wartości początku czasu trwanie impulsu  $t_p$  (n - 1) określonej przez starsze bity MSB, narastającym zboczem wpisuje "1" do przerzutnika D, zaś wysoki poziom na wyjściu tego przerzutnika uaktywnia multiplekser (Enable = 1). Na wyjściu multipleksera pojawia się impuls, wyselekcjonowany przez 4 młodsze bity LSB d (m - 1:0) początku czasu trwanie impulsu  $t_p$  (n - 1), który ustawia Q = 1 wyjściowego przerzutnika RS, pod warunkiem, że półokres kluczowania jest dodatni ( $T_c = 1$ ).

Równocześnie zerowany jest przerzutnik D i multiplekser przestaje być aktywny (Enable = 0). Generacja początku czasu trwania impulsu DPWM następuje po sumarycznym czasie:  $t_p(n - 1) = t_{p1} + t_{p2}$ .



W podobny sposób generowany jest koniec czasu trwania impulsu DPWM.

Rys. 4.7. Przebiegi czasowe w jednej gałęzi sterującej hybrydowego modulatora LBDD z rys. 4.6: a) Przebiegi czasowe sterujące układem; b) Sekwencja przenoszonych impulsów w linii opóźniającej na wejściach multipleksera, przy sygnale wyboru multipleksera, Enable = 1

Przerzutnik D ustawiany jest w stan Q = 1 impulsem generowanym na wyjściu dekodera stanu 00..0 licznika zliczającego wstecz, który na samym początku drugiej połowy okresu  $T_c$  został naładowany do cyfrowej wartości końca czasu trwania impulsu  $t_k$  (n - 1), określonej przez starsze bity MSB. Następuje uaktywnienie multipleksera, na jego wyjściu pojawia się impuls wyselekcjonowany przez 4 młodsze bity d(m - 1:0) cyfrowej wartości końca czasu trwania impulsu  $t_p$  (n - 1), który ustawia Q = 0 wyjściowego przerzutnika RS, pod warunkiem, że półokres kluczowania jest dodatni ( $T_c = 0$ ). Równocześnie zerowany jest przerzutnik D i multiplekser przestaje być aktywny (Enable = 0). Generacja końca czasu trwania impulsu DPWM następuje po sumarycznym czasie:  $t_k$  (n - 1) =  $t_{k1} + t_{k2}$ .

Na rys. 4.8 przedstawiono schemat blokowy pętli synchronizacji opóźnienia DLL ze zgrubnym i precyzyjnym sterowaniem opóźnienia. Zawiera dwie linie opóźniające: zgrubną i dokładną, wraz z niezależnymi pętlami ujemnego sprzężenia zwrotnego. W każdej pętli, na wyjściu detektora fazy wytwarzane jest napięcia przestrajające elementy składowe linii opóźniających sterowanych napięciem (VCDL) (*ang. Voltage-Controlled Delay Lines*): zgrubnej lub precyzyjnej (*ang. coarse and fine* ) [19]. Całkowite opóźnienie linii opóźniającej jest rozłożone równomiernie na 16 odczepów elementów linii opóźniającej, jednocześnie każdy z nich zawiera zgrubne i precyzyjne elementy VCDL.



Rys. 4.8. Schemat blokowy pętli synchronizacji opóźnienia DLL ze zgrubnym i precyzyjnym sterowaniem opóźnienia

Całkowite opóźnienie linii opóźniającej powinno być równe jednemu okresowi  $T_{\rm CLK}$ , co daje 16 równomiernie opóźnionych faz zegara odniesienia na każdym odczepie linii opóźniającej.

$$T_{CLK} = N(t_{dc1} + t_{df1})$$
(4.7)

Gdzie:  $t_{dcl}$ ,  $t_{dfl}$  są opóźnieniami pojedynczych elementów, odpowiednio zgrubnej i precyzyjnej linii VCDL, N = 16 jest liczbą elementów składowych każdej linii VCDL.

Linia opóźniająca przenosi impulsy zegara  $T_{CLR^{2}}$  natomiast na wejścia adresowe multiplekserów podawane są 4 młodsze bity LSB d(3:0) obliczonych wartości binarnych początków  $t_{p}$  (n - 1) i końców  $t_{k}$  (n - 1) czasów trwania impulsów zmodulowanych  $\tau(n - 1)$ , przy czym, zgodnie z sekwencją zapisywania danych do rejestrów A, B, C w układzie przetwarzającym 8 starszych bitów MSB: d $(N_{rq} - 1:m)$ , przedstawionym na rys. 4.5, na samym początku pierwszej połowy okresu  $T_{c}$  na wejścia adresowe multiplekserów podawane są wartości binarne obliczonych czasów początków  $t_{p}$  (n - 1) impulsu LADD, natomiast na samym początku drugiej połowy okresu  $T_{c}$  na wejścia adresowe multiplekserów podawane są wartości binarne obliczonych czasów końców  $t_{k}$  (n - 1) impulsu LADD (rejestry przeprogramowywane dwa razy w czasie każdego okresu kluczowania  $T_{c}$ ).

Architektura oraz implementacja przedstawionej na rys. 4.8 pętli synchronizacji opóźnienia DLL ze zgrubnym i precyzyjnym sterowaniem opóźnienia została przedstawiona w pracach [47, 48], [50-52]. Układ został zaprojektowany w technologii UMC180 nm CMOS. Wykorzystując metody symulacyjne w programie CADENCE, w pracach tych wyznaczono charakterystyki przestrajania pętli synchronizacji opóźnienia DLL ze zgrubnym i precyzyjnym sterowaniem opóźnienia oraz przeprowadzono analizy Monte-Carlo w różnych granicznych warunkach procesu, napięcia i temperatury PVT (*ang. Process,Voltage and Temperature corners*) w celu weryfikacji działania układu po wyprodukowaniu układu w zastosowanej technologii.

Proponowany 11-bitowy modulator LBDD PWM zapewnia *SNR* = 120 dB oraz *THD* sygnału wyjściowego poniżej 0,1% w paśmie podstawowym audio, przy częstotliwości przełączania  $F_c$  = 352,8 MHz i częstotliwości generatora zegara  $F_{CLK}$  = 90,3 MHz oraz indeksie modulacji *M* = 0,95.

## Implementacja hybrydowego modulatora LBDD PWM w oparciu o mikrokontroler STM32 i programowaną linię opóźniającą (PTDL)

#### 5.1. Ogólna koncepcja hybrydowego modulatora LBDD PWM

Jak już wspomniano w rozdz. 4, implementacja modulatora LBDD charakteryzuje się największym stopniem skomplikowania w porównaniu do innych modulatorów LPWM, a ponadto jest znacznie trudniejsza do realizacji ze względu na wymagania dotyczące nakładów obliczeniowych w czasie rzeczywistym dla wyznaczenia początków i końców czasów trwania impulsów zmodulowanych  $\tau(n)$ . W modulatorze tym konieczne jest bowiem wygenerowanie oddzielnych przebiegów zmodulowanych LADD<sub>L</sub> oraz LADD<sub>R</sub> sterujących lewą i prawą gałęzią mostka H stopnia końcowego wzmacniacza klasy BD, odpowiednio dla prostego i odwróconego w fazie o 180° sygnału modulującego.

Przedstawiona na rys. 5.1 architektura hybrydowego, dwubrzegowego modulatora LBDD PWM dla wzmacniacza klasy BD sygnałów akustycznych jest tym trudniejsza do praktycznej implementacji, im większa jest rozdzielczość bitowa modulatora, wyrażona w  $N_{rq}(n)$  bitach.

Wiąże się to z koniecznością stosowania z jednej strony coraz to wyższych częstotliwości  $F_{CLK}$  generatora taktującego, a z drugiej strony niejednakowe opóźnienia wnoszone przez różne ścieżki sygnałowe, i to zarówno w pierwszej części układu przetwarzającego starsze bity MSB ( $N_{rq} - 1 : m$ ) metodą licznikową, jak i w drugiej części układu przetwarzającego młodsze bity LSB d (m - 1 : 0) metodą wykorzystującą pętlę synchronizacji opóźnienia DLL, mogą być źródłem błędów przetwarzania, większych niż wynikałoby to z zakładanej rozdzielczości bitowej  $N_{rq}$ . Źródłem dodatkowych błędów przetwarzania może być również pewna asynchroniczność pracy obu podukładów przetwarzających odpowiednio młodsze i starsze bity obliczonych początków  $t_p(n)$  i końców  $t_k(n)$  czasów trwania zmodulowanych impulsów LADDL oraz LADDR, która wywołana jest także niejednakowymi opóźnieniami przenoszonych sygnałów, wnoszonymi przez ścieżki sygnałowe w tych podukładach.



Rys. 5.1. Ogólny schemat blokowy 10-bitowego, hybrydowego, dwubrzegowego modulatora LBDD PWM dla wzmacniacza audio klasy BD

Przedstawiona na rys. 5.1 architektura hybrydowego modulatora LBDD składa się w istocie z dwóch niezależnych modulatorów  $LADD_LPWM$  oraz  $LADD_RPWM$  (odpowiednio lewy i prawy kanał modulatora), wykorzystujących wspólnie jeden układ opóźniający z pętlą synchronizacji opóźnienia DLL.

Realizacja tego układu w technice układów programowalnych PLD byłaby bardzo trudna, bowiem wymagałaby implementacji wielordzeniowego mikroprocesora, ze względu na nakłady obliczeniowe w czasie rzeczywistym wiążące się z realizacją algorytmów kompensacji wstępnej oraz obliczenia początków i końców czasów trwania impulsów zmodulowanych w każdym okresie kluczowania.

W kolejnych podrozdziałach przedstawiono oryginalną architekturę i implementację 9-bitowego (lub 10-bitowego) zlinearyzowanego modulatora szerokości impulsów LBDD PWM dla wzmacniacza klasy BD, opartego na metodzie hybrydowej z wykorzystaniem 32-bitowego mikrokontrolera STM32F407xx z rodziny ARM Cortex<sup>™</sup>-M4F [80-82] i dwóch programowalnych linii opóźniających z odczepami PTDL [83]. Hybrydowy 9-bitowy (10-bitowy) kwantyzator konwertuje 6-MSB bitów (7-MSB bitów) metodą licznikową w oparciu o mikrokontroler STM32 i jego układy peryferyjne, natomiast pozostałe 3-LSB bity – metodą opartą na PTDL.

Architektura oryginalnych konwerterów cyfrowo-czasowych DTC zbudowanych w oparciu o układy peryferyjne mikrokontrolera STM32 i dwie programowalne linie PTDL, a także wyniki badań symulacyjnych w programie Matlab oraz badań eksperymentalnych, weryfikujących poprawność działania i dokładność przetwarzania algorytmów przetwarzających cyfrowe dane audio zostały opublikowane w pracach [45, 46, 49].

Pełne oprogramowanie dla realizacji wszystkich algorytmów: kompensacji wstępnej, obliczania początków i końców czasów trwania impulsów LBDD PWM, generacji uzależnień czasowych potrzebnych do sterowania modulatora LBDD oraz programów: sterowania przetwornika ADC i odczytu przetworzonych danych, implementacji 6-bitowych (7-bitowych) konwerterów cyfrowo-czasowych DTC metodą licznikową dla sześciu starszych MSB[8:3], (siedmiu MSB[9:3] z wykorzystaniem sterowników czasowych (ang. *Timers*), sterowania konwerterów cyfrowo-czasowych DTC w oparciu o układy PTDL dla trzech młodszych LSB[2:0] przedstawiono w dodatku A5.

#### 5.1.1. Dobór częstotliwości zegara i synchronizacja uzależnień czasowych

Zgodnie z przedstawionymi zależnościami (4.1-4.6) w rozdz. 4, jeżeli rozdzielczość bitowa hybrydowego modulatora LADD wynosi  $N_{rq}$ , przy takim podziale, że ( $N_{rq} - m$ ) MSB bitów przetwarzanych jest metodą licznikową, a *m* LSB bitów metodą wykorzystującą programowaną linię opóźniającą z odczepami PTDL, to linia opóźniająca zawiera 2<sup>*m*</sup> identycznych segmentów opóźniających, a opóźnienie wnoszone przez pojedynczy segment wynosi:

$$t_{d1} = T_{CLK} / 2^m \tag{5.1}$$

Przy założeniu, że częstotliwość próbkowania analogowego sygnału wejściowego wynosi  $f_s$ , to częstotliwość kluczowania  $F_c$  można określić zależnością:

$$F_c = OVR \times f_s \tag{5.2}$$

gdzie OVR jest współczynnikiem nadpróbkowania.

Częstotliwość  $F_{CLK}(N_{rq}, m)$  generatora taktującego w hybrydowym modulatorze LADD określona jest zależnością:

$$F_{CLK}(N_{rq},m) = F_c \times 2^{N_{rq}+1} = OVR \times f_s \times 2^{N_{rq}+1}$$
(5.3)

Uwzględniając zależności (5.1-5.3), błąd przetwarzania hybrydowego modulatora LADD, o rozdzielczości bitowej  $N_{rq}$ , musi być mniejszy niż  $t_{d1}/2$ , gdzie  $t_{d1}$  określa zależność (5.1).

Przy założeniu, że przetwarzanie ( $N_{rq} - m$ ) starszych MSB bitów metodą licznikową zostanie zrealizowane przez mikrokontroler STM32F407xx, podstawą do określenia wszystkich częstotliwości w zależnościach (5.1-5.3), będzie częstotliwość oscylatora  $f_{osc}$  pracy mikrokontrolera.

Realizując modulator hybrydowy o rozdzielczości bitowej  $N_{rq}$  = 9 bitów, przy podziale:

6 MSB starszych bitów oraz 3 LSB młodsze bity, zaprogramowano częstotliwość oscylatora:  $f_{osc}$  = 168 MHz.

- Częstotliwość magistrali APB2 wynosi:  $f_{MAG} = \frac{f_{osc}}{2} = \frac{168 \text{ MHz}}{2} = 84 \text{ MHz}$
- ► Częstotliwość zegara:  $f_{CLK} = \frac{f_{MAG}}{2} = \frac{84 \text{ MHz}}{2} = 42 \text{ MHz}$
- ► Częstotliwość kluczowania  $F_{CLK}(N_{rq} m)$ , dla rozdzielczości  $N_{rq} = 9$  bitów wynosi:

$$F_c(N_{rq} = 9 \text{ bit}) = \frac{F_{CLK}}{2^{N_{rq}-m+1}} = \frac{F_{CLK}}{2^7} = \frac{F_{CLK}}{128} = \frac{42 \text{ MHz}}{128} = 328,125 \text{ kHz}$$
(5.4a)

$$T_c \left( N_{rq} = 9 \text{ bit} \right) = \frac{1}{F_c} = \frac{1}{42 \text{ MHz}} \times 128 = \frac{1000}{42} \times 128 \text{ ns} \cong 3047,619 \text{ ns} = 3,047619 \text{ }\mu\text{s}$$

Natomiast dla rozdzielczości  $N_{rq}$  = 10 bitów częstotliwość kluczowania wynosi:

$$F_c(N_{rq} = 10 \text{ bit}) = \frac{F_{CLK}}{2^{N_{rq}-m+1}} = \frac{F_{CLK}}{2^8} = \frac{F_{CLK}}{256} = \frac{42 \text{ MHz}}{256} \cong 164,062 \text{ kHz}$$
(5.4b)

$$T_c \left( N_{rq} = 10 \text{ bit} \right) = \frac{1}{F_c} = \frac{1}{42 \text{ MHz}} \times 256 = \frac{1000}{42} \times 128 \text{ ns} \cong 6095,238 \text{ ns} = 6,095238 \text{ µs}$$

Całkowity czas konwersji  $T_{CONV}$  wbudowanych przetworników ADC [80] został ustawiony, zgodnie z równaniami (5.4a), na taką samą wartość, jak okres przełączania  $T_c$ , aby uniknąć pierwszej interpolacji strumienia danych PCM i znacznie zaoszczędzić czas obliczeń. Wbudowany przetwornik ADC w systemie mikrokontrolera STM-32F407xx posiada 16 multipleksowanych kanałów i istnieje możliwość zorganizowania konwersji w dwóch grupach: zwykłej i iniekcyjnej [80]. Zgodnie z równaniem (9), aby otrzymać  $T_{CONV} = T_c = 128T_{CLK}$  utworzono regularną grupę pięciu konwersji. Regularne kanały i ich kolejność w sekwencji konwersji zostały wybrane w rejestrach ADC\_SQRx, a całkowita liczba konwersji w regularnej grupie L [3: 0] bitów została zapisana w rejestrze ADC\_SQR1.

$$T_{CONV} = \sum_{1}^{G} \text{Sampling time} + 12 \text{cycles} = 4 \times 15 T_{CLK} + 68 T_{CLK} = 128 T_{CLK}$$
 (5.5)

Tak więc, zastosowany przetwornik analogowo-cyfrowy generuje strumień danych audio PCM z częstotliwością:

$$f_{CONV} = F_c = \frac{F_{CLK}}{2^{N_{rq} - m + 1}} = \frac{42 \text{ MHz}}{2^7} = 328,125 \text{ kHz}$$
 (5.6)

$$T_{CONV} = T_c = \frac{1}{F_c} = \frac{1}{42 \text{ MHz}} \times 128 \cong 3,04762 \,\mu s$$

$$T_{CLK} = \frac{1}{F_{CLK}} = \frac{1}{42 \text{ MHz}} = 23,81 \text{ ms}$$
(5.7)

• Opóźnienie wnoszone przez jeden segment linii PTDL wynosi:

$$t_{d1} = \frac{T_{CLK}}{2^m} = \frac{23,81}{2^3} = 2,97 \text{ ns}$$
 (5.8)

## 5.1.2. Aproksymacja odcinkami prostoliniowymi cyfrowego sygnału akustycznego dla dwubrzegowej modulacji LBDD PWM

Jak pokazano na rys. 5.2, przy modulacji LADD, czasy początku i końca impulsu LADD PWM w *n*-tym okresie kluczowania wyznaczają punkty przecięcia aproksymowanego odcinkami prostoliniowymi, nadpróbkowanego przebiegu modulującego, odpowiednio z opadającą częścią  $s_f(t)$  w pierwszym półokresie przebiegu trójkątnego i narastającą częścią  $s_f(t)$  w drugim półokresie tego przebiegu.



Rys. 5.2. Aproksymacja odcinkami prostoliniowymi cyfrowego sygnału akustycznego, przy (Q = 1)

Wykorzystując ogólne zależności (3.31) i (3.32) oraz (3.38) i (3.39), wyprowadzone w podrozdz. 3.1.2.2, możemy wyznaczyć czasy początków i końców zmodulowanych impulsów LADD PWM w *n*-tych okresach kluczowania, zależnie od ilości dodatkowych próbek wprowadzonych w drugiej interpolacji:

Dla 
$$Q = 1$$
:

$$\bar{t}_{p}(nT_{c}) = \frac{\left[1 - y_{0}(n)\right]}{4 + 2\left[y_{1}(n) - y_{0}(n)\right]} \times 128 \times T_{CLK} \bigg|_{V_{T} = 1V}$$
(5.9)

$$\bar{t}_{k}(nT_{c}) = \frac{\left[y_{2}(n) - 2y_{1}(n) - 3\right]}{\left[y_{2}(n) - y_{1}(n)\right] - 4} \times 128 \times T_{CLK} \bigg|_{V_{T} = 1 \text{ V}}$$
(5.10)

Dla *Q* = 3:

$$\bar{t}_{p}(\{n+1\}T_{c}) = \frac{\left[1 - y_{1}(n+1)\right]}{4 + \left[y_{2}(n+2) - y_{1}(n+1)\right]} \times 128 \times T_{CLK} \bigg|_{Y_{T} = 1\vee}$$
(5.11)

$$\bar{t}_{k}(\{n+1\}T_{c}) = \frac{[3+y_{1}(n+1)]}{4+[y_{1}(n+1)-y_{2}(n+2)]} \times 128 \times T_{CLK} \bigg|_{V_{T}=1 \vee}$$
(5.12)

Dla modulatora LADD<sub>L</sub>, mikroprocesor wywoływany przerwaniami na początku okresu kluczowania  $T_c$  przez wywołanie INT<sub>0</sub> odczytuje wartość przetworzonej próbki PCM dla bezpośredniego sygnału akustycznego (w pierwszym okresie trzeba założyć wstępne dane). Dla modulatora LADD<sub>R</sub> potrzeba tylko wyznaczyć kod PCM dla odwróconego w fazie o 180° sygnału akustycznego, na podstawie odczytanej próbki PCM dla sygnału bezpośredniego.

Opisany wyżej algorytm obliczania czasów początku i końca impulsu LADD w ciągu jednego okresu kluczowania  $T_c$ , na podstawie zestawu równań (5.9) i (5.10) lub (5.11) i (5.12), zależnie od ilości Q dodatkowych próbek, dotyczy modulatora LADD<sub>L</sub>. Identyczny algorytm obliczeń jest powtarzany dla modulatora LADD<sub>R</sub>.

Po zakończeniu obliczeń z dużą rozdzielczością 32-bitową: początku  $t_p(n)$  i końca  $t_k(n)$  czasów trwania impulsu LADD w okresie  $nT_c$ , zostaje przeprowadzony proces rekwantyzacji, opisany w rozdziale 3.1.3, pozwalający na redukcję (obcięcie) długości słowa bitowego obliczonych wartości do mniejszej  $N_{rq}$  rozdzielczości i rozdzielenie ich na składowe odpowiadające starszym LADD<sup>MSB (8:3)</sup> i młodszym LADD<sup>MLSB (2:0)</sup> bitom.

Rekwantyzowany sygnał cyfrowy, po przejściu przez układ kształtowania szumów kwantyzacji, zachowuje niezmienione składowe widma sygnału PWM w paśmie podstawowym sygnału modulującego, zaś szum kwantyzacji zostaje przesunięty poza to pasmo, do zakresu wyższych częstotliwości odfiltrowywanych w procesie demodulacji.

Obliczone wartości czasów początku  $t_p(n)$  i końca  $t_k(n)$  czasów trwania impulsu LADD na podstawie spróbkowanego i rekwantyzowanego do 9 bitów sygnału wyjściowego z przetwornika ADC są podzielone na część MSB 6-bitową i LSB 3-bitową.

Wartości te z n = 4 początkowych cykli są zapisywane do zdefiniowanych buforów pamięci: przechowujących początki BMB(0:n-1) oraz końce EMB(0:n-1) impulsów w danym cyklu. Wspomniane bufory to 8-bitowe zmienne typu całkowitego bez znaku. Na rys. 5.3 pokazane są symbolicznie zdefiniowane rejestry przechowujące obliczone dane i ich relacje czasowe w pierwszych czterech cyklach  $T_c$ .



Rys. 5.3. Rejestry zawierające czasy początków i końców impulsów w *n*-tym i w kolejnym okresie  $T_c$ 

Do rejestrów odpowiedzialnych za MSB ładowane są wstępnie ustalone wartości odpowiednio dla początków i końców czasów trwania impulsów PWM, natomiast pozostałe rejestry są zerowane, aby nie występowały przypadkowe wartości niedozwolone.

Do realizacji zadania wygenerowania przebiegów PWM w układzie uruchomieniowym STM32F4 Discovery zostały wykorzystane wewnętrzne układy liczników: TIM1, TIM2 oraz TIM3. Licznikiem synchronizującym pracę całości jest TIM2. To on generuje impulsy, które uruchamiają w odpowiednim momencie pracę dwóch pozostałych timerów TIM1 oraz TIM3, oprócz tego steruje procesem próbkowania sygnału wejściowego w 12-bitowym przetworniku analogowo-cyfrowym ADC1.

Timery w zestawie uruchomieniowym STM32F4 można podzielić na kilka grup, jedną z nich jest grupa *advanced*, czyli rozbudowane funkcjonalnie o największych możliwościach konfiguracyjnych timery. Do tej grupy należy TIM1. Został on zastosowany do generacji sygnałów PWM o różnych i co cykl aktualizowanych danych czasowych. Podobnie jak kod ADC1 oraz TIM2 czy TIM3, funkcja inicjująca TIM1 została napisana, wykorzystując dostęp bezpośredni do rejestrów urządzenia.

Manipulując rejestrami timera TIM2, uzyskujemy potrzebną częstotliwość próbkowania konwertera ADC1. Zadając: ARR = 0 x 007F oraz PSC = 0 x 0007 licznika, timer TIM2 odlicza w górę od 0 do 127 cykli zegarowych (1/42 MHz = 23,81ns). Poprzez wewnętrzną pętlę PLL częstotliwość na magistrali APB1 wynosi 84 MHz. Dzieląc ją przez 2, uzyskujemy taktowanie TIM2 równe 42MHz. Wygenerowany sygnał o częstotliwości  $f_{TIM2}$  = 164,063 kHz jest również wyprowadzony z TIM2 poprzez kanał pierwszy CH1 na pin 4 portu B, PB3.

Motorem generującym wartości impulsów jest timer TIM3. Po starcie do rejestru TIM3\_ARR ładowana jest wartość próbki z rejestru BMB(*n*). Licznik zlicza w górę (up) i po osiągnięciu 6-bitowej wartości z BMB(*n*) generuje przerwanie pierwsze UEV1. W przerwaniu tym przepisuje do TIM3\_ARR różnicę wartości rejestrów EMB(*n*) oraz BMB(*n*), czyli EMB(*n*)-BMB(*n*). Również komparator generuje przerwanie UEVc1 = UEV1, przez co zdarzenie komparatora generuje narastające zbocze impulsu PWM i wysyła do portu wyjściowego PB(0:2), 3 bitową wartość z rejestru ELB(*n*).

Kolejne zdarzenie wynikające z przerwania UEV2 występuje po osiągnięciu przez licznik wartości EMB(n)-BMB(n), wówczas przepisuje do TIM3\_ARR wartość 128-EMB(n) + BMB(n + 1). Zdarzenie to generuje zbocze opadające impulsu PWM i wysyła wartość BLB(n + 1) na port PB(0:2). W ten sposób powstaje pierwszy impuls w pierwszym cyklu kluczowania. Następne przerwanie UEV3 powoduje przepisanie do TIM3\_ARR wartości różnicy rejestrów EMB(n+1) – BMB(n+1), zdarzenie komparatora UEVc3 generuje narastające zbocze impulsu PWM i wysyła do portu PB(0:2) trzybitową wartość LSB z rejestru ELB(n + 1).

Po osiągnięciu przez licznik wartości EMB(n + 1) – BMB(n + 1), UEV4 przepisuje do TIM3\_ARR wartość 128 – EMB(n + 1) + BMB(n + 2), zdarzenie komparatora UEVc4 generuje opadające zbocze impulsu PWM i wysyła do portu PB(0:2) trzybitową wartość LSB z rejestru BLB(n + 2). W ten sposób powstaje kolejny impuls w drugim cyklu kluczowania. Zdarzenie UEV5 występuje po osiągnięciu przez licznik wartości 128 – EMB(n + 1) + BMB(n + 2), wtedy przepisuje do TIM3\_ARR wartość EMB(n + 2) – BMB(n + 2), wówczas zdarzenie komparatora UEVc5 generuje narastające zbocze kolejnego impulsu PWM i wysyła do portu PB(0:2) trzybitową wartość LSB z rejestru ELB(n + 2). Po osiągnięciu przez licznik wartości 128 – EMB(n + 1) + BMB(n + 2) generowane jest przerwanie UEV6, powoduje ono przepisanie do TIM3\_ARR wartości 128 – EMB(n + 2) + BMB(n + 3), zdarzenie komparatora UEVc6 generuje opadające zbocze impulsu PWM i wysyła do portu PB(0:2) trzybitową wartość LSB z rejestru BLB(n + 3). W ten sposób powstaje kolejny impuls w trzecim cyklu kluczowania. Zdarzenie przerwania UEV<sub>7</sub> po raz kolejny przepisuje do TIM3\_ARR nową wartość różnicy EMB(n + 3) – BMB(n + 3), zaś zdarzenie komparatora UEVc7 generuje narastające zbocze impulsu PWM i wysyła do portu PB(0:2) trzybitową wartość LSB z rejestru ELB(n + 3).

Ostatecznie, po osiągnięciu przez licznik wartości EMB(n + 3) – BMB(n + 3), UEV<sub>8</sub> przepisuje do TIM3\_ARR wartość 128 – EMB(n + 3) + BMB(n), zaś zdarzenie komparatora UEVc8 generuje opadające zbocze impulsu PWM i wysyła do portu PB(0:2) trzybitową wartość LSB z rejestru BLB(n). W ten sposób powstaje kolejny impuls w czwartym cyklu kluczowania.

Po osiągnięciu wartości przez licznik 128 – EMB(n + 3) + BMB(n) program powraca do zdarzenia z przerwania pierwszego UEV1 i zapętla się. Podobnie jest w przypadku komparatora, przerwanie UCVc4=UEVc1, wtedy generowane są kolejne impulsy na podstawie kolejnych wyliczonych 6-bitowych wartości czasów początkowych i końcowych.

Na rysunku 5.3 widzimy wygenerowane przebiegi impulsów (koloru niebieskiego) na wyjściu PE09 układu uruchomieniowego STM32F4 Discovery dla przykładowych danych 6-bitowych czasów początkowych tpp(0:3) oraz końcowych tkp(0:3) z 8-miu rejestrów BMB czy EMB, (0-127) oraz dodatkowo z 8-miu rejestrów 3-bitowch (0-7), słowa np. BLB czy ELB, gdzie zapisane na początku B oznacza początek, zaś E koniec impulsu:

| -        |                  |
|----------|------------------|
| BMB[0] = | 21; BLB[0] = 1;  |
| BMB[1] = | 56; BLB[1] = 2;  |
| BMB[2] = | 21; BLB[2] = 1;  |
| BMB[3] = | 56; BLB[3] = 2;  |
| EMB[0] = | 120; ELB[0] = 6; |
| EMB[1] = | 83; ELB[1] = 3;  |
| EMB[2] = | 120; ELB[2] = 6; |
| EMB[3] = | 83; ELB[3] = 3;  |

Wykres czerwony to prostokątny przebieg o częstotliwości  $F_c$  = 164,064 kHz z wyjścia PB03 timera TIM2. Z wykresu widać wygenerowane dwie paczki impulsów zgodnie z podanymi danymi oraz pełną synchronizację przebiegów.



Rys. 5.4. Przebiegi impulsów wygenerowane w zestawie uruchomieniowym STM32F4 Discovery

# 5.2 Architektura konwertera cyfrowo-czasowego DTC zrealizowanego w oparciu o mikrokontroler STM32 i programowaną linię opóźniającą PTDL

Jak opisano w podrozdz. 2, architektura hybrydowego LBDD DPWM składa się z dwóch synchronicznych hybrydowych podukładów LADD DPWM. Pierwszy z nich LADD<sub>L</sub> DPWM generuje sekwencje zmodulowanych impulsów LADD<sub>L</sub> do sterowania przełącznikami MOSFET lewej gałęzi mostka H (wygenerowany na podstawie bezpośredniego sygnału modulującego), podczas gdy drugi podukład LADD<sub>R</sub> DPWM generuje sekwencje zmodulowanych impulsów LADD<sub>R</sub> do sterowania przełącznikami MOSFET prawej gałęzi mostka H (wygenerowany na podstawie odwróconego w fazie sygnału modulującego). Ponieważ obwody LADDL i LADDR PWM są podobne, można je zaimplementować w ten sam sposób. Poniższy opis dotyczy tylko modulatora LADD PWM.

Na rys. 5.5a przedstawiono architekturę hybrydowego konwertera cyfrowo-czasowego DTC zrealizowanego w oparciu o mikrokontroler STM32 i jego układy peryferyjne oraz programowaną linię opóźniającą PTDL, a także przedstawiono przebiegi czasowe sygnałów sterujących i wyjściowych. W oparciu o mikrokontroler STM32 i jego zaawansowane timery sterujące TIM1 lub TIM8, w każdym okresie kluczowania  $T_c$  generowane są dwa cyfrowe przebiegi z jednobrzegową modulacją LADS PWM<sub>L</sub>. Przebiegi te generowane są metodą licznikową na podstawie obliczonych czasów początków i końców zmodulowanych impulsów LADD<sub>L</sub> z rozdzielczością 6 MSB bitów po rekwantyzacji. Narastające zbocza obu impulsów LADS PWM<sub>L</sub> są zsynchronizowane i rozpoczynają się na początku okresu częstotliwości kluczowania  $T_c$ . Opadające zbocze pierwszego impulsu LADS pojawia się w czasie odpowiadającym obliczonej wartości  $t_p(n)$  położenia zbocza narastającego (wyznaczonej z rozdzielczością 6 MSB bitów po rekwantyzacji), natomiast opadające zbocze drugiego przebiegu LADS pojawia się w czasie odpowiadającym obliczonej wartości  $t_k(n)$  położenia zbocza opadającego. Do wygenerowania tych przebiegów wykorzystano timer TIM1.

Różniczkując opadające zbocza obydwu wygenerowanych przebiegów z jednobrzegową modulacją LADS PWM<sub>L</sub>, otrzymujemy wąskie impulsy szpilkowe odpowiadające lokalizacji czasów początków  $t_p(n)$  i końców  $t_k(n)$  zmodulowanych impulsów LADD<sub>L</sub>, które mogą być wykorzystane do wygenerowania przebiegów z dwubrzegową modulacją LADD<sub>L</sub> DPWM (z rozdzielczością 6 MSB bitów po rekwantyzacji), jak pokazano na rys. 5.5b.

Hybrydowy kwantyzator przetwarza pozostałe 3 LSB bity metodą opartą na ogólnie dostępnej, 3-bitowej linii opóźniającej FAST TTL PTLD [83], składającej się z kaskady N = 8 identycznych komórek opóźniających, z czasem opóźnienia:

$$t_{d1} = \frac{T_{CLK}}{2^m} = \frac{23,81}{2^3} = 2,97 \text{ ns}$$
 (5.13)

a)

All control signals are generating by STM32F Microcontroller

3LSBs of  $t_n(nT_c)$  and  $t_k(nT_c)$ 





Rys. 5.5. Architektura układu przetwarzającego 3-LSB (2: 0) bity danych – z wykorzystaniem kwantyzatora opartego na 3-bitowej linii opóźniającej PTDL: a) Schemat układu; b) Przebiegi sygnałów sterujących i wyjściowych w dziedzinie czasu

Wąskie impulsy z wyjść obu układów różniczkujących, po przejściu przez 3-bitową linię opóźniającą PTDL, są opóźnione na poszczególnych odczepach linii o czasy opóźnień, które są programowane na wejściach adresowych linii przez cyfrowe wartości obliczonych czasów początków i końców zmodulowanych impulsów LADD<sub>L</sub> z rozdzielczością 3 LSB (2:0) bitów po rekwantyzacji. Wymaga to dwukrotnego zaprogramowania PTDL w każdym okresie przełączania  $T_c$ . Na początku okresu  $T_c$  musimy wprowadzić 3 bity LSB (2:0) lokalizacji początku  $t_p(n)$  zmodulowanych impulsów LADD<sub>L</sub> i zachować te dane przez pierwszą połowę okresu kluczowania  $T_c/2$ , podczas gdy na początku w drugiej połowie okresu  $T_c/2$  musimy wprowadzić 3 bity LSB (2:0) końca  $t_k(n)$  zmodulowanych impulsów LADD<sub>L</sub> i zachować te dane przez drugą połowę.

## 5.3. Wyniki symulacji hybrydowego modulatora LBDD PWM w programie Matlab i badania eksperymentalne praktycznie wykonanego modulatora

Przebiegi czasowe i charakterystyki widma częstotliwościowego sygnałów wyjściowych zrealizowanego modulatora LBDD PWM DPWM zostały zasymulowane przy użyciu narzędzi Matlab. Widmo częstotliwości zostało oszacowane poprzez zapamiętanie pewnej liczby impulsów sygnału wyjściowego LBDD PWM, które reprezentują co najmniej jeden okres sygnału modulującego.

Na rys. 5.6 przedstawiono wyniki symulacji przebiegów czasowych (rys. 5.6a) i widma częstotliwości 32-bitowego wyjścia LBDD PWM przed rekwantyzacją (rys. 5.6b) i 9-bitowego wyjścia LBDD PWM po rekwantyzacji, przy użyciu rekurencyjnego modelu kształtowania szumu z dwoma pętlami sprzężenia zwrotnego i opisanego w pracy algorytmu aproksymacji odcinkami prostoliniowymi cyfrowego sygnału LBDD PWM (rys. 5.6c) dla: M = 0.95,  $F_c = 328,125$  kHz,  $f_m = 10$  kHz, Q = 1, gdzie M – indeks modulacji, Q – liczba pośrednich próbek audio PCM podczas interpolacji w okresie  $T_c$ ,  $F_c$  – częstotliwość przełączania, a  $f_m$  – częstotliwość modulującego sygnału audio.



Rys. 5.6. Wyniki symulacji w Matlabie; Przebiegi czasowe na wyjściu LBDD PWM (a) Widmo częstotliwościowe sygnału wyjściowego LBDD PWM, przy: M = 0.95,  $F_c = 328.125$  kHz,  $f_m = 10$  kHz dla Q = 1, (b) Przed rekwantyzacją, (c) Po rekwatyzacji danych wyjściowych do rozdzielczości 9-bitów

Symulacje współczynników *THD* sygnałów wyjściowych LBDD PWM dla dwóch architektur rekurencyjnego modelu kształtowania szumu kwantyzacji przedstawiono na rys. 5.7.



Rys. 5.7. Wyniki symulacji w Matlabie współczynników *THD* na wyjściu LBDD PWM, przy:  $Q = 1, f_{m1} = 10$  kHz lub  $f_{m2} = 20$  kHz i dwóch modelach kształtowania szumów rekwantyzacji: a) z jedną pętlą sprzężenia zwrotnego; b) z dwoma pętlami sprzężenia zwrotnego

Na rys. 5.8 porównano współczynniki *THD* w modulatorze LBDD PWM ze współczynnikami THD w modulatorach NBDD PWM i UBDD PWM.

Analizując przedstawione charakterystyki, widzimy, że nawet prosty algorytm kompensacji wstępnej: nadpróbkowanie w drugim etapie interpolacji ze współczynnikiem Q = 1 i zastosowanie w procesie rekwantyzacji modelu kształtowania szumów kwantyzacji z dwoma pętlami sprzężenia zwrotnego, pozwala na znaczną poprawę liniowości modulatora LBDD PWM. Ponadto, wprowadzając większą liczbę Q pośrednich próbek audio PCM w okresie  $T_{c'}$ możemy dodatkowo zmniejszyć poziom *THD* sygnału LBDD PWM i zbliżyć się do poziomu *THD* optymalnego, analogowego modulatora NPWM. Wniosek ten potwierdza charakterystyka współczynników *THD* dla modulatorów NBDD, UDDD i LBDD w funkcji  $f_r = f_m/F_c$ , pokazana na rys. 5.8a, a także współczynniki *THD* na wyjściu modulatora LBDD PWM w funkcji  $f_r = f_m/F_{c,r}$ , dla różnych wartości Q (rys. 5.8b).



Rys. 5.8. a) Porównanie współczynników *THD* dla modulatorów NBDD, UDDD i LBDD w funkcji  $f_r = f_m/F_c$ ; b) *THD* na wyjściu modulatora LBDD PWM dla różnych wartości Q

Na rys. 5.9 (od góry) przedstawiono oscylogramy dwóch zsynchronizowanych impulsów LADS<sub>L</sub> PWM, o rozdzielczości 6-MSB po rekwantyzacji, generowanych metodą licznikową przez mikrokontrolera STM32 i jego urządzenia peryferyjne. Zbocza opadające obu impulsów 6-MSB LADS<sub>L</sub>PWM są różniczkowane i przepuszczane przez 3-bitowe linie opóźniające PTDL, a następnie wykorzystywane do ustawiania i resetowania przerzutnika wyjściowego, co ilustruje oscylogramy na rys. 5.9 (od dołu).

Na rys. 5.10 przedstawiono oscylogramy przebiegów czasowych generowanych przez hybrydowe, 9-bitowe modulatory  $LADD_L$  i  $LADD_R$  do sterowania odpowiednio lewej i prawej gałęzi mostka H oraz na wyjściu modulatora LBDD PWM w trybie różnicowym DM (od dołu).



Rys. 5.9. Oscylogramy dwóch zsynchronizowanych impulsów 6-MSB LADS<sub>L</sub>PWM, generowanych metodą licznika (od góry) oraz generowanie impulsów 6-MSB LADD<sub>L</sub>PWM na wyjściu modulatora LADD<sub>1</sub>PWM (od dołu)



Rys. 5.10. Oscylogramy przebiegów czasowych generowanych przez 9-bitowe modulatory LADD<sub>L</sub> i LADD<sub>R</sub> (od góry) oraz na wyjściu modulatora LBDD PWM w trybie różnicowym DM (od dołu)

Na rys. 5.11 przedstawiono charakterystykę THD w funkcji częstotliwości sygnału modulującego *THD* =  $\varphi$  ( $f_m$ ) na wyjściu modulatora LBDD PWM w trybie różnicowym DM, otrzymaną w wyniku pomiarów. Natomiast na rys. 5.12 przedstawiono charakterystyki widmowe sygnału na wyjściu modulatora LBDD PWM w trybie różnicowym DM, wyznaczone eksperymentalnie za pomoca szerokopasmowego analizatora widma.



LBDD: THD[%] = f (fm); fc = 328.125 kHz;M = 0.95

Rys. 5.11. Charakterystyka THD w funkcji częstotliwości sygnału modulującego  $THD = \varphi(f_m)$ 



a) LBDD: fm = 1kHz; fc=328.125 kHz; M=0.95; THD[%] = 0.136



Rys. 5.12. Charakterystyki widmowe sygnału na wyjściu modulatora LBDD PWM w trybie różnicowym DM, wyznaczone eksperymentalnie za pomocą szerokopasmowego analizatora widma

#### 5.4. Ocena uzyskanych wyników

Zaproponowano nową i oryginalną architekturę oraz implementację 9-bitowego (10-bitowego) zlinearyzowanego układu modulatora LBDD PWM dla cyfrowego wzmacniacza mocy klasy BD. Cały algorytm przetwarzania sygnałów i danych w modulatorze został zaimplementowany w oparciu o metodę hybrydową z wykorzystaniem mikrokontrolera STM32, wraz z jego urządzeniami peryferyjnymi oraz dwóch ogólnodostępnych, katalogowych, 3-bitowych programowalnych linii opóźniających PTDL.

Przeprowadzono obszerną weryfikację algorytmów przetwarzania sygnałów i danych, zaimplementowanego układu, a także symulację w programie Matlab oraz badania eksperymentalne proponowanego 9-bitowego hybrydowego modulatora LBDD PWM.

Porównanie współczynników *THD* symulowanych w Matlab i przedstawionych na rys. 5.7 wskazuje, że nawet prosty algorytm LBDD (przy Q = 1), wykorzystujący rekurencyjny model kształtowania szumu kwantyzacji z dwoma pętlami sprzężenia zwrotnego pozwala na znaczną poprawę liniowości modulatora w porównaniu z innymi rodzaje DPWM. W przypadku wyższych wartości Q, modulator LBDD może dodatkowo zmniejszyć poziomy *THD*, zbliżając się do optymalnego analogowego modulatora NBDD.

6-MSB bitowy kwantyzator oparty na metodzie licznikowej charakteryzuje się niezbyt dużym stopniem skomplikowania i wykazuje doskonałą liniowość konwersji cyfrowo-czasowej. W tym celu wszystkie bloki funkcjonalne w systemie muszą być idealnie zsynchronizowane, a okres przełączania  $T_c$  w podsystemach LADD\_PWM i LADD\_PWM musi rozpocząć się w tym samym czasie.

Przedstawiony w publikacji oryginalny konwerter 3-LSB bitowy, wykorzystujący zintegrowany 3-bitowy programowalny PTDL, jest również bardzo prosty i charakteryzuje się dużą dokładnością przetwarzania. Wszystkie programowalne czasy opóźnienia "krok do kroku" w linii PTDL odnoszą się do "kroku zerowego". Czas opóźnienia w kroku zerowym wynosi 5 ns, ale nie ma wpływu na dokładność przetwarzania, ponieważ wszystkie lokalizacje czasów początków  $t_p(n)$  i końców  $t_k(n)$  zmodulowanych impulsów fizycznego ciągu 1-bitowych impulsów LBDD PWM są opóźnione o ten sam czas 5 ns.

Praktycznie zmierzony poziom *THD* na wyjściu modulatora LBDD PWM (charakterystyka przedstawiona na rys. 5.11) ma nieco wyższy poziom niż uzyskany w symulacji Matlab (rys. 5.8b, dla Q = 1). Jednak z praktycznego punktu widzenia są one całkiem zadowalające, zapewniając SNR na poziomie 80 dB i *THD* niższe niż 0,3% w paśmie podstawowym audio do 20 kHz.

Zaletą cyfrowego modulatora LBDD PWM jest również łatwe programowanie odpowiedniego czasu opóźnienia na zboczach narastających wszystkich sygnałów sterujących tranzystorami MOSFET stopnia mocy, co w praktyce pozwala ograniczyć prądy skrośne w procesach przełączania tranzystorów. Unikalną zaletą opracowanego 9-bitowego (10-bitowego) modulatora LBDD PWM dla cyfrowego wzmacniacza klasy BD częstotliwości akustycznych jest to, że jego podstawową konfigurację, można zaimplementować za pomocą mikrokontrolera STM32, dwóch ogólnie dostępnych katalogowych 3-bitowych programowalnych linii opóźniających PTDL i kilkunastu standardowych bramek logicznych.

## Wzmacniacze akustyczne klasy BD ze zrównoważonym wyjściem w trybie wspólnym CM

#### 6.1. Wprowadzenie

Wiele prac poświęcono różnym ulepszonym metodom modulacji PWM, a także topologiom wzmacniaczy mocy klasy D, aby uzyskać dwie najważniejsze cechy: wysoką wierność odtwarzania i dużą sprawność energetyczną.

Stopnie końcowe wzmacniaczy klasy D skonfigurowane są w struktury półmostkowe lub mostkowe, w których tranzystory mocy MOSFET pełnią rolę przełączników (kluczy), sterowanych od stanu zamknięcia do stanu otwarcia. Charakterystyki statyczne tych elementów w granicznych stanach przewodzenia powinny być zbliżone do charakterystyk przełącznika w stanach zamknięcia i otwarcia, a czasy przełączania możliwie jak najkrótsze. Maksymalna moc obciążenia limitowana jest przez graniczne wartości prądów i napięć zastosowanych tranzystorów, a nie przez ich dopuszczalną moc strat.

Na rys. 6.1a przedstawiono stopień wyjściowy wzmacniacza klasy BD w układzie mostka H, sterowany z wyjść modulatora NBDD PWM lub jego odpowiednika LBDD PWM, a na rys. 6.1b przedstawiono przebiegi czasowe sygnałów sterujących i napięć wyjściowych w układzie.

Sygnały sterujące zawierają czasy opóźnień między stanami przełączania, w których wszystkie przełączniki są wyłączone, aby osiągnąć przełączanie przy zerowym napięciu (ZVS) i zapobiec prądom skrośnym płynącym przez tranzystory MOSFET w procesach ich przełączania.


Rys. 6.1. Wzmacniacz klasy BD z modulatorem NBDD PWM lub LBDD PWM: a) Schemat układu; b) Przebiegi czasowe sygnałów sterujących i napięcia na wyjściach wzmacniacza: różnicowym w trybie DM i sumacyjnym w trybie CM

Widma częstotliwościowe sygnałów z modulacją NBDD PWM mają postać podwójnych szeregów Fouriera i dla sygnału na wyjściu różnicowym w trybie DM określa zależność (2.8), a na wyjściu sumacyjnym w trybie CM zależność (2.12).

Z równania (2.8) wynika, że efektywna częstotliwość próbkowania różnicowego sygnału wyjściowego w trybie DM jest podwojona, bez zwiększania częstotliwości kluczowania na wyjściu, a wszystkie harmoniczne wokół nieparzystych wielokrotności częstotliwości kluczowania są eliminowane. Jednak na wyjściu sumacyjnym w trybie CM (równanie 2.12) widmo częstotliwościowe sygnału sumacyjnego CM zawiera nieparzyste harmoniczne częstotliwości kluczowania i ich parzyste składowe intermodulacyjne (IM), które są obecne w pełnej skali, nawet przy bardzo niskim poziomie sygnału modulującego.

Wzmacniacze akustyczne klasy BD z modulacją NBDD często w literaturze są wyróżniane jako "bezfiltrowe", przez co należy rozumieć, że nie ma potrzeby stosowania dodatkowego filtru LC, a wydzielenie sygnału modulującego zapewnia samo obciążenie o charakterze rezystancyjno-indukcyjnym (głośnik). Dotyczy to jednak tylko sygnałów różnicowych w trybie DM. Aby dołączyć sygnał różnicowy z wyjścia wzmacniacza do głośnika, przewody dołączające (najczęściej długie), a także ścieżki połączeniowe obwodu montażowego, przenoszą nie tylko sygnał różnicowy, ale również powstające przy modulacjach NBDD lub LBDD sygnały wspólne. Szybkie przełączanie tranzystorów MOSFET w stopniu wyjściowym, duże skoki napięć wyjściowych (w pełnym zakresie napięcia zasilania  $V_{_{DD}}$ ) oraz szerokie widmo częstotliwościowe sygnałów sumacyjnych w trybie CM mogą prowadzić do emisji zakłóceń o wysokiej częstotliwości RF ze stopnia wyjściowego, ścieżek na płytce drukowanej, filtrów i kabli głośnikowych, które stają się przypadkowymi antenami promieniującymi zakłócenia elektromagnetyczne.

Filtry LC we wzmacniaczach klasy BD z modulacją NBDD lub LBDD muszą być projektowane oddzielnie dla sygnałów różnicowych DM i sumacyjnych CM. Często do filtracji sygnałów wspólnych wykorzystuje się cewki sprzężone magnetycznie o indukcyjności wzajemnej *M*, co skutkuje skuteczniejszym tłumieniem sygnałów wyjściowych CM, ponieważ cewki sprzężone wykazują znacznie większą impedancję dla prądu wyjściowego sumacyjnego w trybie CM niż dla prądu różnicowego DM [6, 17].

W wielu pracach zaproponowano różne rozwiązania modulacji cyfrowych oraz struktur układowych wzmacniaczy klasy D, a także nowe metody linearyzacji dla zapewnienia wysokiej wierności odtwarzania i redukcji zakłóceń elektromagnetycznych EMI bezfiltrowych wzmacniaczy klasy D [8, 21].

Oryginalną modulację Common-Mode Free BD (CMFBD), która utrzymuje stałe napięcia wyjściowe w trybie CM, przedstawiono w [8]. Wyjście różnicowe w trybie DM tego wzmacniacza ma taką samą postać jak mostkowy wzmacniacz klasy BD z optymalną modulacją NBDD, jednak częstotliwość przełączania tranzystorów mocy MOSFET tworzących nowy stopień wyjściowy mostka H jest podwójona. Szczegółowa analiza przedstawionej modulacji CMFBD pokazuje, że jest ona odpowiednikiem modulacji szerokości impulsu z przesuniętą fazą nośną (PSCPWM), która jest uważana za wielopoziomową metodę PWM dla wzmacniaczy klasy BD [33, 34].

Na rys. 6.2 przedstawiono schemat ideowy wzmacniacza klasy BD z wykorzystaniem modulacji PSCPMW oraz schemat blokowy modulatora PSCPWM generującego wszystkie sygnały sterujące S1, S2 oraz S3 [8, 33, 34]. Mostek H zawiera dwa dodatkowe przełączniki szeregowe M5 i M6, połączone równolegle z obciążeniem, które służą do bocznikowania dwukierunkowego indukcyjnego prądu obciążenia, gdy M1–M4 są wyłączone i do ustawiania napięcia  $V_{_{DD}}/2$  na obu wyjściach niesymetrycznych mostka, za pomocą rezystorów R<sub>b</sub> bocznikowych tranzystory M1–M4. Na rys. 6.2c przedstawiono również przebiegi czasowe sygnałów sterujących S1, S2 oraz S3 z wyjść modulatora i napięcia na wyjściach wzmacniacza.

Widma częstotliwościowe sygnałów z modulacją PSCPWM na wyjściu różnicowym w trybie DM oraz na wyjściu sumacyjnym w trybie CM mają

postać podwójnych szeregów Fouriera i można je wyrazić po pewnych przekształceniach za pomocą następujących wyrażeń [33, 34]:

$$F_{FSC}^{DM}(t) = M\cos(\omega_{m}t) + \\ + 2\sum_{m=1}^{\infty} \sum_{n=\pm 1}^{\pm \infty} \left\{ \frac{J_{n}\left(\frac{m\pi M}{2}\right)}{m\pi} \sin\left(\frac{(m+n)\pi}{2}\right) \left[1 - \cos(n\pi)\right] \sin\left[m \,\Omega_{c} + n\omega_{m}\right)t \right] \right\} =$$

$$= M \cos(\omega_{c}, t) +$$
(6.1)

$$+4\sum_{m=1}^{\infty}\sum_{n=0}^{\pm\infty} \left\{ \frac{J_n\left(\frac{2m\pi M}{2}\right)}{2m\pi} \sin\left(\frac{\left[2m+(2n+1)\right]\pi}{2}\right) \sin\left[\left\{2m \ \Omega_c + (2n+1)\omega_m\right\}t\right] \right\} F_{FSC}^{CM}(t) = \frac{1}{2}$$
(6.2)

Porównując równania (2,8) i (2.12) z odpowiadającym im równaniami (6.1) i (6.2), a także przebiegi czasowe napięć na wyjściach wzmacniaczy, przedstawione na rys. 6.1b oraz rys. 6.2c, widzimy, że wyjście DM wzmacniacza klasy BD z modulacją PSC PWM jest identyczne jak dla optymalnej modulacji NBDD PWM, jednak PSC PWM utrzymuje stałe napięcie sumacyjne w trybie CM.



Rys. 6.2. Wzmacniacz klasy BD z modulacją PSCPWM: a) Schemat blokowy modulatora PSCPWM; b) Stopień wyjściowy; c) Przebiegi czasowe na wyjściach modulatora i mostka H

Wadą przedstawionego układu z modulacją PSCPWM jest konieczność zastosowania dwóch dodatkowych szeregowych przełączników M5 i M6 oraz przełączania tranzystorów mocy z dwukrotnie większą częstotliwością modulacji NBDD, co skutkuje większymi stratami mocy przełączania. Ponadto straty mocy występują w rezystorach bocznikujących R<sub>b</sub>, połączonych równolegle z M1–M4 i tworzących dzielniki napięcia w celu ustawienia napięcia  $V_{_{DD}}/2$  na obu wyjściach niesymetrycznych, co również zwiększa czasy narastania i opadania impulsów wyjściowych PWM, przyczyniając się do dalszego wzrostu strat mocy w procesach przełączania.

W publikacji przedstawiono nowe architektury i implementacje oryginalnych wzmacniaczy audio klasy BD z otwartą pętlą i ze zbalansowanym wyjściem w trybie wspólnym. Stopień wyjściowy każdego proponowanego wzmacniacza zawiera typowy mostek H z czterema tranzystorami MOSFET i czterema dodatkowymi przełącznikami MOSFET, które równoważą i utrzymują stałą wartość napięcia wyjściowego w trybie CM, co oznacza, że w tych wzmacniaczach nie ma potrzeby filtracji sygnałów wspólnych [9-10], [45-52]. Prezentowane wzmacniacze wykorzystują rozbudowane schematy modulacji cyfrowych LBDD PWM lub LPSC PWM.

# 6.2. Wzmacniacze klasy BD ze zrównoważonym wyjściem wspólnym w trybie CM, wykorzystujące rozbudowane modulatory LBDD PWM lub LPSC PWM

Na rys. 6.3a przedstawiono ulepszoną wersję wzmacniacza audio klasy BD ze zrównoważonym wyjściem wspólnym w trybie CM (opublikowaną wcześniej w [9, 49], wykorzystującą rozbudowany cyfrowy modulator LBDD PWM (rys. 6.3c).

Wzmacniacz ten składa się z typowego stopnia wyjściowego mostka H z czterema tranzystorami MOSFET i czterech dodatkowych przełączników MOSFET (M5, M6 i M7, M8) oddzielających mostek H od zasilacza i przełączających szyny zasilające mostka na połówkowe napięciowe VDD / 2, w przedziałach czasu, w których tranzystory MOSFET górnej strony lub dolnej strony mostka H są zamknięte jednocześnie. W tych stanach, gdy tranzystory M1, M3 strony górnej są załączone, tranzystor M7 jest wyłączony, zaś tranzystor M8 jest załączony, natomiast, gdy tranzystory M2, M4 dolnej strony są załączone, to tranzystor M5 jest wyłączony, a tranzystor M6 jest załączony. Częstotliwość przełączania wszystkich tranzystorów MOSFET jest taka sama jak w przypadku modulacji LBDD PWM, tj. dwukrotnie niższa niż w przypadku modulacji PSCPWM na rys. 6.2b. Poprzez wprowadzenie odpowiedniego czasu opóźnienia na zboczach narastających wszystkich sygnałów sterujących bramkami tranzystorów MOSFET (jak pokazano na rys. 6.3b), możliwe jest osiągnięcie w przybliżeniu przełączanie tranzystorów przy zerowym napięciu (ZVS), co zapobiega prądom skrośnym w procesach przełączania. Aby zaimplementować to opóźnienie, zastosowano 2-wejściową bramkę AND sterownika bramki UCC27537 z wejściami Schmitt-Trigger (rys. 6.3d). Wyjście sterownika bramki jest połączone z bramką tranzystora MOSFET poprzez rezystor R<sub>G</sub> i antyrównoległą diodę Schottky'ego, zapewniając zwiększenie prędkości wyłączania. Uziemienie GND1 sterownika DPWM jest izolowane od pływającego uziemienia GND sterownika bramkowego za pomocą cyfrowego izolatora ISO7420 z barierą izolacyjną wykonaną z dwutlenku krzemu (SiO2).



Rys. 6.3. Wzmacniacz audio klasy BD ze zrównoważonym wyjściem CM, z rozbudowanym cyfrowym modulatorem LBDD PWM: a) Schemat ideowy stopnia wyjściowego; b) Przebiegi czasowe na wyjściach modulatora i stopnia wyjściowego wzmacniacza; c) Schemat logiczny rozbudowanego modulatora LBDD PWM; d) Sterownik bramkowy z pływającym napięciem zasilającym typu "floating" oraz z galwaniczną izolacją sygnału sterującego LBDD PWM

Na rys. 6.3d pokazano również obwód samodoładowującej się pompy ładunkowej [17], generujący zmienne zasilanie dla sterownika bramki tranzystora M2, przy czym to samo rozwiązanie stosuje się do wszystkich innych tranzystorów MOSFET. Ciągłe przełączanie MCP1 zapewnia, że izolowane i zmienne zasilanie polaryzacyjne pompy ładującej jest dostępne przez cały czas dla odpowiedniego sterownika, niezależnie od indeksu modulacji M i bez jakiejkolwiek ingerencji w żądaną sekwencję przełączania odnogi fazowej.

Znacznie prostsze rozwiązania dla systemów sterowania bramkami można zastosować, gdy stopień wyjściowy wzmacniacza jest zaimplementowany na komplementarnych parach MOSFET.

Jak pokazano na rys. 6.4, sterowniki bramek wszystkich tranzystorów MOSFET mają wspólną masę GND1 i są sterowane bezpośrednio z wyjść modulatora LBDD PWM. Schemat blokowy modulatora LBDD PWM jest również prostszy (rys. 6.4d), ponieważ stopień wyjściowy realizowany na komplementarnych parach MOSFET nie wymaga par komplementarnych sygnałów sterujących.

Biorąc pod uwagę, że tranzystory M6 i M8 zasilane są połową napięcia  $V_{_{DD}}/2$ , napięcie zasilania  $V_{_{DD}}$  tego układu powinno mieścić się w ograniczonym zakresie opisanym nierównościami:

$$2\left|V_{GS\min}\right|_{\operatorname{at} R_{DS(\operatorname{centmax})}} > \frac{V_{DD}}{2} \quad ; \quad V_{DD} < \left|V_{GS\max}\right| \quad \text{and} \quad V_{DD} < \left|V_{DS\max}\right| \quad (6.3)$$

Przy wyższym napięciu bramki niż  $|V_{GS \min}|$ , rezystancja źródło-dren w stanie włączenia  $R_{DS (\text{on}) \max}$  będzie mniejsza niż pewna wartość, przy której straty mocy przewodzenia są nadal akceptowalne, gdzie  $|V_{DS \max}|$ i  $|V_{GS \max}|$  są maksymalnymi, dopuszczalnymi wartościami dla komplementarnych tranzystorów MOSFET.

Najczęściej  $|V_{GSmax}| < |V_{DSmax}|$ , co przekłada się na warunek:  $V_{DD} < |V_{GSmax}|$ , w związku z czym nie jest możliwe użycie napięcia zasilania wyższego niż:

$$V_{DS\max}: V_{DD} < |V_{DS\max}|$$
(6.4)

Przedstawiony na rys. 6.4c sterownik bramki posiada możliwość niezależnej regulacji prędkościami załączania i wyłączania dla NMOSFET i PMOS-FET. Rezystor  $R_{g}$  umożliwia regulację prędkości załączania tranzystora MOSFET ( $R_{gn}$  pozwala na regulację czasu opóźnienia narastających zboczy sygnału LBDD PWMPWM, natomiast  $R_{gp}$  pozwala na niezależną regulację czasu opóźnienia zboczy opadających). Podczas wyłączania, antyrównoległa dioda Schottky'ego bocznikuje rezystor szeregowy  $R_c$ , dodatkowo ładunek bramki jest pobierany z równoległego kondensatora C ładowanego do napięcia Zenera  $V_z$ , zapewniając zwiększenie prędkości wyłączania. W czasie załączenia przełącznika niewielki prąd stały płynie w przesuwniku poziomu napięcia, utrzymując sterownik we właściwym stanie.



Rys. 6.4. Wzmacniacz audio klasy BD ze zrównoważonym wyjściem CM, z rozbudowanym cyfrowym modulatorem LBDD, zaimplementowany na komplementarnych parach MOSFET: a) Schemat ideowy stopnia wyjściowego; b) Przebiegi czasowe na wyjściach wzmacniacza; c) Sygnały sterujące LBDD PWM z opóźnionymi czasami załączania tranzystorów NMOS i PMOS; d) Schemat logiczny rozbudowanego modulatora LBDD PWM

Na rys. 6.5a przedstawiono schemat ideowy oryginalnego wzmacniacza audio klasy BD ze zrównoważonym wyjściem w trybie CM, zaimplementowany na komplementarnych parach MOSFET i sterowany z rozbudowanego modulatora LPSC PWM.

Na rys. 6.5b przedstawiono przebiegi napięć na wyjściach DM i CM wzmacniacza oraz logiczne kombinacje sygnałów sterujących  $\bar{S}_1$ ,  $\bar{S}_2$ ,  $\bar{S}_3$ , z opóźnionymi czasami załączania tranzystorów NMOS i PMOS. Również w tym przypadku zastosowanie komplementarnych tranzystorów w stopniu mocy znacznie uprościło ich sterowanie, ponieważ sterowniki bramek wszystkich tranzystorów MOSFET mają wspólną masę GND1 i są bezpośrednio sterowane z wyjść rozbudowanego modulatora LPSC PWM.



Rys. 6.5. Wzmacniacz audio klasy BD ze zrównoważonym wyjściem w trybie CM, wykorzystujący modulację LPSC PWM: a) Nowa topologia stopnia wyjściowego; b) Implementacja czasów opóźnienia załączenia NMOS i PMOS; c) Przebiegi czasowe na wyjściach wzmacniacza i sygnały sterujące  $\overline{S}_{1^{\prime}}, \overline{S}_{2^{\prime}}, \overline{S}_{3^{\prime}}$  z opóźnionymi czasami załączania NMOS i PMOS (bezpośrednio na bramkach tych tranzystorów); d) Schemat blokowy rozbudowanego modulatora PSC PWM

Zamiast rezystorów bocznikujących  $R_b$ , aby ustawić oba wyjścia na poziomie  $V_{DD}/2$  (jak na rys. 6.2b), utworzono dodatkowy mostek H z tranzystorów M5, M7 i M6, M8, jednak dolna i górna strona nowego mostka H są podłączone do tego samego źródła zasilania  $V_{DD}/2$  przez przeciwnie spolaryzowane diody Schottky'ego.

Dwie równoległe gałęzie dwóch szeregowo połączonych tranzystorów NMOSFET (M6, M8) lub PMOSFET (M5, M7) są połączone równolegle z obciążeniem i służą do bocznikowania dwukierunkowego indukcyjnego prądu obciążenia, gdy M1–M4 są wyłączone oraz do ustawienia obu wyjść niesymetrycznych wzmacniacza na poziomie przy  $V_{DD}$ /2. Implementacja czasów opóźnienia załączania tranzystorów NMOS i PMOS tak, jak pokazano na rys. 6.5b, pozwala na niezależną regulację czasów opóźnienia narastających i opadających zboczy sygnałów na bramkach tych tranzystorów.

Układ przedstawiony na rys. 6.5.a można zrealizować z wykorzystaniem tylko NMOSFET-ów, ale należy zapewnić izolację galwaniczną w torze transmisji sygnałów sterujących oraz izolowane i pływające zasilanie sterowników bramek.

### 6.3. Wyniki symulacji w programie SPICE i badania eksperymentalne wzmacniaczy audio klasy DB ze zrównoważonym wyjściem wspólnym w trybie CM

Symulacje w programie SPICE i badania eksperymentalne posłużyły do porównania parametrów proponowanych wzmacniaczy klasy BD ze zbalansowanym wyjściem w trybie CM z prototypem wykorzystującym optymalny schemat modulacji NBDD PWM. Wszystkie wzmacniacze klasy BD zostały przetestowane dla dwóch różnych częstotliwości przełączania:  $F_{c1} = 328$  kHz oraz  $F_{c2} = 164$  kHz, używając dla każdej częstotliwości przełączania dwóch różnych zestawów rezystancji obciążenia, a także wartości parametrów filtra wyjściowego LC: 1),  $R_L = 4 \Omega$ ,  $L = 15 \mu$ H, C = 1.8  $\mu$ F; 2),  $R_L = 8 \Omega$ ,  $L = 33 \mu$ H, C = 1  $\mu$ F.

Ponieważ proponowane wzmacniacze na rys. 6.4 i 6.5 zbudowane są na komplementarnych tranzystorach MOSFET, a przyłożone napięcie zasilania  $V_{DD}$  = 24V przekracza napięcie  $V_{GSmax}$  (nierówność 6.3), konieczne było zastosowanie układu przesuwania poziomu napięcia z diodą Zenera ( $V_z$  = 6.2 V) w celu obniżenia amplitudy napięcia sterującego z wyjścia sterownika bramki (za wyjątkiem tranzystorów MOSFET, których źródła są podłączone do połowy napięcia  $V_{DD}$  / 2, tj. wirtualnej masy GND "0"V).

Na rys. 6.6a, 6.6b przedstawiono przebiegi czasowe sygnałów sterujących, generowanych na wyjściach rozbudowanych modulatorów: LBDD PWM lub LPSC PWM w jednym wybranym okresie kluczowania  $T_c$ , oraz prądy drenów: od I (M1: D) do I (M4: D) i od I (M5: D) do I (M8: D) tranzystorów mocy MOSFET we wzmacniaczach mocy pokazanych odpowiednio: a) na rys. 4; b) na rys. 5.

Optymalne czasy opóźnienia załączania tranzystorów MOSFET zostały dostosowane poprzez dobranie wartości rezystancji  $R_{_{Gn}}$  i  $R_{_{Cp}}$  (rys. 6.4c i rys. 6.5b). W badanych układach wzmacniaczy, dla  $R_{_{Gp}} = 68 \Omega \text{ oraz } R_{_{Gn}} = 150 \Omega$ otrzymujemy optymalne czasy opóźnienia załączania tranzystorów oraz znaczne ograniczenie prądów skrośnych.



Rys. 6.6. Przebiegi czasowe sygnałów sterujących LPWM generowanych w jednym wybranym okresie  $T_c$  oraz prądy drenów tranzystorów mocy w układach pokazanych odpowiednio: a) na rys. 4; b) na rys. 5

Na rys. 6.7a, b, c przedstawiono sprawność energetyczną i moc wyjściową w funkcji wskaźnika modulacji *M*, a także *THD* w funkcji częstotliwości wejściowego sygnału akustycznego dla trzech różnych wzmacniaczy klasy BD: 6.7a) – wzmacniacza z rys. 6.1 z konwencjonalnym modulatorem NBDD PWM; 6.7b) – wzmacniacza z rys. 6.4 z rozbudowanym modulatorem LBDD PWM; 6.7c) – wzmacniacza z rys. 6.5 z rozbudowanym modulatorem LPSC PWM. Charakterystyki te wyznaczono dla dwóch różnych częstotliwości przełączania, przy dwóch zestawach wartości rezystancji obciążenia oraz wartości parametrów filtra wyjściowego LC, dla każdej częstotliwości. Jak widać, charakterystyki mocy wyjściowej wszystkich trzech wzmacniaczy są prawie identyczne, podczas gdy sprawności dwóch proponowanych wzmacniaczy, zawierających cztery dodatkowe przełączniki tranzystorowe do równoważenia wyjść wspólnych w trybie CM, są nieco niższe w porównaniu ze sprawnością prototypowego wzmacniacza z modulatorem NBDD PWM, ze względu na dodatkowe straty mocy w stanach przewodzenia i w procesach przełączania w tych dodatkowych przełącznikach tranzystorowych.

Filtracja niepożądanych składowych widma na wyjściu DM wszystkich trzech testowanych wzmacniaczy jest bardzo łatwa, dla obu stosowanych częstotliwości przełączania, ponieważ widmo częstotliwości nie zawiera harmonicznych częstotliwości przełączania i nie ma składowych IM wokół nieparzystych wielokrotności częstotliwości przełączania. Jak widać na rys. 6.7, wszystkie testowane wzmacniacze wykazują jednak niewielkie zniekształcenia na wyjściach różnicowych DM, spowodowane zniekształconymi sekwencjami zmodulowanych impulsów DPWM, generowanych przez stopnie wyjściowe tych wzmacniaczy.



a) Wzmacniacz klasy BD pokazany na rys. 6.1 z konwencjonalnym modulatorem LBDD



#### b) Wzmacniacz klasy BD pokazany na rys. 6.4 z rozszerzonym modulatorem LBDD PWM

c) Wzmacniacz klasy BD pokazany na rys. 6.5 z rozszerzonym modulatorem LPSC PWM



Rys. 6.7. Sprawność i moc wyjściowa w funkcji wskaźnika modulacji *M* oraz *THD* w funkcji częstotliwości sygnału audio dla trzech wzmacniaczy pokazanych: a) na rys. 6.1; b) na rys. 6.4; c) na rys. 6.5, odpowiednio

Największy udział w generacji zniekształceń nieliniowych na wyjściu różnicowm DM mają błędy wprowadzane przez procesy przełączania tranzystorów MOSFET, wynikające w szczególności z wprowadzanych do sygnałów sterujących czasów opóźnienia załączania tranzystorów.

Na podstawie rys. 6.7a, b, c możemy zaobserwować następujące interesujące właściwości. Opracowane wzmacniacze klasy BD ze zrównoważonym wyjściem wspólnym CM mają nieco wyższe *THD* niż prototypowy wzmacniacz na rys. 6.1 z konwencjonalną modulacją NBDD PWM. Dzieje się tak, ponieważ proponowane wzmacniacze są sterowane przez modulatory generujące sygnały sterujące o rozszerzonym "timingu", co daje więcej błędów czasowych, takich jak: czasy opóźnień,  $t_{on}/t_{off}$ ,  $t_r/t_f$  dodawanych w każdym okresie przełączania  $T_c$  przez sterowniki bramek.



Rys. 6.8. Symulowane odpowiedzi częstotliwościowe THD + N trzech testowanych wzmacniaczy w paśmie do 30 kHz

Współczynnik *THD* wszystkich testowanych wzmacniaczy jest wyższy dla wyższej częstotliwości przełączania  $F_{c1}$  = 328 kHz niż dla  $F_{c2}$  = 164 kHz, ponieważ względne błędy taktowania są większe dla krótszego okresu przełączania  $T_c$ .

a) Wyjścia lewej połowy i prawej połowy mostka H przed (po lewej) i po (po prawej) filtracji



Rys. 6.9. Oscylogramy zmierzone na następujących wyjściach wzmacniacza klasy BD na rys. 6.5: a) Wyjścia lewej gałęzi i prawej gałęzi mostka H; b) Wyjście DM; c) Wyjście CM (w lewej kolumnie przed, w prawej kolumnie po filtracji)  $F_{c2} = 164$  kHz,  $f_m = 10$  kHz; w pionie: 5V/div; w poziomie: 5us/div;  $V_{pp} = 24$  V

Na rys. 6.8a, b, c przedstawiono symulowane odpowiedzi częstotliwościowe THD + N w paśmie do 30 kHz, dla trzech testowanych wzmacniaczy przy dwóch częstotliwościach przełączania:  $F_{c1} = 328$  kHz,  $F_{c2} = 164$  kHz, przy częstotliwości sygnału akustycznego  $f_m = 1$  kHz, indeksie modulacji M = 0.95, rezystancji obciążenia  $R_L = 8 \Omega$  i parametrach filtru:  $L = 33 \mu H$ , C = 1 µF.

Na rys. 6.9 przedstawiono oscylogramy napięcia zmierzone na następujących wyjściach badanego wzmacniacza klasy BD z modulatorem LPSC PWM, przedstawionego na rys. 6.5: Lewa gałąź półmostka, Prawa gałąź półmostka, Wyjście różnicowe DM, Wyjście wspólne w trybie CM przed i po filtracji. Podobne oscylogramy otrzymujemy dla wzmacniacza klasy BD na rys. 6.4 z modulatorem LBDD PWM.

Porównanie napięć wyjściowych na lewej gałęzi półmostka, prawej gałęzi półmostka i na wyjściu wspólnym CM, przedstawione na rys. 6.9 pokazuje, że rzeczywiste przebiegi czasowe są zniekształcane przez nakładające się piki na narastających i opadających zboczach impulsu DPWM w każdym okresie przełączania. Głównym źródłem tych pików są błędy czasowe dodawane w każdym okresie przełączania  $T_c$  przez sterowniki bramek, takie jak czas martwy,  $t_{on}/t_{off}$ ;  $t_r/t_f$ .

Nieuchronność błędów taktowania wynika z faktu, że czasy opóźnienia włączenia tranzystorów NMOS i PMOS muszą być realizowane przez niezależną regulację czasów opóźnienia narastających i opadających zboczy sygnałów sterujących LBDD PWM lub LPSC PWM. Nawet przy równych czasach opóźnienia włączenia NMOS i PMOS, w czasie martwym prąd cewki indukcyjnej na wyjściu LPF włącza diodę podłożową. Podczas następnej fazy, gdy następuje przełączenie tranzystorów MOSFET w obu gałęziach mostka pod koniec czasu martwego, dioda podłożowa pozostaje w stanie przewodzenia do czasu, aż zmagazynowane nośniki mniejszościowe w bazie diody zostaną całkowicie usunięte. Ten zwrotny prąd wsteczny ma zwykle kształt piku i prowadzi do niepożądanych zniekształceń przez nakładanie się impulsów na narastających i opadających zboczach impulsów DPWM w każdym okresie przełączania. Jednak filtracja pojawiających się skoków na wyjściu CM jest bardzo łatwa, nawet gdy indukcyjność filtra L jest bardzo mała, co pokazuje oscylogram na rys. 6.9.

#### 6.4. Ocena uzyskanych wyników

Od strony teoretycznej, jak i praktycznej, opisano i przetestowano dwa oryginalne wzmacniacze audio klasy BD z otwartą pętlą i zrównoważopnymi wyjściami w trybie wspólnym CM. Stopień wyjściowy każdego proponowanego wzmacniacza zawiera typowy mostek H z czterema tranzystorami MOSFET i czterema dodatkowymi przełącznikami MOSFET, które równoważą i utrzymują stałą wartość napięcia na wyjściu wspólnym w trybie CM.

Każdy ze wzmacniaczy wykorzystuje rozbudowany schemat modulacji cyfrowej LBDD PWM lub LPSC PWM i został zaimplementowany na komplementarnych parach MOSFET. Symulacje SPICE i badania eksperymentalne wykazały, że proponowane wzmacniacze mają podobną wydajność audio do prototypu z optymalnym schematem modulacji NBDD PWM, a jednocześnie mają zrównoważone wyjście wspólne CM, ze stałą wartością napięcia  $V_{_{DD}}/2$  na tym wyjściu.

Filtracja niepożądanych składowych widma na wyjściu różnicowym w trybie DM testowanych wzmacniaczy jest bardzo łatwa, ponieważ widmo częstotliwości nie zawiera harmonicznych częstotliwości przełączania i nie ma składowych IM wokół nieparzystych wielokrotności częstotliwości przełączania. Ponieważ wzmacniacze te jednocześnie mają zrównoważone wyjście wspólne CM, ze stałą wartością napięcia  $V_{_{DD}}/2$  na tym wyjściu, to można radykalnie ograniczyć, a raczej wyeliminować filtr wyjściowy.

Są to w pełni bezfiltrowe wzmacniacze klasy BD ze zrównoważonym wyjściem wspólnym w trybie CM. Stopnie końcowe tych wzmacniaczy mogą być sterowane przez rozbudowane modulatory, zarówno analogowe NBDD PWM lub PSC PWM, jak i cyfrowe LBDD PWM lub LPSC PWM.

Proponowane wzmacniacze klasy BD mają nieco wyższe *THD* niż prototypowy konwencjonalny wzmacniacz z modulacją LBDD PWM, ponieważ są sterowane przez rozbudowane modulatory, co daje więcej błędów taktowania dodawanych w każdym okresie przełączania  $T_c$  przez sterowniki bramek. Współczynnik *THD* wszystkich testowanych wzmacniaczy jest wyższy dla wyższej częstotliwości przełączania  $F_{c1}$  = 328 kHz niż dla  $F_{c2}$  = 164 kHz, ponieważ względne błędy taktowania są większe dla krótszego okresu przełączania  $T_c$ .

We wzmacniaczach klasy BD ze zbalansowanym wyjściem wspólnym CM zaleca się stosowanie niezbyt wysokiej częstotliwości przełączania (w przedstawionym rozwiązaniu  $F_{c2}$  = 164 kHz ), co skutkuje wyższą sprawnością energetyczną i niższymi *THD*, nawet przy zredukowanym filtrze wyjściowym LC.

Rozległe badania symulacyjne w SPICE oraz badania eksperymentalne wykazały, że proponowane wzmacniacze klasy BD mają podobne parametry jak prototypowy wzmacniacz klasy BD z optymalną modulacją NBDD, a jednocześnie posiadają zrównoważone stałe napięcie wyjściowe w trybie CM, co umożliwia realizację bezfiltrowych wzmacniaczy klasy D, jednocześnie eliminując lub znacznie zmniejszając zakłócenia promieniowania elektromagnetycznego (EMI).

W praktyce ze względu na niedoskonałe przebiegi napięć sterujących tranzystorami MOSFET, na wyjściu CM wzmacniacza generowane są krótkie impulsy szpilkowe, łatwe do odfiltrowania przez zredukowany filtr wyjściowy LC, nawet przy bardzo niewielkiej wartości indukcyjności L.

## Wnioski końcowe

Jeden z głównych celów, jakim było opracowanie od strony teoretycznej oraz implementacja cyfrowego, linearyzowanego modulatora szerokości impulsów DPWM z kompensacją wstępną do sterowania nowych, oryginalnych wzmacniaczy akustycznych klasy BD, ze zrównoważonym wyjściem dla sygnałów wspólnych w trybie CM, o stałej wartości napięcia na tym wyjściu, został w pełni zrealizowany.

Dużą część książki poświęcono algorytmom przetwarzania sygnałów niezbędnych do konwersji cyfrowych danych audio, uzyskanych ze źródła, na cyfrowy sygnał o modulowanej szerokości impulsów DPWM. Skoncentrowano się na linearyzowanych, rozbudowanych modulatorach szerokości impulsów LBDD PWM i LPSC PWM z kompensacją wstępną, umożliwiających możliwie jak najwierniejszą emulację naturalnych modulacji NBDD PWM lub PSC PWM.

Wyniki zdefiniowane w teorii, zaprojektowane i przesymulowane w programie Matlab algorytmy kompensacji wstępnej, składające się z bloków modułowych: interpolacji, obliczenia położenia początków i końców czasu trwania impulsu LBDD PWM lub LPSC PWM w *n*-tych okresach kluczowania i kształtowania szumów kwantyzacji, a następnie zostały zaimplementowane w oparciu o metodę hybrydową z wykorzystaniem mikrokontrolera STM32 i programowanych linii opóźniających z odczepami PTDL.

Opracowano w pełni oryginalną architekturę konwertera cyfrowo-czasowego DTC, który konwertuje rekwantyzowane dane cyfrowe, określające położenie początków  $t_p(n)$  *i* końców  $t_k(n)$  impulsów DPWM w kolejnych n-tych okresach przełączania  $T_c$ , w fizyczny ciąg 1-bitowych impusów o modulowanej szerokości do sterowania stopniem wyjściowym wzmacniacza klasy D, a następnie został on zaimplementowany w oparciu o mikrokontroler STM32 i programowaną linię opóźniającą PTDL.

Zaproponowano nową i oryginalną architekturę oraz implementację 9-bitowego (10-bitowego) zlinearyzowanego układu modulatora LBDD PWM dla cyfrowego wzmacniacza mocy klasy BD. Cały algorytm przetwarzania sygnałów i danych w modulatorze został zaimplementowany w oparciu o metodę hybrydową z wykorzystaniem mikrokontrolera STM32, wraz z jego urządzeniami peryferyjnymi oraz dwóch ogólnodostępnych, katalogowych, 3-bitowych programowalnych linii opóźniających PTDL. Przeprowadzono obszerną weryfikację algorytmów przetwarzania sygnałów i danych, zaimplementowanego układu, a także symulację w programie Matlab oraz badania eksperymentalne proponowanego 9-bitowego hybrydowego modulatora LBDD PWM.

Porównanie współczynników *THD* symulowanych w programie Matlab wskazuje, że nawet prosty algorytm LBDD (przy Q = 1), wykorzystujący rekurencyjny model kształtowania szumu kwantyzacji z dwoma pętlami sprzężenia zwrotnego pozwala na znaczną poprawę liniowości modulatora, w porównaniu z innymi rodzajami modulacji DPWM. W przypadku wyższych wartości Q, modulator LBDD może dodatkowo zmniejszyć poziomy *THD*, zbliżając się do optymalnego analogowego modulatora NBDD.

6-MSB bitowy kwantyzator oparty na metodzie licznikowej charakteryzuje się stosunkowo niezbyt dużym stopniem skomplikowania i wykazuje doskonałą liniowość konwersji cyfrowo-czasowej. W tym celu wszystkie bloki funkcjonalne w systemie muszą być idealnie zsynchronizowane, a okres przełączania  $T_c$  w podsystemach LADD<sub>L</sub> PWM i LADD<sub>R</sub> PWM musi rozpocząć się w tym samym czasie.

Praktycznie zmierzony poziom *THD* na wyjściu modulatora LBDD PWM ma nieco wyższy poziom niż uzyskany w symulacji Matlab. Jednak z praktycznego punktu widzenia są one całkiem zadowalające, zapewniając *SNR* na poziomie 80 dB i *THD* niższe niż 0,3% w paśmie podstawowym audio do 20 kHz.

Zaletą cyfrowego modulatora LBDD PWM jest również łatwe programowanie odpowiedniego czasu opóźnienia na zboczach narastających wszystkich sygnałów sterujących tranzystorami MOSFET stopnia mocy, co w praktyce pozwala ograniczyć prądy skrośne w procesach przełączania tranzystorów.

Unikalną zaletą opracowanego 9-bitowego (10-bitowego) modulatora LBDD PWM dla cyfrowego wzmacniacza klasy BD częstotliwości akustycznych jest to, że jego podstawową konfigurację można zaimplementować za pomocą tylko mikrokontrolera STM32, dwóch ogólnie dostępnych katalogowych 3-bitowych programowalnych linii opóźniających PTDL i kilkunastu standardowych bramek logicznych.

Drugim, ważnym celem badań było opracowanie oryginalnych nowych architektur wzmacniaczy akustycznych klasy BD, charakteryzujących się zrównoważonym wyjściem dla sygnałów wspólnych, tj. posiadających stałe napięcie na wyjściu sumacyjnym w trybie CM. Stopień wyjściowy proponowanych wzmacniaczy audio klasy BD zawiera typowy mostek H z czterema tranzystorami MOSFET oraz cztery dodatkowe przełączniki MOSFET, które równoważą i utrzymują stałą wartość napięcia na wyjściu sumacyjnym w trybie wspólnym. Przedstawione w pracy wzmacniacze klasy BD wykorzystują rozbudowane schematy modulacji LBDD PWM lub LPSC PWM.

Gdy stopień wyjściowy jest zbudowany tylko na tranzystorach NMOSFET, sterowniki bramek wymagają zasilania typu "floating", a sygnały sterujące bramkami tranzystorów muszą być izolowane galwaniczne. Zastosowanie komplementarnych tranzystorów MOSFET w stopniu wyjściowym znacznie upraszcza systemy sterowania bramkami. Proponowane wzmacniacze zostały porównane pod względem parametrów wyjściowych w trybie różnicowym (DM) i trybie wspólnym (CM) ze wzmacniaczem klasy BD w typowej konfiguracji mostka H, sterowanego z modulatora NBDD PWM.

Obszerne badania symulacyjne w programie SPICE oraz badania eksperymentalne wykazały, że proponowane wzmacniacze klasy BD mają podobne parametry jak prototypowy wzmacniacz klasy BD z optymalną modulacją NBDD, a jednocześnie mają zrównoważone wyjście dla sygnałów wspólnych o stałym napięciu, umożliwiając tym samym realizację bezfiltrowych wzmacniaczy klasy D. Filtracja niepożądanych składowych widma na wyjściu różnicowym w trybie DM testowanych wzmacniaczy jest bardzo łatwa, ponieważ widmo częstotliwości nie zawiera harmonicznych częstotliwości przełączania i nie ma składowych IM wokół nieparzystych wielokrotności częstotliwości przełączania. Ponieważ wzmacniacze te jednocześnie mają zrównoważone wyjście wspólne CM, ze stałą wartością napięcia na tym wyjściu, to można radykalnie ograniczyć , a raczej wyeliminować filtr wyjściowy, przy równoczesnej eliminacji lub znacznym ograniczeniu zakłóceń elektromagnetycznych radiacyjnych (EMI). Są to w pełni bezfiltrowe wzmacniacze klasy BD ze zrównoważonym wyjściem wspólnym w trybie CM.

- 1. W. Marshall Leach, Jr, "Introduction to Electroacoustics and Audio Amplifier Design, Second Edition – Revised Printing", published by Kendall/Hunt, 2001.
- 2. D. Dapkus, "Class-D audio power amplifiers: an overview", Digest of Technical Papers. Proc. of the International Conference on Consumer Electronics 2000, Los Angeles, CA, June 2000, pp. 400-40.
- 3. H.-S. Kim, S.-W. Jung, H.-M. Jung, J.-K. Shin, "Low Cost Implementation of Filterless Class D Audio Amplifier with Constant Switching Frequency", IEEE Transactions on Consumer Electronics, Vol. 52, No. 4, November, 2006, pp.1442-1446.
- M.A. Teplechuk, A. Gribben, Ch. Amadi, "True Filterless Class-D Audio Amplifier", IEEE Journal of Solid-State Circuits, Vol. 46, No. 12, December 2011, pp. 2784-2793.
- K.-H. Kong, Y.-W. Kim, S. Kim, K.-H. Baek, "Power-Efficient Digital Amplifier Using Input Dependent BitFlipping for Portable Audio Systems", IEEE Transactions on Consumer Electronics, Vol. 56, No. 4, November 2010, pp. 2406-2410.
- 6. A. Ikriannikov, N.A. Wilson, "New Concept for Class D Audio Amplifiers for Lower Cost and Better Performance", IEEE Transactions on Consumer Electronics, Vol. 57, No. 3, August 2011, pp. 1218-1226.
- M. Berkhout, L. Dooper, "Class-D Audio Amplifiers in Mobile Applications". IEEE Transactions On Circuits And Systems-I: Regular Papers, Vol. 57, No. 5, May 2010, pp. 991-1002.
- 8. P.P. Siniscalchi, R.K. Hester, "A 20W/channel class-D amplifier with near-zero common-mode radiated emissions", IEEE J. Solid-State Circuits, Vol. 44, No. 12, December 2009, pp.33264-33271.
- 9. J. Jasielski, W. Kołodziejski, S. Kuta, "Cancellation of common-mode output signal in Class-BD audio amplifiers", IEEE Xplore, 2016 Int. Conf. on Signals and Electronic Systems (ICSES), 5-7 Sept. 2016. Krakow, Poland.
- W. Kołodziejski, S. Kuta, J. Jasielski, "Open-Loop Class-BD Audio Amplifiers with Balanced Common Mode Output", Journals Electronics Volume10 Issue12 2021 10.3390 electronics 10121381.
- 11. P. Balmelli, J.M. Khoury, E. Viegas, P. Santos, V. Pereira, J. Alderson, R. Beale, "A Low-EMI 3-W Audio Class-D Amplifier Compatible With AM/FM Radio", IEEE Journal of Solid-State Circuits, Vol. 48, No. 8, August 2013, pp. 1771-1782.
- 12. Y.S. Hwang, J.H. Shen, J.J. Chen, M.R. Fan, "Performance comparison of integrated fully-differential filterless class-D amplifiers with different feedback techniques", Analog Integrated Circuits and Signal Processing, 2013, Vol. 76, pp. 167-177.
- 13. T. Ge J.S. Chang, "Filterless class D amplifiers: power-efficiency and power dissipation" IET Circuits, Devices and Systems, 2010, Vol. 4, Iss. 1, pp. 48–56.

- 14. T. Igarashi, N. Komine, L. Taihua, et al.: "New Method Class D Amplifier Which Enables Reduction of RF Noise and Signal Distortion" IEEE 10th International New Circuits and Systems Conference, Montreal, Quebec, Canada, 17-20 June 2012.
- L. Guo, Tong Ge, J.S. Chang, "A 101 dB PSRR, 0.0027% THD + N and 94%Power-Efficiency Filterless Class D Amplifier", IEEE J. Solid-State Circuits, Vol. 49, No. 11, November 2014, pp. 2608-2617.
- F. Guanziroli, R. Bassoli, C. Crippa, D. Devecchi, G. Nicollini, "A 1 W 104 dB SNR Filter-Less Fully-Digital Open-Loop Class D Audio Amplifier With EMI Reduction", IEEE Journal Of Solid-State Circuits, Vol. 47, No. 3, March 2012, pp. 686-698.
- 17. Copyright©2021 Maxim Integrated, "Reduce EMI from Class D Amplifiers Using New Modulation Techniques and Filter Architectures", Application Note 3878, Aug. 18, 2006, pp. 1-11.
- P. Midya, W.J. Roeckner, "Filterless Class D Amplifiers: Power-Efficiency and Power Dissipation", IET Circuits, Devices & Systems, Vol. 4, Issue 1, January 2010, p. 48-56.
- Shih-Hsiung Chien, Li-Te Wu, Ssu-Ying Chen, at al., "An Open-Loop Class-D Audio Amplifier with Increased Low-Distortion Output Power and PVT-Insensitive EMI Reduction", Proc. of the IEEE 2014 Custom Integrated Circuits Conference, San Jose, 15-17 Sept. 2014.
- Shih-Hsiung Chien, Li-Te Wu, Ssu-Ying Chen, Ren-Dau Jan, Min-Yung Shih, Ching--Tzung Lin, Tai-Haur Kuo, "An Open-Loop Class-D Audio Amplifier with Increased Low-Distortion Output Power and PVT-Insensitive EMI Reduction", Proc. of the IEEE Custom Integrated Circuits Conference, San Jose, CA, USA, 15-17 Sept. 2014.
- T. Mouton, B. Putzeys, "Digital Control of a PWM Switching Amplifier with Global Feedback", Proc. Of AES 37-th International Conference, Hillerod, Denmark, 2009 August 28-30, pp. 1-10.
- R. Cellier, G. Pillonnet, A. Nagari, N. Abouchi, "A Review of Fully Digital Audio Class D Amplifiers Topologies", Circuits and Systems and TAISA Conference, 2009. NEWCAS-TAISA '09. Joint IEEE North-East Workshop, June 28-July 1, 2009.
- 23. Yi Hwa Liu, "Novel Modulation Strategies for Class-D Amplifier", IEEE Trans. on Consumer Electronics, Vol. 53, Issue: 3, 2007, pp. 987-994.
- 24. Copyright©2021 Maxim Integrated, "Class D Amplifiers: Fundamentals of Operation and Recent Developments", Application Note 3977, 31 Jan, 2007.
- J.M. Liu, S.H. Chien, T.H. Kuo, "A 100 W 5.1-Channel Digital Class-D Audio Amplifier With Single-Chip Design", IEEE J. Solid-State Circuits, Vol. 47, No. 6, June 2012, pp. 1344-1354.

- Luo Shumeng and Li Dongmei, "A digital input class-D audio amplifier with sixth-order PWM", Journal of Semiconductors, Vol. 34, No. 11, November, 2013, pp. 115001-1 - 115001-6.
- L. Dooper, M. Berkhout, "A 3.4 W Digital-In Class-D Audio Amplifier in 0.14 μm CMOS", IEEE Journal of Solid-State Circuits, Vol. 47, No. 7, July 2012, pp. 1524-1534.
- M. Wang, X. Jiang, J. Song, T. L. Brooks, "A 120 dB Dynamic Range 400 mW Class--D Speaker Driver With Fourth-Order PWM Modulator", IEEE Journal of Solid--State Circuits, Vol. 45, No. 8, August 2010, pp. 1427-1435.
- 29. B.H. Gwee, J.S. Chang, V. Adrian, "A micropower low-distortion digital Class-D amplifier based on an algoritmic pulse width modulator", IEEE Transactions on Circuits and Systems I :Reg. Papers, Vol. 52. No. 10, pp. 2007-2022, Oct. 2005.
- 30. A.E. Grant, J.R. McKissick, J.H. Meadows: Communication Technology Update and Fundamentals. 2010, s. 232.
- S. Kuta, "Ograniczenia wzmacniaczy mocy z impulsową pracą elementów aktywnych", Zeszyty Naukowe AGH, Nr 914, Automatyka, Zeszyt 30, Kraków, 1982, ss. 1-131.
- 32. K. Nielsen, "Audio Power Amplifier Techniques With Energy Efficient Power Conversion", Ph. D. Thesis, Tech. Univ. of Denmark April 30, 1998.
- M. Johansen, K. Nielsen, "Parallel Phase Shifted Carrier Pulse Width Modulation (PSCPWM) – A Novel Approach to Switching Power Amplifier Design", 102nd AES Convention, March 22-25, Munich, Germany, 1997.
- 34. D. Jacobs, "Digital Puls Width Modulation for Class-D Audio Amplifier", Ph. D. Thesis, University of Stellenbosch, April, 2006.
- F.S. Christensen, T.M. Frederiksen, K. Nielsen, "Paralleled Phase Shifted Carrier Pulse Width Modulation (PSCPWM) Schemes a Fundamental Analysis". 106th AES Convention, 1999 May 9-11, Munich, Preprint 4917 (GJ3).
- 36. M. Bloechl, M. Bataineh, D. Harrell, "Class D Switching Power Amplifiers: Theory, Design, and Performance", IEEE SoutheastCon, 2004. Proceedings, pp. 1-11
- C. Pascual, Z. Song, P.T. Krein, et. al., "High-Fidelity PWM Inverter for Digital Audio Amplification: Spectral Analysis, Real-Time DSP Implementation, and Results", IEEE Transactions on Power Electronics, Vol. 18, No. 1, January, 2003, pp. 474-485.
- S.M. Cox, J. Yu, W.L. Goh, M.T. Tan, "Intrinsic Distortion of a Fully Differential BD-Modulated Class-D Amplifier With Analog Feedback", IEEE Transactions on Circuits and Systems I, Vol. 60, No. 1, January 2013, pp. 63-73.
- Ph. Dondon, M. Cifuentes, G. Tsenov, V. Mladenov, "A practical modelling for the design of a sigma delta class D power switching amplifier and its pedagogical application", Recent Researches in Circuits, Systems and Signal Processing, pp. 93-99.

- 40. M.J. Hawksford, "SDM versus PWM power digital-to-analogue converters (PDAC) in high-resolution digital audio applications", Audio Engineering Society, 118th Convention, 2005 May 28th–31st, Barcelona, Spain, pp. 1-24.
- 41. S. Norsworthy, "Optimal Nonrecursive Noise Shaping Filters For Oversampling Data Converters", 1993 IEEE International Symposium on Circuits and Systems Part 1: Theory, 3-6 May 1993, Chicago, IL, USA, pp.1353-1356.
- 42. J-W Jung, M. J. Hawksford, "An Oversampled Digital PWM Linearization Technique for Digital-to-Analog Conversion", IEEE Transactions on Circuits and Systems I: Regular Papers, Vol. 51, No. 9, pp. 1781-1789, September 2004.
- 43. S. R. Norsworthy, "Optimal Nonrecursive Noise Shaping Filters For Oversampling Data Converters Part 1": Theory, Proc. of 1993 IEEE International Symposium on Circuits and Systems, 3-6 May 1993, Chicago, USA, IEEE Xplore: 06 August 2002.
- 44. W. Kołodziejski, S. Kuta, "Linearized 9-Bit Hybrid LBDD PWMModulator for Digital Class-BD Amplifier", International Journal of Electronics and Telecommunications, 2021, Vol. 67, No. 1, pp. 49-57.
- S. Kuta, W. Kołodziejski, J. Jasielski, "Hybrid Linearized Class-BD Double Sided (LBDD) Digital Pulse Width Modulator (DPWM) for Class-BD Audio Amplifiers", Science, Technology, Innovation, 2017, No. 1, pp. 1-10.
- 46. J. Jasielski, S. Kuta, W. Machowski, W. Kołodziejski, "Hybrid DPWM Implementation Using Coarse and Fine Programmable ADLL", Microelectronics Journal, Elsevier, 2014, Vol. 45, Iss. 9, pp. 1202-1211.
- 47. J. Jasielski, S. Kuta, W. Machowski, W. Kołodziejski, I. Brzozowski, "Double edge class BD hybrid DPWM implementation using linearized LBDD algorithm", Mixed Design of Integrated Circuits & Systems (MIXDES), 2014 Proceedings of the 21<sup>st</sup> International Conference, Date 19-21 June 2014, pp. 209-214.
- J. Jasielski, S. Kuta, W. Machowski, W. Kołodziejski, "Hybrid LBDD PWM Modulator for Digital Class-BD Audio Amplifier Based on STM32F407VGT6 Microcontroller and Analog DLL", Mixed Design of Integrated Circuits & Systems (MIXDES), 2015 Proceedings of the 22st International Conference, Date 25-27 June 2015.
- 49. W. Kołodziejski, S. Kuta, J. Jasielski, "Current controlled delay line elements' improvement study", ICSES 2012, International Conference on Signals and Electronic Systems : 18-21 September 2012, Wrocław, Poland.
- W. Kołodziejski, S. Kuta, J. Jasielski, "Analog delay line elements with wide range controlled-delay", Elektronika, konstrukcje, technologie, zastosowania (Warszawa); ISSN 0033-2089. Tytuł poprz.: Przegląd Elektroniki 2013 R. 54 nr 2, s. 26-32.
- 51. J. Jasielski, S. Kuta, W. Machowski, W. Kołodziejski, "An Analog Dual Delay Locked Loop Using Coarse and Fine Programmable Delay Elements", Proceedings of the 20-th International Conference MIXED DESIGN OF INTEGRATED CIRCU-ITS AND SYSTEMS MIXDES 2013, Gdynia, Poland, June 2013.

- B.H. Gwee, J.S. Chang, H. Li, "A Micropower Low-Distortion Digital Pulsewidth Modulator for a Digital Class D Amplifier, IEEE Transactions on Circuits And Systems I: Analog and Digital Signal Processing", Vol. 49, No. 4, April 2002, pp. 245-2256.
- 53. A. Syed, E. Ahmed, D. Maksimovic, E. Alarcon, "Digital pulse width modulator architectures", Proc. IEEE Power Electron. Spec. Conf., Vol. 6, 2004, pp. 4689-4695.
- 54. Ch. Morrison, S. Weiss, M. Macleod and R. Stewart, "Comparison of Single- and Double-Sided Pulse Width Modulated Signals with Non-Linear Predistortion", Proceedings of the 5th European DSP Education and Research Conference, 2012, Amsterdam, pp. 271-275.
- 55. V. Yousefzadeh, T. Takayama, D. Maksimovic, "Hybrid DPWM with digital delaylockedloop", in: Proceedings of the IEEE COMPEL Workshop, Rensselaer Polytechnic Institute, Troy, NY, USA, July 16-19, 2006, pp. 142-148.
- A. de Castro, G. Sutter, S. C. Huerta, J. A. Cobos, "High Resolution Pulse Width Modulators in FPGA", 3rd Southern Conference on Programmable Logic, (SPL '07), Feb. 2007, pp. 137-142.
- 57. X. Shen, X. Wu, J. Lu, L. Qin, "Hybrid DPWM with Analog Delay Locked Loop", Proc. of the International MultiConference of Engineers and Computer Scientists 2010, Vol II, IMCS 2010 March 17-19, 2010, Hong Kong.
- 58. S.C. Huerta, A. de Castro, O. Garcia, J.A. Cobos, "FPGA-based digital pulsewidth modulator with time resolution under 2 ns", IEEE Trans. Power Electron., vol. 23, no. 6, 2008, pp. 3135-3141.
- K.P. Sozański, "Digital Realization of a Click Modulator for an Audio Power Amplifier", Przegląd Elektrotechniczny (Electrical Review), ISSN 0033-2097, R. 86 NR 2/2010, pp. 353-357.
- 60. G.W. Roberts, M. Ali-Bakhshian, "A Brief Introduction to Time-to-Digital and Digital-to-Time Converters", IEEE Transactions on Circuits and Systems I: Express Briefs, Vol. 57, No. 3, March 2010, pp. 153-157.
- 61. Hai Wang, Min Zhang, Yan Liu, "High-Resolution Digital-to-Time Converter Implemented in an FPGA Chip", Applied Sciences, 2017, Vol.7, Iss.52; pp. 1-11.
- 62. Y.B. Quek, "Class-D LC Filter Design", Application Report SLOA119A–April 2006– Revised January 2008, Texas Instruments, pp. 2-20.
- H.W. Ott, "Understanding and Controlling Common-Mode Emissions in High-Power Electronics", Henry Ott Consultants Livingston, NJ 07039 (973) 992-1793, 2001, pp. 1-5.
- 64. J. Cerezo, International Rectifie, "Class D Audio Amplifier Performance Relationship to MOSFET Parameters", Application Note AN-1070, pp. 1-14.
- 65. Ch.K. Lam, M.T. Tan, S.M. Cox, K.S. Yeo, "Class-D Amplifier Power Stage With PWM Feedback Loop", IEEE Transactions On Power Electronics, Vol. 28, No. 8, pp. 3870-3881, August 2013.

- 66. J. Jasielski , S. Kuta, "Applied methods of power supply and galvanic isolation of gate drivers of power transistors in bridging end stages of Class D amplifiers and inverters", Science, Technology, Innovation, Iss.: 2 (1), 2018, pp. 31-41.
- 67. S. Park, T.M. Jahns, "A Self-Boost Charge Pump Topology for a Gate Drive High--Side Power Supply", IEEE Transactions On Power Ele ctronics, Vol. 20, No. 2, March 2005.
- 68. J. Stevens, "Using a Single-Output Gate-Driver for High-Side or Low-Side Drive", Application Report SLUA669 – March 2013, Texas Instruments, pp. 1-7.
- 69. Se-Kyo Chung, Jung-Gyu Lim, "Design of Bootstrap Power Supply for Half-Bridge Circuits using Snubber Energy Regeneration", Journal of Power Electronics, Vol. 7, No. 4, October 2007, pp. 294-300.
- Fairchild Semiconductor Corporation, "Design and Application Guide of Bootstrap Circuit for High-Voltage Gate-Drive IC", AN-6076, 2008, Rev. 1.0.0/9/30/08.
- 71. G.F.W. Khoo, D.R.H. Carter, R.A. McMahon, "Analysis of a charge pump power supply with a floating voltage reference", IEEE Trans. Circuits Syst., vol. 47, no. 10, pp. 1494-1501, Oct. 2000.
- 72. Ph. Meyer, J. Tucker, "Providing Continuous Gate Drive Using a Charge Pump", 2011, Texas Instruments Incorporated, SLVA444 February 2011.
- 73. S.K. Tewksbury, R.W. Hallock, "Oversampled Linear Predictive and Noise-Shaping Coders of Order N, IEEE Trans. Circuits Sys. CAS-25, July 1978, pp. 437-447.
- 74. T. Zieliński, "Cyfrowe przetwarzanie sygnałów od teorii do zastosowań", WKiŁ, Warszawa, 2005.
- 75. R.E. Crochiere, L.R. Rabiner, "Interpolation and Decimation of Digital Signals-A Tutorial Review", Proceedings of IEEE, Vol. 69, No. 3, March 1981, pp. 300-331.
- 76. M. Nentwig, "Polyphase filter / Farrows interpolation", http://www.dsprelated. com/ showarticle/22.php [2013-02-12].
- 77. Tutoriale, "Technika cyfrowa, przetwarzanie analogowo-cyfrowe. Próbkowanie", ttp://livesound.pl/tutoriale/kursy/3979-technika-cyfrowa-przetwarzanieanalogowo-cyfrowe-probkowanie[2013-02-11].
- 78. ISO7420x Low-Power Dual-Channel Digital Isolators, SLLS984I –JUNE 2009– REVISED JULY 2015, Texas Instruments, www.ti.com
- 79. RM0090 Reference manual. STM32F40xxx, STM32F41xxx, STM32F42xxx, STM-32F43xxx advanced ARM-based 32-bit MCUs.
- 80. STM32F405xx STM32F407xx, Datasheet, June 2013, DocID022152 Rev 4.
- 81. UM1472 User manual Discovery kit for STM32F407/417 lines, January 2014 DocID022256 Rev 4.
- 82. http://www.cornucopiaplastics.com/3-BitProgrammableFASTTTLLogicDelay.

## Dodatki

## Dodatki A1

### A.1.1. Wyznaczenia przebiegów czasowych sygnałów z modulacją NPWM, dla sinusoidalnego sygnału modulującego

Wykorzystując metodę binarną, w programie Matlab dość łatwo można wyznaczyć z zadaną dokładnością przebiegi czasowe sygnałów z modulacją NPWM (początki i końce czasu trwania impulsu w każdym okresie kluczowania), dla deterministycznego sygnału modulującego.

#### A.1.1.1 Wyznaczenie przebiegów czasowych sygnałów z modulacją NADS

Rys. D.1 wyjaśnia zasadę wyznaczenie szerokości impulsu w *n*-tym okresie kluczowania metodą binarną, przy modulacji jednobrzegowej NADS, dla sinusoidalnego przebiegu modulującego:  $y(t) = M \sin(\omega_m t)$ .



Rys. D.1. Wyznaczenie szerokości impulsu w *n*-tym okresie metodą binarną dla modulacji NADS

Jak zaznaczono na rys. D.1, w kolejnych okresach kluczowania ciągły czas *t* możemy zapisać:

$$t = n T_c + \bar{t};$$
 dla:  $n = 0, 1, 2, ..., (N-1);$  gdzie  $0 \le \bar{t} < T_c,$  (D.1)

 $N = (T_m/T_c)$  jest liczbą impulsów PWM w jednym okresie sygnału modulującego.

Przebiegi czasowe sygnałów: modulującego i piłokształtnego w *n*-tym okresie kluczowania opisują równania:

$$y(t) = M \sin \left[ \omega_m \left( nT_c + \bar{t} \right) \right]; \quad u_T \frac{2}{T_c} \left( nT_c + \bar{t} \right) + (1 + 2n); \quad 0 \le \bar{t} < T_c \quad (D.2)$$

dla: *n* = 0, 1, 2,..., (*N*– 1) (pierwszy okres kluczowania otrzymujemy dla: *n* = 0)

Przy modulacji NADS, początek impulsu PWM w *n*-tym okresie kluczowania wynosi  $nT_c$ , natomiast koniec impulsu wyznacza punkt przecięcia przebiegu modulującego y  $(nT_c + \bar{t})$  z przebiegiem piłokształtnym  $u_T (nT_c + \bar{t})$ . Algorytm wyznaczania tego punktu będzie bardziej przejrzysty, gdy przebieg piłokształtny będzie zapisany zawsze dla pierwszego okresu kluczowania (n = 0), zaś przesuwany będzie tylko przebieg modulujący, tj.:

$$y(t) = M \sin \left[\omega_m \left(nT_c + \overline{t}\right)\right] dla : n = 0, 1, 2, ..., (N-1); natomiast:  $u_T(\overline{t}) \frac{2}{T_c} \overline{t} - 1$  (D.3)$$

Binarna metoda wyznaczania końca czasu trwanie impulsu PWM w *n*-tym okresie kluczowania polega na kolejnym binarnym dzieleniu okresu  $T_c$  na odcinki dwa razy krótsze:  $T_c/2i$ ) dla i = 2, 4, 8, 16..., aż do momentu, gdy znajdziemy w wyniku podziału taki przedział  $0 \le t < T_c$ , w którym

$$y(t) = M \sin \left[\omega_m \left(nT_c + \overline{t}\right)\right]; \quad u_T(\overline{t}) = \frac{2}{T_c} \quad \overline{t} - 1.$$

Algorytm ten można opisać w kilku krokach:

- (1) Podstawiam: <u>n</u> = 0, i = 2, k = 0
- (2) Obliczam:  $\overline{t}_k \frac{T_c}{i}$ ;
- (3) Jeżeli:  $M \sin \left[2 \pi f_m(\bar{t}_k + nT_c)\right] > u_T(\bar{t}_k)$ , to powiększam: k = k + 1

w przeciwnym razie  

$$\bar{t}_{k+1} = \frac{T_c}{i} + \frac{T_c}{2i} = \bar{t}_k + \frac{T_c}{2i}$$

$$\bar{t}_{k+1} = \frac{T_c}{i} - \frac{T_c}{2i} = \bar{t}_k - \frac{T_c}{2i}$$

- (4) Powiększam: i = 2i
- (5) Zależnie od spełnienia warunku (3), (sprawdzając przy tym, z jaką dokładnością spełniony jest ten warunek), z nową wartością  $\overline{t}_{k+1}$ , wchodzę w pętlę programu do wyznaczenia nowej wartości  $\overline{t}_{k+1}$ , czyli do kroku (3). Przy każdym powiększeniu k o 1, dwukrotnie zwiększa się indeks i (krok 4) i podobnie jak to miejsce w przypadku binarnej kompensacji wagowej, z coraz to większą dokładnością  $\left(\Delta \bar{t}_{k} - \frac{T_{c}}{2^{p}}\right)$ zbliżamy się do dokładnej wartości współrzędnej punktu przecięcia obydwu przebiegów czasowych.
- (6) Jeżeli warunek (3) spełniony jest z zadaną dokładnością, to wyznaczenie czasu końca impulsu PWM w *n*-tym okresie kluczowania należy uznać za zakończone.

Początek i koniec impulsu PWM w n-tym okresie, są odpowiednio równe:  $t_p(n) = nT_c$ ;  $t_k(n) = nT_c + \overline{t_{k+1}}(n)$ 

- $\overline{t}_{k+1}(n)$  jest ostatnią wartością wyznaczoną przy wyjściu z pętli.
- (7) Podstawiam: n = n + 1, i = 2, k = 0 i wchodzę do kroku (2), aż do wyczerpania wszystkich wartości n = 0, 1, 2, ..., (N-1).

#### A.1.1.2 Wyznaczenie przebiegów czasowych sygnałów z modulacja NADD

W przypadku modulacji dwubrzegowej NADD, w każdym okresie kluczowania należy wyznaczyć zarówno początek, jak i koniec czasu trwania impulsu PWM. W tym celu możemy wykorzystać algorytm podobny do opisanego wyżej, realizowany w dwóch oddzielnych, nieco zmodyfikowanych pętlach programu.

W obu pętlach, w kroku (2) algorytmu należy obliczyć:  $\bar{t}_k = \frac{T_c}{2i}$  (zamiast  $\bar{t}_k = \frac{T_c}{i}$ ) Pierwsza pętla algorytmu dotyczy wyznaczania początków czasu trwania impulsów  $(\bar{t}_n(n))$  PWM w *n*-tym okresie kluczowania (w miejsce indeksu *k* należy podstawić *p*), i zgodnie z rys. D.2, w kroku (3) opisanego wyżej algorytmu sygnał sinusoidalny należy porównać z opadającą częścią przebiegu trójkątnego, opisanego dla pierwszego okresu kluczowania (n = 0), równaniem :

$$u_{T1}(t) = -\frac{4}{T_c}\bar{t} - +1$$
; dla:  $0 \le \bar{t} < \frac{T_c}{2}$  (D.4)

Przy wyjściu z pętli, początek zmodulowanego impulsu jest równy:  $t_n(n) = nT_c + \overline{t}_n(n).$ 

Druga pętla algorytmu dotyczy wyznaczania końców czasu trwania  $(\bar{t}_k(n))$  impulsów PWM w *n*-tym okresie kluczowania i w kroku (3) opisanego wyżej algorytmu sygnał sinusoidalny należy porównać z narastającą częścią przebiegu trójkątnego, opisanego dla pierwszego okresu kluczowania (n = 0), równaniem:

$$u_{T1}(t) = \frac{4}{T_c} \bar{t} - 1$$
; dla:  $\frac{T_c}{2} \le \bar{t} < T_c$  (D.5)

Przy wyjściu z pętli, koniec zmodulowanego impulsu jest równy:  $t_k(n) = nT_c + T_c/2 + \overline{t_k}(n)$ 



Rys. D.2. Wyznaczenie szerokości impulsu w *n*-tym okresie metodą binarną dla modulacji NADD

## A.1.2. Analiza spektralna sygnałów z modulacją PWM w programie Matlab

Widma częstotliwościowe sygnałów zmodulowanych PWM wyznaczono metodą estymacyjną przy założeniu, że sygnał modulujący jest periodyczny.

Na rys. D.3 przedstawiono poglądowy rozkład impulsów odpowiadający modulacjom w klasie BD, na którym zaznaczono początki i końce czasów trwania impulsów, ich szerokości oraz odległości środków impulsów od początku układu współrzędnych. Przedstawiony ciąg impulsów składa się z dwóch podzbiorów, z których jeden zawiera N impulsów o amplitudzie +1, zaś drugi, N impulsów o amplitudzie –1.



Rys. D.3. Poglądowy rozkład impulsów przy modulacjach PWM

Pojedynczy impuls w *n*-tym okresie kluczowania może być zapisany w dziedzinie czasu w postaci:

$$x(t) = A \left[ \operatorname{Rect}\left(\frac{t-\tau_n}{T_n}\right) \right] = A \begin{cases} 1 \left[ t - \left(\tau_n - \frac{T_n}{2}\right) \right] - 1 \left[ t - \left(\tau_n + \frac{T_n}{2}\right) \right] dla \ t \in \left(\tau_n - \frac{T_n}{2}, \tau_n + \frac{T_n}{2}\right) \\ \frac{1}{2} & dla \ t = \tau_n \pm \frac{T_n}{2} \\ 0 & dla \ t \text{ pozostałych} \end{cases}$$
(D.6)

Ponieważ pojedynczemu impulsowi prostokątnemu w dziedzinie czasu odpowiada transformata Fouriera w dziedzinie częstotliwości:

$$A \operatorname{Rect} \frac{t - \tau_n}{T_n} \iff A T_n \operatorname{Sinc} \left( \operatorname{T}_n f \right)^{-j 2 \pi f \tau_n}$$
(D.7)

Korzystając z liniowości przekształcenia Fouriera, dla całego ciągu impulsów przedstawionego na rys. D.3, otrzymujemy:

$$\sum_{n=1}^{N} A \left[ \operatorname{Rect} \left( \frac{t - \tau_n}{T_n} \right) \right] - \sum_{n=N+1}^{2N} A \left[ \operatorname{Rect} \left( \frac{t - \tau_n}{T_n} \right) \right] \Leftrightarrow$$

$$\sum_{n=1}^{N} A T_n \operatorname{Sinc} (T_n f) \left[ e^{-j2\pi f \tau_n} \right] \sum_{n=N+1}^{2N} A T_n \operatorname{Sinc} (T_n f) \left[ e^{-j2\pi f \tau_n} \right]$$
(D.8)

Rysunek D.4 wyjaśnia kolejne etapy wyznaczania widma częstotliwościowego sygnału z modulacją PWM w klasie BD. Dla całego ciągu impulsów w dziedzinie czasu wyznaczane są zespolone widma częstotliwościowe w postaci odpowiadających im funkcji Sinc, a następnie sekwencja ta jest mnożona przez funkcje okna Hanninga w celu zwiększenia rozdzielczości częstotliwościowej i amplitudowej analizy częstotliwościowej. Otrzymane w wyniku analizy macierze zespolonych składowych częstotliwościowych wszystkich impulsów są dodawane, następnie uśredniane (średnia wartość zależy od ilości analizowanych impulsów). Uśredniona wartość macierzy zespolonych składowych częstotliwościowych jest estymatą widma częstotliwościowego zmodulowanego sygnału PWM.



Rys. D.4. Kolejne etapy wyznaczania widma częstotliwościowego sygnału PWM z modulacją w klasie BD

## Dodatki A2

#### Kody programów w języku Matlab modulacji analogowych, jednobrzegowych NADS i NBDS oraz dwubrzegowych NADD i NBDD

```
clc;
clear all;
close all;
format short;
typ_mod1 = ,Modulacja NADS';
typ_mod2 = ,Modulacja NBDS';
Am = 0.95;
Fc = 352.8;
rozm_cz = 12;
dz = 20;
fm = 0.98*dz; % 1, 10, 20
Tc = 1/Fc;
Tm = 1/fm;
N = Fc/(fm/dz); \% ilość cykli
dt = 1/(N*Fc);
t = 0:dt:N/Fc;
f = 0:fm/dz:Fc;
xm = Am*sin(2*pi*fm*t);
                              % przebieg modulujący
y = sawtooth(2*pi*Fc*t,1);
                              % przebieg kluczujący Fc, jednobrzegowy
y = sawtooth(2*pi*Fc*t,0.5);
                              % przebieg kluczujący Fc, dwubrzegowy
```

#### % Modulacje: NADS, NBDS

```
xplus=0; xminus=0; xpp=-1;
for i = 1:1:N
tcp=Tc/2; tcm=Tc/2;
    for iter=1:1:64
    if ( (Am*sin(2*pi*fm*(tcp+(i-1)*Tc)))>((2/Tc)*tcp-1) )
    tcp=tcp+Tc/2^(iter+1);
    else
        tcp=tcp-Tc/2^(iter+1);
```

```
end:
  tkonplus(i)=tcp:
 if ( (-Am*sin(2*pi*fm*(tcm+(i-1)*Tc)))>((2/Tc)*tcm-1) )
  tcm=tcm+Tc/2^(iter+1);
  else
   tcm=tcm-Tc/2^(iter+1):
  end:
  tkonminus(i)=tcm;
end:
 % przebieg modulowany gdy A>0, unipolarny
xplus = xplus+rec(t-(i-1)*Tc,tkonplus(i));
% przebieg modulowany gdy A<0, unipolarny
xminus= xminus+rec(t-(i-1)*Tc,tkonminus(i));
% przebieg modulowany gdy A>0, bipolarny
xpp = xpp+2*rec(t-(i-1)*Tc,tkonplus(i));
end:
for i = 1:1:length(tkonplus) % if length(tkonplus)==length(tkonminus)
  okno(i) = hanning(length(tkonplus(i)));
  wsp(i) = sqrt(sum(okno(i).^2));
  hann_okno(i) = okno(i)/wsp(i)*sqrt(length(okno(i)));
  sr impp(i) = Tc^{(i-1)}(tkonplus(i))/2;
  ze_widp(i,:) = (tkonplus(i))^*...
   sinc(f*(tkonplus(i))).*...
   exp(-j*2*pi*f*sr_impp(i))*hann_okno(i);
  sr_impm(i) = Tc^*(i-1) + (tkonminus(i))/2;
  ze widm(i,:) = (tkonminus(i))^*...
   sinc(f*(tkonminus(i))).*...
   exp(-j*2*pi*f*sr_impm(i))*hann_okno(i);
end:
wp_p = sum(ze_widp)/length(tkonplus);
wp_m = sum(ze_widm)/length(tkonminus);
wp_rozn = abs(wp_p-wp_m)/max(abs(wp_p-wp_m));
wp_p = 2*abs(wp_p)/max(abs(wp_p));
wp_p(1) = 0;
```

```
% Modulacje: NADD, NBDD.
xpp =-1; xplus1 =0; xplus2 =0;
xminus= 1; xminus1=0; xminus2=0;
for i = 1:1:N
 tcpp=Tc/4; tckp=3*Tc/4;
 tcpm=Tc/4; tckm=3*Tc/4;
 for iter=1:1:64
  if ( (Am*sin(2*pi*fm*(tcpp+(i-1)*Tc)))>((4/Tc)*tcpp-1) )
   tcpp=tcpp+Tc/2^(iter+1);
  else
   tcpp=tcpp-Tc/2^(iter+1);
  end:
  tpp(i)=tcpp+(i-1)*Tc;
 if ( (Am*sin(2*pi*fm*(tckp+(i-1)*Tc)))<((-4/Tc)*tckp+3) )
  tckp=tckp+Tc/2^(iter+1);
 else
  tckp=tckp-Tc/2^(iter+1);
 end:
 tkp(i)=tckp+(i-1)*Tc;
 if ( (-Am*sin(2*pi*fm*(tcpm+(i-1)*Tc)))>((4/Tc)*tcpm-1))
  tcpm=tcpm+Tc/2^(iter+1);
 else
  tcpm=tcpm-Tc/2^(iter+1);
 end:
 tpm(i)=tcpm+(i-1)*Tc;
 if ( (-Am*sin(2*pi*fm*(tckm+(i-1)*Tc)))<((-4/Tc)*tckm+3) )
  tckm=tckm+Tc/2^(iter+1);
 else
  tckm=tckm-Tc/2^(iter+1);
 end:
 tkm(i)=tckm+(i-1)*Tc;
 end:
xplus1 = xplus1+rec(t,tpp(i));
xplus2 = xplus2+rec(t,tkp(i));
xplus = 1-(xplus2-xplus1); % przebieg NPWM dla A>0
xminus1 = xminus1+rec(t,tpm(i));
xminus2 = xminus2 + rec(t,tkm(i));
xminus = 1-(xminus2-xminus1); % przebieg NPWM dla A<0</pre>
tkonplus = tkp - tpp;
```
```
tkonminus = tkm - tpm;
end:
xpp = xpp + 2*xplus;
for i = 1:1:length(tkonplus)
 okno(i) = hanning(length(tkonplus(i)));
 wsp(i) = sqrt(sum(okno(i).^2));
 hann_okno(i) = okno(i)/wsp(i)*sqrt(length(okno(i)));
sr_impp(i) = (tpp(i)+tkp(i))/2;
ze widp(i,:) = tkonplus(i)*...
  sinc(f*tkonplus(i)).*...
  exp(-j*2*pi*f*sr_impp(i))*hann_okno(i);
 sr impm(i) = (tpm(i)+tkm(i))/2;
 ze_widm(i,:) = tkonminus(i)*...
  sinc(f*tkonminus(i)).*...
  exp(-j*2*pi*f*sr_impm(i))*hann_okno(i);
end:
wp_p = sum(ze_widp)/length(tkonplus);
wp_m = sum(ze_widm)/length(tkonminus);
wp rozn = abs(wp p-wp m)/max(abs(wp p-wp m));
wp_p = 2*abs(wp_p)/max(wp_p);
wp p(1) = 0;
% Przebiegi czasowe i spektralne: część wspólna dla modulacji analogowych
pwm = xplus-xminus; % wypadkowy przebieg fali PWM
p pwm = xpp; % przebieg fali PWM dla A>0
```

```
p_pwin = xpp, % przebieg fair f w M dla A>0
p_mp = xm; % A= 0.95, przebieg fali modulującej
p_mm = -xm; % A=-0.95, przebieg fali modulującej
widmo = wp_rozn; % widmo przebiegu
```

```
figure(1)
subplot(311)
plot(t,y,'m','linewidth',1);
hold on;
plot(t,p_mp,'r','linewidth',2)
plot(t,p_pwm,'b','linewidth',2)
hold off;
```

```
title([typ_mod1 ', M= ' num2Str(Am)...
                "Fc= , num2Str(Fc) ,kHz'...
                ', fm= ' num2Str(fm) 'kHz'],'Fontsize',12);
 xlabel('t [ms]');
 ylabel('A');
 axis([0 Tm -1.1 1.1]);
 grid on;
subplot(312);
 plot(f,wp p,'k.",markersize',14);
 hold on:
 plot(f,wp_p,'b','linewidth',1);
 hold off:
 title(['Widmo NPWM, rozdz. df= ' num2Str(fm/dz) 'kHz'],'Fontsize',12);
 xlabel('f [kHz]');
 vlabel('|Am|');
 axis([-2 Fc -0.1 1.1]);
 grid on;
subplot(313);
 plot(f,20*log10(wp_p),'k.",'markersize',14);
 hold on;
 plot(f,20*log10(wp_p),'b','linewidth',1);
 hold off:
 title('Widmo NPWM w dB''Fontsize',12);
 xlabel('f [kHz]');
 ylabel('20*log10|Am|');
 axis([-2 Fc -400 10]);
 grid on;
figure(2)
subplot(311)
 plot(t,y,'m','linewidth',1);
 hold on;
 plot(t,pwm,'b','linewidth',2)
 plot(t,p_mp,'r','linewidth',2)
 plot(t,p_mm,'g','linewidth',2)
 hold off;
 title([typ_mod2 ', M= ' num2Str(Am)...
                "Fc=, num2Str(Fc), kHz'...
                ', fm= ' num2Str(fm) 'kHz'],'Fontsize',12);
```

```
xlabel('t [ms]');
 ylabel('A');
 axis([0 Tm -1.1 1.1]);
 grid on;
subplot(312);
 plot(f,widmo,'k.",markersize',14);
 hold on;
 plot(f,widmo,'b','linewidth',1);
 hold off;
 title(['Widmo NPWM, rozdz. df= ' num2Str(fm/dz) 'kHz'],'Fontsize',12);
 xlabel('f [kHz]');
 ylabel('|Am|');
 axis([-2 Fc -0.1 1.1]);
 grid on
subplot(313);
 plot(f,20*log10(widmo),'k.','markersize',14);
 hold on;
 plot(f,20*log10(widmo),'b','linewidth',1);
 hold off;
 title('Widmo NPWM w dB''Fontsize',12);
 xlabel('f [kHz]');
 ylabel('20*log10|Am|');
 axis([-2 Fc -400 10]);
 grid on;
```

## Dodatki A3

## Kody programów w języku Matlab modulacji cyfrowych, jednobrzegowych UADS, UBDS oraz dwubrzegowych UADD, UBDD

```
clc;
clear all;
close all;
format long;
Am = 0.95;
Fs = 44.1;
Ts = 1/Fs;
K = 7;
Fc = (K+1)*Fs;
Tc = 1/Fc;
rc = 12;
dz = 10;
                       % martwe okresy
om = 4;
okr = 1;
fm = 0.98*dz; % 1, 10, 20
Tm = 1/fm;
N = 360; % ilość cykli
tp = 0:Ts:(dz+2*om)*Tm-Ts;
x = Am*sin(2*pi*fm*tp);
                              % przebieg modulujący
zera=zeros(1,(K+1)*length(x));
zera(1:K+1:(K+1)*length(x))=x(1:length(x));
x_zero=zera;
ipr_up = length(x_zero);
                              % Liczba próbek po upsamplingu
                              % Wektor z próbek
wpr_up = 0:1:ipr_up-1;
M = 45; \%75 \%235;
                              % połowa długości filtra
```

```
NM = 2*M+1: n = 1:M:
wc = pi/(K+1);
fc = wc/(2*pi); \% fc = 1/(2*(K+1))
hh = 2*fc*sin(wc*n)./(wc*n); % współczynnik skalujacy
\% 2*fc = 1/(ilp+1)
% wzmocnienie K+1 razy, aby próbka środkowa była równa 1
hh = (K+1)*[hh(M:-1:1) 2*fc hh(1:M)];
w = blackman(NM);
                    % okno Blackmana
h = hh.*w':
a = om^{Fs^{(K+1)}/fm}
x f = conv(x zero,h);
                      % Splot sygnału z odpowiedzia
                      % impulsowa filtru
x_fKa = x_f(:,M+a+1:end-M-a);
f = 0:fm/dz:Fc;
t = 0:Tc/(N*10):dz*Tm; \%-Tc/N;
xm = Am*sin(2*pi*fm*t);
y = sawtooth(2*pi*Fc*t,1); % przebieg kluczujący Fc jednobrzegowy
xn=-1; xc=0;
for i = 1:1:length(x fKa)
%tkon(i)=(Tc/2)*(Am*sin(2*pi*fm*(i-1)*Tc)+1);
tkon(i,:)=(Tc/2)*(x_fKa(i)+1);
tkon = tkon + 1e-6*(tkon.*(randn(1,N*okr))');
xn = xn+2*rec(t-(i-1)*Tc,tkon(i)); % przebieg modulowany
% skwantowany przebieg wejściowy xm
xc = xc+Am*sin(2*pi*fm*(i-1)*Tc)*rec(t-(i-1)*Tc,(1-1e-9)*Tc);
end:
for n = 1:1:length(tkon)
 okno(n) = hanning(length(tkon(n)));
 wsp(n) = sqrt(sum(okno(n).^2));
 hann_okno(n) = okno(n)/wsp(n)*sqrt(length(okno(n)));
 sr_{imp}(n) = Tc^{*}(n-1) + tkon(n)/2;
```

```
si_inip(ii)= it (ii-i)+tkon(ii)/2,
f_sinc(n,:) = (tkon(n)*sinc(f*tkon(n)).*...
exp(-j*2*pi*f*sr_imp(n)))*hann_okno(n);
end;
wp = sum(f sinc)/length(tkon);
```

```
wp= 2*abs(wp)/abs(max(wp));
wp(1)=0
upwm = xn; % przebieg fali modulowanej
p_mod = xm;
widmo = wp; % widmo przebiegu
figure(1)
subplot(311)
 plot(t,y,'m','linewidth',1);
 hold on;
 plot(t,xc,'k','linewidth',1);
 plot(t,p_mod,'r','linewidth',1);
 plot(t,upwm,'b','linewidth',2);
 hold off;
 title(['Modulacja cyfrowa' ', M= ' num2Str(Am)...
       "Fc=, num2Str(Fc),kHz'...
       "fm=, num2Str(fm),kHz'...
       , df= , num2Str(fm/dz) ,kHz'],'Fontsize',12);
 xlabel('t [ms]', Fontsize', 12);
 ylabel('A','Fontsize',12);
);
 axis([0 Tm -1.1 1.1]);
 grid on;
subplot(312);
 plot(f,widmo,'k.",markersize',14);
 hold on
 plot(f,widmo,'b','linewidth',1);
 hold off:
 %title(['Widmo UPWM, rozdz. df= ' num2Str(fm/dz) 'kHz'],'Fontsize',12);
 xlabel('f [kHz]', Fontsize', 12);
 ylabel('|Am|','Fontsize',12);
 axis([-2 Fc -0.1 1.1]);
 grid on
subplot(313);
 plot(f,20*log10(widmo),'k.''markersize',14);
 hold on
```

```
plot(f,20*log10(widmo),'b','linewidth',1);
 hold off:
 %title('Widmo UPWM w dB''Fontsize',12);
 xlabel('f [kHz]', Fontsize', 12);
 ylabel('20*log10|Am|',Fontsize',12);
 axis([-2 Fc -150 10]);
 grid on;
clc;
clear all;
%close all:
format long;
       = 0.95:
Am
Fs
       = 44.1:
Ts
       = 1/Fs;
К
       = 7;
       = (K+1)*Fs;
Fc
Tc
       = 1/Fc;
rozm cz = 9;
okr = 1:
dz = 10;
om = 6; % martwe okresy
fm = 0.98*dz; % 1, 10, 20
Tm = 1/fm;
N = 360; % ilość cykli
tp = 0:Ts:(dz+2*om)*Tm-Ts;
xp = Am^*sin(2^*pi^*fm^*tp); \% p. modulujący A= 0.95;
xm = -Am*sin(2*pi*fm*tp); \% p. modulujący A=-0.95;
zerap=zeros(1,(K+1)*length(xp));
zerap(1:K+1:(K+1)*length(xp))=xp(1:length(xp));
x zerop=zerap;
zeram=zeros(1,(K+1)*length(xm));
zeram(1:K+1:(K+1)*length(xm))=xm(1:length(xm));
x_zerom=zeram;
M = 210; % połowa długości filtra
NM = 2*M+1; n = 1:M;
wc = pi/(K+1);
fc = wc/(2*pi); \% fc=1/(2*(K+1))
```

```
hh = 2*fc*sin(wc*n)./(wc*n); % współczynnik skalujący
 \% 2*fc = 1/(ilp+1)
% wzmocnienie K+1 razy, aby próbka środkowa była równa 1
hh = (K+1)*[hh(M:-1:1) 2*fc hh(1:M)];
w = blackman(NM); % okno Blackmana
h = hh.*w';
a = om*Fc/fm;
x fp = conv(x \text{ zerop,}h); % Splot sygnału z odpowiedzia
 % impulsowa filtru
x_{fp} = x_{fp}(:, M+a+1:end-M-a);
x_fm = conv(x_zerom,h); % Splot sygnału z odpowiedzia
 % impulsowa filtru
x_fm = x_fm(:, M+a+1:end-M-a);
f = 0:fm/dz:Fc;
t = 0:Tc/(10*N):dz*Tm; \%-Tc/N;
x = Am^*sin(2^*pi^*fm^*t);
y = sawtooth(2*pi*Fc*t,1); % przebieg kluczujący Fc jednobrzegowy
 xnplus=0; xcplus=0; xnminus=0; xcminus=0;
for i = 1:N
  %tkonplus(i)=(Tc/2)*(+Am*sin(2*pi*fm*(i-1)*Tc)+1);
  tkonplus(i,:)=(Tc/2)^*(x_fp(i)+1);
  xnplus = xnplus + rec(t-(i-1)*Tc,tkonplus(i)); % przebieg modulowany
  xcplus = xcplus + Am^*sin(2^*pi^*fm^*(i-1)^*Tc)^*rec(t-(i-1)^*Tc,(1-1e-12)^*Tc);
  %tkonminus(i)=(Tc/2)*(-Am*sin(2*pi*fm*(i-1)*Tc)+1);
  tkonminus(i,:)=(Tc/2)*(x_fm(i)+1);
  xnminus = xnminus + rec(t-(i-1)*Tc,tkonminus(i)); % przebieg modulowany
  xcminus = xcminus +(-Am)*sin(2*pi*fm*(i-1)*Tc)*rec(t-(i-1)*Tc,(1-1e-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*Tc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rec(t-(i-1)*rc)*rc)*rec(t-(i-1)*rc)*rc)*rec(t-(i-1)*rc)*rc(t-(i-1)*rc)*rc)*rc(t-(i-1)*rc)*rc(t-(i-1)*rc)*rc)*rc(t-(i-1)*rc)*rc)*rc(t-(i-1)*rc)*rc(t-(i-1)*rc)*rc)*rc(t-(i-1)*rc)*rc(t-(i-1)*rc)*rc)*rc(t-(i-1)*rc)*rc(t-(i-1)*rc)*rc)*rc(t-(i-1)*rc)*rc)*rc(t-(i-1)*rc)*rc(t-(i-1)*rc)*rc)*rc(t-(i-1)*rc)*rc)*rc)
  -12)*Tc);
  tkon(i)=tkonplus(i)-tkonminus(i);
  tkon = tkon + 1e-6*(tkon.*(randn(1,N*okr))');
end
for i = 1:1:length(tkon)
   okno(i) = hanning(length(tkon(i)));
  wsp(i) = sqrt(sum(okno(i).^2));
  hann_okno(i) = okno(i)/wsp(i)*sqrt(length(okno(i)));
  sr_imp(i) = Tc^*(i-1) + (tkonplus(i) + tkonminus(i))/2; \%(tkon(i))/2;
  f_{sinc(i,:)} = (tkon(i)*sinc(f*tkon(i)).*...
```

```
exp(-j*2*pi*f*sr_imp(i)))*hann_okno(i);
```

```
end
wp = abs(sum(f_sinc))/length(tkon);
wp = wp/max(wp);
wp(1) = 0;
upwm = xnplus-xnminus; % przebieg fali nośnej
p mod = x; % przebieg fali modulujacej
widmo = wp; % widmo przebiegu
figure(2)
subplot(311)
 plot(t,xcplus,'k','linewidth',1);
 hold on:
 plot(t,p_mod,'r','linewidth',1);
 plot(t,-p_mod,'g','linewidth',1);
 plot(t,xcminus/g'',linewidth',1);
 plot(t,v,'m,'linewidth',1);
 plot(t,upwm,'b','linewidth',1);
 hold off:
 title(['Modulacja cyfrowa' ', M= ' num2str(Am)...
                "Fc= , num2str(Fc) ,kHz'...
               ', fm= ' num2str(fm) 'kHz'],'Fontsize',10);
 xlabel('t [ms], Fontsize, 12);
 vlabel('A','Fontsize',12);
 axis([0 Tm -1.1 1.1]);
 grid on;
subplot(312);
 plot(f,widmo,'k.",markersize',12);
 hold on
 plot(f,widmo,'b','linewidth',1);
 hold off;
 title(['Widmo UPWM, rozdz. df= ' num2str(fm/dz) 'kHz'],'Fontsize',10);
 xlabel('f [kHz],'Fontsize',12);
 ylabel('|Am|', Fontsize', 12);
 axis([-2 2+Fc -0.1 1.1]);
 grid on
subplot(313);
 plot(f,20*log10(widmo),'k.",markersize',12);
 hold on
 plot(f,20*log10(widmo),'b','linewidth',1);
 hold off;
```

title('Widmo UPWM w dB','Fontsize',10); xlabel('f [kHz]','Fontsize',12); ylabel('20\*log10|Am|','Fontsize',12); axis([-2 2+Fc -150 10]); grid on;

## Kody programów w języku Matlab linearyzowanych modulacji cyfrowych, jednobrzegowych LADS, LBDS oraz dwubrzegowych LADD, LBDD

| clc;                           |                                                   |  |  |  |
|--------------------------------|---------------------------------------------------|--|--|--|
| clear all;                     |                                                   |  |  |  |
| close all;                     |                                                   |  |  |  |
| format <mark>long</mark> ;     |                                                   |  |  |  |
| Am = 0.95;                     |                                                   |  |  |  |
| Fs = 44.1;                     | % czestotliwosc probkowania                       |  |  |  |
| N = 360;                       |                                                   |  |  |  |
| rc = 10;                       | % rozmiar czcionki                                |  |  |  |
| K = 7;                         | % podstawowe probki ->Fc                          |  |  |  |
| Q = 0;                         | % nadprobkowanie                                  |  |  |  |
| om = 5;                        | % om – martwe okresy, MQ – polowa dlugosci filtra |  |  |  |
| MQ = 200;                      |                                                   |  |  |  |
| okr = 3;                       |                                                   |  |  |  |
| dz = 10;                       | % okresy do analizy; f wejsciowa -> fm            |  |  |  |
| Ts = 1/Fs;                     |                                                   |  |  |  |
| Tc = Ts/(K+1);                 |                                                   |  |  |  |
| Fc = 1/Tc;                     |                                                   |  |  |  |
| dt = Tc/(10*N)                 | ;                                                 |  |  |  |
| fm = 0.98 * dz;                |                                                   |  |  |  |
| Tm = 1/fm;                     |                                                   |  |  |  |
| wpo = (K+1)*(                  | Q+1);                                             |  |  |  |
| t = 0:Ts:(dz+2*om)*Tm-Ts;      |                                                   |  |  |  |
| xp = Am*sin(2*pi*fm*t);        |                                                   |  |  |  |
| $xm = -Am^*sin(2^*pi^*fm^*t);$ |                                                   |  |  |  |
|                                |                                                   |  |  |  |
| ts = 0:Ts:dz*Tm-Ts;            |                                                   |  |  |  |
| xsp = Am*sin(2*pi*fm*ts);      |                                                   |  |  |  |
| xsm = -Am*sin(2*pi*fm*ts);     |                                                   |  |  |  |

```
txy = 0:dt:dz*Tm-dt;
xap = Am*sin(2*pi*fm*txy);
xam = -Am*sin(2*pi*fm*txy);
                                     % przebieg kluczujacy
ya = sawtooth(2*pi*Fc*txy,1);
f = 0:fm/dz:Fc;
zerap = zeros(1,wpo*length(xp));
zerap(1:wpo:wpo*length(xp))= xp(1:length(xp));
x_zerop = [zerap 0];
zeram = zeros(1,wpo*length(xm));
zeram(1:wpo:wpo*length(xm))= xm(1:length(xm));
x_zerom = [zeram 0];
NMQ = 2*MQ+1;
n = 1:MQ;
wc = pi/(wpo);
fc = wc/(2*pi);
                                     \% fc=1/(2*Q)
hh = 2*fc*sin(wc*n)./(wc*n);
                                     % wspolczynnik skalujacy 2*fc = 1/Q
hh = (wpo)*[hh(MQ:-1:1) 2*fc hh(1:MQ)]; % wzmocnienie Q+1 razy, aby
                                     % probbka srodkowa rowna 1
w = blackman(NMQ);
                                     % okno Blackmana
h = hh.*w';
a = floor(om*Fc/fm);
x_{fp} = conv(x_{zerop,h});
                                     % Splot sygnalu z odpowiedzia
                                     % impulsowa filtru
x_fp = x_fp(:,MQ+1:end-MQ);
x_fQp = x_fp(:,a+1:a+1+(Q+1)*360);
x_fm = conv(x_zerom,h);
                                     % Splot sygnalu z odpowiedzia
                                     % impulsowa filtru
x_fm = x_fm(:,MQ+1:end-MQ);
x_fQm = x_fm(:,a+1:a+1+(Q+1)*360);
ip = length(x_fQp);
wip = 0:ip-1;
tx_fp = wip*Ts/(wpo);
ipp = length(x_zerop);
wipp = 0:ipp-1;
```

```
tx_zerop = wipp*Ts/(wpo);
tQ=Tc/(Q+1);
for i=1:0+2
 S(i,:)=(2/Tc)*(i-1)*tQ-1;
end
% Przebieg LBDS
lpwm_p = 0; lpwm_m = 0;
for n=1:N
  xn fp(:,n) = x fOp(:,1+(n-1)*(0+1):n*(0+1)+1);
  xn_fm(:,n) = x_fQm(:,1+(n-1)^*(Q+1):n^*(Q+1)+1);
 i=1:
 while i<=0+1
 if (xn_fp(i,n)>S(i) \&\& xn_fp(i+1,n)<S(i+1))
   tkonp(n,:) = Tc^{*}(i^{*}xn_{fp}(i,n)-(i-1)^{*}xn_{fp}(i+1,n)+1)/...
 ((xn fp(i,n)-xn fp(i+1,n))*(0+1)+2);
 break:
  end
  i=i+1;
 end
 lpwm_p = lpwm_p + rec2(txy-(n-1)*Tc,tkonp(n),0);
 k=1:
 while k<=0+1
  if (xn_fm(k,n)>S(k) \&\& xn_fm(k+1,n)<S(k+1))
     tkonm(n,:) = Tc^{*}(k)^{*}xn fm(k,n) - (k-1)^{*}xn fm(k+1,n) + 1)/...
            ((xn_fm(k,n)-xn_fm(k+1,n))^*(Q+1)+2);
   break:
  end
  k=k+1;
 end
 lpwm_m = lpwm_m + rec2(txy-(n-1)*Tc,tkonm(n),0);
end
  lpwm_c = (lpwm_p + lpwm_m)/2;
  lpwm_r = lpwm_p - lpwm_m;
for i = 1:1:length(tkonp)
 oknop(i) = hanning(length(tkonp(i)));
 wspp(i) = sqrt(sum(oknop(i).^2));
 hann_oknop(i) = oknop(i)/wspp(i)*sqrt(length(oknop(i)));
 sr_impp(i) = (i-1)*Tc+tkonp(i)/2;
```

```
f_{sincp(i,:)} = tkonp(i)*sinc(f*tkonp(i)).*...
 exp(-j*2*pi*f*sr impp(i))*hann oknop(i);
end
wpp = (sum(f_sincp))/length(tkonp);
for i = 1:1:length(tkonm)
 oknom(i) = hanning(length(tkonm(i)));
 wspm(i) = sqrt(sum(oknom(i).^2));
 hann_oknom(i) = oknom(i)/wspm(i)*sqrt(length(oknom(i)));
 sr_impm(i) = (i-1)*Tc+tkonm(i)/2;
 f_sincm(i,:) = tkonm(i)*sinc(f*tkonm(i)).*...
          exp(-j*2*pi*f*sr_impm(i))*hann_oknom(i);
end
wpm = (sum(f sincm))/length(tkonm);
wp_p = abs(wpp); wp_p = wp_p/max(wp_p);
wp_m = abs(wpm); wp_m = wp_m/max(wp_m);
wp_pr = abs(wpp-wpm); wp_pr = wp_pr/max(wp_pr);
wp_pc = abs((wpp+wpm)/2);
wp_pc = wp_pc/max(wp_pc);
figure(1)
subplot(411)
 plot(txy,ya,'m','linewidth',1);
 hold on;
  plot(txy,xap,'r');
  stem(ts,xsp,'b','linewidth',1);
  plot(txy(1:length(lpwm_p)),lpwm_p,'b','linewidth',2);
  stem(tx_fp,x_fQp,'r.')
 hold off;
 title(['Modulacja LBDS' ': M= ' num2str(Am)...
               (, Q = ' num2str(Q) ...
               ', Fc= ' num2str(Fc) 'kHz'...
               ; fm= ' num2str(fm) 'kHz;'],'Fontsize',rc);
 xlabel('t[ms]','Fontsize',12);
 ylabel('Am','Fontsize',12);
 axis([0 Tm -1.1 1.1]);
 grid on;
```

```
subplot(412)
 plot(txy,ya,'m','linewidth',1);
 hold on:
  plot(txy,xam,'r');
  stem(ts,xsm,'b','linewidth',1);
  plot(txv(1:length(lpwm m)),lpwm m,'b'',linewidth',2);
  stem(tx_fp,x_fQm,'r.');
  hold off:
  title([ ' M= ' num2str(-Am)...
                 (0) = (num2str(0))...
                 '. Fc= ' num2str(Fc) 'kHz'...
                 ', fm= ' num2str(fm) 'kHz.'],'Fontsize',rc);
  xlabel('t[ms]', Fontsize', 12);
  ylabel('Am','Fontsize',12);
  axis([0 Tm -1.1 1.1]);
  grid on;
subplot(413)
  plot(txy(1:length(lpwm_r)),lpwm_r,'b','linewidth',2);
  title('Przebieg pwm rÃ<sup>3</sup>Å<sup>1</sup>/4nicowy''Fontsize',rc);
  xlabel('t[ms]','Fontsize',12);
  ylabel('Am','Fontsize',12);
  axis([0 Tm -1.1 1.1]);
  grid on;
subplot(414)
  plot(txy(1:length(lpwm_c)),lpwm_c,'b','linewidth',2);
  title(,Przebieg pwm sumacyjny',Fontsize',rc);
  xlabel('t[ms]', Fontsize', 12);
  vlabel('Am','Fontsize',12);
  axis([0 Tm -0.1 1.1]);
  grid on;
```

```
% dwubrzegowa linearyzowana i cyfrowa modulacja LADD oraz LBDD
clc;
clear all;
close all;
format long;
rc = 9; % rozmiar czcionki
M = 0.95; % amplituda
Nrg = 6;
```

```
dz = 10:
fm = 1*dz:
                               %[kHz] sygnal wejsciowy
Tm = 1/fm;
fosc = 168000:
                               %[kHz] sygnal zegarowy
fclk = fosc/4;
okr = 1;
wsp = 1;
                               % rozdzielczosc widma np: wsp=2 => 500Hz
fs = ceil(fclk/2^(Nrq+1));
                               %[kHz] – podstawowa czestotliwosc probko-
                               wania
Ts = 1/fs;
t = 0:Ts:wsp*Tm*dz*okr;
xpp = M*sin(2*pi*fm*t);
xpo = (-1)^*xpp;
                               % jego sygnal, odwrocony
ta = 0:Ts/dz:dz*Tm-Ts/dz;
ya = sawtooth(2*pi*fs*(ta+Ts/2),0.5);
tl = 0:Ts/fs:Tm*dz-Ts/fs;
                               % punkty PWM
f = 0:1/wsp:fs;
% LADDp – sygnal prosty, obliczenia tppl(n) oraz tkpl(n)
lpwmp = 0;
for n=1:length(xpp)-1
 tppl(n,:) = Ts^{*}(((n-1)^{*}xpp(n+1)-(n)^{*}xpp(n)+4^{*}(n-1)+1)/...
 (xpp(n+1)-xpp(n)+4));
 yppl(n,:) = (-4/Ts)*tppl(n)+4*(n-1)+1;
 tkpl(n,:) = Ts^{*}(((n-1)^{*}xpp(n+1)-n^{*}xpp(n)-4^{*}(n-1)-3)/...
 (xpp(n+1)-xpp(n)-4));
 ykpl(n,:) = (4/Ts)*tkpl(n)-4*(n-1)-3;
 tkonpl(n) = tkpl(n) - tppl(n);
 sr_imppl(n) = (tkpl(n) + tppl(n))/2;
 lpwmp = lpwmp+rec2(tl,tkonpl(n),tppl(n));
end
% LADDo – sygnal, odwrocony, obliczenia tpol(n) oraz tkol(n)
lpwmo = 0;
for n=1:length(xpo)-1
 tpol(n,:) = Ts^{*}(((n-1)^{*}xpo(n+1)-(n)^{*}xpo(n)+4^{*}(n-1)+1)/...
                (xpo(n+1)-xpo(n)+4));
 ypol(n,:) = (-4/Ts)*tpol(n)+4*(n-1)+1;
 tkol(n,:) = Ts^{*}(((n-1)^{*}xpo(n+1)-n^{*}xpo(n)-4^{*}(n-1)-3)/...
                (xpo(n+1)-xpo(n)-4));
```

```
ykol(n,:) = (4/Ts)*tkol(n)-4*(n-1)-3;
 tkonol(n) = tkol(n) - tpol(n);
 sr_impol(n) = (tkol(n) + tpol(n))/2;
 lpwmo = lpwmo+rec2(tl,tkonol(n),tpol(n));
end
lpwm_r = lpwmp -lpwmo;
tkonpl = tkonpl + 2e-7*(randn(1,okr*wsp*fs));
tkonol = tkonol + 2e-7*(randn(1,okr*wsp*fs));
m i = ones(1, length(f));
f_sincp = sum((tkonpl(:)*m_j).*sinc(tkonpl(:)*f)...
       .*exp(-j*2*pi*sr_imppl(:)*f));
f_sinco = sum((tkonol(:)*m_j).*sinc(tkonol(:)*f)...
       .*exp(-j*2*pi*sr_impol(:)*f));
w_r = abs(f_sincp_f_sinco);
w_r = w_r / max(w_r);
Qrq = 9;
filtr = [5 - 10 \ 10 - 5 \ 1];
                               % filtr sprzezenia zwrotnego
dl_fil = length(filtr);
                               % "dlugosc filtru
wyj_filp = [];
wyj_filp(1) = 0;
                               % Pierwszy element wyjsciowego
                               % filtru sprzezenia zwrotnego,
                               % Zwrotne filtrowanie wektora
erq_pp = zeros(1,dl_fil);
wyj_filo = [];
wyj_filo(1) = 0;
                               % Pierwszy element wyjsciowego
                               % filtru sprzezenia zwrotnego,
erg_po = zeros(1,dl_fil);
                               % Zwrotne filtrowanie wektora
for n=1:length(tkonpl)
 tk_24bitp(n) = round(tkonpp(n)/Ts*2^24);
  dnp = tk_24bitp(n) - wyj_filp;
 dn_8bitp(n) = bitshift(tk_24bitp(n), -16);
  erqp = tk_24bitp(n) - bitshift(dn_8bitp(n),16);
 tk_Qrqbitp(n) = bitshift(abs(dnp+erqp),-(24-Qrq));
   erq_pp = [erqp erq_pp(1:end-1)];
 wyj_filp = erq_pp*filtr';
 tkonpr(n) = Ts^{tk}Qrqbitp(n)/(2^Qrq);
end
for n=1:length(tkonol)
tk_24bito(n) = round(tkonop(n)/Ts*2^24);
```

```
dno = tk_24bito(n) - wyj_filo;
 dn_8bito(n) = bitshift(tk_24bito(n),-16);
 ergo = tk_24bito(n) - bitshift(dn_8bito(n),16);
 tk Orqbito(n) = bitshift(abs(dno+erqo),-(24-Qrq));
 erq_po = [erqo erq_po(1:end-1)];
 wyj filo = erg po*filtr';
 tkonor(n) = Ts^{tk}_Qrqbito(n)/(2^Qrq);
end
tkonpp = tkonpp + 7e-9*(randn(1,wsp*fs));
f_sincpr = sum((tkonpp(:)*m_j).*sinc(tkonpr(:)*f).*...
exp(-j*2*pi*sr_imppl(:)*f));
tkonop = tkonop + 7e-9*(randn(1,wsp*fs));
f_sincor = sum((tkonop(:)*m_j).*sinc(tkonor(:)*f).*...
exp(-j*2*pi*sr_impol(:)*f));
wp r = abs(f sincpr-f sincor);
wp_r = wp_r/max(wp_r);
figure(1)
subplot(311)
    plot(ta,ya,'m','linewidth',1);
 hold on
    plot(tl.lpwmp,'b''linewidth',1);
    plot(t,xpp,'k-.'',linewidth',1);
 hold off:
 title(['M=' num2str(M) '; fc=328.125kHz''; fm=' num2str(fm),...
 'kHz'],'Fontsize',rc);
 xlabel('t[ms]');
 ylabel('Am');
 axis([0 Tm/1 -1.1 1.1]);
 grid on;
subplot(312)
    plot(ta,ya,'m','linewidth',1);
 hold on
    plot(tl.lpwmo,'b''linewidth',1);
    plot(t,xpo,'k-.,'linewidth',1);
 hold off;
 xlabel('t[ms]');
 ylabel('Am');
```

```
axis([0 Tm -1.1 1.1]);
 grid on:
subplot(313)
 hold on
    plot(tl,lpwm_r,'b','linewidth',1);
 hold off:
 title('LBDD DPWM differential output', Fontsize', rc);
 xlabel('t[ms]');
 vlabel('Am');
 axis([0 Tm -1.1 1.1]);
 grid on:
figure(2)
subplot(411)
     plot(f,20*log10(w_r),'k.",markersize',10);
 hold on
 plot(f,20*log10(w_r),'b','linewidth',1);
 hold off:
 title(['24-bit LBDD DPWM output'] ,'Fontsize',rc);
 xlabel('f [kHz]');
 vlabel('20log_1_0|Am|');
 axis([0 fs -150 10]);
 grid on;
 subplot(412)
    plot(f,20*log10(w r),'k.",markersize',10);
 hold on
    plot(f,20*log10(w_r),'b','linewidth',1);
 hold off;
 title('Zoomed view of 24-bit LBDD DPWM output''Fontsize',rc);
 xlabel('f [kHz]');
 ylabel('20log_1_0|Am|');
 axis([0 fs/15 -150 10]);
 grid on;
 subplot(413)
 plot(f,20*log10(wp_r),'k.",'markersize',10);
 hold on
   plot(f,20*log10(wp_r),'b','linewidth',1);
 hold off;
 title(['Noise-shaped 9-bit LBDD DPWM output'] ,'Fontsize',rc);
```

```
xlabel('f [kHz]');
ylabel('20log_1_0|Am|');
axis([0 fs -150 10]);
grid on;
subplot(414)
plot(f,20*log10(wp_r),'k.','markersize',12);
hold on
    plot(f,20*log10(wp_r),'b','linewidth',1);
hold off;
title('Zoomed view of noise-shaped 9-bit LBDD DPWM output','Fontsize-
',rc);
xlabel('f [kHz]');
ylabel('20log_1_0|Am|');
axis([0 fs/15 -150 10]);
grid on;
```

Kod programu w języku C dla środowiska µVision V5.26.2.0 w oparciu o rejestry urządzeń mikrokontrolera STM32F4 Discovery generujący rekwantyzowane 9 bitowe czasy początkowe i końcowe dla czterech kanałów PWM LADS

#include <stm32f4xx.h>

| #define ilCyk_Tc<br>czowaniu Tc;<br>#define BUFFER_SIZE |                                                                            | (uint32_t)0x0                                          | 0000200 // 512 cykle                                                  | w klu-             |
|---------------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------|-----------------------------------------------------------------------|--------------------|
|                                                         |                                                                            | (uint32_t)0x0                                          | 0000200                                                               |                    |
| const float VT = 1.46;                                  |                                                                            |                                                        |                                                                       |                    |
| // nadprokowa<br>uint16_t Q = 1;<br>//                  | anie, Q ilosc prol                                                         | bek dodatkowy                                          | ych                                                                   |                    |
| // zmienne<br>volatile uint16_                          | _t samADC[2*Bl                                                             | JFFER_SIZE];                                           |                                                                       |                    |
| volatile uint32_                                        | _t valADC = 0, sa                                                          | mADCsr[1024                                            | k];                                                                   |                    |
| // ADC, probki<br>volatile float                        | ADC1<br>tab_lp_sim[2*B<br>rsim[BUFFER_S<br>tab_lo_sim[2*B<br>rsim[BUFFER_S | UFFER_SIZE],<br>SIZE][2],<br>UFFER_SIZE],<br>SIZE][2]; | lp_fsim[BUFFER_SIZE][<br>lo_fsim[BUFFER_SIZE][                        | 2], lp_<br>2], lo_ |
| volatile uint16_                                        | t tplp[BUFFER<br>tplo[BU                                                   | _SIZE], tklp[BU<br>JFFER_SIZE], tł                     | FFER_SIZE],<br><lo[buffer_size];< td=""><td></td></lo[buffer_size];<> |                    |
| volatile uint16 <u>.</u>                                | _t tplp6b[BUFFE                                                            | ER_SIZE], tklp6                                        | b[BUFFER_SIZE],                                                       |                    |

tplo6b[BUFFER\_SIZE], tklo6b[BUFFER\_SIZE];

volatile uint16\_t tplp3b[BUFFER\_SIZE], tklp3b[BUFFER\_SIZE], tplo3b[BUFFER\_SIZE], tklo3b[BUFFER\_SIZE];

```
volatile uint16_t tp3b[BUFFER_SIZE], tk3b[BUFFER_SIZE];
```

uint16\_t il\_pr = 4, n = 0, k = 0, kk = 0, ind = 0, dif; int8\_t znak = 0x01;

```
//-----
// rekwantyzacja- dane
#define w2do32b 0xFFFFFFF // 2^32 bitow
#define w2do24b 0x00FFFFF // 2^24 bitow
#define w2do16b 0x0000FFFF // 2^16 bitow
#define w2do9b 0x00001FF // 2^9 bitow
#define w2do24_9b 0x00007FFF // (24-9)-> 2^15 bitow
```

```
int filtr[5] = {5,-10, 10, -5, 1};
int erpp[5] = {0, 0, 0, 0, 0}, erkp[5] = {0, 0, 0, 0, 0},
erpo[5] = {0, 0, 0, 0, 0}, erko[5] = {0, 0, 0, 0, 0};
```

```
volatile float tplp_24b, tplp_08b,
tklp_24b, tklp_08b,
tplo_24b, tplo_08b,
tklo_24b, tplo_08b;
```

volatile int32\_t epp, dpp, ekp, dkp, epo, dpo, eko, dko;

```
volatile uint16_t tplp_rq[BUFFER_SIZE], tklp_rq[BUFFER_SIZE],
tplo_rq[BUFFER_SIZE], tklo_rq[BUFFER_SIZE];
```

volatile uint16\_t tplp6b\_rq[BUFFER\_SIZE], tklp6b\_rq[BUFFER\_SIZE], tplo6b\_rq[BUFFER\_SIZE], tklo6b\_rq[BUFFER\_SIZE];

## volatile uint16\_t tplp3b\_rq[BUFFER\_SIZE], tklp3b\_rq[BUFFER\_SIZE], tplo3b\_rq[BUFFER\_SIZE], tklo3b\_rq[BUFFER\_SIZE];

void confPins(GPIO\_TypeDef\* port, uint16\_t pin, uint16\_t param); void setPorts(void);

```
void mastTIM2(void);
                          // glowny czasomierz
void pwmTIM1(void);
                          //LADS \times 4
void DMA2_S1_TIM1(void);
                         // DMA dla kanalu TIM1 CH1
void DMA2_S2_TIM1(void);
                          // DMA dla kanalu TIM1 CH2
void DMA2_S6_TIM1(void);
                          // DMA dla kanalu TIM1 CH3
                          // DMA dla kanalu TIM1 CH4
void DMA2_S4_TIM1(void);
void reOuant(void);
void DMA2_S5_GPIOB(void);
// konwerter analogowo-cyfrowy
void convADC1(void);
void DMA2_S0_ADC1(void);
// funkcje dodatkowe
void bufLPF(void);
void obliczenia tp tk(void);
void form_time(void);
void LSBclkTIM3(void);
// funkcja glowna
int main(void)
{
      SysTick_Config(SystemCoreClock/1000);
      setPorts();
      _DSB();
      Init_TIM6();
      Init_DAC_DMA1();
      mastTIM2();
      convADC1();
      DMA2 S0 ADC1();
      pwmTIM1();
```

```
DMA2_S1_TIM1();
                         // tplp
      DMA2_S2_TIM1();
                         // tklp
      DMA2_S4_TIM1();
                         // tklo
      DMA2_S6_TIM1();
                         // tplo
      //-----
      LSBclkTIM3();
      LED3_GPIO->BSRRH = LED3_bm | LED4_bm | LED5_bm | LED6_bm;
      while(1){
      }
}
void mastTIM2(void)
                              // GLOWNY CZASOMIERZ STERUJA-
CY TIM1 oraz ADC1
{
// Timer ogolnego przeznaczenia TIM2
/*
      Impulsy synchronizujace TIM1, ADC1 etc.
      Wybrana czestotliwosc czasomierza: Fs = APB1(42MHz) / 2^8
                                => Fs = 164.0625kHz,
      wyjscie PWM: PB3, jako wyzwalacz dla: ADC, CD74HCT75 i oscylo-
      skopu
*/
// TIM2 control register 2 (TIM2_CR2)
TIM2->CR2 |= TIM_CR2_MMS_1; // (1<<5), => update: trigger output
(TRGO).
// TIM2 DMA/Interrupt enable register (TIMx_DIER)
           |= TIM_DIER_UIE;// (1<<0) => UIE: Update interrupt enable
TIM2->DIER
```

// TIM2 compare mode register 2 (TIM2\_CCMR2), channel 3 and 4
TIM2->CCMR2 = 0x0000;

// TIM2 compare register 2 (TIM2\_CCR2)

TIM2 -> CNT = 0x0000;

TIM2->CCR2 = ilCyk\_Tc/8 // CCR2 is the value to be loaded in the actual compare 2 register (preload value). // TIM2 event generation register (TIM2 EGR)

// CNT[15:0]: Counter value

TIM2->EGR = TIM\_EGR\_UG; // (1<<0), UG: Update generation

```
// TIM2 control register 1 (TIM2_CR1)
TIM2->CR1 |= TIM_CR1_ARPE;// (1<<7), TIM2_ARR buffered ARPE =>
Auto-reload preload enable
}
```

```
void convADC1(void) // conf ADC1
{
    /* Analog-to-digital converter (ADC) */
    /*Select the frequency of the clock to the ADC.
        f_ADC = APB2ENR (84MHz) / Prescaler (2); f_ADC = 42MHz
*/
ADC->CCR = 0x0000; // divided by 2, (0 << 17)|( 0 << 16), ADC_CCR_ADCPRE;</pre>
```

// configuration of ADC1 registers // ADC control register 2 (ADC\_CR2) ADC1->CR2 ADC CR2 EXTEN 1 | ADC CR2 EXTEN 0 = 11 (0 << 29) | (1 << 28)=> trigger detection on the rising edge | ADC\_CR2\_EXTSEL\_1 | ADC\_CR2\_EXTSEL\_0 // (0<<27)|(0<<26)|(1<<25)|(1<<24) => TIM2 external trigger ADC\_CR2\_DDS //(1<<9) => DMA disable selection (for single ADC mode) ADC\_CR2\_DMA => Direct memory access mode - ENABLED //(1<<8) ADC CR2 ADON;//(1<<0) => ADC1 converter ON // ADC sample time register 2 (ADC\_SMPR2) ADC1->SMPR2 = ADC SMPR2 SMP0; // bits (0 0 0) - 3 cycles => the sampling time // ADC watchdog higher threshold register (ADC\_HTR) ADC1->HTR = ADC HTR HT; // 0x0FFF => analog watchdog higher threshold // ADC regular sequence register 1 (ADC SOR1) ADC1->SQR1 = 0x0000; // bits (0 0 0 0): => 1 conversion // ADC regular sequence register 3 (ADC\_SQR3) ADC1->SQR3 = ADC\_SQR3\_SQ1\_0; // 0x0001; => channel: CH1 // ADC control register 1 (ADC\_CR1) ADC1->CR1 |= ADC\_CR1\_EOCIE // (1<<5)end of conversion interrupt: enabled | (ADC\_CR1\_DISCNUM & 0) // bits (0 0 0): channel 1=> discontinuous mode channel count ADC\_CR1\_DISCEN; // (1<<11) => discontinuous mode channel: enabled // Counter TIM2 enabled TIM2->CR1 |= TIM CR1 CEN; // (1<<0), start of the TIM2 counter and the ADC1 converter

| }                                                                                    |                                                                                                             |                                                                                         |
|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| void DMA2_S0_ADC1(void)<br>{                                                         | //                                                                                                          | DMA_CH0 for ADC1_CH1                                                                    |
| /*Direct Memory Access (DM<br>pheral devices and memory. (<br>no FIFO.*/             | A) used to quickly t<br>Channel 0, transfer f                                                               | ransfer data between peri-<br>from Peripheral to Memory,                                |
| // Disable the selected DMA2<br>DMA2_Stream0->CR &= ~(DM<br>while(DMA2_Stream0->CR & | ! Stream0<br>MA_SxCR_EN);<br>~(DMA_SxCR_EN))                                                                | ;                                                                                       |
| // Cleaning all flags<br>DMA2->LIFCR  = (DM                                          | A2->LISR & 0x3D);                                                                                           |                                                                                         |
| // Peripheral address   -> &Al<br>DMA2_Stream0->PAR                                  | DC1->DR<br>L = (uint32_t)&(ADC                                                                              | 1->DR);                                                                                 |
| // Memory address -> &samA<br>DMA2_Stream0->M0A                                      | ADC1<br>AR = (uint32_t)&san                                                                                 | nADC[0];                                                                                |
| // Number of data items to tr<br>DMA2_Stream0->ND7                                   | ansfer<br>ΓR = 2*BUFFER_SIZ                                                                                 | Е;                                                                                      |
| // Configuring the stream: St<br>DMA2_Stream0->CR                                    | ream0<br> = DMA_SxCR_PL_                                                                                    | 1 // (1<<16)                                                                            |
|                                                                                      | DMA_SxCR_MSIZ<br>  DMA_SxCR_PSIZ<br>  DMA_SxCR_MIN(<br>  DMA_SxCR_CIRC<br>  DMA_SxCR_TCIE<br>  DMA_SxCR_EN; | E_0 // (1<<13)<br>E_0 // (1<<11)<br>C // (1<<10)<br>// (1<<8)<br>// (1<<4)<br>// (1<<0) |
| // Enabled interrupt<br>NVIC_EnableIRQ(DMA2_Strea<br>}                               | am0_IRQn);                                                                                                  |                                                                                         |
| void DMA2_Stream0_IRQHan {                                                           | dler(void) // interr                                                                                        | upt service DMA2_S0                                                                     |

```
// Cleaning all flags
DMA2 \rightarrow LIFCR = (DMA2 \rightarrow LISR \& 0x003D):
// Current target, for 0 target is Memory 0 (DMA_SxM0AR pointer)
if (DMA2_Stream0->CR & ~(DMA_SxCR_CT)){
// calculations of times
        bufLPF();
}
}
void bufLPF(void)
for(int i = 0; i < 2*BUFFER_SIZE; i++){</pre>
               tab_lp_sim[i] = (+VT)*(samADC[i]/2048.f - 1);
               tab_lo_sim[i] = (-1) * tab_lp_sim[i];
}
// system operation indicator
LED6_GPIO->BSRRL = LED6_bm;
                                       // BLUE led}
obliczenia_tp_tk();
}
void obliczenia_tp_tk(void)
{
// Numer cvklu kluczowania, Fs= 164.0952kHz,Ts=6.0952us
uint32 t k = 0;
while( k < BUFFER_SIZE ){</pre>
// dt=48.37ns rozdzielczosc dla 6 bitow
               11 bitow (0 - 2047)
11
               lp_fsim[k][0] = tab_lp_sim[2*k+0];
               lp_fsim[k][1] = tab_lp_sim[2*k+1];
tplp[k] = (uint16_t)(4095.f) * (VT - lp_fsim[k][0]) / (4*VT + (Q+1)*(lp_fsi-
m[k][1] - lp_fsim[k][0]) );
               12 bitow (2047 - 4095)
//
               lp_rsim[k][0] = tab_lp_sim[2*k+1];
               lp_rsim[k][1] = tab_lp_sim[2*k+2];
tklp[k] = (uint16_t)(4095.f) * (3*VT + lp_rsim[k][0]) / (4*VT - (Q+1)*(lp_rsi-
m[k][1] - lp_rsim[k][0]) ); //
                                       11 bitow (0 - 2047)
               lo_fsim[k][0] = tab_lo_sim[2*k+0];
               lo_fsim[k][1] = tab_lo_sim[2*k+1];
```

```
tplo[k] = (uint16 t)(4095.f) * (VT - lo_fsim[k][0]) / (4*VT + (0+1)*(lo_fsi-
m[k][1] - lo_fsim[k][0]) );
               12 bitow (2047 - 4095)
//
              lo_rsim[k][0] = tab_lo_sim[2*k+1];
              lo_rsim[k][1] = tab_lo_sim[2*k+2];
tklo[k] = (uint16_t)(4095.f) * (3*VT + lo_rsim[k][0]) / (4*VT - (Q+1)*(lo_rsi-
m[k][1] - lo_rsim[k][0]) );
// Zwiekszanie numeru cyklu kluczowania
       k++;
       }
reQuant():
}
void reQuant(void) // re-quantization of times
{
uint16_t k;
k = 0:
while( k < BUFFER SIZE ){
// rekwantyzacja tplp
//-----
tplp_24b = (uint32_t)((tplp[k])/(2047.f)*w2do24b);
dpp = tplp 24b + opp;
tplp_08b = (int32_t)(dpp /w2do24_9b);
epp = dpp - ((uint32 t)tplp 08b *w2do24 9b);
erpp[4] = erpp[3]; erpp[3] = erpp[2]; erpp[2] = erpp[1];
erpp[1] = erpp[0]; erpp[0] = epp;
opp = 0;
opp = (erpp[0]*filtr[0] + erpp[1]*filtr[1] + erpp[2]*filtr[2] + erpp[3]*filtr[3]
+ erpp[4]*filtr[4]);
tplp_rq[k] = (uint16_t)(511.f^*(tplp_08b/w2do9b));
tplp6b[k] = (uint16_t)tplp_rq[k] >> 3; // 6 bitow, 0-63
                                            // 3 bity, 0-07
tplp3b[k] = (uint16_t)tplp_rq[k] \& 7;
       k++;
       }
k = 0:
while( k < BUFFER SIZE ){
// rekwantyzacja tklp
```

```
//-----
tklp_24b = (uint32_t)((tklp[k])/(2047.f)*w2do24b);
dkp = tklp_24b + okp;
tklp_08b = (uint32_t)(dkp /w2do24_9b);
ekp = dkp - ((uint32_t)tklp_08b *w2do24_9b);
erkp[4] = erkp[3]; erkp[3] = erkp[2]; erkp[2] = erkp[1];
erkp[1] = erpp[0]; erkp[0] = ekp;
okp = 0;
okp = (erkp[0]*filtr[0] + erkp[1]*filtr[1] + erkp[2]*filtr[2] + erkp[3]*filtr[3]
+ erkp[4]*filtr[4]);
tklp_rq[k] = (uint16_t)(511.f^*(tklp_08b/w2do9b));
tklp6b[k] = (uint16_t)tklp_rq[k] >> 3; // 6 bitow, 0-63
tklp3b[k] = (uint16_t)tklp_rq[k] & 7; // 3 bity, 0-07
       k++:
       }
k = 0:
while( k < BUFFER_SIZE ){</pre>
// rekwantyzacja tplo
//-----
tplo_24b = (uint32_t)((tplo[k])/(2047.f)*w2do24b);
dpo = tplo 24b + opo;
tplo \ 08b = (uint32 \ t)(dpo \ /w2do24 \ 9b);
epo = dpo - ((uint32_t)tplo_08b *w2do24_9b);
erpo[4] = erpo[3]; erpo[3] = erpo[2]; erpo[2] = erpo[1];
erpo[1] = erpo[0]; erpo[0] = epo;
opo = 0;
opo = (erpo[0]*filtr[0] + erpo[1]*filtr[1] + erpo[2]*filtr[2]+ erpo[3]*filtr[3]
+ erpo[4]*filtr[4]);
tplo_rq[k] = (uint16_t)(511.f^*(tplo_08b/w2do9b));
tplo6b[k] = (uint16_t)tplo_rq[k] >> 3; // 6 bitow, 0-63
                                       // 3 bity, 0-07
tplo3b[k] = (uint16_t)tplo_rq[k] \& 7;
       k++:
       }
k = 0:
while( k < BUFFER_SIZE ){</pre>
// rekwantyzacja tklo
//-----
tklo_24b = (uint32_t)((tklo[k])/(2047.f)*w2do24b);
```

```
dko = tklo_24b + oko;
tklo_08b = (uint32_t)(dko /w2do24 9b):
eko = dko - ((uint32_t)tklo_08b *w2do24_9b);
erko[4] = erko[3]; erko[3] = erko[2]; erko[2] = erko[1];
erko[1] = erpo[0]; erko[0] = eko;
oko = 0:
oko = (erko[0]*filtr[0] + erko[1]*filtr[1] + erko[2]*filtr[2]+ erko[3]*filtr[3]
+ erko[4]*filtr[4]);
tklo rg[k] = (uint16 t)(511.f^{*}(tklo 08b/w2do9b));
tklo6b[k] = (uint16_t)tklo_rq[k] >> 3;
                                          // 6 bitow, 0-63
tklo3b[k] = (uint16_t)tklo_rq[k] & 7; // 3 bitv. 0-07
       k++:
       }
}
// wyprowadzenie danych do PWM
//-----
void pwmTIM1(void)
                        // Konfiguracja TIM1->164.095kHz, CH:1-4:
PE09,PE11,PE13,PE14
{
// CR1 - control register 1
TIM1->CR1 = TIM CR1 ARPE: // (1<<7) => TIMx ARR register is buf-
fered
                                    //=> Counter overflow or underflow
                                    //=> generates an update abort or
DMA request
// SMCR - slave mode control register
TIM1->SMCR = TIM SMCR TS 0 | TIM SMCR SMS 2; // (1<<4) | (1<<2);
                     //=> Internal Trigger 1 (ITR1 -> TIM2_TRG0)
//=> Reset Mode - Rising edge of the selected
                     // => trigger input (TRGI) reinitializes the counter
                     // => and generates an update of the registers.
// CCMR1 - capture/compare mode register 1
//Configuration of 4 output channels.
//The given OCxx bit describes its function when the channel is configured
//at the output.
TIM1->CCMR1= TIM CCMR1 OC1M 2 | TIM CCMR1 OC1M 1//CCxS= Out-
put, OCxM= PWM1 | TIM_CCMR1_OC2M_2 | TIM_CCMR1_OC2M_1;
```

```
TIM1->CCMR1 |= TIM_CCMR1_OC1PE | TIM_CCMR1_OC2PE; //
                                   => Set preload bits for both channels
CH1 and CH2
// CCMR2 - capture/compare mode register 2
TIM1->CCMR2 = TIM_CCMR2_OC3M_2 | TIM_CCMR2_OC3M_1
                                   TIM CCMR2 OC4M 2 | TIM CCMR2
OC4M_1;
TIM1->CCMR2 |= TIM_CCMR2_OC3PE | TIM_CCMR2_OC4PE; //
                                   => Set preload bits for both channels
CH3 and CH4
// CCER - capture/compare enable register
TIM1->CCER = TIM CCER CC1E | TIM CCER CC2E//OCx active HIGH, OCx
enabled
       | TIM_CCER_CC3E | TIM_CCER_CC4E;
// TIM1 prescaler (TIM1_PSC)
TIM1->PSC = 0x0007;// TIM_CLK = SYS_CLK/(TIM_PSC+1) <= SYS_CLK =
168MHz
// ARR auto-reload register
TIM1->ARR = ilCyk_Tc/4-1; // 512/4-1 =127 resolution defines period, f_
UEV = 164.063 kHz
// CNT counter value reset
TIM1 -> CNT = 0x0000;
// RCR repetition counter register
TIM1->RCR
              = 0 \times 0000;
// CCRx capture/compare register x
// initialization of initial PWM values
TIM1 -> CCR1 = 0x001E:
                                   // CH1 PE09
TIM1->CCR2 = 0x003C;
                                   // CH2 PE11
TIM1->CCR3 = 0x005A;
                                   // CH3 PE12
TIM1 - CCR4 = 0x0078;
                                   // CH4 PE13
TIM1->BDTR |= TIM_BDTR_MOE | TIM_BDTR_OSSR | TIM_BDTR_OSSI;
TIM1->DIER = (1 << 8) | (1 << 9) | (1 << 10) | (1 << 11) | (1 << 12);
// EGR - event generation register
```

```
TIM1 \rightarrow EGR \mid = TIM \_ EGR \_ TG;
                                   // Update generation, polarity: (+)-
>TG: (-) ->UG
// Start TIM1
TIM1->CR1 |= TIM_CR1_CEN;
}
void DMA2 S1 TIM1(void)
                                    // DMA dla TIM1 CH1
{ // Channel 6, MEM->PER, no FIFO,
       DMA2_Stream1->CR &= \sim (DMA_SxCR_EN);
       while(DMA2 Stream1->CR & DMA SxCR EN):
       DMA2 \rightarrow LIFCR = (DMA2 \rightarrow LISR \& 0x0F60);
                                                  //H.. Str>3, clear all
flags
       DMA2_Stream1->PAR = (uint32_t)&(TIM1->CCR1); // peripheral
       address
       DMA2_Stream1->M0AR = (uint32_t)&tplp6b[0]; // memory ad-
       dress
       DMA2 Stream1->NDTR = BUFFER SIZE;
                                                   // 1 hword at each
       update
       DMA2_Stream1->CR = (1 << 27) |(1 << 26); // kanal6 <-
       // DMA_SxCR_CHSEL_2 | DMA_SxCR_CHSEL_1;
       DMA2 Stream1->CR |= 0 << 19;// podwojny bufor , DMA SxCR CT;
       DMA2_Stream1->CR |= 0 << 18;// podwojny bufor, DMA_SxCR_DBM;
       DMA2 Stream1->CR |= 1 << 17;// priorytet, DMA SxCR PL 1;
       DMA2_Stream1->CR |= 0 << 15;// inc. size Per, DMA_SxCR_PINCOS;
       DMA2_Stream1->CR |= 1 << 13;// rozmiar Mem 16b, DMA_SxCR_
MSIZE 1:
       DMA2 Stream1->CR |= 1 << 11;// rozmiar Per 16b, DMA SxCR PSI-
ZE_1;
       DMA2_Stream1->CR |= 1 << 10;// inc. Mem- z, DMA_SxCR_MINC;
       DMA2_Stream1->CR |= 0 << 9;// inc. Per- bez, DMA_SxCR_PINC;
       DMA2_Stream1->CR |= 1 << 8; // tryb kolowy, DMA_SxCR_CIRC;
       DMA2_Stream1->CR |= 1 << 6;// kier.Mem->Per, DMA_SxCR_DIR_0;
       DMA2 Stream1->CR |= DMA SxCR EN;
                                                  // start DMA2 S1
       }
void DMA2 S2 TIM1(void)
                                   // DMA dla TIM1 CH2
{ // Channel 6, MEM->PER, no FIFO,
```

```
DMA2 Stream2->CR &= \sim (DMA SxCR EN);
      while(DMA2 Stream2->CR & DMA SxCR EN):
      DMA2->LIFCR = (DMA2->LISR & 0x0F60);//H.. Str>3, clear all flags
      DMA2 Stream2->PAR = (uint32 t)&(TIM1->CCR2);// peripheral ad-
dress
      DMA2_Stream2->M0AR = (uint32_t)&tklp6b[0]; // memory ad-
dress
      DMA2_Stream2->NDTR = BUFFER_SIZE;
                                                // 1 hword at each
update
      DMA2_Stream2->CR |= (1 << 27)|(1 << 26);// kanal6 <-
                                 // DMA SxCR CHSEL 2 | DMA SxCR
CHSEL_1;
      DMA2_Stream2->CR |= 0 << 19;// podwojny bufor, DMA_SxCR_CT;
      DMA2_Stream2->CR |= 0 << 18;// podwojny bufor, DMA_SxCR_DBM;
      DMA2_Stream2->CR |= 1 << 17;// priorytet, DMA_SxCR_PL_1;
      DMA2_Stream2->CR |= 0 << 15;// inc. size Per, DMA_SxCR_PINCOS;
      DMA2_Stream2->CR |= 1 << 13;// rozmiar Mem 16b, DMA_SxCR_
MSIZE_1;
      DMA2 Stream2->CR |= 1 << 11;// rozmiar Per
                                                      16b,
                                                             DMA
SxCR_PSIZE_1;
      DMA2_Stream2->CR |= 1 << 10;// inc. Mem- z, DMA_SxCR_MINC;
      DMA2_Stream2->CR |= 0 << 9;// inc. Per- bez, DMA_SxCR_
PINC:
      DMA2_Stream2->CR |= 1 << 8;// tryb kolowy, DMA_SxCR_CIRC;
      DMA2_Stream2->CR |= 1 << 6; // kier.Mem->Per, DMA_SxCR_DIR_0;
      DMA2 Stream2->CR |= DMA SxCR EN;
                                               // start DMA2 S2
      }
void DMA2_S6_TIM1(void)
                                 // DMA dla TIM1 CH3
{// Channel 6, MEM->PER, no FIFO,
      DMA2_Stream6->CR &= ~(DMA_SxCR_EN);
      while(DMA2 Stream6->CR & DMA SxCR EN);
      DMA2->HIFCR = (DMA2->HISR & 0x0F60);//H.. Str>3, clear all flags
      DMA2_Stream6->PAR = (uint32_t)&(TIM1->CCR3); // peripheral
address
      DMA2_Stream6->M0AR = (uint32_t)&tplo6b[0];
                                                           memory
                                                       //
address
      DMA2_Stream6->NDTR = BUFFER_SIZE;
                                               // 1 hword at each
```

| update  |                                                                                                                            |
|---------|----------------------------------------------------------------------------------------------------------------------------|
|         | DMA2_Stream6->CR  = (1 << 27) (1 << 26);// kanal 6 <-                                                                      |
|         | // DMA_SxCR_CHSEL_2   DMA_SxCR_                                                                                            |
| CHSEL_  | 1;                                                                                                                         |
|         | DMA2 Stream6->CR $ = 0 << 19$ ;// podwojny bufor , DMA SxCR CT;                                                            |
|         | DMA2 Stream6->CR  = 0 << 18:// podwoinv bufor. DMA SxCR DBM:                                                               |
|         | DMA2 Stream6->CR $= 1 << 17://$ priorytet, DMA SxCR PL 1:                                                                  |
|         | DMA2 Stream6->CR $= 0 << 15$ :// inc size Per DMA SxCR                                                                     |
| PINCOS  |                                                                                                                            |
| 1 11000 |                                                                                                                            |
| MSI7F   |                                                                                                                            |
| MJIZL_  | DMA2 Stream6-SCR = 1 << 11.// rozmiar Par 16h DMA SyCR PSL                                                                 |
| 7F 1.   |                                                                                                                            |
| 26_1,   | DMA2 Stream6-SCR $= 1 < < 10 \cdot / / inc Mem - 7 DMA SyCR MINC.$                                                         |
|         | $DMA2_Stream6 > CR = 1 < 10,7 mc. Mem 2, DMA_SXCR_MINC,$                                                                   |
| DINC.   | $DMA2_Streamo-PCK = 0 << 9,77 mc. ref- bez, DMA_Sxch_$                                                                     |
| FINC;   | DMA2 Stroom $\mathcal{O}$ = 1 < $\mathcal{O}$ // true bolowny DMA SyCP CIPC.                                               |
|         | $DMA2_SUBGIIO - 2CK = 1 << 0; // Uyb Kolowy, DMA_SXCK_CIRC; DMA2_Stream6 > CB = 1 << 6; // bior Mom > Don DMA_SYCR_DID 0;$ |
|         | $DMA2_SUBAIIIO - SCR = 1 << 0; // RIELMEIII - SPEL, DMA_SXCR_DIR_U;$                                                       |
| 1 I     | DMA2_Stream6->CR  = DMA_SXCR_EN; // Start DMA2_56                                                                          |
| }       | (A) CA TIMI (void) // DMA dla TIMI CUA                                                                                     |
|         | $MA2_54_1IM1(VOID) // DMA dia IIM1 CH4$                                                                                    |
| {// Cna | nnei o, MEM->PER, no FIFU,                                                                                                 |
|         | $DMA2\_Stream4->CR \& = ~(DMA\_SXCR\_EN);$                                                                                 |
|         | While(DMA2_Stream4->CR & DMA_SXCR_EN);                                                                                     |
|         | DMA2->HIFCR = ( $DMA2$ ->HISR & $0x0F60$ );//H Str>3, clear all flags                                                      |
|         | DMA2_Stream4->PAR = (uint32_t)&(TIM1->CCR4); // peripheral                                                                 |
| address |                                                                                                                            |
|         | DMA2_Stream4->M0AR = (uint32_t)&tklo6b[0]; // memory                                                                       |
| address | 3                                                                                                                          |
|         | DMA2_Stream4->NDTR = BUFFER_SIZE;// 1 hword at each update                                                                 |
|         | DMA2_Stream4->CR  = (1 << 27) (1 << 26); // kanal 6 <-                                                                     |
|         | // DMA_SxCR_CHSEL_2   DMA_SxCR_                                                                                            |
| CHSEL_  | 1;                                                                                                                         |
|         | DMA2_Stream4->CR  = 0 << 19;// podwojny bufor, DMA_SxCR_CT;                                                                |
|         | DMA2_Stream4->CR  = 0 << 18;// podwojny bufor, DMA_SxCR_DBM;                                                               |
|         | DMA2_Stream4->CR  = 1 << 17;// priorytet, DMA_SxCR_PL_1;                                                                   |
|         | DMA2_Stream4->CR  = 0 << 15;// inc. size Per , DMA_SxCR_                                                                   |
| PINCOS  |                                                                                                                            |

```
DMA2_Stream4->CR |= 1 << 13;// rozmiar Mem 16b, DMA_SxCR
MSIZE_1;
       DMA2 Stream4->CR |= 1 << 11;// rozmiar Per 16b, DMA SxCR PSI-
ZE_1;
       DMA2_Stream4->CR |= 1 << 10;// inc. Mem- z, DMA_SxCR_MINC;
       DMA2 Stream4->CR |= 0 << 9;// inc. Per- bez, DMA SxCR
PINC;
      DMA2_Stream4->CR |= 1 << 8;// tryb kolow, DMA_SxCR_CIRC;
      DMA2 Stream4->CR |= 1 << 6;// kier.Mem->Per, DMA SxCR DIR 0;
       DMA2_Stream4->CR |= DMA_SxCR_EN;
                                               // start DMA2 S4
}
// konfiguracja pinow
void setPorts(void)
{// Clock enable for all ports A..E
RCC->AHB1ENR |=(RCC_AHB1ENR_GPIOAEN | RCC_AHB1ENR_GPIOBEN |
RCC_AHB1ENR_GPIOCEN
              | RCC_AHB1ENR_GPIODEN | RCC_AHB1ENR_GPIOEEN);
RCC->AHB1ENR |= RCC AHB1ENR DMA1EN | RCC AHB1ENR DMA2EN;
RCC->APB2ENR |= RCC APB2ENR TIM8EN | RCC APB2ENR TIM1EN | RCC
APB2ENR ADC1EN;
RCC->APB1ENR |= RCC_APB1ENR_TIM2EN | RCC_APB1ENR_TIM3EN
              | RCC APB1ENR DACEN | RCC APB1ENR TIM6EN;
GPIOD \rightarrow MODER = (1 << 30)|(1 << 28)|
       (1 << 26)|(1 << 24);//set pins PD: 12 - 15
// TIM1 OUT pwm
confPins(PE09CH1 GPIO, PE09CH1 set, conf pin TIM1);
                                                      // OUT CH1P
confPins(PE11CH2_GPI0, PE11CH2_set, conf_pin_TIM1);
                                                      // OUT CH2P
confPins(PE13CH3 GPIO, PE13CH3 set, conf pin TIM1);
                                                      // OUT CH3P
confPins(PE14CH4_GPIO, PE14CH4_set, conf_pin_TIM1);
                                                      // OUT CH4P
// TIM2 OUT, PB3 master
confPins(PB03CH2_GPI0, PB03CH2_set, conf_pin_TIM2);
// TIM3 OUT, PB4 slave -> 3bits
confPins(PB04CH2_GPIO, PB04CH2_set, conf_pin_TIM3);
// analog in ADC1, PA1
confPins(PA01CH1 GPIO, PA01CH1 set, conf pin ADC1);
}
```
void LSBclkTIM3(void)// sterowanie wysylka 3bitow tp oraz tk na linie opozniajaca

```
{// General-purpose timer TIM3
```

// Output: PB4, f=328.125kHz <--(2\* 164.0625kHz)

TIM3->SMCR = TIM\_SMCR\_TS\_0 | TIM\_SMCR\_SMS\_2;

```
//=> Internal Trigger 1 (ITR0 -> TIM1_TRGO)
```

// TIM3 DMA/Interrupt enable register (TIMx\_DIER)

TIM3->DIER |= TIM\_DIER\_UIE; // (1<<0) => UIE: Update interrupt enable

```
// TIM3 compare mode register 1 (TIM3_CCMR1), channel 1 and 2
TIM3->CCMR1 |= TIM CCMR1 OC1M 2| TIM CCMR1 OC1M 1
```

// (1<<14)|(1<<13)|(0<<12) => 0C1M[2:0]: Output compare 2 mode

| TIM\_CCMR1\_OC2PE// (1<<11) => Output compare 2 preload enable

| TIM\_CCMR1\_OC1PE;// (1<<3) => Preload register on TIMx\_CCR1 enabled

// TIM3 compare mode register 2 (TIM3\_CCMR2), channel 3 and 4 TIM3->CCMR2 = 0x0000;

// TIM3 compare enable register (TIM3\_CCER)

TIM3->CCER = 0x0001; // (1<<5) => Compare 2 output enable // TIM3 prescaler (TIM3\_PSC)

TIM3->PSC = 0x0003; // prescaler value = 1 => the counter clock //frequency CLK\_CNT is equal to: fCLK\_PSC / (PSC[15:0] + 1)

// TIM3 auto-reload register (TIM3\_ARR)

TIM3->ARR = ilCyk\_Tc/4-1; // 512/4-1 = 127 (0x007F) => ARR[15:0]: //Auto-reload value (16bits -> 65535)

// TIM3 counter (TIM3\_CNT)

TIM3->CNT = 0x0000; // CNT[15:0]: Counter value

TIM3->CCR1 = ilCyk\_Tc/8; // CCR1 is the value to be loaded in the // actual compare 2 register, (preload value).

// TIM3 event generation register (TIM3\_EGR)

TIM3->EGR = TIM\_EGR\_UG; // (1<<0), UG: Update Generation // TIM3 control register 1 (TIM3\_CR1)

TIM3->CR1 |= TIM\_CR1\_ARPE // (1<<7), TIM3\_ARR buffered ARPE => Auto-reload preload enable

| TIM\_CR1\_DIR; // (1<<4), Counter used as downcounter // Counter initialization

```
TIM3->CR1
               |= TIM_CR1_CEN;
TIM ITConfig(TIM3, TIM IT CC1, ENABLE);
NVIC_EnableIRQ(TIM3_IRQn);
}
void TIM3_IRQHandler()
{// Checks whether the TIM1 interrupt has occurred or not
if (TIM_GetITStatus(TIM3, TIM_IT_Update))
{
switch( kk ){
                     GPIOB->ODR = tplp3b[ind]; kk++; break; }
       case 0:{
       case 1: { GPIOB->ODR = tklp3b[ind]; kk--; break; }
       }
// Clears the TIM3 interrupt pending bit
TIM_ClearITPendingBit(TIM3, TIM_IT_Update);
}
ind = (ind+1) & (BUFFER_SIZE+1);
LED3_GPIO->BSRRL = LED3_bm;
  }
```

**Wojciech Kołodziejski** – dr inż., wykładowca, pracownik naukowy Państwowej Wyższej Szkoły Zawodowej w Tarnowie. W 1998 roku ukończył studia na Wydziale Elektrotechniki, Informatyki, Automatyki i Elektroniki Akademii Górniczo-Hutniczej w Krakowie na kierunku elektronika, studia podyplomowe w 1986 roku w zakresie komputerowych i µ-komputerowych systemów przetwarzania informacji cyfrowej. W 1985 roku obronił dyplom z fizyki na Uniwersytecie Pedagogicznym w Krakowie. Od kilku lat zajmuje się cyfrowymi modulatorami DPWM stosowanymi we wzmacniaczach klasy D oraz metodami ich sterowania z wykorzystaniem układów linii opóźniającej i mikrokontrolerów z serii STM32. Zajmuje się również eliminacją sygnałów wspólnych w DPWM, czyli nowym typie modulacji Common-Mode Free BD (CMBD).



