Implementation of Fault Tolerant FIR Filter for Digital Communication Systems

Jyotishma Bharti  
Department of Electronic and Communication Engineering  
Integral University, Lucknow

Tarana Afrin Chandel  
Associate Professor  
Department of Electronic and Communication Engineering  
Integral University, Lucknow

Abstract

A realistic communication system is not free from noise. So the transmission of information through may rather be corrupted by noise in the channel. Therefore it is necessary for every communication systems to have suitable means to recognize and correct those errors in the information received over communication channels. There are various types of filters are used by Digital signal processing (DSP) applications. In which digital parallel FIR filters are very widely used in numerous application. Over the years, many implementation techniques of digital FIR filter for DSP application has exploit the various practical difficulties such as low speed, high delay and above of all fault tolerance. Due to the VLSI complexity scaling, there are many complex systems that embed with many filters. The filters operations in those complex systems are usually parallel. As filters is the unit that comes in any type of communication system ranging from simple voice data to complex real time data conversation. So it is then mandatory to implement some technique that shows the fault tolerance achieved in parallel filters. In this paper we are implementing the FIR Filter with 6-bit Fault tolerant using BCH codes. The complete design has been developed by VHDL and synthesize and simulated by XILINX ISE Tool.

Keywords- Error Correction Codes (ECC), Digital Signal Processing (DSP), Finite Impulse Response (FIR) Parallel FIR, Very Large Scale Integration (VLSI)

I. INTRODUCTION

The demand for high performance and low power DSP is getting exponentially higher due to the bombardment of multimedia application such as automotive, medical and space applications where reliability is critical. And in those specific applications, the electronic circuits should have to provide some degree of fault tolerance. Although there are various other techniques that can be used to protect a circuit from errors. These errors can be removed ranging from modifications in the manufacturing process of the circuits for reducing the number of errors by adding redundancy bits at the logic or system level in order to ensure that these errors can do not affect the system functionality.

As in this paper we are more focusing on Filter processing so it is mandatory to emphasize on the application area of Filters. The filters are basic unit of any type of communication. In the basic communication system the transmission of information/raw data is not always be free from unwanted information bits or Noise. Thus it is very necessary for any communication systems to must have appropriate means for the finding and correction of errors in the information received over any communication channels. This paper deals with the study of the use of the various Error corrections coding scheme into Digital FIR Filter design.

II. ERROR CORRECTING CODES – AN OVERVIEW

During the Digital communication system the information always travels through a medium. And the transformation of the information through this channel could always not be free from noise. Also we know that in digitally encoded data, there is a series of symbols denoted generally in the terms of 0s and 1s. Suppose that we want to transmit the information that "There is no class on Monday". This information can be defined by 01101111, say, and transmitted over a channel where some unwanted data i.e. "noise" may be introduced. Noise means simply errors. The aim of an error-correcting code is to lengthen the message in such a way that the original message can be recovered even if errors are present here. By error we mean that there is unwanted change in data which is required to be correct for efficient and reliable reception of data.

The following diagram represents the communications channel.

Fig. 1: Basic Communication System
An error is the change or the mismatching takes place between the data sent by transmitter and the data received by the receiver e.g. 10101010 sent by sender 10101011 received by receiver. Here is an error of 1 bit. Error control refers to mechanisms to detect and correct errors that occur in the transmission of frame. There are assorted techniques available for error control e.g. Error detection, Positive acknowledgement Retransmission after time-out, Negative acknowledgement and retransmission. These mechanisms are also referred as Automatic Repeat Request (ARQ). The base of all error detection and correction is the inclusion of redundant information.

![Fig. 2: Classification of Error Correcting Codes](image)

### III. PROPOSED BLOCK DIAGRAM

In this work we are generating a Self-error detector and corrector for FIR Filter. We are integrating two different topologies into a one solution. The proposed block diagram is shown in figure 3.

![Fig. 3: Proposed Block Diagram](image)

The figure 3 shows the proposed schematic for our research work. The filter input first propagates through the error detection and correction circuit. Then the output from the error correcting detecting circuit will finally go to the parallel FIR filter. The basics of these FIR filter and Error detecting correcting circuit will be discussed in coming sections.

### IV. PARALLEL FILTER

A discrete time filter follows the following equation:

$$y[n] = \sum_{l=0}^{\infty} x[n-l] \cdot h[l]$$  \hspace{1cm} (1)

As stated in equation 1, \(x[n]\) is the input signal, \(y[n]\) is the output, and \(h[l]\) is the impulse response of the filter. The FILTERS has been categorized by this impulse response. For a FIR FILTER the response \(h[l]\) should be nonzero, only for a finite number of samples. Otherwise the filter is an infinite impulse response (IIR) filter. There are several structures to implement both FIR and IIR filters.

![Fig. 3: Proposed Block Diagram](image)

We can also cascade \(n\) number of filters in a single communication systems.

### V. ERROR CORRECTION CODES

In our work we had been gone through various Error detection and correction circuits. But we found BCH codes is the best suited for our purpose. The some property of BCH codes is going to be discussed in this section. The BCH codes use to be defined by the code size \(n\) and the number of errors to be corrected \(t\).

- Block length: \(n = 2^m - 1\)
- Number of information bits: \(k \geq n - m \cdot t\)
- Minimum distance: \(d_{\text{min}} \geq 2t + 1\).
The generator polynomial of the code is specified in terms of its roots over the Galois field GF (2^m). Let’s take α as a primitive element in GF (2^m). The generator polynomial g(x) of the code is the lowest degree polynomial over GF (2). Let m_i(x) be the minimum polynomials of α_i then generator polynomial G(x) can be computed by:

\[ G(x) = \text{LCM} \{m_1(x), m_2(x), \ldots, m_t(x)\} \quad (2) \]

In this work n=63, k=30 and t=6 is considered. Hence the generator Polynomial with, a, a^2, a^3 as the roots is obtained by multiplying the following minimal polynomials:

\[ m_1(x) = 1+x+x^4 \]
\[ m_3(x) = 1+x+x^2+x^3+x^4 \]

Substituting \( m_1(x) \) and \( m_3(x) \) in equation (2) generator polynomial is obtained.

\[ G(x) = \text{LCM} \{m_1(x), m_3(x)\} \]
\[ G(x) = \{(1+x +x^4) (1+x+x^2+x^3+x^4)\} \]

To build BCH codes over GF (2^6), we need to find out the elements of GF (2^6) generated by \( p(x) = 1+x+x^6 \) is given in Table below

<table>
<thead>
<tr>
<th>( a )</th>
<th>( \alpha^2 )</th>
<th>( \alpha^3 )</th>
<th>( \alpha^2+\alpha^3 )</th>
<th>( \alpha^6 )</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>( \alpha )</td>
<td>( \alpha^2 )</td>
<td>( \alpha^3 )</td>
<td>( \alpha^2+\alpha^3 )</td>
<td>( \alpha^6 )</td>
</tr>
<tr>
<td>( \alpha^2 )</td>
<td>( \alpha^3 )</td>
<td>( \alpha^2+\alpha^3 )</td>
<td>( \alpha^6 )</td>
<td></td>
</tr>
<tr>
<td>( \alpha^3 )</td>
<td>( \alpha^4 )</td>
<td>( \alpha^2+\alpha^3+\alpha^4 )</td>
<td>( \alpha^6 )</td>
<td></td>
</tr>
<tr>
<td>( \alpha^4 )</td>
<td>( \alpha^5 )</td>
<td>( \alpha^2+\alpha^3+\alpha^4+\alpha^5 )</td>
<td>( \alpha^6 )</td>
<td></td>
</tr>
<tr>
<td>( \alpha^5 )</td>
<td>( \alpha^6 )</td>
<td>( \alpha^2+\alpha^3+\alpha^4+\alpha^5+\alpha^6 )</td>
<td>( \alpha^6 )</td>
<td></td>
</tr>
<tr>
<td>( \alpha^6 )</td>
<td>( \alpha^7 )</td>
<td>( \alpha^2+\alpha^3+\alpha^4+\alpha^5+\alpha^6 )</td>
<td>( \alpha^6 )</td>
<td></td>
</tr>
</tbody>
</table>

\[ G(x) = 1+x^4+x^6+x^7+x^8 \quad (3) \]

Table 1: The elements of GF (2^6) generated by \( p(x) = 1+x+x^6 \)

In BCH, the code words are formed by adding the remainder after division of message polynomial with generator polynomial. All code words are the multiples of generator polynomial. At the encoding side, the generator polynomials are not usually split as it will demand more hardware and control circuitry. The polynomial is used as such for encoding. For BCH circuit there are two blocks has been used named As Encoder and Decoder. Encoder always starts with Parallel to serial register with 33 bit LFSR.
The (63,30) BCH Encoder is always implemented with a Linear Feedback Shift Register (LFSR). BCH codeword are encoded as follows.

\[ C(x) = x^{n-k} \cdot M(x) + b(x) \]  

(4)

Where, Message bits \( M(x) = M_0 + M_1x + \ldots + M_{k-1}x^{k-1} \)

Code word \( C(x) \) is \( c_0 + c_1x + \ldots + c_{n-1}x^{n-1} \)

Remainder is \( b(x) = b_0 + b_1x + \ldots + b_{m-1}x^{m-1} \) where, \( c_i, b_i \) are the subsets of Galois field. Figure 4 shows block diagram of (63,30) BCH Encoder module. The 30 message bits \( M_0, M_1, \ldots, M_{29} \) are applied to the parallel to serial shift register. Using these message bits, parity bits are computed and then sent to serial to parallel shift register. These parity bits are appended to original message bits to obtain 63 bit encoded data. This entire encoding process requires 63 clock cycles.

![BCH Encoder Block Diagram](image)

**Fig. 4: BCH Encoder**

Figure 5 shows the block diagram of BCH decoder. The decoding algorithm for BCH codes consists of three major steps.

1. Calculate the syndrome value \( S_i \), \( i=1,2,\ldots,2t \) from the received word \( r(x) \).
2. Determine the error location polynomial \( s(x) \)
3. Find the roots of \( s(x) \) and then correct the errors

At the decoder side the received 63 bit data will propagate through the parallel to serial shift register, then obtained serial output will be used as an input to compute syndrome \( s(x) \). For error-free transmission \( s(x) = 0 \). Otherwise, transmitted message will be in error. This is called error detection process. There are several types of error correction process i.e. Peterson and Zierler algorithm, Chine’s search algorithm.

Peterson’s algorithm accepts syndrome \( s(x) \) as an input and computes error locator polynomial \( \sigma(x) \). For finding the error locator polynomial using the formula

\[ \sigma_1 = S_1, \quad \sigma_2 = (S_3 + S_1^3)(S_1 - 1) \]

This polynomial can be further used to find the location of the errors. Using chine’s search algorithm error location is determined. This process includes searching the unique roots of the error locator polynomial. The input for the chine’s search is \( \sigma(x) \) and it returns roots of error locator polynomial which corresponds to the error positions.

**VI. SYNTHESIS & SIMULATION RESULTS**

This section shows the various results obtained from the XILINX ISE Tool. The figure 6 & 7 shows the RTL view of our designed circuit i.e. Fault tolerant FIR Filter. As shown in the figure there are two inputs named as \( A \), and error. The input \( A \) denotes the original message to be filtered through the FIR filtration. While error signal are for stimulating the various number of errors.

![RTL for Fault Tolerant FIR](image)

**Fig. 6: RTL for Fault Tolerant FIR**
The figure 6 shows only the input output ports which can be used as a physical interface for real world implementation. On the other hand figure 7 shows the internal structure of the Fault tolerant FIR filter. In this two separate block has been connected together to achieve the desired output.

![Internal RTL](image)

**Fig. 7: Internal RTL**

The figures 8, 9 & 10 shows the cumulative result for the fault tolerant fir filter with different input conditions.

![Simulation Result with initial Conditions](image)

**Fig. 8: Simulation Result with initial Conditions**

The figure 8 shows the simulation results with initial conditions i.e. RST='1'. For initialization of all the registers, signals into its original states/values.

![Simulation results with 4 bit error correction](image)

**Fig. 9: Simulation results with 4 bit error correction**
The figure 9 & 10 shows the result with stimulation of 4 bit and 6 bit error values, respectively, through error signal. And we can easily observe that there is not a slight change in the output waveform.

![Fig. 10: Simulation results with 6 bit error correction](image1)

![Fig. 11: Simulation results with >6 bit error](image2)

The figure 11 shows the simulation result with more than 6 bit error stimulation through error signal. And also there is some changes happened in the waveform. In other words we can see there are some extra lobes had been developed.

**VII. CONCLUSION**

We had successfully implemented the Fault tolerant FIR Filter. Our design has provide the adequate result with less than and equal to 6. Means our fir filter can retain their original input signals if by any means there has been error generated. The complete design has been designed and implemented by Xilinx ISE tool. The Synthesis has been done by XILINX Synthesis Tool and the simulation has been carried out by Xilinx ISIM and Modelsim.

**REFERENCES**

Implementation of Fault Tolerant FIR Filter for Digital Communication Systems


