Implementation of Adaptive Viterbi Decoder
Implementation of Adaptive Viterbi Decoder
Implementation of Adaptive Viterbi Decoder
Dipak Iwanate#3
VIII Sem B.E. (Etrx) K.D.K.College of Engineering Nagpur , Maharashtra(I)
ABSTRACT Viterbi algorithm is employed in wireless communication to decode the convolutional codes; those codes are used in every robust digital communication systems. Such decoders are complex & dissipiate large amount of power. Thus the paper presents the design of an Adaptive Viterbi Decoder (AVD) that uses survivor path with parameters for wireless communication in an attempt to reduce the power and cost and at the same time increase in speed. Most of the researches work to reduce power consumption, or work with high frequency for using the decoder in the modern applications such as 3 GPP, DVB, and wireless communications. Field Programmable Gate Array technology (FPGA) is considered a highly configurable option for implementing many sophisticated signal Processsing tasks. The proposed decoder design is implemented on Xilinx Spartan 3 , XC3S200 FPGA chip using VHDL code and Xilinx ISE 9.1 used for synthesis.
these decoders increased with the increasing of the constraint length. Thus, we attempts to; 1. Design an adaptive Viterbi decoder that uses survivor path storage with parameters for wireless communication. 2. Design and implement the decoder using Xilinx system generator modeling tool. Evaluate the decoder for timing accuracy and resource utilization. VHDL stands for VHSIC Hardware description language. VHSIC is itself an abbreviation for very high speed integrated Circuit. This language was first introduced in 1981 for the Department of Defense (DoD) under the VHSIC program. In 1983 IBM , Texas instruments and intermetrics started to develop this language. In 1987 IEEE standardized the language. VHDL is a hardware description language. It describes the behavior of an electronic circuit or a system from which the physical circuit or system can then be implemented. VHDL is intended for circuit synthesis as well as circuit simulation. VHDL is programming language that allows one to model and develop complex digital system in dyanamic environment by dataflow, behavioral and structural style of modeling. The behavior of field programmable gate arrays can be illustrated by this language. 2. VITERBI ALGORITHM Viterbi algorithm was devised by Andrew J. Viterbi (1967). The optimality and the relatively modest complexity for small constraint lengths have served to make the Viterbi algorithm the most popular in decoding of convolutional codes with constraint length less than 10. Viterbi algorithm is called as optimum algorithm because it minimizes the probability of error. The Viterbi algorithm is one of the standard sections in number of highspeed modems of the process for information infrastructure applicable in modern world. The unit of branch metric will calculate all the branch metrics and then processed to add compare for selecting the surviving branches as per the branch metrics finally the decoded data bits are generated by the trace back unit.
General Terms
Viterbi Algorith
Keywords
FPGA, VHDL, AVD, AWGN,DoD, VHSIC. 1. INTRODUCTION Most digital communication systems nowadays convolutionally encoded the transmitted data to compensate for Additive White Gaussian Noise (AWGN), fading of the channel, quantization distortions and other data degradation effects. For its efficiency the Viterbi algorithm has proven to be a very practical algorithm for forward error correction of convolutionally encoded messages. The requirements for the Viterbi decoder or Viterbi detector depend on the applications used. Most of the researches work to reduce cost, the power consumption, or work with high frequency for using the decoder in the modern applications such as 3GPP, DVB, and Wireless communications. Some of them comparing between using FPGA, ASIC, and DSP to find which one is suitable for the applications, other studies the differences method for back trace unit to find the correct path, and the other trying to work with high frequency by using parallel operations of decoder units . The complexity of
ISSN: 2231-5381
http://www.internationaljournalssrg.org
Page 153
3.2.2 Add Compare Select Unit (ACSU) This ACSU is the main unit of the survivor path
decoder . The function of this unit is to find the addition of the Hamming code received from BMU's and to compare the total Hamming code. This takes the branch metrics computed by the BMC and computes the partial path metrics at each node in the trellis. The surviving path at each node is identified, and the information-sequence updating and storage unit notified accordingly. Since the entire trellis is multiple images of the same simple element, a single circuit called AddCompare-Select may be assigned to each trellis state.
The input to our proposed design is an identified code symbols and frames, i.e. The design decodes successive bit stream and the proposed decoder has no need to segment the received bit stream into n-bit blocks that are corresponding to a stage in the trellis in order to compute the branch metrics at any given point in time . The architecture of the viterbi decoder is illustrated in fig 3.1.
Fig 3.1 Basic building blocks of the Viterbi decoder. The basic performance of the Viterbi decoder is analyzed with the block diagram shown below. It consists of three main blocks1. Branch Metric Calculation 2. Path Metric Calculation 3. Survivor Management Unit
The aim of the adaptive Viterbi Decoder is to reduce the average computation and path storage required by the Viterbi algorithm. Instead of computing and retaining all 2K-1 possible paths, only those paths which satisfy certain cost conditions are retained for each received symbol at each state node. Path retention is based on the following criteria.
ISSN: 2231-5381
http://www.internationaljournalssrg.org
Page 154
Fig 5.2 State diagram Fig 4.1 Block diagram of adaptive viterbi decoder.
5. CONVOLUTIONAL CODES The convolutional encoder is basically a finite state machine. The k bit input is fed to the constraint length K shift register and the n outputs are calculated from the generator polynomials by the modulo-2 addition. The generator polynomial specifies the connections of the encoder to the modulo-2 adder. The Fig 5.1 below illustrates a simple convolutional coder with Input (mo) 0 1 0 1 0 Bit
Table 5.1 State table Present (S1S0) 00 00 01 01 10 10 11 11 state Next state(S1 S0) 00 01 10 11 00 01 10 11 Output bits(V1V0) 00 11 11 00 10 01 01 10
1 0 1
Trellis diagram is the description of state diagram of the encoder by a time line i.e. to represent each time unit with a separate state diagram Fig 5.1 Convolutional encoder. Convolutional encoder can be described in terms of state table, state diagram and trellis diagram. The State is defined as the contents of the shift register of the encoder. In state table output symbol can be described as a function of input symbol and the state. State diagram shows the transition between different states.
ISSN: 2231-5381
http://www.internationaljournalssrg.org
Page 155
ISSN: 2231-5381
http://www.internationaljournalssrg.org
Page 156
6.1 Advantages
The use of error-correcting codes has proven to be an effective way to overcome data corruption in digital communication channels. It is used for increasing the speed, reducing the power and cost. .
6.2 Applications
A Low-Power Viterbi Decoder for Wireless Communications Applications. Pipelined VLSI Architecture of The Viterbi Decoder for IMT-2000. 200Mbps Viterbi decoder for UWB. Viterbi Decoder for WCDMA System. Low complexity efficient trackback viterbi decoder for wireless applications. A Soft IP Generator for High-speed Viterbi Decoders.
Reconfigure the Viterbi decoder, and adaptive Viterbi decoder units will give simple elements in each unit and new algorithms. It was found that the survivor path decoder is capable of supporting frequency up to 790 MHz for constraint lengths 7, and 9 , rate 1/3 and long survivor path is 4. The different constraint length didnt affect of the complexity of the decoder and the processing time of computing the correct path. As mobile and wireless communication becomes increasingly ubiquitous, the need for dynamic reconfigure ability of hardware shall pose fundamental challenges for communication algorithm designers as well as hardware architectures. This paper attempts to solve this problem for the particular case of the Viterbi decoder, which is a critical component at a physical layer of most wireless communication systems. A new Viterbi decoder architectures have been proposed. These results were evaluated and assessed. Next the adopted design were coded in VHDL and implemented on a SPARTAN 3. REFERENCES
[1] Prof. Siddeeq Y. Ameen,Mohammed H. Al-Jammas and Ahmed S. Alenezi, FPGA Implementation of Modified Architecture for Adaptive Viterbi DecoderIEEE,2011. [2] S. W. Shaker, S. H. Alramely and K. A. Shehata, Design and implementation of low- power Viterbi decoder for software-defined WiMAX receiver, 17th Telecommunication Forum TELFOR, Serbia, Belgrade, 2009.
7. CONCLUSION The processing execution time has been reduced by removing the trace back algorithms that is used to find the correct paths. The survivor path algorithm used, the address of the memory unit to select the correct path which specify the output code.
ISSN: 2231-5381
http://www.internationaljournalssrg.org
Page 157
ISSN: 2231-5381
http://www.internationaljournalssrg.org
Page 158
ISSN: 2231-5381
http://www.internationaljournalssrg.org
Page 159