### Product Code Iterative Decoder



 $\frac{ \texttt{Arif E. Nugroho}}{arif\_endro@opencores.org}$ 



VLSI Research Group LabTek VIII Institut Teknologi Bandung Jl. Ganesha 10 Bandung 40141 West Java, Indonesia

## **Contents**

| 1 | Intr | oduction           | 1 |
|---|------|--------------------|---|
|   | 1.1  | Product Code       | 1 |
|   | 1.2  | Decoding Algorithm | 2 |
|   | 1.3  | Circuit Schematic  | 3 |
|   |      |                    |   |
| 2 | Imp  | lementation        | 4 |
|   | 2.1  | Simulation         | 4 |
|   | 2.2  | Synthesize         | 4 |
|   | - 4  |                    | _ |
| A | Info | ormations          | 7 |
|   | A.1  | Warranty           | 7 |
|   | A.2  | Tools              | 7 |

# **List of Figures**

| 1-1 | Sequence of Product Codes         | 1 |
|-----|-----------------------------------|---|
| 1-2 | Product Code generations          | 2 |
| 1-3 | Schematic of Product Code Decoder | 3 |

1

## Introduction

#### 1.1. Product Code

Product code is also known as turbo code, this error correction methods is known to approach the Shannon Limit. This design uses iterative methods on decoding the product codes, see Figure 1-3, this design is based on Mr. Wada-san homepage[1].

This is two dimesional product code iterative decoder, there are four bits information followed by two row parity bits and two column parity bits. Each signal informations is represented in two's complement eight bit data, thus it indicate an integer value of -128 to 127 for each of information bit.



Figure 1-1: Sequence of Product Codes

1.2. DECODING ALGORITHM 2



Figure 1-2: Product Code generations

### 1.2. Decoding Algorithm

 $posteriori\ value = channel\ value\ (Lch) + priori\ value + external\ value\ (Le)$  (1-1)

$$\begin{cases} posteriori = Lch + priori + Le (row parity) & (0) \\ posteriori = Lch + priori + Le (column parity) & (1) \\ .... \\ mosteriori = Lch + priori + Le (row parity) & (n-1) \\ posteriori = Lch + priori + Le (column parity) & (n) \\ \end{cases}$$

$$(1-2)$$

$$Lch = Y0, Y1, Y2, Y3$$
 (1-3)

$$priori = posteriori (n-1)$$
 (1-4)

$$Le = sgn(a * b) * min\{abs(a), abs(b)\}$$

$$(1-5)$$

sgn(a \* b) means the sign result of multiplication between operand a and b, and abs(x) means absolute value of operand x. The last value of posteriori is the decoded informations, i.e the posteriori value at  $n^{th}$  iterations. The decoded informations can be obtained from the sign of the last posteriori value, positive value is zero and negative

1.3. CIRCUIT SCHEMATIC 3

value is one, i.e this is the most significant bit of the posteriori value.

## 1.3. Circuit Schematic



Figure 1-3: Schematic of Product Code Decoder

## **Implementation**

### 2.1. Simulation

This design has been simulated using ModelSim 6.0 SE, here is the summary of bit errors on different signal to noise ratio (SNR) of input signal:

| SNR(dB) | BIT ERRORS |
|---------|------------|
| 100     | 0/10000    |
| 9       | 441/10000  |
| 6       | 926/10000  |
| 3       | 1394/10000 |
| О       | 2203/10000 |

Table 2-1: Bit errors on different SNR

signal with SNR 0 dB is signal with very big noise.

### 2.2. Synthesize

This design has been synthesized using ISE Xilinx 6.3i, here is the summary of the area utilization in FPGA Xilinx:

2.2. SYNTHESIZE 5

| XC2V2000-FF896-4            |           |  |
|-----------------------------|-----------|--|
| Slices                      | 547/10752 |  |
| Slices Flip Flops           | 203/21504 |  |
| 4 input LUT                 | 922/21504 |  |
| Total Equivalent gate count | 7294      |  |

Table 2-2: Area utilizations summary

The maximum clock frequency is 64.070 MHz (Minimum period 15.608ns)

## **Bibliography**

[1] Tom Wada, **2-D Product Code Iterative Decoder**, http://www.ie.u-ryukyu.ac.jp/ $^{\sim}$  wada/design06/spec\_e.html October  $1^{st}$ , 2005

#### A

## **Informations**

## A.1. Warranty

#### NO WARRANTY

THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

### A.2. Tools

- ALLIANCE CAD SYSTEM developed by ASIM team at ©LIP6/Université Pierre et Marie Curie, http://asim.lip6.fr/recherche/alliance
   The primary VHDL Analyser for Synthesize
- ModelSim 6.0 The Simulator
- Xilinx 6.3i The Synthesizer

A.2. TOOLS

- $\bullet~$  VIM (Vi IMproved) The Editor
- LATEX The Typesetter

Version: 1.0