

**Comb Filter** 

July 17, 1998



Xilinx Inc. 2100 Logic Drive San Jose, CA 95124

Phone: +1 408-559-7778
Fax: +1 408-559-7114
E-mail: coregen@xilinx.com
URL: www.xilinx.com

#### **Features**

- Drop-in modules for the XC4000E, EX, XL, XV and Spartan families
- · Multiplier-free filter yields efficient implementation
- · All zeros, no poles
- · Input data widths from 2 to 32 bits
- Variable length feed-forward path selection (configurable delay) from 1 to 17 samples
- · Registered outputs
- · Sections can be cascaded
- · 2's complement input data
- Uses fast carry logic for high speed
- High performance and density guaranteed through Relational Placed Macro (RPM) mapping and placement technology
- Can be combined with an Integrator core to build integrating and decimating filters as described by Hogenauer
- Available in Xilinx CORF Generator

## **Functional Description**

The Comb filter provides a standard differentiator with variable length feed-forward delays from 1 to 17 incoming sample periods. The subtractor takes the feed-forward delayed input data and subtracts it from the data input to give a registered output that is one bit wider than the input.

Multiple Comb Filter stages can be cascaded by connecting the output of the first stage to the input of the second stage and parameterizing the proper bit widths to allow for bit growth through the multiple adder stages. The data output from the last stage can be truncated (the least significant bits not connected) to carry the desired amount of precision to the next signal processing block.

Latency for this block is equal to the number of feed-forward delays plus one for the output register.

**Product Specification** 

The Comb filter transfer function,  $H_c(z) = 1-z^{-M}$ , has M roots which map as zeros (nulls) on the unit circle of the complex Z plane. The corresponding frequency response exhibits nulls at  $f_k = (f_s/M)k$ , where:

 $f_s$  = sample frequency M = feed-forward path delay samples k = 0, 1, 2, 3, ..., M

The amplitude-frequency response resembles the teeth of a comb, and the cascading of Comb filters produces sharper teeth. Because a one-bit word growth may occur in each filter stage, the succeeding stages must grow in word length, or a scaling and truncation regimen is required to maintain constant word size in all stages.

This all-zero Comb filter, in tandem with single pole recursive filters, can, through pole-zero cancellation, produce selective frequency responses such as low pass, band pass, etc. This is a viable filter design technique and is known as frequency sampling [1]. An outstanding example of this technique is to cascade several Comb filter stages in series with an equal number of single pole integrators (poles are at f=0). The result is a multiplier-free, high order decimating (or interpolating) filter [2].

- L. R. Rabiner and B. Gold, "Theory and Application of Digital Signal Processing." Prentice-Hall, 1975, pp. 48-50.
- E. B. Hogenauer, "An Economical Class of Digital Filters for Decimation and Interpolation." IEEE Trans. On Acoustics, Speech, and Signal Processing, Vol. ASSP-29, April 1981, pp. 155-162.

#### **Pinout**

Port names for the schematic symbol are shown in Figure 1 and described in Table 1.



Figure 1: Block Symbol and Schematic Diagram

**Table 1: Core Signal Pinout** 

| Signal       | Signal Direction | Description                                                                                                                                                                 |  |
|--------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| DIN [n:0]    | Input            | DATA IN – filter data input.                                                                                                                                                |  |
| CE           | Input            | CLOCK ENABLE – active high signal used to allow the transfer of data from the internal RAM to the registered output and the incrementing the Internal Address Counter.      |  |
| С            | Input            | CLOCK – with the exception of asynchronous control inputs (where applicable), control and data inputs are captured, and new output data formed on rising clock transitions. |  |
| DOUT [n+1:0] | Output           | DATA OUT - Comb filter output.                                                                                                                                              |  |

#### **CORE Generator Parameters**

The CORE Generator parameterization window for this macro is shown in Figure 2. The parameters are as follows:

- Component Name: Enter a name for the component.
- Input Width: Select an input filter width from the pulldown menu. The valid range is 2-32.
- Pipeline Stages: Select the number of delay stages from the pull-down menu. The valid range is 1-17.



Figure 2: Parameterization Window

### **Core Resource Utilization**

The following equations show the number of CLBs used in the XC4000 family based on the input data width.

Number of CLBs where N = Input Data Width:

Even N:

CLBs = N + 1 If delay = 1 or 2 CLBs = N + 2 If delay = 3, 4, or 5 CLBs = N + 4 If delay = 6 or more

Odd N:

CLBs = N + 2 If delay = 1 or 2 CLBs = N + 4 If delay = 3, 4, or 5 CLBs = N + 6 If delay = 6 or more

# **Ordering Information**

This macro comes free with the Xilinx CORE Generator. For additional information contact your local Xilinx sales representative, or e-mail requests to coregen@xilinx.com.

#### **Parameter File Information**

| Parameter Name  | Type    | Notes  |
|-----------------|---------|--------|
| Component_Name  | String  |        |
| Input_Width     | Integer | 2 - 32 |
| Pipeline_Stages | Integer | 1 -17  |