



# **FIR Filter IP**

IP Version: v2.3.1

## **User Guide**

FPGA-IPUG-02095-1.6

December 2025

## 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 all associated risk is the responsibility entirely of the Buyer. The information provided herein is for informational purposes only and may contain technical inaccuracies or omissions, and may be otherwise rendered inaccurate for many reasons, and Lattice assumes no obligation to update or otherwise correct or revise this information. 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. LATTICE PRODUCTS AND SERVICES ARE NOT DESIGNED, MANUFACTURED, OR TESTED FOR USE IN LIFE OR SAFETY CRITICAL SYSTEMS, HAZARDOUS ENVIRONMENTS, OR ANY OTHER ENVIRONMENTS REQUIRING FAIL-SAFE PERFORMANCE, INCLUDING ANY APPLICATION IN WHICH THE FAILURE OF THE PRODUCT OR SERVICE COULD LEAD TO DEATH, PERSONAL INJURY, SEVERE PROPERTY DAMAGE OR ENVIRONMENTAL HARM (COLLECTIVELY, "HIGH-RISK USES"). FURTHER, BUYER MUST TAKE PRUDENT STEPS TO PROTECT AGAINST PRODUCT AND SERVICE FAILURES, INCLUDING PROVIDING APPROPRIATE REDUNDANCIES, FAIL-SAFE FEATURES, AND/OR SHUT-DOWN MECHANISMS. LATTICE EXPRESSLY DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY OF FITNESS OF THE PRODUCTS OR SERVICES FOR HIGH-RISK USES. 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.

## Inclusive Language

This document was created consistent with Lattice Semiconductor's inclusive language policy. In some cases, the language in underlying tools and other items may not yet have been updated. Please refer to Lattice's inclusive language [FAQ 6878](#) for a cross reference of terms. Note in some cases such as register names and state names it has been necessary to continue to utilize older terminology for compatibility.

# Contents

|                                           |    |
|-------------------------------------------|----|
| Contents .....                            | 3  |
| Abbreviations in This Document.....       | 5  |
| 1. Introduction .....                     | 6  |
| 1.1. Quick Facts .....                    | 6  |
| 1.2. Features .....                       | 6  |
| 1.3. Conventions .....                    | 7  |
| 1.3.1. Nomenclature .....                 | 7  |
| 1.3.2. Signal Names.....                  | 7  |
| 1.3.3. Attribute Names .....              | 7  |
| 2. Functional Descriptions .....          | 8  |
| 2.1. Overview .....                       | 8  |
| 2.2. FIR Filter IP Core Architecture..... | 9  |
| 2.2.1. Direct-form .....                  | 9  |
| 2.2.2. Symmetric.....                     | 9  |
| 2.2.3. Multi-Channel FIR Filter .....     | 10 |
| 2.3. Signal Description.....              | 10 |
| 2.4. Attribute Summary.....               | 11 |
| 2.5. Coefficients Specification .....     | 14 |
| 2.6. Timing Specifications.....           | 15 |
| 3. IP Generation and Evaluation .....     | 17 |
| 3.1. Licensing the IP.....                | 17 |
| 3.2. Generation and Synthesis .....       | 17 |
| 3.3. Running Functional Simulation .....  | 19 |
| 3.3.1. Functional Simulation Results..... | 20 |
| 3.4. Hardware Evaluation.....             | 21 |
| Appendix A. Resource Utilization .....    | 22 |
| References .....                          | 25 |
| Technical Support Assistance .....        | 26 |
| Revision History .....                    | 27 |

## Figures

|                                                                        |    |
|------------------------------------------------------------------------|----|
| Figure 2.1. FIR Filter IP Core Block Diagram .....                     | 8  |
| Figure 2.2. FIR Filter IP Core Functional Diagram .....                | 8  |
| Figure 2.3. Direct-form FIR Filter Implementation .....                | 9  |
| Figure 2.4. Symmetric Coefficients FIR Filter Implementation .....     | 9  |
| Figure 2.5. Multi-Channel FIR Filter Implementation .....              | 10 |
| Figure 2.6. Single-Channel FIR Filter with Continuous Input .....      | 15 |
| Figure 2.7. Multi-Channel FIR Filter with Continuous Input .....       | 15 |
| Figure 2.8. Coefficients Reloading .....                               | 16 |
| Figure 3.1. Module/IP Block Wizard .....                               | 17 |
| Figure 3.2. Configure User Interface of FIR Filter IP Core .....       | 18 |
| Figure 3.3. Check Generated Result .....                               | 18 |
| Figure 3.4. Simulation Wizard .....                                    | 19 |
| Figure 3.5. Adding and Reordering Source .....                         | 20 |
| Figure 3.6. Simulation Waveform .....                                  | 20 |
| Figure 3.7. Simulation Testbench Diagram .....                         | 21 |
| Figure 3.8. Sample Simulation Results (Symmetric, 64-tap Filter) ..... | 21 |

## Tables

|                                                                  |    |
|------------------------------------------------------------------|----|
| Table 1.1. FIR Filter Quick Facts .....                          | 6  |
| Table 2.1. FIR Filter IP Core Signal Description .....           | 10 |
| Table 2.2. Attributes Table .....                                | 11 |
| Table 2.3. Attribute Description .....                           | 12 |
| Table 3.1. Generated File List .....                             | 19 |
| Table A.1. LIFCL-33-8USG84C Device Resource Utilization .....    | 22 |
| Table A.2. LFMX05-25-7BBG400C Device Resource Utilization .....  | 22 |
| Table A.3. LAV-AT-G70-1LFG676C Device Resource Utilization ..... | 23 |
| Table A.4. LAV-AT-E70-3LFG676C Device Resource Utilization ..... | 23 |

## Abbreviations in This Document

A list of abbreviations used in this document.

| Abbreviations | Definition                    |
|---------------|-------------------------------|
| DSP           | Digital Signal Processing     |
| EBR           | Embedded Block RAM            |
| FIR           | Finite Impulse Response       |
| FPGA          | Field Programmable Gate Array |
| IP            | Intellectual Property         |
| LSE           | Lattice Synthesis Engine      |
| LUT           | Look Up Table                 |

# 1. Introduction

The Lattice Finite Impulse Response (FIR) Filter IP Core is implemented using high performance Digital Signal Processing (DSP) blocks available in Lattice devices. The input data, coefficient, and output data widths are configurable over a wide range. The IP core uses full internal precision while allowing variable output precision with several choices for saturation and rounding. The coefficients of the filter can be specified at generation time and/or reloadable during run-time through input ports.

## 1.1. Quick Facts

Table 1.1 presents a summary of the FIR filter.

**Table 1.1. FIR Filter Quick Facts**

|                             |                          |                                                                                                                     |
|-----------------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------|
| <b>IP Requirements</b>      | Supported Devices        | CrossLink™-NX, Certus™-NX, Certus-NX-RT, CertusPro™-NX, CertusPro-NX-RT, MachXO5™-NX, Lattice Avant™, and Certus-N2 |
|                             | IP Changes <sup>1</sup>  | For a list of changes to the IP, refer to the <a href="#">FIR Filter IP Release Notes (FPGA-RN-02025)</a> .         |
| <b>Resource Utilization</b> | Supported User Interface | Native interface, see the <a href="#">Signal Description</a> section.                                               |
|                             | Resources                | See <a href="#">Appendix A. Resource Utilization</a>                                                                |
| <b>Design Tool Support</b>  | Lattice Implementation   | IP Core Version 2.3.1 – Lattice Radiant Software 2025.2                                                             |
|                             | Synthesis                | Lattice Synthesis Engine (LSE)                                                                                      |
|                             |                          | Synopsys Synplify Pro® for Lattice                                                                                  |
|                             | Simulation               | For a list of supported simulators, see the <a href="#">Lattice Radiant Software User Guide</a> .                   |

**Notes:**

1. In some instances, the IP may be updated without changes to the user guide. This user guide may reflect an earlier IP version but remains fully compatible with the later IP version. Refer to the IP Release Notes for the latest updates.

## 1.2. Features

The key features of the FIR Filter include:

- Variable number of taps up to 1024
- Input data and coefficient widths of 4 to 16 bits
- Multi-channel support for up to 64 channels
- Signed or unsigned input data and coefficients
- Coefficients symmetry and negative symmetry optimization
- Re-loadable coefficients support
- Full precision arithmetic
- Selectable output width and precision
- Selectable overflow: wrap-around or saturation
- Selectable rounding: rounding up, round away from zero, round towards zero and convergent rounding
- Width and precision specified using fixed point notations

## 1.3. Conventions

### 1.3.1. Nomenclature

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

### 1.3.2. Signal Names

Signal names that end with:

- `_n` are active low, asserted when value is logic 0.
- `_i` are input signals.
- `_o` are output signals.
- `_io` are bi-directional input/output signals.

### 1.3.3. Attribute Names

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

## 2. Functional Descriptions

### 2.1. Overview

A top-level block diagram of the FIR Filter IP core is shown in [Figure 2.1](#).



**Figure 2.1. FIR Filter IP Core Block Diagram**

The functional diagram is shown in [Figure 2.2](#). The data and coefficients are stored in different memories shown as the tap memory and coefficients memory. The symmetry adder, multiplier array and adder tree are implemented using DSP blocks. The symmetry adder is used if the coefficients are symmetric. The adder tree performs the sum of the products. Depending on the configuration, the adder tree, or a part of it, is implemented inside the DSP blocks. The output processing block performs the output width reduction and precision control. This also contains logic to support different types of rounding and overflow. The control logic block manages the scheduling of data and arithmetic operations based on the type of filter.



**Figure 2.2. FIR Filter IP Core Functional Diagram**

## 2.2. FIR Filter IP Core Architecture

FIR Filter operation on data samples can be described as a sum-of-products operation. For an N-tap FIR filter, the current input sample and (N-1) previous input samples are multiplied by N filter coefficients and the resulting N products are added to give one output sample as shown below:

$$y_n = \sum_{i=0}^{N-1} x_{n-i} h_i = x_n h_0 + x_{n-1} h_1 + \dots + x_{n-N+1} h_{N-1}$$

wherein:

- $h_n$ , where  $n = 0, 1, \dots, N-1$ , is the impulse response;
- $x_n$ , where  $n = 0, 1, \dots, \infty$  is the input;
- $y_n$ , where  $n = 0, 1, \dots, \infty$  is the output;
- $N-1$ , number of delay elements, represents the order of the filter;
- $N$ , the number of current and previous input data samples used for one output sample represents the number of filter taps () .

### 2.2.1. Direct-form

In the direct-form implementation shown in Figure 2.3, the input samples are shifted into a shift register queue and each shift register is connected to a multiplier. The products from the multipliers are added to get the output sample of the FIR filter.



Figure 2.3. Direct-form FIR Filter Implementation

### 2.2.2. Symmetric

The impulse response for most FIR filters is symmetric. This symmetry can generally be exploited to reduce the arithmetic requirements and produce area-efficient filter realizations. It is possible to use only one half of the multipliers for symmetric coefficients compared to that used for a similar filter with non-symmetric coefficients. An implementation for symmetric coefficients is shown in Figure 2.4.



Figure 2.4. Symmetric Coefficients FIR Filter Implementation

### 2.2.3. Multi-Channel FIR Filter

To implement a multi-channel FIR Filter, the same DSP resources are used in a time-multiplexed way. This uses independent tap and coefficient memories to feed each DSP block. It is also possible to use the same coefficient set for all channels, which in turn required less memory usage.



Figure 2.5. Multi-Channel FIR Filter Implementation

## 2.3. Signal Description

Table 2.1 lists FIR Filter IP Core top-level input and output signals and their descriptions.

Table 2.1. FIR Filter IP Core Signal Description

| Port Name                                              | Direction | Bits                     | Description                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------------------------------------------|-----------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Clocks and Reset</b>                                |           |                          |                                                                                                                                                                                                                                                                                                                                                                                       |
| clk_i                                                  | Input     | 1                        | System clock for data and control inputs and outputs.                                                                                                                                                                                                                                                                                                                                 |
| rstn_i                                                 | Input     | 1                        | System wide asynchronous active-low reset signal.                                                                                                                                                                                                                                                                                                                                     |
| <b>General</b>                                         |           |                          |                                                                                                                                                                                                                                                                                                                                                                                       |
| din_i                                                  | Input     | <i>Input Data Width</i>  | Input data                                                                                                                                                                                                                                                                                                                                                                            |
| ininvalid_i                                            | Input     | 1                        | Input valid signal. The input data din_i is read-in only when ininvalid_i is high.                                                                                                                                                                                                                                                                                                    |
| dout_o                                                 | Output    | <i>Output Width</i>      | Output data                                                                                                                                                                                                                                                                                                                                                                           |
| outvalid_o                                             | Output    | 1                        | Output data qualifier. Output data dout_o is valid only when this signal is high.                                                                                                                                                                                                                                                                                                     |
| rfi_o                                                  | Output    | 1                        | Ready for input. This output, when high, indicates that the IP core is ready to receive the next input data. A valid data may be applied at din only if rfi_o is high during the previous clock cycle.                                                                                                                                                                                |
| <b>When <i>Reloadable coefficients</i> is selected</b> |           |                          |                                                                                                                                                                                                                                                                                                                                                                                       |
| coeffin_i                                              | Input     | <i>Coefficient Width</i> | Coefficients input. The coefficients have to be loaded through this port in a specific order. All the coefficients need to be loaded in one batch, while keeping the signal coeffwe_i high during the entire duration of loading. After all the coefficients are loaded, the input signal coeffset_i must be pulsed high for one clock cycle for the new coefficients to take effect. |
| coeffwe_i                                              | Input     | 1                        | When asserted, the value on bus coeffin_i is written into coefficient memories.                                                                                                                                                                                                                                                                                                       |

| Port Name                                        | Direction | Bits | Description                                                                                                                                                                                                         |
|--------------------------------------------------|-----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| coeffset_i                                       | Input     | 1    | This input is used to signal the filter to use the recently loaded coefficient set. This signal must be pulsed high for one clock cycle after the loading the entire coefficient set using coeffin_i and coeffwe_i. |
| <b>When Number of Channels is greater than 1</b> |           |      |                                                                                                                                                                                                                     |
| ibstart_i                                        | Input     | 1    | Input block start. For multi-channel configurations, this input identifies channel 0 of the input.                                                                                                                  |
| obstart_o                                        | Output    | 1    | Output block start. For multi-channel configurations, this output identifies channel 0.                                                                                                                             |
| <b>Optional</b>                                  |           |      |                                                                                                                                                                                                                     |
| ce_i                                             | Input     | 1    | Clock Enable. While this signal is de-asserted, the core ignores all other synchronous inputs and maintain its current state                                                                                        |
| sr_i                                             | Input     | 1    | Synchronous Reset. When asserted for at least one clock cycle, all the registers in the IP core are initialized to reset state.                                                                                     |

## 2.4. Attribute Summary

Table 2.2 provides the list of user selectable and compile time configurable parameters for the FIR Filter IP Core. The parameter settings are specified using the FIR Filter user interface in Lattice Radiant software.

**Table 2.2. Attributes Table**

| Attribute                          | Selectable Values                                                                                                                                                                                                                                                                                                                     | Default   | Dependency on Other Attributes                                             |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------------------------------------------------------------------|
| Number of Channels                 | For the Avant devices: 1–64<br>For the Nexus devices: Only single channel is supported                                                                                                                                                                                                                                                | 1         | —                                                                          |
| Number of Taps                     | For the Avant devices: <ul style="list-style-type: none"><li>1–2048 if <i>Symmetric Coefficients</i> is enabled; otherwise, it is 1–1024</li><li>1–512 if <i>Number of Channels</i> &gt; 1</li></ul> For the Nexus devices:<br>1–64 if <i>Symmetric Coefficients</i> is enabled; otherwise, it is 1–32 (depending on the device used) | 16        | <i>Symmetric Coefficients == True;</i><br><i>Number of Channels &gt; 1</i> |
| Reloadable Coefficients            | Checked, Unchecked                                                                                                                                                                                                                                                                                                                    | Unchecked | —                                                                          |
| Symmetric Coefficients             | Checked, Unchecked                                                                                                                                                                                                                                                                                                                    | Unchecked | —                                                                          |
| Negative Symmetry                  | Checked, Unchecked                                                                                                                                                                                                                                                                                                                    | Unchecked | <i>Symmetric Coefficients == Checked</i>                                   |
| Coefficients Set                   | Common, Separate                                                                                                                                                                                                                                                                                                                      | Common    | Number of Channels > 1                                                     |
| Coefficients Radix                 | Binary, Hex, Decimal, Floating Point                                                                                                                                                                                                                                                                                                  | Decimal   | <i>Reloadable Coefficients == Unchecked</i>                                |
| Coefficients File                  | Browser Window                                                                                                                                                                                                                                                                                                                        | None      | <i>Reloadable Coefficients == Unchecked</i>                                |
| Input Data Type                    | Signed, Unsigned                                                                                                                                                                                                                                                                                                                      | Signed    | —                                                                          |
| Input Data Width                   | 4–16                                                                                                                                                                                                                                                                                                                                  | 16        | —                                                                          |
| Input Data Binary Point Position   | –2 to <i>Input Data Width</i> + 2                                                                                                                                                                                                                                                                                                     | 0         | —                                                                          |
| Coefficients Type                  | Signed, Unsigned                                                                                                                                                                                                                                                                                                                      | Signed    | —                                                                          |
| Coefficients Width                 | 4–16                                                                                                                                                                                                                                                                                                                                  | 16        | —                                                                          |
| Coefficients Binary Point Position | –2 to <i>Coefficients Width</i> + 2                                                                                                                                                                                                                                                                                                   | 0         | —                                                                          |

| Attribute                                   | Selectable Values                                                                                                                                                                                          | Default    | Dependency on Other Attributes                     |
|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------------------------------------------|
| Output Width                                | 4 to <i>Input Data Width + Coefficients Width + ceil (log<sub>2</sub> (Number of Taps))</i>                                                                                                                | 36         | —                                                  |
| Output Binary Point Position                | <i>4 + Input Data Binary Point Position + Coefficients Binary Point Position – Output Width Full Precision to Output Width + Input Data Binary Point Position + Coefficients Binary Point Position – 4</i> | 0          | —                                                  |
| Output Width Full Precision                 | Calculated                                                                                                                                                                                                 | 36         | Display information only                           |
| Output Binary Point Position Full Precision | Calculated                                                                                                                                                                                                 | 0          | Display information only                           |
| Overflow                                    | Saturation, Wrap Around                                                                                                                                                                                    | Saturation | <i>Output Width != Output Width Full Precision</i> |
| Rounding                                    | None, Rounding Up, Rounding away from zero, Rounding towards zero, Convergent rounding                                                                                                                     | None       | <i>Output Width != Output Width Full Precision</i> |
| Data Memory Type                            | EBR, Distributed, Auto                                                                                                                                                                                     | EBR        | —                                                  |
| Coefficients Memory Type                    | EBR, Distributed, Auto                                                                                                                                                                                     | EBR        | —                                                  |
| Output Buffer Type                          | EBR, Distributed, Auto                                                                                                                                                                                     | EBR        | —                                                  |
| Synchronous Reset (sr_i)                    | Checked, Unchecked                                                                                                                                                                                         | Unchecked  | —                                                  |
| Clock Enable (ce_i)                         | Checked, Unchecked                                                                                                                                                                                         | Unchecked  | —                                                  |

**Table 2.3. Attribute Description**

| Attribute                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>General Tab</b>                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>Filter Specifications</b>       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Number of Channels                 | Specifies the number of channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Number of Taps                     | Specifies the number of taps.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Coefficients Specifications</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Reloadable Coefficients            | Indicates whether the coefficients are fixed or reloadable. If checked, the coefficients can be reloaded during core operation using the input port coeffin_i. With this option, the desired coefficients must be loaded before the operation of the filter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Symmetric Coefficients             | Indicates that the coefficients are used in symmetric form. If this is checked, the number of taps expected is twice the number of coefficients on the coefficient file.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Negative Symmetry                  | If this is checked, the coefficients are considered to be negative symmetric. The second half of coefficients are made equal to the negative of the coefficients on the coefficient file.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Coefficients Set                   | <ul style="list-style-type: none"> <li>If <i>Separate</i> is selected, each channel has a unique set of coefficients. As an example for Direct-form filter, the required number of coefficients is calculated as Number of Taps × Number of Channels.</li> <li>If <i>Common</i> is selected, all channels use the same set of coefficients given, requiring only one set of coefficients for any number of channels.</li> </ul>                                                                                                                                                                                                                                                                                                                                 |
| Coefficients Radix                 | <p>This option allows you to specify the radix for the coefficients in the coefficients file with the following considerations:</p> <ul style="list-style-type: none"> <li>For decimal radix, the negative values have a preceding unary minus sign.</li> <li>For hexadecimal (Hex) and binary radices, the negative values must be written in 2's complement form using exactly as many digits as specified by the <i>Coefficients Width</i> parameter.</li> <li>The floating-point coefficients are specified in the form &lt;nn...n&gt;.&lt;dd...d&gt;, where the digits 'n' denote the integer part and the digits 'd' the decimal part. The values of the floating-point coefficients must be consistent with the <i>Coefficients width</i> and</li> </ul> |

| Attribute                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             | <i>Coefficients Binary Point Position</i> parameters. For example, if <nn...n>.<dd...d> is 8.4 and <i>Coefficients Type</i> is unsigned, the value of the coefficients should be between 0 and 11111111.1111 (255.9375).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Coefficients File                           | Indicates the name and location of the coefficients file. This text file has one coefficient per line. If <i>Coefficients File</i> is not specified, the filter is initialized with a default coefficient set consisting of 16 coefficients.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <b>I/O Specifications Tab</b>               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>Data</b>                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Input Data Type                             | Shows whether input data type to be used is signed or unsigned. The input data is interpreted as a 2's complement number if the type is signed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Input Data Width                            | Specifies the input data width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Input Data Binary Point Position            | This number specifies the bit position of the binary point from the LSB of the input data. If the number is zero, the point is right after LSB; if the number is positive, the point is to the left of LSB; and if the number is negative, the point is to the right of LSB.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <b>Coefficients</b>                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Coefficients Type                           | This option allows you to specify the coefficients type as signed or unsigned. The coefficient data is interpreted as a 2's complement number if the type is signed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Coefficients Width                          | Specifies the coefficients width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Coefficients Binary Point Position          | This number specifies the bit position of the binary point from the LSB of the coefficients. If the number is zero, the point is right after LSB; if the number is positive, the point is to the left of LSB and if the number is negative, the point is to the right of LSB.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>Output</b>                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Output Width                                | Specifies the output data width. The output of the core is usually a part of the full precision output equal to the <i>Output Width</i> and extracted based on the different <i>Output Binary Point Position</i> parameters.<br>The format for the internal full precision output is displayed as static text next to <i>Output Width Full Precision</i> .                                                                                                                                                                                                                                                                                                                                                                              |
| Output Binary Point Position                | Specifies the bit position of the binary point from the LSB of the actual core output. If the number is zero, the point is right after LSB; if the number is positive, the point is to the left of LSB; and if the number is negative, the point is to the right of LSB. This number, together with the parameter <i>Output Width</i> , determines how the actual core output is extracted from the true full precision output. The precision control parameters <i>Overflow</i> and <i>Rounding</i> are applied respectively when MSBs and LSBs are discarded from the true full precision output.                                                                                                                                     |
| Output Width Full Precision                 | Shows the full precision of the output width when the resulting value is not rounded.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Output Binary Point Position Full Precision | Shows the binary point position of the output when the resulting value is not rounded.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Precision Control</b>                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Overflow                                    | This can be used whenever there is a need to drop some of the MSBs from the true output. The following options are supported: <ul style="list-style-type: none"> <li>• Saturation: The output value is clipped to the maximum if positive or minimum if negative, while discarding the MSBs.</li> <li>• Wrap-around: The MSBs are simply discarded without making any correction.</li> </ul>                                                                                                                                                                                                                                                                                                                                            |
| Rounding                                    | This option allows you to specify the rounding method when there is a need to drop one or more LSBs from the true output. The following five options are supported for rounding: <ul style="list-style-type: none"> <li>• None: Discards all bits to the right of the output least significant bit and leaves the output uncorrected.</li> <li>• Rounding up – Rounds up to nearest positive number.</li> <li>• Rounding away from zero – Rounds away from zero if the fractional part is exactly one-half.</li> <li>• Rounding towards zero – Rounds towards zero if the fractional part is exactly one-half.</li> <li>• Convergent rounding – Rounds to the nearest even value if the fractional part is exactly one-half.</li> </ul> |

| Attribute                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Implementation Tab</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Memory Type</b>        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Data Memory Type          | <p>Specifies the type of memory that is used for storing the input data. The following options are supported:</p> <ul style="list-style-type: none"> <li>• EBR: EBR memories are used for storing the data.</li> <li>• Distributed: Look up table based distributed memories are used for storing data.</li> <li>• Auto: EBR memories are used for memory sizes deeper than 128 locations and distributed memories are used for all other memories.</li> </ul>   |
| Coefficients Memory Type  | <p>Specifies the type of memory that is used for storing the coefficients. The following options are supported:</p> <ul style="list-style-type: none"> <li>• EBR: EBR memories are used for storing the data.</li> <li>• Distributed: Look up table based distributed memories are used for storing data.</li> <li>• Auto: EBR memories are used for memory sizes deeper than 128 locations and distributed memories are used for all other memories.</li> </ul> |
| Output Buffer Type        | Indicates the memory type for the output buffer.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>Optional Ports</b>     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Synchronous Reset (sr_i)  | When enabled, this signal resets all the registers in the FIR filter IP core.                                                                                                                                                                                                                                                                                                                                                                                    |
| Clock Enable (ce_i)       | When enabled, this can be used for power saving when the core is not being used. Use of clock enable port increases the resource utilization and may affect the performance due to the increased routing congestion.                                                                                                                                                                                                                                             |

## 2.5. Coefficients Specification

By default, the Reloadable Coefficients is disabled and the coefficients of the filter are specified using a coefficients file. The coefficients file is a text file with one coefficient data per line.

The coefficient values in the file can be in *Binary*, *Decimal*, or *Hexadecimal* radix. *Floating Point* is also supported for decimal values with fractional part, or values less than 1. This can be selected through the *Coefficients Radix* attribute.

For Signed values, Binary and Hexadecimal should be in 2's complement to represent negative values. While for Decimal and Floating Point, the negative unary operator (–) can be used.

The following is an example of a Coefficient File for a 16-tap Direct-form FIR Filter:

- In Binary:
 

```
1111110100000010
1111100111110010
0000011101100011
0000100100011111
1111001000110010
1110101100000001
0010010101011110
0111001010110001
0111001010110001
0010010101011110
1110101100000001
1111001000110010
0000100100011111
0000011101100011
1111100111110010
1111110100000010
```
- As Floating Point:
 

```
-0.011688232421875
```

```

-0.023651123046875
0.0288543701171875
0.0356292724609375
-0.053924560546875
-0.0820159912109375
0.145965576171875
0.4480133056640625
0.4480133056640625
0.145965576171875
-0.0820159912109375
-0.053924560546875
0.0356292724609375
0.0288543701171875
-0.023651123046875
-0.011688232421875
  
```

The required number of lines is also dependent on the number of taps, filter architecture, and the number of channels:

- For a Single Channel – Direct-form Filter, the number of coefficients required is the number of taps specified.
- For a Single Channel – Symmetric Filter, the number of coefficients required is half of the number of taps specified (Even Symmetric). If the number of taps is an odd number (Odd Symmetric), the number of coefficients required is half of the number of taps + 1.
- For a multi-channel filter (Number of Channels > 1) and Coefficients Set = *Separate*, the number of coefficients required is the number of coefficients for a Single Channel × the number of channels. As an example for Direct-form Filter, it is calculated as Number of Taps × Number of Channels.
- For a multi-channel filter (Number of Channels > 1) and Coefficients Set = *Common*, the number of coefficients required is the same as for a Single Channel.

When Reloadable Coefficients is enabled, additional ports are used to dynamically write the coefficients into memory. The number of coefficient data loaded is based on the number of required coefficients. Refer to [Figure 2.8](#) for the timing specifications when using dynamic coefficients reloading.

## 2.6. Timing Specifications

The timing specifications for the FIR Filter IP are as follows:



**Figure 2.6. Single-Channel FIR Filter with Continuous Input**



**Figure 2.7. Multi-Channel FIR Filter with Continuous Input**



**Figure 2.8. Coefficients Reloading**

### 3. IP Generation and Evaluation

This section provides information on how to generate and synthesize FIR Filter IP Core using Lattice Radiant Software, as well as on how to run simulation, synthesis and hardware evaluation. For more details on the Lattice Radiant Software, refer to the [Lattice Radiant Software](#) User Guide.

**Note:** The screenshots provided are for reference only. Details may vary depending on the version of the IP or software being used. If there have been no significant changes to the GUI, a screenshot may reflect an earlier version of the IP.

#### 3.1. Licensing the IP

The FIR Filter IP is provided at no additional cost with the Lattice Radiant software.

#### 3.2. Generation and Synthesis

The Lattice Radiant Software allows you to customize and generate modules and IPs and integrate them into the device architecture. The procedure for generating FIR Filter IP Core in Lattice Radiant Software is described below.

To generate the FIR Filter IP Core:

1. Create a new Lattice Radiant Software project or open an existing project.
2. In the **IP Catalog** tab, double-click on **FIR Filter** under **IP-> DSP** category. The **Module/IP Block Wizard** opens, as shown in [Figure 3.1](#). Enter values in the **Instance name** and the **Create in** fields and click **Next**.



**Figure 3.1. Module/IP Block Wizard**

3. In the **Module/IP Block Wizard** GUI, customize the selected FIR Filter IP Core using drop-down menus and check boxes. As a sample configuration, see [Figure 3.2](#). For configuration options, see the
4. [Attribute Summary](#) section.



Figure 3.2. Configure User Interface of FIR Filter IP Core

- 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 Generated Result

- Click the **Finish** button. All the generated files are placed under the directory paths in the **Create in** and the **Instance name** fields shown in [Figure 3.1](#).

The generated FIR Filter IP Core package includes the closed-box (`<Instance Name>_bb.v`) and instance templates (`<Instance Name>_tmpl.v/vhd`) that can be used to instantiate the core 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 IP core 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                                                                     |
|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| <code>&lt;Instance Name&gt;.ipx</code>                                                              | This file contains the information on the files associated to the generated IP. |
| <code>&lt;Instance Name&gt;.cfg</code>                                                              | This file contains the parameter values used in IP configuration.               |
| <code>component.xml</code>                                                                          | Contains the ipxact:component information of the IP.                            |
| <code>design.xml</code>                                                                             | Documents the configuration parameters of the IP in IP-XACT 2014 format.        |
| <code>rtl/&lt;Instance Name&gt;.v</code>                                                            | This file provides an example RTL top file that instantiates the IP core.       |
| <code>rtl/&lt;Instance Name&gt;_bb.v</code>                                                         | This file provides the synthesis closed-box.                                    |
| <code>misc/&lt;Instance Name&gt;_tmpl.v</code><br><code>misc /&lt;Instance Name&gt;_tmpl.vhd</code> | These files provide instance templates for the IP core.                         |

### 3.3. Running Functional Simulation

After the IP is generated, running functional simulation can be performed using different available simulators. The default simulator already has pre-compiled libraries ready for simulation. Choosing a non-default simulator, however, may require additional steps.

To run functional simulation using the default simulator:



- Click the **Simulation Wizard** button located on the **Toolbar** to initiate the **Simulation Wizard**, as 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. 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 result of the simulation in our example is provided in [Figure 3.6](#).



**Figure 3.6. Simulation Waveform**

### 3.3.1. Functional Simulation Results

The included testbench simulates a basic FIR Filter operation by generating a sample noisy signal from IP generation, then using the same filter coefficients to calculate the expected outputs given the FIR Filter configuration. The sample noisy signal is created by mixing a high frequency signal with varying amplitude to a lower frequency sinusoidal signal.



**Figure 3.7. Simulation Testbench Diagram**

Upon IP Generation, memory files containing the stream of input data, and the expected output data are generated. If Reloadable Coefficients are enabled, it also generates the applicable Coefficients Memory file. The expected simulation results output a 'SIMULATION PASSED' message in the logs, and the input noisy signal and expected output can be observed in simulation if Analog formatting is set.



**Figure 3.8. Sample Simulation Results (Symmetric, 64-tap Filter)**

### 3.4. Hardware Evaluation

The FIR Filter IP Core supports Lattice's IP hardware evaluation capability. This makes it possible to create versions of the IP core that operates in hardware for approximately four hours without requiring the purchase of an IP license. It may also be used to evaluate the core in hardware in user-defined designs. The hardware evaluation capability may be enabled/disabled in the Strategy dialog box. It is enabled by default. To change this setting, go to Project > Active Strategy > LSE/Synplify Pro Settings.

## Appendix A. Resource Utilization

**Table A.1** shows the resource utilization of the FIR Filter IP Core for the LIFCL-33-8USG84C device using Synplify Pro of the Lattice Radiant Software 2024.2. Default configuration is used, and some attributes are changed from the default value to show the effect on the resource utilization.

The default configurations are: Number of Taps=16, Reloadable Coefficients = False, Symmetric Coefficients = False, Input/Coefficients Type = Signed, Input/Coefficients Width = 16, Output Width = 36

**Table A.1. LIFCL-33-8USG84C Device Resource Utilization**

| Configuration                                                                                                                                                                                     | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs | EBRs | DSPs <sup>2</sup> |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------|------|------|-------------------|
| Default                                                                                                                                                                                           | 200.000                     | 100       | 103  | 0    | 16                |
| Reloadable Coefficients: true,<br>Reorder Coefficients Inside: true,<br>Others = Default                                                                                                          | 200.000                     | 686       | 135  | 0    | 16                |
| Number of Taps: 32<br>Symmetric Coefficients: true<br>Others: Default                                                                                                                             | 200.000                     | 100       | 103  | 0    | 16                |
| Number of Taps: 28<br>Input Data Type: Unsigned<br>Overflow: Saturation<br>Rounding: Rounding up<br>Others: Default                                                                               | 200.000                     | 100       | 103  | 0    | 28                |
| Number of Taps: 32<br>Symmetric Coefficients: true<br>Coefficient Radix: Floating Point<br>Coefficient File: provided<br>Coefficients Binary Point Position: 4<br>Output Binary Point Position: 4 | 200.000                     | 100       | 103  | 0    | 16                |

**Notes:**

1. Fmax is generated when the FPGA design only contains FIR Filter IP Core, and the target frequency is 200 MHz. These values may be reduced when user logic is added to the FPGA design.
2. Values are based on the number of 18X18 Multipliers.

**Table A.2** shows the resource utilization of the FIR Filter IP Core for the LFMX05-25-7BBG400C device using Synplify Pro of the Lattice Radiant Software 2024.2. Default configuration is used, and some attributes are changed from the default value to show the effect on the resource utilization.

The default configurations are: Number of Taps=16, Reloadable Coefficients = False, Symmetric Coefficients = False, Input/Coefficients Type = Signed, Input/Coefficients Width = 16, Output Width = 36

**Table A.2. LFMX05-25-7BBG400C Device Resource Utilization**

| Configuration                                                                                                       | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs | EBRs | DSPs <sup>2</sup> |
|---------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------|------|------|-------------------|
| Default                                                                                                             | 200.000                     | 100       | 103  | 0    | 16                |
| Reloadable Coefficients: true,<br>Reorder Coefficients Inside: true,<br>Others = Default                            | 200.000                     | 686       | 135  | 0    | 16                |
| Number of Taps: 32<br>Symmetric Coefficients: true<br>Others: Default                                               | 200.000                     | 100       | 103  | 0    | 16                |
| Number of Taps: 28<br>Input Data Type: Unsigned<br>Overflow: Saturation<br>Rounding: Rounding up<br>Others: Default | 200.000                     | 100       | 103  | 0    | 28                |
| Number of Taps: 32                                                                                                  | 200.000                     | 100       | 103  | 0    | 16                |

| Configuration                                                                                                                                                               | Clk Fmax (MHz) <sup>1</sup> | Registers | LUTs | EBRs | DSPs <sup>2</sup> |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------|------|------|-------------------|
| Symmetric Coefficients: true<br>Coefficient Radix: Floating Point<br>Coefficient File: provided<br>Coefficients Binary Point Position: 4<br>Output Binary Point Position: 4 |                             |           |      |      |                   |

**Notes:**

1. Fmax is generated when the FPGA design only contains FIR Filter IP Core, and the target frequency is 200 MHz. These values may be reduced when user logic is added to the FPGA design.
2. Values are based on the number of 18X18 Multipliers.

**Table A.3.** shows the resource utilization of the FIR Filter IP Core for the LAV-AT-G70-1LFG676C device using Synplify Pro of the Lattice Radiant Software 2024.2. Default configuration is used, and some attributes are changed from the default value to show the effect on the resource utilization.

The default configurations are: Number of Taps=16, Reloadable Coefficients = False, Symmetric Coefficients = False, Input/Coefficients Type = Signed, Input/Coefficients Width = 16, Output Width = 36

**Table A.3. LAV-AT-G70-1LFG676C Device Resource Utilization**

| Configuration                                                                                                                                                   | Clk Fmax (MHz) | Registers | LUTs | EBRs | DSPs |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------|------|------|------|
| Default<br>(Coefficients file provided)                                                                                                                         | 250.000        | 63        | 13   | 0    | 16   |
| Reloadable Coefficients: true<br>Others = Default                                                                                                               | 250.000        | 608       | 112  | 1    | 16   |
| Number of Taps: 255<br>Symmetric Coefficients: true<br>Reloadable Coefficients: true<br>Others: Default                                                         | 151.217        | 4225      | 630  | 1    | 128  |
| Number of Taps: 512<br>Coefficient Radix: Floating Point<br>Coefficients Binary Point Position: 16<br>Output Binary Point Position: 16<br>Output Data Width: 40 | 91.988         | 477       | 95   | 3    | 512  |
| Number of Taps: 64<br>Number of Channels: 4                                                                                                                     | 183.925        | 57        | 75   | 64   | 64   |
| Number of Taps: 300<br>Number of Channels: 8<br>Reloadable Coefficients: true<br>Output Data Width: 38                                                          | 154.440        | 9960      | 163  | 301  | 300  |

**Table A.4.** shows the resource utilization of the FIR Filter IP Core for the LAV-AT-E70-3LFG676C device using Synplify Pro of the Lattice Radiant Software 2024.2. Default configuration is used, and some attributes are changed from the default value to show the effect on the resource utilization.

The default configurations are: Number of Taps=16, Reloadable Coefficients = False, Symmetric Coefficients = False, Input/Coefficients Type = Signed, Input/Coefficients Width = 16, Output Width = 36

**Table A.4. LAV-AT-E70-3LFG676C Device Resource Utilization**

| Configuration                                       | Clk Fmax (MHz) | Registers | LUTs | EBRs | DSPs |
|-----------------------------------------------------|----------------|-----------|------|------|------|
| Default<br>(Coefficients file provided)             | 250.000        | 63        | 13   | 0    | 16   |
| Reloadable Coefficients: true<br>Others = Default   | 250.000        | 608       | 112  | 1    | 16   |
| Number of Taps: 255<br>Symmetric Coefficients: true | 188.182        | 4225      | 630  | 1    | 128  |

| Configuration                                                                                                                                                   | Clk Fmax (MHz) | Registers | LUTs | EBRs | DSPs |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------|------|------|------|
| Reloadable Coefficients: true<br>Others: Default                                                                                                                |                |           |      |      |      |
| Number of Taps: 512<br>Coefficient Radix: Floating Point<br>Coefficients Binary Point Position: 16<br>Output Binary Point Position: 16<br>Output Data Width: 40 | 121.286        | 477       | 95   | 3    | 512  |
| Number of Taps: 64<br>Number of Channels: 4                                                                                                                     | 234.522        | 57        | 75   | 64   | 64   |
| Number of Taps: 300<br>Number of Channels: 8<br>Reloadable Coefficients: true<br>Output Data Width: 38                                                          | 171.262        | 9960      | 163  | 301  | 300  |

## References

- [FIR Filter IP Release Notes \(FPGA-RN-02025\)](#)
- [Avant-E web page](#)
- [Avant-G web page](#)
- [Avant-X web page](#)
- [Certus-N2 web page](#)
- [Certus-NX web page](#)
- [CertusPro-NX web page](#)
- [CrossLink-NX web page](#)
- [MachXO5-NX web page](#)
- [Lattice Radiant Software web page](#)
- [Lattice Solutions IP Cores web page](#)
- [Lattice Insights web page for Lattice Semiconductor training courses and learning plans](#)

## Technical Support Assistance

Submit a technical support case through [www.latticesemi.com/techsupport](http://www.latticesemi.com/techsupport).

For frequently asked questions, refer to the Lattice Answer Database at [www.latticesemi.com/Support/AnswerDatabase](http://www.latticesemi.com/Support/AnswerDatabase).

## Revision History

**Note:** In some instances, the IP may be updated without changes to the user guide. The user guide may reflect an earlier IP version but remains fully compatible with the later IP version. Refer to the IP Release Notes for the latest updates.

### Revision 1.6, IP v2.3.1, December 2025

| Section                        | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Abbreviations in This Document | Removed <i>OPN</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Quick Facts                    | <ul style="list-style-type: none"> <li>In <a href="#">Table 1.1. FIR Filter Quick Facts</a>:           <ul style="list-style-type: none"> <li>Updated from <i>IP Core v2.3.0</i> to <i>IP Core v2.3.1</i>.</li> <li>Updated from <i>Lattice Radiant software 2025.1</i> to <i>Lattice Radiant software 2025.2</i>.</li> <li>Added note, <i>In some instances, the IP may be updated without changes to the user guide. This user guide may reflect an earlier IP version but remains fully compatible with the later IP version. Refer to the IP Release Notes for the latest updates.</i></li> </ul> </li> </ul> |
| IP Generation and Evaluation   | <ul style="list-style-type: none"> <li>Added note, <i>The screenshots provided are for reference only. Details may vary depending on the version of the IP or software being used. If there have been no significant changes to the GUI, a screenshot may reflect an earlier version of the IP.</i></li> <li>Updated content of <a href="#">Licensing the IP</a>: <i>The FIR Filter IP is provided at no additional cost with the Lattice Radiant software.</i></li> </ul>                                                                                                                                        |
| Ordering Part Numbers          | Removed this section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Revision History               | Added note.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### Document Revision 1.5, IP v2.3.0, July 2025

| Section                      | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                 | <p>Table 1.1. FIR Filter Quick Facts:</p> <ul style="list-style-type: none"> <li>IP Requirements           <ul style="list-style-type: none"> <li>Changed <i>FPGA Families Supported</i> to <i>Supported Devices</i>.</li> <li>Removed <i>CrossLinkU-NX</i> from <i>Supported Devices</i>.</li> <li>Added <i>Certus-NX-RT</i> and <i>CertusPro-NX-RT</i> to <i>Supported Devices</i>.</li> </ul> </li> <li>Resource Utilization           <ul style="list-style-type: none"> <li>Removed <i>Targeted Devices</i>.</li> </ul> </li> <li>Lattice Implementation           <ul style="list-style-type: none"> <li>Updated <i>IP</i> and the <i>Lattice Radiant Software</i> version.</li> </ul> </li> </ul> |
| Functional Descriptions      | <ul style="list-style-type: none"> <li>Updated Figure 2.5. Multi-Channel FIR Filter Implementation.</li> <li>Removed <i>Frequency Constraint (MHz)</i> from Table 2.2. Attributes Table.</li> <li>Removed <i>Synthesis Options</i> from Table 2.3. Attribute Description.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                     |
| IP Generation and Evaluation | <p>3.3 Running Functional Simulation:</p> <ul style="list-style-type: none"> <li>Updated Figure 3.6. Simulation Waveform.</li> <li>Added sub-chapter Functional Simulation Results.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Ordering Part Numbers        | Updated instance of <i>Multi-site Perpetual</i> to <i>Single Seat Perpetual</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

### Document Revision 1.4, IP v2.2.0, December 2024

| Section            | Change Summary                                                                                                                                                                                                                                                                                          |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All                | <ul style="list-style-type: none"> <li>Updated the document title from <i>FIR Filter IP Core – Lattice Radiant Software</i> to <i>FIR Filter IP</i>.</li> <li>Added the IP version information on the cover page.</li> <li>Made editorial fixes.</li> </ul>                                             |
| Inclusive Language | Added boilerplate.                                                                                                                                                                                                                                                                                      |
| Introduction       | <p>In Table 1.1. FIR Filter Quick Facts:</p> <ul style="list-style-type: none"> <li>Added <i>Certus-N2</i> to <i>FPGA Families Supported</i>.</li> <li>Added the <i>LFD2NX-9</i>, <i>LFD2NX-28</i>, and <i>LN2-CT-20</i> devices to <i>Targeted Devices</i>.</li> <li>Add <i>IP Changes</i>.</li> </ul> |

| Section                          | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  | <ul style="list-style-type: none"> <li>Updated <i>Resources and Lattice Implementation</i>.</li> <li>Updated the <i>Features</i> section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Functional Descriptions          | <ul style="list-style-type: none"> <li>Added Figure 2.5. Multi-Channel FIR Filter Implementation.</li> <li>In Table 2.1. FIR Filter IP Core Signal Description: <ul style="list-style-type: none"> <li>Updated the <i>Bits</i> column for <i>coeffin_i</i>.</li> <li>Added information for <i>When Number of Channels is greater than 1</i>.</li> <li>Removed <i>Notes</i>.</li> </ul> </li> <li>Added the Number of Channels and Coefficients Set attributes and removed the Multiplexing Factor, Reorder Coefficients Inside and Half Band attributes from Table 2.2. Attributes Table and Table 2.3. Attribute Description.</li> <li>In Table 2.2. Attributes Table, updated the Selectable Values for the following attributes: <ul style="list-style-type: none"> <li><i>Number of Taps</i> (updated <i>Dependency on Other Attributes</i> as well)</li> <li><i>Input Data Width</i></li> <li><i>Coefficients Width</i></li> <li><i>Frequency Constraint (MHz)</i></li> </ul> </li> <li>Added the Coefficients Specification and Timing Specifications sections.</li> </ul> |
| IP Generation and Evaluation     | <ul style="list-style-type: none"> <li>Updated Figure 3.2. Configure User Interface of FIR Filter IP Core and Figure 3.3. Check Generated Result.</li> <li>Updated black box to closed-box in the Generation and Synthesis section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Ordering Part Numbers            | Added the <i>Certus-N2</i> OPNs and updated the <i>Bundled</i> OPNs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Appendix A. Resource Utilization | Updated resource utilizations for the Lattice Radiant software version 2024.2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| References                       | Updated this section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### Document Revision 1.3, Lattice Radiant SW Version 2024.1, June 2024

| Section                      | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Disclaimers                  | Updated this section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Acronyms in This Document    | Updated this section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Introduction                 | <ul style="list-style-type: none"> <li>Table 1.1. FIR Filter Quick Facts: <ul style="list-style-type: none"> <li>added <i>Lattice Avant</i> and <i>CrossLinkU-NX</i> to <i>FPGA Families Supported</i>;</li> <li>added <i>LAV-AT-E70</i>, <i>LAV-AT-G70</i>, <i>LAV-AT-X70</i>, <i>LFMX05-55T</i>, <i>LFMX05-100T</i>, <i>LIFCL-33</i>, <i>LIFCL-33U</i>, and <i>LFCPNX-50</i> to <i>Targeted Devices</i>;</li> <li>updated <i>Resource</i> to <i>See Table A.1, Table A.2, Table A.3, and Table A.4</i>;</li> <li>updated <i>Lattice Implementation</i> to <i>IP Core Version 2.0.0 – Lattice Radiant Software 2.2 or later</i>.</li> </ul> </li> <li>Features: <ul style="list-style-type: none"> <li>Changed <i>Variable number of taps</i> up to 56 to <i>Variable number of taps</i>.</li> </ul> </li> </ul> |
| Functional Descriptions      | <p>Table 2.2. Attributes Table:</p> <ul style="list-style-type: none"> <li>updated Selectable Values of the Number of Taps attribute to <i>1–56 if Half Band == True or Symmetric Coefficients = True otherwise, it is 1–28 (depending on device used)</i>;</li> <li>added the default value of the Output Width attribute: 36;</li> <li>updated Selectable Values of the Output Binary Point Position attribute to <i>4 + Input Data Binary Point Position + Coefficients Binary Point Position – Output Width Full Precision to Output Width + Input Data Binary Point Position + Coefficients Binary Point Position – 4</i>.</li> </ul>                                                                                                                                                                        |
| IP Generation and Evaluation | Updated Figure 3.1. Module/IP Block Wizard, Figure 3.2. Configure User Interface of FIR Filter IP Core, Figure 3.3. Check Generated Result, and Figure 3.4. Simulation Wizard.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Ordering Part Numbers        | Updated the OPNs for the FIR Filter IP core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Resource Utilization         | <ul style="list-style-type: none"> <li>Replaced the original Table A.1 with Table A.1. Resource Utilization (<i>LIFCL-33-8USG84C</i>) and updated corresponding description for the table.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Section                      | Change Summary                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              | <ul style="list-style-type: none"> <li>Replaced the original Table A.2 with Table A.2. Resource Utilization (LFMX05-25-7BBG400C) and updated corresponding description for the table.</li> <li>Added Table A.3. Resource Utilization (LAV-AT-E70-3LFG676C), Table A.4. Resource Utilization (LAV-AT-G70-1LFG676C), and corresponding descriptions for each table.</li> </ul> |
| References                   | <ul style="list-style-type: none"> <li>Added links to Avant-E Family Devices web page, MachXO5-NX Family Devices web page, CrossLink-NX Family Devices web page, CertusPro-NX Family Devices web page, Certus-NX Family Devices web page, and Lattice Insights for Lattice Semiconductor Training Series and Learning Plans.</li> </ul>                                      |
| Technical Support Assistance | Added the link to Lattice Answer Database.                                                                                                                                                                                                                                                                                                                                   |

**Document Revision 1.2, Lattice Radiant SW Version 3.2, May 2022**

| Section                          | Change Summary                                                                                                                                                                                                                                                                                                                              |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction                     | Updated Table 1.1. FIR Filter Quick Facts: <ul style="list-style-type: none"> <li>Added MachXO5-NX to FPGA Families Supported</li> <li>Added LFMX05-25 to Targeted Devices</li> <li>Added Table A.2. Resource Utilization (LFMX05-25-7BBG400I) to Resources</li> </ul>                                                                      |
| IP Generation and Evaluation     | Updated Figure 3.1. Module/IP Block Wizard, Figure 3.2. Configure User Interface of FIR Filter IP Core and Figure 3.3. Check Generated Result.                                                                                                                                                                                              |
| Ordering Part Numbers            | Added the following part numbers: <ul style="list-style-type: none"> <li>FIR-COMP-XO5-U - FIR Filter Generator for MachXO5-NX - Single Design License</li> <li>FIR-COMP-XO5-UT - FIR Filter Generator for MachXO5-NX - Site License</li> <li>FIR-COMP-XO5-US - FIR Filter Generator for MachXO5-NX - 1 Year Subscription License</li> </ul> |
| Appendix A. Resource Utilization | Updated resource utilization for LFMX05-25-9BBG400I and LFMX05-25-7BBG400I.                                                                                                                                                                                                                                                                 |

**Document Revision 1.1, Lattice Radiant SW Version 3.0, June 2021**

| Section               | Change Summary                                                                                                                                                                                                                                                                                        |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Introduction          | <ul style="list-style-type: none"> <li>Removed last paragraph.</li> <li>Updated Table 1.1. FIR Filter Quick Facts.           <ul style="list-style-type: none"> <li>Revised Supported FPGA Families</li> <li>Revised Targeted Devices</li> <li>Revised Lattice Implementation.</li> </ul> </li> </ul> |
| Ordering Part Numbers | Added part numbers.                                                                                                                                                                                                                                                                                   |

**Document Revision 1.0, Lattice Radiant SW Version 2.2, October 2020**

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





[www.latticesemi.com](http://www.latticesemi.com)