

# 1D Filter Module - Lattice Radiant Software

# **User Guide**



#### **Disclaimers**

Lattice makes no warranty, representation, or guarantee regarding the accuracy of information contained in this document or the suitability of its products for any particular purpose. All information herein is provided AS IS, with all faults and associated risk the responsibility entirely of the Buyer. Buyer shall not rely on any data and performance specifications or parameters provided herein. Products sold by Lattice have been subject to limited testing and it is the Buyer's responsibility to independently determine the suitability of any products and to test and verify the same. No Lattice products should be used in conjunction with mission- or safety-critical or any other application in which the failure of Lattice's product could create a situation where personal injury, death, severe property or environmental damage may occur. The information provided in this document is proprietary to Lattice Semiconductor, and Lattice reserves the right to make any changes to the information in this document or to any products at any time without notice.



### **Contents**

| Acronyms in This Document                   | 5  |
|---------------------------------------------|----|
| 1. Introduction                             |    |
| 1.1. Features                               | 6  |
| 1.2. Conventions                            |    |
| 1.2.1. Nomenclature                         | 6  |
| 1.2.2. Signal Names                         |    |
| 1.2.3. Attribute Names                      |    |
| 2. Functional Description                   | 7  |
| 2.1. 1D Asymmetry Serial Mode               |    |
| 2.2. 1D Asymmetry Parallel Mode             | 7  |
| 2.3. 1D Symmetry Mode                       | 7  |
| 2.4. Signal Descriptions                    |    |
| 2.5. Attribute Summary                      | 9  |
| 3. IP Generation, Synthesis, and Validation | 10 |
| 3.1. Licensing the IP                       |    |
| 3.2. Generating and Synthesizing the IP     | 10 |
| 3.3. Running the Functional Simulation      | 12 |
| Appendix A. Resource Utilization            | 14 |
| References                                  |    |
| Technical Support Assistance                | 16 |
| Revision History                            | 17 |



## **Figures**

| Figure 2.1. 1D Filter Block Diagram                                   | 8  |
|-----------------------------------------------------------------------|----|
| Figure 2.1. 1D Filter Block DiagramFigure 3.1. Module/IP Block Wizard | 10 |
| Figure 3.2. Configure User Interface of 1D Filter Module              | 11 |
| Figure 3.3. Check Generating Result                                   | 11 |
| Figure 3.4. Simulation Wizard                                         | 12 |
| Figure 3.5. Adding and Reordering Source                              | 13 |
| Figure 3.6. Simulation Waveform                                       | 13 |
| Tables                                                                |    |
| Table 2.1. 1D Filter Module Signal Description                        | 8  |
| Table 2.2. Attributes Table                                           | 9  |
| Table 2.3. Attributes Descriptions                                    | 9  |
| Table 3.1. Generated File List                                        | 12 |
| Table A.1. Resource Utilization (LIFCL)                               | 14 |
| Table A.2. Resource Utilization (LFCPNX)                              | 14 |



# **Acronyms in This Document**

A list of acronyms used in this document.

| Acronym | Definition                    |
|---------|-------------------------------|
| FPGA    | Field Programmable Gate Array |
| IP      | Intellectual Property         |
| LSB     | Least Significant Bit         |
| MSB     | Most Significant Bit          |
| RTL     | Register Transfer Level       |



### 1. Introduction

The 1D Filter Module has three modes: 1D Symmetry, 1D Asymmetry Serial, and 1D Asymmetry Parallel, which support configurable number of taps each with its own coefficient.

### 1.1. Features

The key features of 1D Filter Module include:

- Supports the following modes:
  - 1D Symmetry
  - 1D Asymmetry Serial
  - 1D Asymmetry Parallel
- Configurable number of taps
- Supports both Positive and Negative Symmetry for 1D Symmetry Mode only
- Configurable Reset Mode
- Configurable data width and sign representation for Data A and B
- Configurable Bus Ordering

### 1.2. Conventions

#### 1.2.1. Nomenclature

The nomenclature used in this document is based on Verilog HDL.

### 1.2.2. Signal Names

Signal names that end with:

- \_n are active low
- \_*i* are input signals
- \_o are output signals

### 1.2.3. Attribute Names

Attribute names in this document are formatted in title case and italicized (Attribute Name).



## **Functional Description**

The 1D Filter Module filters the input data according to the following general equation:

$$result = \sum_{n=0}^{NUM\_OF\_TAPS-1} (A_n * B_n)$$

The following sections provides information on the 1D Filter Module modes:

- 1D Asymmetry Serial
- 1D Asymmetry Parallel
- 1D Symmetry

### 2.1. 1D Asymmetry Serial Mode

data\_a\_i width = DATAA Width,

data b i width = Number of Taps \* DATAB Width

A is a data input that is provided serially, B is an input for coefficients which is provided in a parallel way.

For this mode, the output data is calculated as follows:

$$result = \sum_{n=0}^{NUM\_OF\_TAPS-1} (A_n * B[(n+1) * DATAB - 1: n * DATAB])$$

### 2.2. 1D Asymmetry Parallel Mode

data\_a\_i width = Number of Taps \* DATAA Width,

data b i width = Number of Taps \* DATAB Width,

A is a data input, B is an input for coefficients; both are provided in a parallel way.

For this mode, the output data is calculated as follows:

$$result = \sum_{n=0}^{NUM\_OF\_TAPS-1} (A[(n+1)*DATAA - 1:n*DATAA]*B[(n+1)*DATAB - 1:n*DATAB])$$

### 2.3. 1D Symmetry Mode

data\_a\_i width = DATAA Width,

data\_b\_i width:

- a. when the *Number of Taps* is odd, data\_b\_i width =  $\frac{\text{Number of Taps} + 1}{2} * DATAB Width$ , b. when the *Number of Taps* is even, data\_b\_i width =  $\frac{\text{Number of Taps}}{2} * DATAB Width$ .

For this mode, the output data is calculated as follows:

$$result = \sum_{n=0}^{K-1} (A_n + A_{(k-n)}) * B[(n+1) * DATAB - 1: n * DATAB]),$$

- a.  $K = \frac{\text{Number of Taps} + 1}{2}$ , when *Number of Taps* is odd, and
- b.  $K = \frac{\text{Number of Taps}}{2}$ , when *Number of Taps* is even.





Figure 2.1. 1D Filter Block Diagram

### 2.4. Signal Descriptions

Table 2.1. 1D Filter Module Signal Description

| Table 2.1. 15 Titler Woulde Signal Description |                      |                             |                        |
|------------------------------------------------|----------------------|-----------------------------|------------------------|
| Port Name                                      | 1/0                  | Width                       | Description            |
| Clock and Reset Por                            | ts                   |                             |                        |
| clk_i                                          | In                   | 1                           | System clock input.    |
| reset_i                                        | In                   | 1                           | Reset input.           |
| User Interface Ports                           | User Interface Ports |                             |                        |
| clk_en_i                                       | In                   | 1                           | Clock enable input.    |
| data_a_i                                       | In                   | DATAA<br>Width¹             | Input data for port A. |
| data_b_i                                       | In                   | DATAB<br>Width <sup>1</sup> | Input data for port B. |
| result_o                                       | Out                  | OUT_WIDTH <sup>2</sup>      | Output data result.    |

#### Note:

The bit width of some signals is set by the attribute. Refer to Table 2.2 for the description of these attributes.

- 1. If DATAA Width ≤ 9 and DATAB Width ≤ 9, then OUT\_WIDTH = DATAA Width + DATAB Width +6;
- 2. If at least one of DATAA Width or DATAB Width > 9, then OUT\_WIDTH = DATAA Width + DATAB Width + 18.



### 2.5. Attribute Summary

The configurable attributes of the 1D Filter Module are shown in Table 2.2 and are described in Table 2.3. The attributes can be configured through the IP Catalog's Module/IP wizard of the Lattice Radiant™ software.

**Table 2.2. Attributes Table** 

| Attribute          | Selectable Values         | Default     | Dependency on Other Attributes           |
|--------------------|---------------------------|-------------|------------------------------------------|
| Configuration      | •                         |             |                                          |
|                    | 1D Symmetry,              | 1D          |                                          |
| Mode               | 1D Asymmetry Serial,      | Asymmetry   | _                                        |
|                    | 1D Asymmetry Parallel     | Serial      |                                          |
|                    |                           |             | For <i>Mode</i> == 1D Symmetry:          |
| Number of Taps     | 2-N                       | 2           | If Device Type LIFCL-17, N = 48 else N = |
|                    |                           |             | 55.                                      |
| Symmetry           | Positive, Negative        | Positive    | Active if <i>Mode</i> == 1D Symmetry     |
| Reset Mode         | Sync, Async               | Sync        | _                                        |
| DATAA Sign         | Signed, Unsigned          | Signed      | Active if Symmetry == Positive           |
| DATAA Width        | 2–18                      | 18          | _                                        |
| DATAB Sign         | Signed, Unsigned          | Signed      | Active if Symmetry == Positive           |
| DATAB Width        | 2–18                      | 18          | _                                        |
| Rus Ordoring Stylo | Big Endian [MSB : LSB],   | Big Endian  |                                          |
| Bus Ordering Style | Little Endian [LSB : MSB] | [MSB : LSB] |                                          |

#### **Table 2.3. Attributes Descriptions**

| Attribute          | Description                                                                                                                                                                                                                             |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Configuration      |                                                                                                                                                                                                                                         |
| Mode               | Specifies the mode of 1D Filter Module. Refer to Functional Description section for more details.                                                                                                                                       |
| Number of Taps     | Specifies the number of taps.                                                                                                                                                                                                           |
| Symmetry           | Specifies the Symmetry of the 1D Filter Module. Selectable values are Positive and Negative Symmetry.                                                                                                                                   |
| Reset Mode         | Specifies the mode of reset that is used.                                                                                                                                                                                               |
| DATAA Sign         | Specifies the sign representation for port data_a_i.                                                                                                                                                                                    |
| DATAA Width        | Specifies the data width for port A. The exact value of this attribute can be calculated depending on the type of <i>Mode</i> . Refer to Functional Description section for more details.                                               |
| DATAB Sign         | Specifies the sign representation for port data_b_i.                                                                                                                                                                                    |
| DATAB Width        | Specifies the data width for port B. The exact value of this attribute can be calculated depending on the type of <i>Mode</i> . Refer to Functional Description section for more details.                                               |
| Bus Ordering Style | Specifies the bus ordering of input and output data ports.  Big Endian: the data_a_i, data_b_i and result_o busses ordering is from MSB to LSB.  Little Endian: the data_a_i, data_b_i and result_o busses ordering is from LSB to MSB; |



## 3. IP Generation, Synthesis, and Validation

This section provides information on how to generate and synthesize this module using the Lattice Radiant software. For more on Lattice Radiant software, refer to the Lattice Radiant software user guide and relevant tutorials.

### 3.1. Licensing the IP

No license is required for this module.

### 3.2. Generating and Synthesizing the IP

The Lattice Radiant software allows you to customize and generate modules and IPs and integrate them into the device's architecture. The procedure for generating the 1D Filter Module in Lattice Radiant software is described below.

To generate the 1D Filter Module:

- 1. Create a new Lattice Radiant software project or open an existing project.
- 2. In the IP Catalog tab, double-click on 1D\_Filter under Module, DSP\_Arithmetic\_Modules category.
- 3. The Module/IP Block Wizard opens as shown in Figure 3.1. Enter values in the Component name and the Create in fields and click Next.



Figure 3.1. Module/IP Block Wizard



4. In the module's dialog box of the **Module/IP Block Wizard** window, customize the selected 1D Filter Module using drop-down menus and check boxes. As a sample configuration, see Figure 3.2. For configuration options, see the Attribute Summary section.



Figure 3.2. Configure User Interface of 1D Filter Module

5. Click **Generate**. The **Check Generating Result** dialog box opens, showing design block messages and results as shown in Figure 3.3.



Figure 3.3. Check Generating Result

© 2022 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notic



6. Click **Finish**. All the generated files are placed under the directory paths in the **Create in** and the **Component name** fields shown in Figure 3.1.

The generated 1D Filter Module package includes the black box (<Instance Name>\_bb.v) and instance templates (<Instance Name>\_tmpl.v/vhd) that can be used to instantiate the module in a top-level design. An example RTL top-level reference source file (<Instance Name>.v) that can be used as an instantiation template for the module is also provided. You may also use this top-level reference as the starting template for the top-level for their complete design. The generated files are listed in Table 3.1.

Table 3.1. Generated File List

| Attribute                                                                                   | Description                                                                     |
|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| <instance name="">.ipx</instance>                                                           | This file contains the information on the files associated to the generated IP. |
| <instance name="">.cfg</instance>                                                           | This file contains the attribute values used in IP configuration.               |
| component.xml                                                                               | Contains the ipxact:component information of the IP.                            |
| design.xml                                                                                  | Documents the configuration attributes of the IP in IP-XACT 2014 format.        |
| rtl/ <instance name="">.v</instance>                                                        | This file provides an example RTL top file that instantiates the module.        |
| rtl/ <instance name="">_bb.v</instance>                                                     | This file provides the synthesis black box.                                     |
| misc/ <instance name="">_tmpl.v<br/>misc /<instance name="">_tmpl.vhd</instance></instance> | These files provide instance templates for the module.                          |

### 3.3. Running the Functional Simulation

Running functional simulation can be performed after the IP is generated.

To run functional simulation:

1. Click the button located on the **Toolbar** to initiate the **Simulation Wizard** shown in Figure 3.4.



Figure 3.4. Simulation Wizard



2. Click **Next** to open the **Add and Reorder Source** window as shown in Figure 3.5.



Figure 3.5. Adding and Reordering Source

- 3. Click Next. The Summary window is shown.
- 4. Click **Finish** to run the simulation.

**Note:** It is necessary to follow the procedure above until it is fully automated in the Lattice Radiant software suite. The results of the simulation in our example are provided in Figure 3.6.



Figure 3.6. Simulation Waveform



## **Appendix A. Resource Utilization**

Table A.1 and Table A.2 show the resource utilization of the 1D Filter Module for the LIFCL-40-9BG400I, and LFCPNX-100-9LFG672I device, using Lattice Synthesis Engine of Lattice Radiant software. Default configuration is used and some attributes are changed from the default value to show the effect on the resource utilization.

Table A.1. Resource Utilization (LIFCL)

| Configuration                                                | Clk Fmax (MHz)* | Registers | LUTs | DSP |
|--------------------------------------------------------------|-----------------|-----------|------|-----|
| Default                                                      | 200 MHz         | 0         | 1    | 2   |
| DATAA Width = 2, DATAB Width = 2,<br>Others = Default        | 200 MHz         | 0         | 1    | 2   |
| Mode = 1D Symmetry, Symmetry = Negative,<br>Others = Default | 200 MHz         | 0         | 1    | 2   |
| Number of taps = 5, Others = Default                         | 200 MHz         | 0         | 1    | 6   |

<sup>\*</sup>Note: Fmax is generated when the FPGA design only contains 1D Filter Module and the target frequency is 200 MHz. These values may be reduced when user logic is added to the FPGA design.

Table A.2. Resource Utilization (LFCPNX)

| Configuration                                                | Clk Fmax (MHz)* | Registers | LUTs | DSP |
|--------------------------------------------------------------|-----------------|-----------|------|-----|
| Default                                                      | 250 MHz         | 0         | 1    | 2   |
| DATAA Width = 2, DATAB Width = 2,<br>Others = Default        | 250 MHz         | 0         | 1    | 2   |
| Mode = 1D Symmetry, Symmetry = Negative,<br>Others = Default | 250 MHz         | 0         | 1    | 2   |
| Number of taps = 5, Others = Default                         | 250 MHz         | 0         | 1    | 6   |

<sup>\*</sup>Note: Fmax is generated when the FPGA design only contains 1D Filter Module and the target frequency is 250 MHz. These values may be reduced when user logic is added to the FPGA design.



## **References**

For complete information on Lattice Radiant Project-Based Environment, Design Flow, Implementation Flow and Tasks, as well as on the Simulation Flow, see the Lattice Radiant software user guide.



FPGA-IPUG-02099-1.5

# **Technical Support Assistance**

Submit a technical support case through www.latticesemi.com/techsupport.

16



## **Revision History**

### Document Revision 1.5, Lattice Radiant SW version 3.2, May 2022

| Section                | Change Summary                                     |
|------------------------|----------------------------------------------------|
| Functional Description | Updated dependency of Number of Taps in Table 2.2. |

#### Document Revision 1.4, Lattice Radiant SW version 3.1, November 2021

| Section                          | Change Summary                                                                            |  |
|----------------------------------|-------------------------------------------------------------------------------------------|--|
| Appendix A. Resource Utilization | Added Table A.1. Resource Utilization (LIFCL) and updated Table A.2. Resource Utilization |  |
|                                  | (LFCPNX).                                                                                 |  |

### Document Revision 1.3, Lattice Radiant SW version 3.0, June 2021

| Section                | Change Summary                                            |
|------------------------|-----------------------------------------------------------|
| Introduction           | Removed Quick Facts section.                              |
| Functional Description | Updated equations in this section.                        |
| References             | Updated reference to Lattice Radiant software user guide. |

### Document Revision 1.2, Lattice Radiant SW version 2.3, December 2020

| Section                | Change Summary                                                    |
|------------------------|-------------------------------------------------------------------|
| Functional Description | Updated dependency of <i>Number of Taps</i> in Attribute Summary. |
| References             | Updated this section.                                             |

### Document Revision 1.1, Lattice Radiant SW version 2.1, June 2020

| Section                          | Change Summary                                                                          |
|----------------------------------|-----------------------------------------------------------------------------------------|
| Introduction                     | Updated Table 1.1.                                                                      |
|                                  | Added support to Certus-NX                                                              |
|                                  | Added LFD2NX-40 as targeted device.                                                     |
|                                  | Updated Lattice Implementation to Lattice Radiant 2.1.                                  |
| Functional Description           | Updated dependency of <i>Number of Taps</i> to support LFD2NX-40 in Attributes Summary. |
| Appendix A. Resource Utilization | Updated device to LIFCL-40-9BG400I.                                                     |

### Document Revision 1.0, Lattice Radiant SW version 2.0, February 2020

| Section | Change Summary   |
|---------|------------------|
| All     | Initial release. |

© 2022 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice



www.latticesemi.com