AREA EFFICIENT AND FAULT TOLERANT FIR FILTER

Brajesh Kumar Gupta (nit jamshedpur)  
Associate prof. R. Sinha ( nit jamshedpur )

Abstract— Triple Modular Redundancy (TMR) and Hamming Codes have been used to protect different circuits against Single Event Upsets (SEUs). In this paper, the use of a Novel Hamming approach on FIR Filters is studied and implemented in order to provide low complexity, reduce delay and area efficient protection techniques for higher bits data.

Index Terms— Single Event Upset (SEU), Hamming codes, Novel Hamming codes, Reliability, Digital filters, FPGA, Xilinx 9.2

1. INTRODUCTION

Memory cells have been protected from soft errors for more than a decade; due to the increase in soft error rate in logic circuits, the encoder and decoder circuitry around the memory blocks have become susceptible to soft errors as well and must also be protected.

1.1. Single Event Upsets (SEU)

In some environments, such as space, radiation sources are abundant as is evident in figure 1. The effects of radiation are a well-known cause of errors in microelectronic circuits [1]. These errors range from temporary failures of the system (which most of the times produce a restart of the operations) to serious and permanent damage of the devices. One type of temporary effects is Single Event Effects (SEEs), that cause undesirable changes in the values of flip-flops (SEUs) or combinational logic (SETs) [2]. When a particle hits the silicon, it loses its energy and transmits it to the silicon, causing a current burst. In the case of SEUs, these can randomly change the content of storage cells. To protect storage cells of integrated circuits from this phenomenon, several approaches may be followed [3][4]. One is by technology hardening of memory cells and another one is by designing circuits able to detect an SEU event and act accordingly to prevent error propagation.

1.2. Hamming Codes

Hamming code is well known for its single-bit error detection and correction capability. Hamming code is based on the principle of adding ‘r’ redundancy bits to ‘n’ data bits such that

\[ 2^r \geq n + r + 1 \]

and guarantee full reliability in the system. Triple Modular Redundancy (TMR) and Error Detection and Correction Code (EDAC), like Hamming Code, are examples of such methods.

Filters are commonly used in digital communication systems for equalization, signal separation, noise reduction, etc. As communications are fundamental for space borne applications, such as satellites, unmanned missions, etc., digital filters play an important role in space systems [5].

This paper introduces optimizations for the use of improved Hamming Codes to protect generic (FIR) filter, described by (1) and illustrated in Figure 2. It shows that by knowing attributes of the design to protect the circuit, it is possible to reduce resource consumption and achieve an optimal design.

Figure 1: Energetic particles causing SEEs

Figure 2: Direct Form FIR filter structure and transposed FIR Filter structure.
For example, it needs 4 redundancy bits for a 7-bit data item and 6 redundancy bits for a 56-bit data stream. Let us say, the 7-bit data to be transmitted is 0111001. Then the 11-bit data actually transmitted is 011P100P1PP, where the P’s refer to the Hamming bits that are to be calculated and interspersed at bit positions 1, 2, 4, & 8. Thus the 11-bit data actually transmitted is 01101001111. For the calculation of Hamming bits at positions 1, 2, 4, & 8, even-parity checks were performed on 6, 6, 4, & 4 bits respectively. Thus a total of 20 bits are involved in the process of Hamming bits calculations. The error-detection and correction process in Hamming code is as illustrated in Table 1. Hamming code is normally used for transmission of 7-bit data items. Scaling it for larger data lengths results in a lot of overhead due to interspersing the redundancy bits and their removal later, it is not efficient for higher data bits.

2. PROPOSED NOVEL HAMMING CODE

A novel Hamming code is proposed in this section, to increase the efficiency of higher data bits. Let us consider the same example. The 7-bit data to be transmitted is 0111001. The number of redundancy bits, ‘r’ to be appended to n-bit data is obtained such that the relation

\[(2^r - 1) \geq n\]

is satisfied. The number of redundancy bits in this method is same as that for Hamming code for some values of n. But in some cases, it will be just one more redundancy bit than needed in the Hamming code [6][7][8]. For 7-bit data, the number of redundancy bits required will be 4. Then the 11-bit data actually transmitted is PPPP0111001, where the P’s refer to the redundancy bits that are to be calculated and appended at bit positions 8, 9, 10, & 11. Thus the 11-bit data actually transmitted is 01101001111. For the calculation of bits at positions 8, 9, 10, & 11, even-parity checks were performed on 5, 5, 5, & 4 bits respectively. Thus a total of 19 bits are involved in the process of calculation of redundancy bits. The error-detection and correction process as proposed in this novel method is illustrated in Table 2.

<table>
<thead>
<tr>
<th>TABLE 1: ERROR DETECTION AND CORRECTION USING HAMMING CODE</th>
</tr>
</thead>
<tbody>
<tr>
<td>Received information include Hamming bits</td>
</tr>
<tr>
<td>11 10 9 8 7 6 5 4 3 2 1</td>
</tr>
<tr>
<td>0 1 1 0 1 0 1 1 1 1 1</td>
</tr>
<tr>
<td>0 1 1 1 1 0 0 1 1 1 1</td>
</tr>
<tr>
<td>0 1 1 0 1 0 0 1 1 1 1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>TABLE 2: ERROR DETECTION AND CORRECTION USING NOVEL METHOD</th>
</tr>
</thead>
<tbody>
<tr>
<td>Received information including redundancy bits</td>
</tr>
<tr>
<td>11 10 9 8 7 6 5 4 3 2 1</td>
</tr>
<tr>
<td>0 1 1 0 0 0 1 1 0 0 1</td>
</tr>
<tr>
<td>0 1 1 1 0 1 1 1 0 0 1</td>
</tr>
<tr>
<td>0 1 0 0 0 1 1 1 0 0 1</td>
</tr>
<tr>
<td>0 0 1 0 0 1 1 1 0 0 1</td>
</tr>
<tr>
<td>1 1 1 0 0 1 1 1 0 0 1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>TABLE 3: COMPARISON OF NUMBER OF BITS INVOLVED IN CALCULATION OF REDUNDANCY BITS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Length of data stream</td>
</tr>
<tr>
<td>-----------------------</td>
</tr>
<tr>
<td>7 bit data</td>
</tr>
<tr>
<td>31 bit data</td>
</tr>
<tr>
<td>56 bit data</td>
</tr>
</tbody>
</table>

TMR is the simplest and effective way for protecting a design. The area consumption of this method is obviously up to three times higher, depending on which implementation is chosen. The optimal design of the TMR logic is discussed in [9]. A previous approach to protect FIR filters using Hamming codes discussed in [10] is illustrated in Fig. 3 and Fig. 4. EDAC codes to protect the circuit incurs a great achievement in terms of area with respect to the use of TMR [10].
3. IMPLEMENTATION OF PROPOSED TECHNIQUE

In this section, the proposed technique is used to demonstrate, how the lot of overhead due to interspersing the redundancy bits, their subsequent removal, pad to pad delay in the decoder and consumption of total area of FIR filter for higher bits are reduced. These are based on the novel hamming code implementation in the FIR filter instead of conventional hamming code used to protect FIR filter previously[10].

A. Novel Hamming Single Encoder

One of the improvisation would be to replace the Hamming encoders and Hamming decoder[10] with Novel Hamming encoder and Novel Hamming decoder respectively, in Fig. 3. The delay in the Novel Hamming decoder reduced in comparison of conventional Hamming decoder, they are only used if there are errors in the circuit and even in that case, if only a single error is present in the register, it can still be corrected with the Novel decoder at each stage. In summary, these additional encoders are useful only if we assume that a tap value will be hit by more than one SEU at different time instants, as it propagates through the delay line.

B. Novel Additional Hamming Data Protection

The operation observed in the above design (fig. 5) is improved in this section by using a novel addition Hamming data protection. Here, the output of each decoder is fed to the data bits of the next register while the parity bits are taken directly from the previous stage, as shown in Figure 6. This would allow recovering from multiple errors that occur in the data bits as long as they happen in different clock cycles. This is achieved without additional encoders.

4. EXPERIMENTAL RESULTS

The proposed techniques have been implemented in VHDL (Xilinx 9.2) and then the circuits have been synthesized for FPGA VIRTEX-6. An experimental setup [11] based on the Single Event Upset Simulation Tool (SST) has been used to insert SEUs, the block diagram of which is shown in figure 7. The results obtained are summarized in figure 8,9,10,11. The results clearly indicates the efficiency of the proposed techniques in terms of circuit complexity and area as compared to the traditional approaches[10].

The generic FIR filters have been implemented with 6 and 12 taps using the same structure and coefficient as in [10]. Equations (2) and (3) show the FIR filter coefficients, as mentioned in the references above.

\[ h[n] = [-1 24 50 50 24 -1] \]  
\[ h[n] = [1 -1 -9 6 73 120 120 73 6 -9 -1 1] \]
The VIRTEX-6 results show that the decrement in the usage of LUTs when comparing the proposed technique to the ordinary [10] as we increase the no. of bits.
5. CONCLUSIONS

In the proposed improvement the redundancy bits are appended at the end of data bits. This eliminates the overhead of interspersing the redundancy bits at the sender end and their removal at the receiver end after checking for single-bit errors and consequent correction, if any. Further the effort needed in identifying the values of the redundancy bits is lower in the proposed novel method. Hamming code is normally used for transmission of 7-bit data item. Scaling it for larger data lengths results in a lot of overhead due to interspersing the redundancy bits and their removal later. In contrast, the proposed method is highly scalable without such overhead. We see that there is only 7-bit overhead for a 56-bit data stream, which is much less compared to 4-bit overhead for a 7-bit data. A new approach for protecting the FIR filters from single event upsets (SEUs) are implemented in the design. We have focused on achieving low complexity and low area occupancy with minimum delay. Improved method can be scaled easily for larger data lengths as compared to [10]. The simulation results of the proposed designs encourage in terms of delay and area used. The implementation results show that the proposed design is suitable to protect FIR filters efficiently from single event upsets. Future work includes the consideration of power consumption as a metric for optimization, since it is a key factor in space applications.

6. REFERENCES


[9] B. Shim, N.R Shanbhag and S. Lee, "Energy-efficient soft error-


7. AUTHORS PROFILE

1. Associate Prof. Rashmi Sinha : Department of Electronics and Communication Engineering, National Institute of technology, Jamshedpur (India)

   Email : rsinha.ece@nitjsr.ac.in

2. Brajesh Kumar Gupta : M.Tech Scholar, Department of Electronics and Communication Engineering, National Institute of technology, Jamshedpur (India)

   Email : bkgupta8bu@gmail.com