Implementation of Multirate Modified Wave Digital Filters Using Digital Signal Processors

Keywords: multirate signal processing, wave digital filters, IIR digital filters, digital signal processors

ABSTRACT

This paper describes implementation of multirate modified lattice wave digital filters using digital signal processors. A cascaded interpolators based on bireciprocal modified lattice wave digital filters for interpolating high quality audio signals are presented. The interpolators are implemented in SHARC digital signal processor (Analog Devices). The results of this implementation are presented, the frequency response of the cascaded interpolator realized by ADSP-21061 processor are shown for the interpolation ratio $R=8$. Such an interpolator achieves the signal-to-noise and distortion ratio $S_{INAD}$ near to -90dB and the passband ripple $\delta_p \approx 8 \times 10^{-9}$dB.

1. INTRODUCTION

According to the well known advantages of wave digital filters [4, 5] like: small passband sensitivity to coefficients, small rounding errors, big resistivity to parasitic oscillations (limit cycles), great dynamic range, low level of the rounding noise, etc. such filters are well suited for the high quality audio signal processing.

![Block diagrams of lattice wave digital filters](image1)

Fig. 1. Block diagrams of lattice wave digital filters (a), (b) analysis filter bank, (c) synthesis filter bank

![Block diagram of classical first-order all-pass section](image2)

Fig. 2. Block diagram of classical first-order all-pass section (a), (b) realization diagram of a two port adaptor

Lattice wave digital filters are built with two blocks realizing all-pass functions $S_1$ and $S_2$. Typically blocks $S_1$ and $S_2$ are realized by a cascade of first-order and second-order all-pass
sections. Wave digital filters were proposed in 70’s when multiplication was a quite expensive operation. That is why they were designed with the minimum number of multipliers. A typical classical two port adaptor is depicted in Fig. 2b. It requires a single multiplier and three adders. Reflection signals $b_1$ and $b_2$ of can be calculated by equations

$$\begin{align*}
b_1 &= -\gamma_1 a_1 + (1 + \gamma_1) a_2 \\
b_2 &= (1 - \gamma_1) a_1 + \gamma_1 a_2.
\end{align*}$$

(1)

2. MODIFIED WAVE DIGITAL FILTERS

Today, modern digital signal processors (DSP’s) are designed to be able to calculate one addition and one multiplication in a single operational cycle [1]. In result, the classical two port adaptor structure of Fig. 2b is ineffective in the DSP implementation, especially for the floating point arithmetics. Hence, this structure has to be changed. The idea of the so-called modified wave digital filters with equal numbers of additions and multiplications was proposed by Fettweis [3]. In Figure 3 the idea of this modification consisting in adding complementary multipliers is illustrated.

Fig. 3. Block diagram of the first-order modified all-pass section: (a) the idea of complementary multipliers, (b) realization diagram of the two port adaptor

Reflection signals $b_1'$ and $b_2'$ of the modified two port adaptor (Fig. 4a) can be calculated by equations

$$\begin{align*}
b_1' &= \gamma_1 a_1' + \gamma_2 a_2' \\
b_2' &= \gamma_2 a_1' + \gamma_1 a_2' ,
\end{align*}$$

(2)

Fig. 4. Realization diagram of first-order modified all-pass section: (a), (b) case 1, (c) case 2, (d) case 3

in which coefficients $\gamma$ are given by equations
\[ \begin{align*}
\gamma_{11} &= -\frac{k_{u1}}{k_{s1}}, \\
\gamma_{12} &= \frac{1 + \gamma_1}{k_{s1}}, \\
\gamma_{21} &= \frac{1 - \gamma_1}{k_{s1}}, \\
\gamma_{22} &= \gamma_1,
\end{align*} \]

(3)

Three cases for realizations of modified two port adaptors are possible (Fig. 4) described by equations listed in Table 1 and depicted in Figs 4b, 4c, 4d. Every realization needs four operations: two multiplications and two additions.

As an example, the realization an N-order branch of the lattice filter with modified first-order sections is depicted in Fig. 5. The resultant value of the branch coefficient can be calculated as

\[ \gamma_s = \prod_{i=1}^{n} \frac{k_{s}}{k_{u}}. \]

(4)

Table 1 Equations for the first-order modified two port adaptor

<table>
<thead>
<tr>
<th>Case 1 for: ( \gamma_{21}=1, \gamma_{2}=1 )</th>
<th>Case 2 for: ( \gamma_{1}=1, \gamma_{2}=1 )</th>
<th>Case 3 for: ( \gamma_{11}=1, \gamma_{21}=1 )</th>
</tr>
</thead>
<tbody>
<tr>
<td>( k_{u} = \frac{1}{1 - \gamma} ) ( k_{s} = 1 + \gamma )</td>
<td>( k_{u} = -\frac{1 + \gamma}{\gamma} ) ( k_{s} = 1 + \gamma )</td>
<td>( k_{u} = \frac{1}{1 - \gamma} ) ( k_{s} = -\frac{1}{\gamma} )</td>
</tr>
<tr>
<td>( \gamma_{11} = -\frac{1}{1 - \gamma} ) ( \gamma_{12} = 1 ) ( \gamma_{21} = 1 ) ( \gamma_{22} = \gamma_1 )</td>
<td>( \gamma_{11} = 1 ) ( \gamma_{12} = 1 ) ( \gamma_{21} = -\frac{1}{\gamma} ) ( \gamma_{22} = \gamma_1 )</td>
<td>( \gamma_{11} = 1 ) ( \gamma_{12} = -\frac{1}{\gamma} ) ( \gamma_{21} = 1 ) ( \gamma_{22} = \gamma_1 )</td>
</tr>
</tbody>
</table>

Fig. 5. Diagram of the N-order branch of the lattice wave digital filter realized by first-order sections

Authors' implementation of modified first-order section using ADSP-21061 digital signal processor is presented in Figure 6. To compute a single response sample, four operational cycles are necessary (with additional assumption that the program is in a cache memory[1]).

Fig. 6. Implementation of modified first-order section by ADSP-21061: (a) realization diagram of first-order section, (b) assembler realization program
3. INTERPOLATOR

A class of lattice wave digital filters referred to as bireciprocal, is suitable for the realization of interpolators. Characteristic function \( K(\psi) \) of bireciprocal filters satisfies equation

\[
K(\psi) = \frac{1}{\psi K(1/\psi)}.
\]  

(5)

For this kind of filters every even filter coefficient is equal to zero and the filter circuit is simplified. By replacing the output adder (Fig. 1c) by a switch it is possible to double the output signal sampling speed. A cascaded version of this interpolator with bireciprocal lattice modified wave digital filters is shown in Fig. 7. The filter branches are realized like in Fig. 5.

Parameters chosen by authors for the interpolator used in a class-D power audio amplifier [2] are: passband ripple \( \delta_p < 0.1 \text{dB} \), oversampling ratio \( R=8 \), passband 4...20kHz, signal-to-noise and distortion ratio \( S_{\text{INAD}} < 90 \text{dB} \). Authors applied bireciprocal lattice wave elliptic digital filters for this realization. Filter coefficients are designed with authors' program prepared in Matlab environment, based on methods presented in [4, 5].

Table 2. Design parameters for interpolator stages

<table>
<thead>
<tr>
<th>Stage</th>
<th>Order</th>
<th>( F_p )</th>
<th>( F_z )</th>
<th>( \delta_p ) [dB]</th>
<th>( \delta_z ) [dB]</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>15</td>
<td>0.2267</td>
<td>0.2733</td>
<td>3.2 \times 10^{-9}</td>
<td>90</td>
</tr>
<tr>
<td>2</td>
<td>7</td>
<td>0.1134</td>
<td>0.3866</td>
<td>1.1 \times 10^{-9}</td>
<td>90</td>
</tr>
<tr>
<td>3</td>
<td>5</td>
<td>0.0567</td>
<td>0.4433</td>
<td>6 \times 10^{-10}</td>
<td>90</td>
</tr>
<tr>
<td>Total</td>
<td></td>
<td>0.0567</td>
<td>0.0683</td>
<td>7.5 \times 10^{-9}</td>
<td>90</td>
</tr>
</tbody>
</table>

Fig. 8. Block diagram of the cascaded version of the interpolator with a single switch and resultant multipliers
The interpolator was realized with ADSP-21061 signal processor from Analog Devices using modified wave digital filters. The structure of the interpolator is depicted in Fig. 8. Resultant value of the coefficient $\gamma_{sw1}$ is described by the following equation

$$
\gamma_{sw1} = \gamma_{s12}\gamma_{s22}\gamma_{s32}
$$

where: $\gamma_{s12}$, $\gamma_{s22}$, $\gamma_{s32}$ are resultant coefficients of upper branches for the stages 1, 2, 3, respectively. Other resultant coefficients $\gamma_{sw2}$...$\gamma_{sw8}$ can be similarly calculated. Frequency response of the cascaded interpolator realized with ADSP-21061 for $R=8$ is shown in Fig. 8. The interpolator achieves the signal-to-noise and distortion ratio $S_{INAD}$ near to -90dB and the passband ripple $\delta_p \approx 8 \cdot 10^{-9}$dB. To compute the response for one input sample it needs 50 multiplications and 42 additions.

![Figure 8](image)

Fig. 8. Frequency response of cascaded interpolator realized by ADSP-21061 for $R=8$: (a), (c), (d) magnitude response, (b) phase response

4. CONCLUSIONS

Modified wave digital filters are very efficient for implementation by modern floating point signal processors. Especially for applications where big dynamic range of the signal is important.

REFERENCES