# Simple Real-Time Digital PWM Implementation for Class-D Amplifiers With Distortion-Free Baseband

Fernando Chierchie, *Student Member, IEEE*, Eduardo E. Paolini, Leandro Stefanazzi, and Alejandro R. Oliva

*Abstract*—A real-time, digital algorithm for pulse width modulation (PWM) with distortion-free baseband is developed in this paper. The algorithm not only eliminates the intrinsic baseband distortion of digital PWM but also avoids the appearance of side-band components of the carrier in the baseband even for low switching frequencies. Previous attempts to implement digital PWM with these spectral properties required several processors due to their complexity; the proposed algorithm uses only several FIR filters and a few multiplications and additions and therefore is implemented in real time on a standard DSP. The performance of the algorithm is compared with that of uniform, double-edge PWM modulator via experimental measurements for several bandlimited modulating signals.

*Index Terms*—Digital modulation, harmonic distortion, power amplifier, pulse width modulation (PWM), switching amplifier.

#### I. INTRODUCTION

**P**ULSE WIDTH MODULATION (PWM) is widely used to drive different types of switching converters, from dc-dc power converters [1] to class-D audio amplifiers [2] and RF transmitters [3]. Much of the recent research effort on PWM is focused on reducing the distortion introduced by digital implementations of PWM modulators. Some approaches are aimed at the elimination of certain specific harmonics produced by the modulation [4] while others are customized for multilevel ac drives applications [5] or three phase inverters [6], [7]. Some of these techniques are based on optimization methods which attempt to minimize the harmonic distortion of the output voltage [8], others on random switching PWM techniques applied to reduce the dominant harmonics [9].

Manuscript received July 8, 2013; revised September 30, 2013; accepted November 26, 2013. Date of publication January 2, 2014; date of current version May 2, 2014. This work was supported in part by CONICET, CIC, and SGCyT-UNS (PGI 24ZK21 and PGI 24K055).

F. Chierchie and A. R. Oliva are with the Instituto de Inv. en Ing. Eléctrica (IIIE) Alfredo Desages (UNS-CONICET) and the Dto. de Ing. Eléctrica y de Computadoras, Universidad Nacional del Sur, 8000 Bahía Blanca, Argentina, and also with the Consejo Nacional de Investigaciones Científicas y Técnicas (CONICET), Argentina (e-mail: fernando.chierchie@uns.edu.ar).

E. E. Paolini is with the Instituto de Inv. en Ing. Eléctrica (IIIE) Alfredo Desages (UNS-CONICET) and the Dto. de Ing. Eléctrica y de Computadoras, Universidad Nacional del Sur, 8000, Bahía Blanca, Argentina, and also with the Comisión de Investigaciones Científicas (CIC), Argentina.

L. Stefanazzi is with Instituto de Inv. en Ing. Eléctrica (IIIE) Alfredo Desages (UNS-CONICET) and the Dto. de Ing. Eléctrica y de Computadoras, Universidad Nacional del Sur, 8000, Bahía Blanca, Argentina, and also with the Instituto Nacional de Tecnología Industrial (INTI), Argentina.

Color versions of one or more of the figures in this paper are available online at http://ieeexplore.ieee.org.

Digital Object Identifier 10.1109/TIE.2013.2297312

In general, all those methods developed for ac drive applications are not suited for class-D or switching amplifiers because they are designed for sinusoidal signals and not for arbitrary band-limited signals, as required by audio amplifiers. The problem with digital PWM amplifiers is that standard modulation processes [10]–[13] produce baseband distortion that cannot be eliminated by the demodulator, usually a low-pass filter. Although part of this distortion can be reduced by using very high PWM frequencies, thus reducing the efficiency, it cannot be completely removed from the output spectrum.

Click modulation [14], [15] is an interesting alternative for analog PWM as it allows the generation of low switching rate binary signals with separated baseband. The first hardware implementation of click modulation applied to switching amplifiers required three DSPs to run the algorithm and two FPGA acting as a digital pulse former [16], [17]. In a recent implementation [18], [19], a DSP and a FPGA were required to achieve a bandwidth of 12 kHz which is below the 0–20 kHz standard for consumer audio products. These implementations are not only hardware demanding but also suffer from the discrete-time approximations that are required to implement the click modulator [20]. Recently a discrete-time approach of click modulation, which avoids the aliasing problems of the discretization process, has been presented [21], but a real-time implementation has not been yet reported.

In this paper, a digital algorithm for baseband distortionfree pulse width modulation (BBDFPWM) suitable for realtime operation is developed, and its performance is evaluated via experimental measurements. The algorithm is derived in the time domain and it is based on computing the samples of the baseband content of the PWM signal as a function of the duty cycle values. A nonlinear model of the PWM process that accurately reflects the nonlinearity introduced by the modulation is derived. Patent [22] and other articles, such as [23], [24], arrived at similar mathematical descriptions following different development paths. Based on such models, distortion reduction methods with different application ranges and capabilities for reducing distortion have been proposed. In this paper, an approximate numerical inversion of this nonlinear relation is performed in real time by the proposed BBDFPWM algorithm composed by the cascade connection of equal blocks of short length FIR filters and some multiplications and additions. Hence, its implementation is straightforward in any standard DSP platform. The performance of the algorithm is proportional to the number of cascade blocks, allowing the designer to tradeoff between a required performance and computational cost.

<sup>0278-0046 © 2014</sup> IEEE. Personal use is permitted, but republication/redistribution requires IEEE permission. See http://www.ieee.org/publications\_standards/publications/rights/index.html for more information.



Fig. 1. Block diagrams. (a) Standard SDEUPWM and (b) proposed BBDFPWM digital algorithm.



Fig. 2. Typical signals and spectral content. (a) Discrete input signal with its spectrum and (b) PWM signals with spectra.

The problem is described in Section II and the algorithm architecture is derived in Section III. Guidelines for the selection of the parameters of the algorithm, which determine its expected performance and computational complexity, are presented in Section IV. Comparisons to standard PWM methods and a previous approach in [22] are presented in Section V. In Section VI, the performance of the BBDFPWM algorithm is demonstrated with experimental measurements of real-world modulating test signals performed in the laboratory using an standard DSP. Finally, some conclusions are drawn in Section VII.

## **II. PROBLEM STATEMENT**

In uniform digital PWM, the duty cycles  $d_n$  of the squarewave signal p(t) are a scaled version of the sample values  $x_n$ of a modulating signal that is band-limited to  $f_m$ . In other words, if  $x_n$  and  $d_n$  are normalized, i.e., comprised within the range (0, 1) the duty cycles are given by  $d_n = x_n$ , as shown in Fig. 1(a). A typical discrete-time modulating signal, sampled at  $f_s$  and with a maximum frequency content limited to  $f_m$ , is shown in Fig. 2(a).

Symmetrical Double Edge Uniform PWM (SDEUPWM) is one of the most common alternatives for digital PWM because of its easy implementation and good spectral behavior [10]. In SDEUPWM, the center of the pulses are evenly spaced by the carrier period  $T_c = 1/f_c$  and the location of the rising and



Fig. 3. Derivation of the BBDFPWM algorithm: (a) PWM modulator, ideal demodulator, and output sampling. (b) Nonlinear discrete-time model of the above.

falling edges depends on the sample value of the modulating signal  $x_n$ .

Two components contribute to the baseband distortion produced by SDEUPWM, as shown schematically in Fig. 2(b): the carrier sidebands that lie within the baseband (between 0 Hz and  $f_c/2$ ) for low  $f_c/f_m$  ratios and the intrinsic baseband distortion that appears in the baseband independently of the  $f_c/f_m$  ratio that is dependent on the time derivatives of the modulating signal [10]; both are represented with the shaded area in the spectrum of Fig. 2(b). These distortion components cannot be eliminated by the low-pass-filter traditionally used as demodulator in most power electronics applications.

In this paper, a real-time implementation of a baseband distortion-free PWM algorithm (BBDFPWM) that has theoretically zero (and practical negligible) baseband distortion is presented. A block diagram is shown in Fig. 1(b), where the modulating signal  $x_n$ , sampled at  $f_s$ , is processed with the BBDFPWM algorithm to obtain the duty cycles  $d_n$  of the PWM signal p(t) sampled at  $f_c$  (the PWM carrier frequency). The signal p(t) produced by the BBDFPWM has duty cycles that are slightly different from the duty cycles of the SDEUPWM as illustrated in the PWM waveforms of Fig. 2(b). This small changes produce a very different frequency content.

The BBDFPWM ensures that the baseband spectrum of p(t) is free from the intrinsic baseband distortion produced by digital PWM and also from carrier sidebands which do not appear below  $f_c/2$  even for PWM switching frequencies  $f_c$  as low as  $2f_m$ . This characteristic allows for a greater flexibility in the selection of the carrier frequency and represents an improvement not only from other digital modulators but also from the analog or natural PWM which must use very high carrier frequencies to achieve reduced distortion levels.

#### **III. BBDFPWM ALGORITHM**

The objective of the BBDFPWM algorithm is to derive the duty cycles  $d_n$  from the modulating signal samples  $x_n$  such that the frequency content of the PWM signal p(t) in the range  $[0, f_c/2)$  is free of distortion. Its derivation can be explained with the help of Fig. 3(a). The continuous-time signal y(t) is the low-pass filtered (demodulated) version of p(t). Since y(t)

 $\begin{array}{c} \text{TABLE} \ \ \mathbf{I} \\ \text{Impulse Response of FIR Filters } (0 \leq n < N, M = (N-1)/2) \end{array}$ 

|            | Impulse Responses $h_{i,n}$ defined as a causal version of $c_{i,m}$ : $h_{i,n} = c_{i,m} _{m=n-M}$ .                                    |                       |
|------------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| $h_{1,n}$  | $c_{1,0} = 1$                                                                                                                            | if $n = M$            |
|            | 0                                                                                                                                        | if $n \neq M$         |
| $h_{3,n}$  | $c_{3,0} = -\pi^2/72$                                                                                                                    | if $n = M$            |
|            | $c_{3,m} = -(-1)^m / (12m^2) \big _{m=n-M}$                                                                                              | if $n \neq M$         |
| $h_{5,n}$  | $c_{5,0} = \pi^4/9600$                                                                                                                   | if $n = M$            |
|            | $c_{5,m} = \frac{(-1)^m}{480m^4} \left( -6 + m^2 \pi^2 \right) \Big _{m=n-M}$                                                            | $\text{if } n \neq M$ |
| $h_{7,n}$  | $c_{7,0} = -\pi^6/2257920$                                                                                                               | if $n = M$            |
|            | $c_{7,m} = -\frac{(-1)^m}{53760m^6} \left( 120 - 20m^2\pi^2 + m^4\pi^4 \right) \Big _{m=n-M}$                                            | if $n \neq M$         |
| $h_{9,n}$  | $c_{9,0} = \pi^8 / 836075520$                                                                                                            | if $n = M$            |
|            | $c_{9,m} = \frac{(-1)^m}{11612160m^8} \left( -5040 + 840m^2\pi^2 - 42m^4\pi^4 + m^6\pi^6 \right) \Big _{m=n-M}$                          | $\text{if } n \neq M$ |
| $h_{11,n}$ | $c_{11,0} = -\pi^{10}/449622835200$                                                                                                      | if $n = M$            |
|            | $c_{11,m} = -\frac{(-1)^m}{4087480320m^{10}} \left( 362880 - 60480m^2\pi^2 + 3024m^4\pi^4 - 72m^6\pi^6 + m^8\pi^8 \right) \Big _{m=n-M}$ | $\text{if } n \neq M$ |

has no frequency components above  $f_c/2$ , it can be sampled at  $f_c$  without aliasing to obtain the sample values  $y_n$ . To simplify the presentation, it will be assumed that  $f_s = f_c$ . In short, the objective of the BBDFPWM algorithm is to compute  $d_n$  form  $x_n$  such that  $y_n = x_n$ .

The development of the algorithm is based on three steps. First, a discrete-time nonlinear model of the baseband behavior of the PWM that relates  $d_n$  to  $y_n$  is obtained [23]–[25] and an approximation to the exact model is introduced for real-time operation purposes. Second, the pulse width values  $d_n$  are derived from  $x_n$  using an iterative numerical method, and third, the numerical method is translated into an architecture suitable for on-line operation using standard FIR filters and some additional mathematical operations, such as additions and multiplications.

## A. Nonlinear PWM Discrete-Time Model

The two-level PWM signal p(t) switching between 0 and 1 can be represented using the step function u(t) as [10], [25]

$$p(t) = \sum_{n=-\infty}^{\infty} \left[ u \left( t - nT_s + d_n \frac{T_s}{2} \right) - u \left( t - nT_s - d_n \frac{T_s}{2} \right) \right]$$
(1)

where  $d_n \in (0, 1)$ . If p(t) is filtered with an ideal low-pass filter with cutoff frequency  $f_c/2$  and impulse response  $h_{LP}(t) = f_c \operatorname{sinc}(f_c t) = f_c \sin(\pi f_c t)/(\pi f_c t)$ , the signal  $y(t) = h_{LP}(t) * p(t)$  (where "\*" indicates convolution) is obtained. Uniformly sampling y(t) at  $f_c$  results in the discrete-time output signal [24], [25]

$$y_n = \sum_{m=-\infty}^{\infty} f_m(d_{n-m}) \tag{2}$$

with

$$f_m(d) \stackrel{\Delta}{=} \frac{\left(\operatorname{Si}\left[m\pi + d\left(\frac{\pi}{2}\right)\right] - \operatorname{Si}\left[m\pi - d\left(\frac{\pi}{2}\right)\right]\right)}{\pi} \quad (3)$$

where  $Si(z) = \int_0^z \sin(\tau)/\tau d\tau = \int_0^z \operatorname{sinc}(\tau/\pi) d\tau$  is the sine integral function.



Fig. 4. Block representation of the kth iteration of (7). The block "PWM model" implements (6) [See Fig. 3(b)].

Equation (2) is a discrete-time nonlinear baseband model of the PWM modulation with the duty cycles  $d_n$  as input and the samples  $y_n$  as output. The computation of  $y_n$  using (2) requires knowing in advance the infinite set of duty cycles  $d_n$ , precluding real-time operation.

To reduce the complexity in the computation of  $y_n$  in (2) and to make a real-time implementation feasible, two simplifications are introduced: 1) the function  $f_m(d)$  is approximated by its power series and 2) the infinite sum is truncated to  $\pm M$  values.

The nonlinear function  $f_k(d)$  can be approximated by the odd-power series

$$f_m(d) \approx \begin{cases} c_{1,0}d + c_{3,0}d^3 + \dots + c_{P,0}d^P, & \text{if } m = 0, \\ c_{3,m}d^3 + \dots + c_{P,m}d^P, & \text{if } m \neq 0 \end{cases}$$
(4)

where the coefficients  $c_{i,m}$  are listed in Table I and P is the maximum power used for the approximation. Replacing (4) in (2), the output  $y_n$  can be approximated as

$$y_n \approx c_{1,0}d_n + \sum_{m=-\infty}^{\infty} \left( c_{3,m}d_{n-m}^3 + \dots + c_{P,m}d_{n-m}^P \right)$$
  
=  $\dots + c_{3,-1}d_{n+1}^3 + \dots + c_{P,-1}d_{n+1}^P$   
+  $c_{1,0}d_n + c_{3,0}d_n^3 + \dots + c_{P,0}d_n^P$   
+  $c_{3,1}d_{n-1}^3 + \dots + c_{P,1}d_{n-1}^P + \dots$  (5)

The second approximation consists in truncating the infinite summation in (5) to  $m = \pm M$  values, making the current output sample value  $y_n$  dependent only on N = 2M + 1 duty



Fig. 5. Digital PWM modulator stages.

cycles  $d_n$ . Collecting the coefficients  $c_{i,m}$  corresponding to the same power of d, the output sample  $y_n$  can be written as

$$y_n = \sum_{m=0}^{N-1} \sum_{i=1}^{(P+1)/2} h_{2i-1,m} (d_{n-m})^{2i-1}$$
$$= \sum_{m=0}^{N-1} \left[ h_{1,m} d_{n-m} + h_{3,m} (d_{n-m})^3 + h_{5,m} (d_{n-m})^5 + \dots + h_{P,m} (d_{n-m})^P \right]$$

that can be expressed as

$$y_n = h_{1,n} * d_n + h_{3,n} * d_n^3 + h_{5,n} * d_n^5 + \dots + h_{P,n} * d_n^P \quad (6)$$

where "\*" indicates discrete-time convolution and  $h_{i,n}$  is a *M*-samples shifted version of  $c_{i,n}$ , i.e.,  $h_{i,n} = c_{i,n-M}$ .

Each term of the sum in (6) represents the convolution of a filter with impulse response  $h_{i,n}$  with the *i*th power of  $d_n$ . The impulse responses are symmetric around M, corresponding to Type I FIR filters of length N = 2M + 1 with constant group delay  $\tau = M$ . The impulses responses for powers i = 1 to i = 11 are listed in Table I.

The simplified PWM model in (6) can be represented as the block diagram of Fig. 3(b), which is generalized Hammerstein model where the *i*th branch is composed of a static nonlinearity  $(\cdot)^i$  followed by an FIR filter with impulse response  $h_{i,n}$  [26].

#### B. Computation of the Duty Cycles $d_n$

The duty cycles can be obtained numerically applying Newton's iterative method, for details see [24]. One way of approaching this solution is to use the scalar equation

$$d_n^{(k+1)} = d_n^{(k)} - r\left(d_n^{(k)}\right) \left[y_n^{(k)} - x_{n-(k+1)M}\right]$$
(7)

where  $r(d_n) = [\operatorname{sinc}(d_n/2)]^{-1}$ . Equation (7) can be represented as the block diagram shown in Fig. 4 which expresses the next iteration pulse-width value  $d_n^{(k+1)}$  as the current iteration value  $d_n^{(k)}$  corrected by the weighted difference between the current iteration output sample value  $y_n^{(k)}$  and the input sample  $x_{n-(k+1)M}$  that is delayed to take into account the constant group delay of the FIR filters in (6).

#### C. Algorithm Architecture

The structure of the algorithm is developed using (6) to compute the output sample  $y_n$  and (7) to compute the duty cycles  $d^{(K)}$ , where K is the number of iterations used in the actual implementation.

The algorithm consists of the cascade connection of certain number of blocks like the one represented in Fig. 4. The complete structure for three iterations is shown in the block diagram of Fig. 5. Because of the delay introduced by the FIR filters used in the discrete-time model of the PWM given by (6), the input sample values  $x_n$  are delayed by M samples in each iteration prior to the comparison with  $y_n^{(k)}$ . The first stage of the algorithm uses  $d_n^{(0)} = x_n$ , i.e., the duty cycles for the first iteration of the algorithm are the same values used in the SDEUPWM. The samples of the filtered output signal are computed using the generalized Hammerstein structure of the discrete-time baseband model of PWM depicted in Fig. 3(b).

The process is repeated K times: the duty cycle  $d_n^{(k-1)}$  produced by the previous stage is used as the input of the following stage to compute  $d_n^{(k)}$ . In each stage, the magnitude  $|y_n^{(k)} - x_{n-(k+1)M}|$  is reduced, diminishing the baseband distortion produced by the modulation process.

## IV. SELECTION OF ALGORITHM PARAMETERS

Several parameters of the architecture developed in the previous section have to be selected for an actual DSP implementation. These parameters are: the length N of the FIR filters, the maximum odd power P used for the discrete-time nonlinear model of the PWM modulator, and the number of stages K of the iterative algorithm. Baseband distortion will be reduced for increased values of all these parameters, but the computational complexity will also be incremented. In this section, the performance of the algorithm is analyzed in terms of the total harmonic distortion plus noise (THD+N) as a function of N, P, and K.

A numerical simulation (parametric simulation) was performed for odd values of  $9 \le N \le 99$ ,  $3 \le P \le 13$ , and for  $1 \le K \le 4$ . The duty cycles  $d_n$  that result from the algorithm are used as input to the PWM model of Fig. 3(b). The output samples  $y_n$  together with a delayed version of the modulating signal samples  $x_{n-KM}$  are used to compute the THD+N as the ratio between the RMS value of the error  $y_n - x_{n-KM}$  and the RMS value of  $y_n$ 

$$\text{THD} + \text{N} \left[ \text{dB} \right] = 20 \log \left( \frac{\text{RMS} \{ y_n - x_{n-KM} \}}{\text{RMS} \{ y_n \}} \right)$$



Fig. 6. Parametric simulation. (a) 3-D plot of THD + N [dB]; contour plot for K = 3: (b) band-limited random noise and (c) multitone signal.

which equals the logarithm of the ratio between the energy of the harmonics plus noise and the energy of the signal.

Parametric simulations were carried out for two different modulating signals  $x_n$ : a bandpass type random signal and a multitone signal. The random signal is generated by bandpass filtering Gaussian noise and the multitone signal is generated by adding nine sinusoids starting with frequency  $1 \times 10^{-3} f_c$  and with each successive tone doubling its previous frequency (spaced in octaves).

Fig. 6 shows the result of the parametric simulation as a function of N, P, and K. Fig. 6(a) depicts the surfaces of THD+N in dB as a function of N and P for K = 1, ..., 4 for the random band-limited modulating signal. Although the THD+N reduces with each stage K of the algorithm, it is desirable not to increase this number, since each new stage uses the PWM model of Fig. 3(b), which requires the computation of (P-1)/2 FIR filters of length N.

No noticeable reduction of the distortion is achieved by increasing P above  $P \approx 7$ . The effect of P together with the effect of N on the THD + N [dB] can be observed more clearly on the contour plots of Fig. 6(b) and (c), which correspond to the random noise and multitone modulating signals, respectively, both for K = 3 stages (iterations). These pictures show the contour lines of the THD+N as a function of N and P. For both signals, a selection of N above 50 is adequate to achieve low levels of distortion with a moderated computational load.

The number of multiplications per sample  $\mathcal{N}$  required to compute each duty cycle  $d_n$  as a function of N, P, and K is given by

$$\mathcal{N} = \frac{K}{4}(P-1)(N+1) + K.$$
 (8)

For each of the K stages, (P-1)/2 symmetric FIR filter are computed requiring (N+1)/2 multiplications each. An additional multiplication is needed to weigh the difference  $y_n^{(k)} - x_{n-(k+1)M}$ . Fig. 6(b) and (c) also depicts, with dashed lines, the contour lines of  $\mathcal{N}$  as a function of N and P and for K = 3 stages.

## V. COMPARISON WITH SIMILAR APPROACHES

The discrete-time PWM model represented by the generalized Hammerstein structure of Fig. 3(b) is similar to that presented in patent [22], but the method employed to reduce the distortion is different. Algorithm [22] is capable of a large



Fig. 7. Spectra of the PWM output. Comparison between BBDFPWM, SDEUPWM, and reference [22] under  $f_c/f_m = 10$ .

reduction of PWM distortion with very low implementation cost if the relation between the PWM carrier frequency  $f_c$  and the maximum frequency of the modulating signal is very high  $(f_c/f_m \gg 1)$ . The result presented in [22, Fig. 18] achieves a reduction of  $\approx 50$  dB in the harmonic with higher amplitude when the ratio  $f_c/f_m$  is high. However, its efficiency decreases when the frequency ratio is reduced. Fig. 7 compares the spectra of the PWM produced with a typical SDEUPWM modulator together with those resulting from algorithm [22] and one and three stages of BBDFPWM modulators for a modulating sinusoidal signal of frequency  $f_m = f_c/10$ . In this case, algorithm [22] achieves a reduction of nearly 15 dB in the first harmonic. One stage of BBDFPWM achieves a slightly better reduction (20 dB), and three stages of BBDFPWM result in a dramatic reduction of the first harmonic in excess of 50 dB. The reduction is even larger for higher order harmonics.

Algorithm [22], and other similar approaches [27], [28] (usually known as pseudo-natural PWM because they imitate the behavior of analog or natural PWM, which exhibits less distortion that uniform PWM) are able to reduce PWM distortion when the frequency ratio  $f_c/f_m$  is large, but their performance decreases when the frequency ratio is reduced. On the other hand, BBDFPWM achieves a uniform performance for the entire baseband  $[0, f_c/2)$ , with a higher implementation or computational cost. However, a higher order version of algorithm [22] "rapidly becomes complicated in terms of calculation" [22, p. 27], while the modular structure of BBDFPWM allows for easy tradeoff between performance and computational cost.



Fig. 8. Spectral measurements of (a) IMD with SDEUPWM; (b) multitone with SDEUPWM; (c) band-limited noise with SDEUPWM; (d) IMD with BBDFPWM; (e) multitone with BBDFPWM; (f) band-limited noise with BBDFPWM.

#### VI. DSP IMPLEMENTATION AND MEASUREMENTS

The architecture of the BBDFPWM algorithm described by the block diagrams of Figs. 3(b) and 5 was implemented on a low-cost TMS320F28335 DSP to evaluate its real-time behavior. The nonlinear function  $r(d_n)$  in (7) is computed using a look-up table and the FIR filters are implemented using a library provided by the manufacturer. No other special signal processing tools are required, making the implementation of the algorithm rather straightforward.

The pulse former block in Fig. 1 is implemented with the standard PWM module of the DSP using an up/down counter at a switching frequency of  $f_c = 50$  kHz that coincides with the input signal sampling frequency,  $f_s = f_c$ . The PWM resolution is fixed by the relation between the PWM frequency  $f_c = 50$  kHz and the DSP clock frequency  $f_{clk} = 150$  MHz, which results in  $b = \log_2(f_{clk}/f_c) \approx 11.55$  bits. Although this resolution will limit the performance of the current implementation, it is sufficient to show the improvements produced by the modulation strategy. The PWM resolution is a typical problem of all digital implementations of PWM algorithms; although this issue is out of the scope of this work, several alternatives to increase the resolution without augmenting the clock frequency are available in the literature [29], [30]. Noiseshaping techniques, that displace the quantization noise out of the band of interest, can also be applied [31].

Based on the analysis in Section IV and taking into account the limited resolution of the PWM modulator (which introduces a THD+N of around -80 dB), the parameters of the algorithm are selected as: K = 3 stages, with an approximation of order P = 7, and FIR filters of length N = 59. The operating point marked with a dot in Fig. 6 results in an expected THD+N exceeding -80 dB (0.01%).

## A. Spectral Measurements

Different types of band-limited signals with frequency content below  $f_c/2 = 25$  kHz were used to test the performance of the algorithm. The PWM signal p(t) is measured at an output pin of the DSP using an spectrum analyzer.

First, intermodulation distortion measurements (IMD) are carried out using DIN standard 45403 [32]. The modulating signal is composed of low- and high-frequency sinusoids of  $f_1 = 250$  Hz and  $f_2 = 8$  kHz, respectively, where the latter has an amplitude 12.04 dB lower than the former. Due to the nonlinear nature of SDEUPWM, intermodulation products will appear at frequencies  $\alpha f_1 \pm \beta f_2$  ( $\alpha$  and  $\beta$  integers); it is expected that BBDFPWM removes all this components within the baseband. The baseband spectra measured for SDEUPWM and for BBDFPWM are depicted in Fig. 8(a) and (d), respectively. For SDEUPWM, four sidebands of the 8 kHz tone are observed at  $f_2 \pm f_1$  and  $f_2 \pm 2f_1$ , and a harmonic at  $2f_2 = 16$  kHz and its sidebands at  $2f_2 \pm f_1$  are also detected. The proposed algorithm completely removes these spurious intermodulation products. Only the noise floor 80 dB below the amplitude of the input at  $f_1$  is observed.



Fig. 9. THD + N measurement with the standard SDEUPWM and with BBDFPWM.

Second, a multitone signal (usually used for equipment testing [32]) composed of the sum of nine sinusoids beginning with f = 50 Hz and reaching 12.8 kHz spaced in octaves was also used for testing. The measured spectra are shown in Fig. 8(b) and (e) for SDEUPWM and BBDFPWM, respectively. The improvement is noteworthy since only the modulating signal tones can be observed in the output spectrum of BBDFPWM. For the SDEUPWM, several spurious tones contaminate the baseband.

The last test signal is random noise with Gaussian distribution and bandpass filtered between 200 Hz and 10 kHz. This kind of signal can be used to model an audio signal driving a class-D amplifier. The spectral measurements are shown in Fig. 8(c) (SDEUPWM) and Fig. 8(f) (BBDFPWM) revealing that the BBDFPWM algorithm eliminates the spectral regrowth that appears between 9 kHz and 15.3 kHz when SDEUPWM is used.

These experiments show that the BBDFPWM modulation algorithm is able to eliminate baseband distortion, or at least making it negligible, with a level well under the quantization noise level of the PWM resolution.

#### B. THD + N Measurements

For this test a spectrally pure sinusoidal signal is modulated using SDEUPWM and BBDFPWM. The frequency of the test tone is varied between 250 Hz and 20 kHz. The THD + N is measured with the spectral analyzer as the quotient between the power of the harmonics plus noise and the power of the complete signal (sinusoidal signal plus harmonics and noise).

The THD + N measurements are depicted in Fig. 9 for both modulation algorithms. It can be observed that the THD+N remains almost flat, with a value of approximately 0.07% for the entire frequency band for BBDFPWM. The irregular behavior of the THD + N curve for the SDEUPWM between 9 kHz and 15 kHz, with a maximum of 5.58%, occurs because the harmonics of the modulating signal appear outside the baseband, where the measurement is performed. For frequencies above 15 kHz, the lateral sidebands of the carrier began to appear within the baseband, increasing the THD + N. These behavior does not occur with the BBDFPWM algorithm since not only the modulating signal harmonics are eliminated but also the carrier sidebands are removed from the baseband.

The flat behavior of the THD + N measurement in an actual implementation achieved even for low switching frequencies was previously obtained only using click modulation [17], [19], [33]. Those implementations are computationally demanding requiring either more than one DSP or FPGA, reducing the

usable audio frequency range or restricting their operation to offline computation. The proposed approach uses FIR filtering and does not require other advanced processing tools such as an analytic exponential modulator or zero crossing point estimation which are building blocks of click modulation. Other digital PWM methods such as the one reported in [22], reviewed in Section V, and the ones based on crossing point estimation (pseudo-natural PWM) [28] require a very high switching frequency to avoid that carrier sidebands fall into baseband and hence to guarantee low distortion in the whole audio band.

## VII. CONCLUSION

A real-time digital PWM modulating algorithm with zero (or reduced) distortion in the baseband was developed in this paper. The residual distortion depends mainly on the number of bits of the PWM resolution. An actual DSP implementation was developed and the algorithm was tested with different bandlimited signals showing that it is able to achieve the design objectives with a reduced computational load. Experimental results reveal that the BBDFPWM modulator clearly outperforms the traditional SDEUPWM. These characteristics may be of interest for high-quality, high-efficiency power converters, or class-D amplifiers.

#### REFERENCES

- C.-A. Yeh and Y.-S. Lai, "Digital pulsewidth modulation technique for a synchronous buck DC/DC converter to reduce switching frequency," *IEEE Trans. Ind. Electron.*, vol. 59, no. 1, pp. 550–561, Jan. 2012.
- [2] S.-H. Yu and M.-H. Tseng, "Optimal control of a nine-level class-d audio amplifier using sliding-mode quantization," *IEEE Trans. Ind. Electron.*, vol. 58, no. 7, pp. 3069–3076, Jul. 2011.
- [3] K. Hausmair, S. Chi, P. Singerl, and C. Vogel, "Aliasing-free digital pulsewidth modulation for burst-mode RF transmitters," *IEEE Trans. Circuits Syst. I, Reg. Papers*, vol. 60, no. 2, pp. 415–427, Feb. 2013.
- [4] W. Lu, K. Zhou, D. Wang, and M. Cheng, "A generic digital  $nk \pm m$  order harmonic repetitive control scheme for PWM converters," *IEEE Trans. Ind. Electron.*, vol. 61, no. 3, pp. 1516–1527, Mar. 2014.
- [5] R. Rathore, H. Holtz, and T. Boller, "Generalized optimal pulsewidth modulation of multilevel inverters for low-switching-frequency control of medium-voltage high-power industrial AC drives," *IEEE Trans. Ind. Electron.*, vol. 60, no. 10, pp. 4215–4224, Oct. 2013.
- [6] K. Kobravi, R. Iravani, and H. Kojori, "Three-leg/four-leg matrix converter generalized modulation strategy-part II: Implementation and verification," *IEEE Trans. Ind. Electron.*, vol. 60, no. 3, pp. 860–872, Mar. 2013.
- [7] D. Fernandes, F. Costa, and E. dos Santos, "Digital-scalar PWM approaches applied to four-leg voltage-source inverters," *IEEE Trans. Ind. Electron.*, vol. 60, no. 5, pp. 2022–2030, May 2013.
- [8] J. Yuan, J. Pan, W. Fei, C. Cai, Y. Chen, and B. Chen, "An immunealgorithm-based space-vector PWM control strategy in a three-phase inverter," *IEEE Trans. Ind. Electron.*, vol. 60, no. 5, pp. 2084–2093, May 2013.
- [9] Y. Lai, Y. Chang, and B. Chen, "Novel random-switching PWM technique with constant sampling frequency and constant inductor average current for digitally controlled converter," *IEEE Trans. Ind. Electron.*, vol. 60, no. 8, pp. 3126–3135, Aug. 2013.
- [10] Z. Song and D. V. Sarwate, "The frequency spectrum of pulse width modulated signals," *Signal Process.*, vol. 83, no. 10, pp. 2227–2258, Oct. 2003.
- [11] M. Margaliot and G. Weiss, "The low-frequency distortion in D-class amplifiers," *IEEE Trans. Circuits Syst. II, Exp. Briefs*, vol. 57, no. 10, pp. 772–776, Oct. 2010.
- [12] J. Yu, M. T. Tan, W. L. Goh, and S. Cox, "A dual-feedforward carriermodulated second-order class-D amplifier with improved THD," *IEEE Trans. Circuits Syst. II, Exp. Briefs*, vol. 59, no. 1, pp. 35–39, Jan. 2012.

- [13] S. Cox, J. Yu, W. L. Goh, and M. T. Tan, "Intrinsic distortion of a fully differential BD-modulated class-D amplifier with analog feedback," *IEEE Trans. Circuits Syst. I, Reg. Papers*, vol. 60, no. 1, pp. 63–73, Jan. 2013.
- [14] B. Logan, Jr., "Click modulation," AT&T Bell Lab. Tech. J., vol. 63, no. 3, pp. 401–423, Mar. 1984.
- [15] A. Oliva, E. E. Paolini, and S. S. Ang, "A new audio file format for lowcost, high-fidelity, portable digital audio amplifiers," *Texas Instrum. White Paper*, pp. 1–14, 2005.
- [16] M. Streitenberger, H. Bresch, and L. Mathis, "Theory and implementation of a new type of digital power amplifier for audio applications," in *Proc. IEEE ISCAS*, Geneva, Switzerland, 2000, vol. 1, pp. 511–514.
- [17] M. Streitenberger, F. Felgenhauer, H. Bresch, and W. Mathis, "Class-d audio amplifiers with separated baseband for low-power mobile applications," in *Proc. IEEE Int. Conf. Circuits Syst. Commun.*, 2002, pp. 186–189.
- [18] K. Sozanski, "A digital click modulator for a class-d audio power amplifier," in *Proc. SPA*, Sep. 2009, pp. 121–126.
- [19] K. Sozanski, "Digital realization of a click modulator for an audio power amplifier," *Przeglad Elektrotech.*, vol. 86, no. 2, pp. 353–357, Feb. 2010.
- [20] S. Santi, M. Ballardini, R. Rovatti, and G. Setti, "The effects of digital implementation on ZePoC codec," in *Proc. Eur. Conf. Circuit Theory Des.*, Aug./Sep. 2005, vol. 3, pp. 173–176.
- [21] L. Stefanazzi, A. Oliva, and E. Paolini, "Alias-free digital click modulator," *IEEE Trans. Ind. Informat.*, vol. 9, no. 2, pp. 1074–1083, May 2013.
- [22] L. Risbo and H. K. Andersen, "Conversion of a PCM signal into a UPWM signal," U.S. Patent 6 657 566, Dec. 2, 2003.
- [23] S. O. Aase, "A prefilter equalizer for pulse width modulation," *Signal Process.*, vol. 92, no. 10, pp. 2444–2453, Oct. 2012.
- [24] F. Chierchie and E. Paolini, "Real-time digital PWM with zero baseband distortion and low switching frequency," *IEEE Trans. Circuits Syst. I, Reg. Papers*, vol. 60, no. 10, pp. 2752–2762, Oct. 2013.
- [25] J. Huang, K. Padmanabhan, and O. Collins, "The sampling theorem with constant amplitude variable width pulses," *IEEE Trans. Circuits Syst. I, Reg. Papers*, vol. 58, no. 6, pp. 1178–1190, Jun. 2011.
- [26] A. Balestrino, A. Landi, M. Ould-Zmirli, and L. Sani, "Automatic nonlinear auto-tuning method for Hammerstein modeling of electrical drives," *IEEE Trans. Ind. Electron.*, vol. 48, no. 3, pp. 645–655, Jun. 2001.
- [27] J. Goldberg and M. Sandler, "Pseudo-natural pulse width modulation for high accuracy digital-to-analogue conversion," *Electron. Lett.*, vol. 27, no. 16, pp. 1491–1492, Aug. 1991.
- [28] C. Pascual, Z. Song, P. Krein, D. Sarwate, P. Midya, and W. Roeckner, "High-fidelity PWM inverter for digital audio amplification: Spectral analysis, real-time DSP implementation, and results," *IEEE Trans. Power Electron.*, vol. 18, no. 1, pp. 473–485, Jan. 2003.
- [29] D. Navarro, O. Lucía, L. A. Barragán, J. I. Artigas, I. Urriza, and O. Jiménez, "Synchronous FPGA-based high-resolution implementations of digital pulse-width modulators," *IEEE Trans. Power Electron.*, vol. 27, no. 5, pp. 2515–2525, May 2012.
- [30] D. Costinett, M. Rodriguez, and D. Maksimovic, "Simple digital pulse width modulator under 100 ps resolution using general-purpose FPGAs," *IEEE Trans. Power Electron.*, vol. 28, no. 10, pp. 4466–4472, Oct. 2013.
- [31] R. Kirlin, C. Lascu, and A. Trzynadlowski, "Shaping the noise spectrum in power electronic converters," *IEEE Trans. Ind. Electron.*, vol. 58, no. 7, pp. 2780–2788, Jul. 2011.
- [32] B. Metzler, Audio Measurement Handbook. Beaverton, OR, USA: Audio Precision, 1993.
- [33] L. Stefanazzi, F. Chierchie, E. E. Paolini, and A. R. Oliva, "Low distortion switching amplifier with discrete-time click modulation," *IEEE Trans. Ind. Electron.*, vol. 61, no. 7, pp. 3511–3518, Jul. 2014.



**Fernando Chierchie** (S'10) received the B.S. degree in electronic engineering and the M.S. degree in control systems both from the Universidad Nacional del Sur (UNS), Bahía Blanca, Argentina, in 2009 and 2011, respectively.

He is a Teaching Assistant with Digital Signal Processing at UNS. His research interests are switching amplifiers, signal processing, power electronics, and DSP implementations of digital control and signal processing algorithms.



**Eduardo E. Paolini** received the B.S.E.E. degree from the Universidad Nacional del Sur (UNS), Bahía Blanca, Argentina, in 1987.

He has been an Adjunct Professor at the UNS since 1998 and a member of the Comisión de Investigaciones Científicas (CIC), Buenos Aires, Argentina since 2011. His research interests are digital signal processing and switched and nonlinear systems.



Leandro Stefanazzi received the B.S. degree in electronic engineering, the M.S. degree in control systems, and the Ph.D. degree from the Universidad Nacional del Sur, Bahía Blanca, Argentina, in 2006, 2008, and 2013, respectively.

From June 2009 to November 2010, he was with the Electronics and Information Technology Laboratory of the French Atomic Energy Commission (CEA-LETI) as a Research Engineer in the area of communications for 3GPP/LTE standards. He is currently with the Instituto Nacional de Tecnología

Industrial (INTI), Argentina. His research interests are digital signal processing and power electronics.



Alejandro R. Oliva received the B.S.E.E. degree from the Universidad Nacional del Sur (UNS), Bahía Blanca, Argentina, in 1987, and the M.S. and Ph.D. degrees in electrical engineering from the University of Arkansas, Fayetteville, AR, USA, in 1996 and 2004, respectively.

He has been a Professor in the Electrical Engineering Department of the UNS since 1999. Since 2005, he has been a member of the Consejo Nacional de Investigaciones Científicas y Técnicas (CONICET), Buenos Aires, Argentina. His main research interests

are power electronics and power management.