Forward Error Control System Performance of Maximum Free Distance Convolutional Codes with Different Modulation Schemes by Jassim, M. A. (MSC) & HADI, W. A. (Wael)
                                                                                    International Journal of New Technology and Research (IJNTR) 
                                                                              ISSN:2454-4116,  Volume-2, Issue-11, November  2016  Pages 06-12 
                                                                                        6                                                                                  www.ijntr.org 
 
Abstract— Forward Error Control (FEC) based on 
Convolution Encoders with Viterbi decoding is a good 
methodology to decrease the effect of Additive Gaussian Noise 
residing inside digital data transmissions channel. In this paper 
a Convolutional encoders with maximum free distance and 
different constraint lengths have been tested with AWGN 
channel effect using MATLAB. The performance and analysis 
has done by changing rates of Convolutional encoders and 
different constraint lengths and take in consider QPSK, 
16-QAM and 64-QAM as modulation schemes.  
 
Index Terms— Additive White Gaussian Noise (AWGN), 
Convolutional Encoder, Trellis Diagram, QPSK, 16-QAM and 
64-QAM Modulation.  
 
I. INTRODUCTION 
  Convolutional  codes  are introduced in 1955 by Elias. 
Convolutional codes are one of the powerful and widely 
used class of codes, These codes are having many 
applications, that are used in deep-space communications, 
voice band modems, wireless standards(such as  802.11)  
and  in  satellite  communications. Convolutional codes are 
plays a role in low-latency applications such as speech 
transmission [1].  
 
II. CONVOLUTIONAL ENCODERS  
A. Convolutional Encoders Structure 
       Convolutional encoder of (n, k) is defined by k × n 
matrix, where k is input bits and n output bit so Convolutional 
encoder information rate of k/n. An important parameter of 
Convolutional encoder is their constraint length which is 
corresponds to the total size of their internal memory [2]. 
This parameter is important in Viterbi decoding algorithms 
complexity since it means more states in convolutional 
encoder trellis. In Convolutional encoder the message stream 
input to encoder continuously and run through it. Thus the 
Convolutional encoder required very little buffering and 
storage hardware [3]. Convolutional encoder parameters 
notation used in this paper as following  
           n = number of output bits. 
          k = number of input bits. 
 
Dr. WAEL A.H. HADI, Electrical Engineering Department, 
Al-Tachnologyi University / Engineering collage, Baghdad, Iraq. 
Msc. Amjad Ali Jassim, Electrical Engineering Department, 
Al-Tachnologyi University / Engineering collage, Baghdad, Iraq. 
 
          m = number of stages of shift registers. 
          L = number of bits in message sequence. 
          u = input bits. 
          Constraint Length: K = (m + 1) digits. 
          Code Rate: r = k/n. 
         Shift register = D. 
 
 
Fig.1. Convolutional encoder of code rate ½, constraint 
length K = 3, Generator polynomials of {5, 7} octal. 
 
     The generator polynomials of Convolutional encoder 
represent the connections between shift registers. To generate 
the output code a mode two addition (EX-OR) between shift 
registers contents are performed. The output code is the 
results of generator polynomials C1C2. In Convolutional 
encoders common transition table calculations take in 
consider the input bit and shift register contents in present 
state and next state illustrate the generation of output code. 
For Fig.1, Convolutional encoder Table 2, show transition 
calculations.   
 
Table 1. Transition table calculations of output code C1 and 
C2, rate ½, K=3, generator {5, 7} octal. 
 
 
     The notation of states as a, b, c and d. is to simplify the 
point of view for Convolutional encoder trellis states.   
 
Forward Error Control System Performance of 
Maximum Free Distance Convolutional Codes with 
Different Modulation Schemes  
MSC. Amjad Ali Jassim, Dr. Wael A.H. HADI 
Forward Error Control System Performance of Maximum Free Distance Convolutional Codes with Different 
Modulation Schemes  
 
                                                                                7                                                                 www.ijntr.org 
 
B. Convolutional Encoder state diagram 
In refer to Table 1. Convolutional encoder state diagram 
could be constructed by joining the input bit with the output 
resulted code starts from present state to next state. See 
 Fig. 2.  
 
 
Fig.2 State transition illustration 
 
         According this demonstrated simple rule shown in 
Fig.2. Then full description of Convolutional code trellis 
diagram of Figure 1 is presented in Fig.3 below.   
 
Fig.3 Convolutional code trellis diagram, code rate ½, 
constraint length K=3, generators {5, 7}.  
     
         In case increasing constraint length. The number of 
shift registers increased too. The convolutional encoder 
calculations remain in same steps. Take for example 
convolutional encoder with the same code rate of ½, but 
with constraint length increased to K=4. Then the number 
of shift registers rose to 3, Generator polynomials {15, 17} 
see reference [4] for convolutional encoders table.  
 
Fig.4 Convolutional encoder of code rate ½, constraint 
length K = 4, Generator polynomials of {15, 17} octal.   
 
       The transition table gives eight states, as shown in 
Table 2. This increasing in number of states reflected on 
Viterbi decoding complexity.  
         
Table 2. Convolutional encoder transition table illustrate 
calculations of output code C1 and C2, code rate ½, K=4, 
generator {15, 17} octal. 
 
And convolutional encoder trellis had shown in Fig. 5. 
 
Fig.5 Convolutional code trellis diagram, code rate ½, 
constraint length K=4, generators {15, 17}.  
 
        The convolutional encoder parameter denoted by dfree 
[5], refers to convolutional encoder free distance that can be 
interpreted as the minimal length of an erroneous "burst" at 
the output of a convolutional decoder [6]. The fact that 
errors appear as "bursts" should be accounted for when 
designing a concatenated code [7]. If assumed for another 
application an inner convolutional code. The common 
solution for this problem is to interleave data before 
convolutional encoding [8], so that the outer block (such as 
Reed-Solomon) code can correct most of the errors. The 
interleaver also shown in Turbo code application placed 
between two convolutional encoders. In hardware 
implementation of convolutional encoder, FPGA used to 
implement both convolutional encoder and Viterbi decoder 
see references [9] and [10]. Convolutional encoders applied 
in many digital transmission applications, the tested 
convolutional encoders in this paper represent also so called 
mother codes.  
      From which the puncturing process applied to 
convolutional encoders to produce different data rates that 
                                                                                    International Journal of New Technology and Research (IJNTR) 
                                                                              ISSN:2454-4116,  Volume-2, Issue-11, November  2016  Pages 06-12 
                                                                                        8                                                                                  www.ijntr.org 
matched to the needed digital transmission data rates [11].   
III. FORWARD ERROR CONTROL SYSTEM 
The system considered in this paper consist of outer 
convolutional encoder and modulation scheme of QPSK, the 
transmission channel is Additive White Gaussian Noise 
(AWGN), the receiver side use demodulation process then 








Fig. 6, show Forward Error Control System (FEC). 
IV. SIMULATION RESULTS AND DISCUSSION 
The simulation test performed with different convolutional 
encoder‟s rates and constraint lengths, the figures below 
show the simulation results. The simulation program flow 
chart is shown in Fig. 7:-  
 
Fig. 7. Simulation program flow chart. 
 
Simulation  results listed in figures from 8 to 19. 
IV. CONCLUSION 
From simulation results, the increasing constraint length 
with increasing free distance of convolutional encoder show 
improvement in bit error rates BER performance. But this 
improvement in performance come with important 
consideration related to Viterbi decoder complexity growth. 
So the choice of convolutional encoder may take two 
consideration first the application data rates and the second 
the important of the application and its cost. The modulation 
schemes used such as QPSK applied in low data rates where 
16-QAM and 64-QAM are useful with higher data rates 
hence 16-QAM consist of 4 bits per symbol and 64-QAM 6 
bits per symbol. The investigated modulation types represent 
standard modulation types used with modern application such 
as „LTE‟ long term evolution.   
REFERENCES 
[1] Sneha Bawane, V.V. Gohokar “Simulation of Convolutional Encoder,” 
 IJRET: International Journal of Research and Technology, 
Eissn:2319-1163,pissn:2321-7308. 
[2] Mathieu Cluzean, Matthieu Finiasz ,ENESTA, “Reconstruction of 
Punctured Convolutional Codes”, work supported by the French DGA 
in the context of the AINTERCOM contract. 
[3] Mr. Sandesh Y.M, Mr. Kasetty Rambabu, “Implement of 
Convolutional Encoder and Viterbi Decoder for Constraint Length 7 
and Bit Rate ½” Journal of Engineering Research and Applications, 
ISSN: 2248-9622, Vol. 3, Issue 6, Nov-Dec 2013, pp.42-46. 
[4] Dr. Chih-Peng Li” Chapter 10 Convolutional Codes “, WITS LAB 
Wireless Information Transmission System Lab, Institute of 
Communication Engineering, National Sun Yat - Sen University. 
[5] Kenchana Katta “ Design of Convolutional Encoders and Viterbi 
Decoder using MATLAB”, International Journal for Researches 
Science and Technology, Volume – 1, ISSUE-7, December - 2014. 
[6] Alex Balatsoukas-Stimming “Convolutinal Codes”, 
Telecommunication Laboratory , Technical University of Crete, 
November 6th, 2008. 
[7] Daniel J.Costello, Jr Hermano A. Cabral, Oscar Y. Takeshita “ Some 
Thought on the Equivalence of Systematic and Non-Systematic 
Convolutional Encoders”, work supported by NSF grant NCR95-22939 
and NASA grant NAG5-8355, August 2, 2001. 
[8] Sergio Benedetto. Fellw, IEEE, Roberto Garello, Member, IEEE, and 
Guido Montorsi, Member, IEEE “ A Search for Good Convolutional 
Codes to be Used in the Construction of Turbo Codes”IEEE 
Transaction on Communications, Vol. 46, NO. 9. September 1998. 
[9] Shraddha Shukla, Negendra Sah “An Experiment Implementation of 
Convolutional Encoder and Viterbi Decoder by FPGA Emulation”, 
IJAREEIE, International Journal of Advance Research in Electrical, 
Electronics and Instrumentation Engineering, An ISO 3297”2007 
Certified Organization, Vol. 3, ISSUE, May 2014. 
[10]  Yan Sun, Zhizhong Ding, “FPGA Design Implementation of a 
Convolutional Encoder and a Viterbi Decoder Based on 802.11a for 
OFDM”, Scientific Research, Wireless Engineering and Technology , 
2012, 3, 125-131.  
[11]  Melanie Marazin, Roland Gautier and Gilles Burel “ Blind Recovery of 
k/n Rte Convolutional Encoders in a Noisy Environment”, EURASIP 


















Forward Error Control System Performance of Maximum Free Distance Convolutional Codes with Different 
Modulation Schemes  
 
                                                                                9                                                                 www.ijntr.org 
 
Fig. 8. FEC system tested with rate ½ convolutional encoders and QPSK.  
Fig. 9. FEC system tested with rate 1/3 convolutional encoders and QPSK. 
Fig. 10. FEC system tested with rate 1/4 convolutional encoders and QPSK.  
                                                                                    International Journal of New Technology and Research (IJNTR) 
                                                                              ISSN:2454-4116,  Volume-2, Issue-11, November  2016  Pages 06-12 
                                                                                        10                                                                                  www.ijntr.org 
 
Fig. 11. FEC system comparison between different code rates with QPSK   
Fig. 12. FEC system tested with rate 1/2 convolutional encoders and 16-QAM.  
 
Fig. 13. FEC system tested with rate 1/3 convolutional encoders and 16-QAM. 
Forward Error Control System Performance of Maximum Free Distance Convolutional Codes with Different 
Modulation Schemes  
 
                                                                                11                                                                 www.ijntr.org 
 
 
Fig. 14 FEC system tested with rate 1/4 convolutional encoders and 16-QAM. 
Fig. 15. FEC system comparison between different code rates with 16-QAM 
 
Fig. 16. FEC system tested with rate 1/2 convolutional encoders and 64-QAM. 
                                                                                    International Journal of New Technology and Research (IJNTR) 
                                                                              ISSN:2454-4116,  Volume-2, Issue-11, November  2016  Pages 06-12 
                                                                                        12                                                                                  www.ijntr.org 
Fig. 17. FEC system tested with rate 1/3 convolutional encoders and 64-QAM. 
Fig. 18. FEC system tested with rate 1/4 convolutional encoders and 64-QAM. 
 
Fig. 19. FEC system comparison between different code rates with 64-QAM   
 
