Chapter 6.

Slides:



Advertisements
Similar presentations
Cyclic Code.
Advertisements

Error Control Code.
II. Linear Block Codes. © Tallal Elshabrawy 2 Last Lecture H Matrix and Calculation of d min Error Detection Capability Error Correction Capability Error.
Information Theory Introduction to Channel Coding Jalal Al Roumy.
Cellular Communications
Chapter 3: Channel Coding (part 1)
Chapter 11 Error-Control CodingChapter 11 : Lecture edition by K.Heikkinen.
DIGITAL COMMUNICATION Coding
Digital Data Communications Techniques Updated: 2/9/2009.
3F4 Error Control Coding Dr. I. J. Wassell.
ChannelCoding Hafiz Malik Dept. of Electrical & Computer Engineering The University of Michigan-Dearborn
DIGITAL COMMUNICATION Error - Correction A.J. Han Vinck.
1 INF244 Textbook: Lin and Costello Lectures (Tu+Th ) covering roughly Chapter 1;Chapters 9-19? Weekly exercises: For your convenience Mandatory.
Channel Coding and Error Control
Channel Coding Part 1: Block Coding
Copyright © 2003, Dr. Dharma P. Agrawal and Dr. Qing-An Zeng. All rights reserved. 1 Chapter 4 Channel Coding.
CHANNEL CODING TECHNIQUES By K.Swaraja Assoc prof MREC
Lecture 10: Error Control Coding I Chapter 8 – Coding and Error Control From: Wireless Communications and Networks by William Stallings, Prentice Hall,
Exercise in the previous class p: the probability that symbols are delivered correctly C: 1 00 → → → → What is the threshold.
Information Coding in noisy channel error protection:-- improve tolerance of errors error detection: --- indicate occurrence of errors. Source.
1 SNS COLLEGE OF ENGINEERING Department of Electronics and Communication Engineering Subject: Digital communication Sem: V Cyclic Codes.
Codes Codes are used for the following purposes: - to detect errors - to correct errors after detection Error Control Coding © Erhan A. Ince Types: -Linear.
MIMO continued and Error Correction Code. 2 by 2 MIMO Now consider we have two transmitting antennas and two receiving antennas. A simple scheme called.
Data and Computer Communications Chapter 6 – Digital Data Communications Techniques.
Data and Computer Communications by William Stallings Eighth Edition Digital Data Communications Techniques Digital Data Communications Techniques Click.
Basic Characteristics of Block Codes
Error Control Code. Widely used in many areas, like communications, DVD, data storage… In communications, because of noise, you can never be sure that.
March 22, 2005Week 10 1 EE521 Analog and Digital Communications James K. Beard, Ph. D. Tuesday, March 22, 2005
Coding Theory. 2 Communication System Channel encoder Source encoder Modulator Demodulator Channel Voice Image Data CRC encoder Interleaver Deinterleaver.
§6 Linear Codes § 6.1 Classification of error control system § 6.2 Channel coding conception § 6.3 The generator and parity-check matrices § 6.5 Hamming.
DIGITAL COMMUNICATIONS Linear Block Codes
TI Cellular Mobile Communication Systems Lecture 4 Engr. Shahryar Saleem Assistant Professor Department of Telecom Engineering University of Engineering.
ADVANTAGE of GENERATOR MATRIX:
Linear Block Code 指導教授:黃文傑 博士 學生:吳濟廷
Chapter 31 INTRODUCTION TO ALGEBRAIC CODING THEORY.
CELLULAR COMMUNICATIONS MIDTERM REVIEW. Representing Oscillations   w is angular frequency    Need two variables to represent a state  Use a single.
Information Theory Linear Block Codes Jalal Al Roumy.
1 Block Coding Messages are made up of k bits. Transmitted packets have n bits, n > k: k-data bits and r-redundant bits. n = k + r.
The parity bits of linear block codes are linear combination of the message. Therefore, we can represent the encoder by a linear system described by matrices.
Error Detection and Correction – Hamming Code
Digital Communications I: Modulation and Coding Course Term Catharina Logothetis Lecture 9.
Hamming Distance & Hamming Code
Error Control Coding. Purpose To detect and correct error(s) that is introduced during transmission of digital signal.
Coding No. 1  Seattle Pacific University Digital Coding Kevin Bolding Electrical Engineering Seattle Pacific University.
Block Coded Modulation Tareq Elhabbash, Yousef Yazji, Mahmoud Amassi.
II. Linear Block Codes. © Tallal Elshabrawy 2 Digital Communication Systems Source of Information User of Information Source Encoder Channel Encoder Modulator.
Channel Coding: Part I Presentation II Irvanda Kurniadi V. ( ) Digital Communication 1.
Digital Communications Chapter 6. Channel Coding: Part 1
Coding and Error Control
Lecture 4 Error Detecting and Correcting Techniques Dr. Ghalib A. Shah
8 Coding Theory Discrete Mathematics: A Concept-based Approach.
The Viterbi Decoding Algorithm
Error Detection and Correction
Subject Name: COMPUTER NETWORKS-1
DATA COMMUNICATION AND NETWORKINGS
Advanced Computer Networks
Digital data communication (Error control)
Subject Name: Information Theory Coding Subject Code: 10EC55
Chapter 6.
II. Linear Block Codes.
Block codes. encodes each message individually into a codeword n is fixed, Input/out belong to alphabet Q of cardinality q. The set of Q-ary n-tuples.
Information Redundancy Fault Tolerant Computing
Standard Array.
DIGITAL COMMUNICATION Coding
Coding and Error Control
II. Linear Block Codes.
CS 325: CS Hardware and Software Organization and Architecture
Error Detection and Correction
Reliability and Channel Coding
Types of Errors Data transmission suffers unpredictable changes because of interference The interference can change the shape of the signal Single-bit.
Presentation transcript:

Chapter 6

Block diagram of a DCS Format Source encode Channel encode Pulse modulate Bandpass modulate Digital modulation Channel Digital demodulation Format Source decode Demod. Sample Channel decode Detect Lecture 9

Channel coding: What is channel coding? Transforming signals to improve communications performance by increasing the robustness against channel impairments (noise, interference, fading, ...) Waveform coding: Transforming waveforms to better waveforms (ex- Make signals antipodal or orthogonal Structured sequences: Transforming data sequences into better sequences, having structured redundancy. Use redundancy (redundant bits) for error detection and correction -“Better” in the sense of making the decision process less subject to errors. Lecture 9

Encoding and Decoding Data block of k-bits is encoded using a defined algorithm into an n-bit codeword • Codeword transmitted • Received n-bit codeword is decoded/detected using a defined algorithm into a k-bit data block 4

Antipodal and Orthogonal Signals – Distance is twice “signal voltage” – Only works for one-dimensional signals Orthogonal – Orthogonal symbol set – Works for 2 to N dimensional signals Lecture 8 5

M-ary Signals Waveform Coding Symbol represents k bits at a time – Symbol selected based on k bits – M waveforms may be transmitted Allow for the tradeoff of error probability for bandwidth efficiency. Orthogonality of k-bit symbols – Number of bits that agree=Number of bits that disagree Lecture 8 6

Hadamard Matrix Orthogonal Codes Start with the data set for one bit and generate a Hadamard code for the data set Lecture 8 7

Hadamard Matrix Orthogonal Codes (2) Symbol represents k bits at a time – Symbol selected based on k bits – M waveforms may be transmitted See Hadamard in MATLAB H4=hadamard(16) H4xcor=H4'*H4=H4*H4' ans = 16*eye(16 Lecture 8 8

Hadamard Matrix Orthogonal Codes (2) The Hadamard Code Set generates orthogonal code for the bit representations Letting 0 = +1V and 1 = -1V For a D-bit pre-coded symbol a 2^D bit symbol is generated from a 2^D x 2^D matrix –Bit rate increases from D-bits/sec to 2^D bits/sec! • For equally likely, equal-energy orthogonal signals, the probability of codeword (symbol) error can be bounded as Lecture 8 9

Biorthogonal Codes Code sets with cross correlation of 0 or -1 Based on Hadamard codes (2-bit data set shown) Lecture 8

Biorthogonal Codes (2) Lecture 8

B3 Example H2=hadamard(4) B3=[H2;-H2] B3*B3' ans = Lecture 8

Biorthogonal Codes (3) Biorthogonal codes require half as many code bits per code word as Hadamard. The required bandwidth would be one-half Due to some antipodal codes, they perform better • For equally likely, equal-energy orthogonal signals, the probability of codeword (symbol) error can be bounded as Lecture 8

Biorthogonal Codes (4) Comparing to Hadamard to Biorthogonal – Note that for D bits, M is ½ the size for Biorthogonal Lecture 8

Biorthogonal Codes (4) Comparing to Hadamard to Biorthogonal – Note that for D bits, M is ½ the size for Biorthogonal Lecture 8

Waveform Coding System Example For a k-bit precoded symbol, one of M generators creates an encoded waveform. • For a Hadamard Code, 2k bits replace the k-bit input Lecture 8

Error control techniques Automatic Repeat reQuest (ARQ) Full-duplex connection, error detection codes The receiver sends feedback to the transmitter, saying that if any error is detected in the received packet or not (Not-Acknowledgement (NACK) and Acknowledgement (ACK), respectively). The transmitter retransmits the previously sent packet if it receives NACK.   Forward Error Correction (FEC) Simplex connection, error correction codes The receiver tries to correct some errors  Hybrid ARQ (ARQ+FEC) Full-duplex, error detection and correction codes Lecture 9

Why using error correction coding? Error performance vs. bandwidth Power vs. bandwidth Data rate vs. bandwidth Capacity vs. bandwidth PB Coded A Coding gain: For a given bit-error probability, the reduction in the Eb/N0 that can be realized through the use of code: F C B D E     E E Uncoded G [dB]  [dB]    b   b [dB]  N0  u  N0  c E / N (dB) b 0 Lecture 9

Types of Error Control Error detection and retransmission Parity bits (ACK and NACK signals) Cyclic redundancy checking Often used when two-way communication used. Also used when low bit-error-rate channels are used. Forward Error Correction –Redundant bits for detection and correction of bit errors incorporated into the sequence Structured sequences. Often used for one-way, noisy channels. Also used for real-time sequences that can not afford retransmission time. Lecture 8

Structured Sequence Encoded sequences with redundancy • Types of codes – Block Codes or Linear Block Codes (Chap. 6) – Convolutional Codes (Chap. 7) – Turbo Codes (Chap. 8) Lecture 8

Channel Models Discrete Memoryless Channel (DMC) – A discrete input alphabet, a discrete output alphabet, and a set of conditional probabilities of conditional outputs given the particular input. • Binary Symmetric Channel – A special case of DMC where the input alphabet and output alphabets consist of binary elements. The conditional probabilities are symmetric p and 1-p. – Hard decisions based on the binary output alphabet performed. • Gaussian Channels – A discrete input alphabet, a continuous output alphabet– Soft decisions based on the continuous output alphabet performed. Lecture 8

Code Rate Redundancy For clock codes, source data is segmented into k bit data blocks. • The k-bits are encoded into larger n-bit blocks. • The additional n -k bits are redundant bits, parity bits, or check bits. • The codes are referred to as (n, k) block codes. – The ratio of redundant to data bits is (n-k)/k. – The ratio of the data bits to total bits, k/n is referred to as the code rate. Therefore a rate ½ code is double the length of the underlying data. Lecture 8

Binary Bit Error Probability Defining the probability of j errors in a block of n symbols/bits where p is the probability of an error. Binomial Probability Law • The probability of j failures in n Bernoulli trials Lecture 8

Code Example Triple Redundancy Encode a 0 or 1 as 000 or 111 – Single bit errors detected and corrected Assume p = 10-3 Lecture 8

Code Example Triple Redundancy Probability of two or more errors Probability of one or no errors If the raw bit error rate of the environment is p=10-3… • The probability of detecting the correct transmitted bit becomes 3*10-6 Lecture 8

Parity-Check Codes Simple parity – single parity check code – Add a single bit to a defined set of bits to force the “sum of bits” to be even (0) or odd (1). – A rate k / (k+1) code – Useful for bit error rate detection • Rectangular Code (also called a Product Code) – Add row and column parity bits to a rectangular set of bits/symbols and a row or column parity bit for the parity row or column. – For an m x n block, (m +1) x (n+1) bits are sent – A rate mn/(m+1)(n+1) code – Correct signal bit errors! Lecture 8

(4,3) Single-Parity-Code (4,3) even-parity code example – 8 legal codewords, 8 “illegal” code words to detect single bit errors – Note: an even number of bit error can not be detected, only odd – The probability of an undetected message error Lecture 8

Rectangular Code Add row and column parity bits to a rectangular set of bits/symbols and a row or column parity bit for the parity row or column • For an m x n block, m+1 x n+1 bits are sent • A rate mn/(m+1)(n+1) code • Correct signal bit errors! – Identify parity error row and column, then fix the “wrong bit” Lecture 8

Rectangular Code Example 5 x 5 bit array → 25 total bits • 6 x 6 encoded array → 36 total bits • • A (36,25) code • Compute probability that there is an undetected error message – The block error or word error becomes: j errors in blocks of n symbols and t the number of bit errors. (note t =1 corrected) Lecture 8

Error-Correction Code Tradeoffs Improve message error/bit error rate performance Tradeoffs – Error performance vs. bandwidth More bits per sec implies more bandwidth – Power Output vs. bandwidth Lowering Eb/No changer BER, to get it back, encode and increase bandwidth If communication needs not be in real time … sending more bits increases BER at the cost of latency! Lecture 8

Coding Gain For a given bit-error probability, the relief or reduction in required Eb/No Lecture 8

Data Rate vs. Bandwidth From previous SNR discussions The tradeoff between Eb/No and bit rate Lecture 8

Linear Block Codes Encodeing a “message space” k-tuple into a “code space” n-tuple with an (n,k) linear block code – maxmize the distance between code words – Use as efficient of an encoding as possible – 2k message vectors are possible (for example M k-tuples to send) – 2n message codes are possible (M n-tuples after encoding) Encoding methodology A giant table lookup. Generators that can span the subspace to create the desired linear independent sets can be defined. Lecture 8

Linear Block Codes We wish to define an n-tuple codeword U where mi are the message bits (k-tuple elements), and Vi are k linearly independent n-tuples that span the space. – This allows us to think of coding as a vector-matrix multiple with m a 1 x k vector and V a k x n matrix • If a generator matrix composed of the elements of V can be defined Lecture 8

Systematic Linear Block Codes The generator preserves part of the message in the resulting codeword P is the parity array and I regenerates the message bits – Lecture 8

Linear Block Codes Example Lecture 8

Systematic Code Vectors Because of the structure of the generators The codeword becomes where p are the parity bits generated for the message m Lecture 8

Linear Block Codes Example Lecture 8

Parity Check Matrix The parity check matrix allows the checking of a codeword – It should be trivial if there are no errors … but if there are?! Syndrome testing m Let the message be I Lecture 8

1 0 0 1 0 1 1 0 1 Parity Check Matrix 1 1 0 1 0 0 0 1 1 0 1 0 0 0 0 1 1 0 1 0 1 1 0 0 1 1 0 1 0 0 0 1 1 0 0 1 0 1 1 1 0 1 1 1 0 1 0 1 1 0 0 H = 0  0 G =   0  1 1  Lecture 8

Encoding Using H Matrix (Parity Check Equations) 1 0 0   1  0 0 1  [v v v v v v v ]1 1 0  = 0 1 0 0   0  1  1 2 3 4 5 6 1 1    1 1    v 0 + v 3 + v 5 + v 6 v1 + v 3 + v 4 + v 5 v 2 + v 4 + v 5 + v 6 = 0 v 0 = v 3 + v 5 + v 6 = 0 ⇒ v1 = v 3 + v 4 + v 5 = 0 v 2 = v 4 + v 5 + v 6 v 0 = u 0 + u 2 + u 3 ⇒ v1 = u 0 + u 1 + u 2 v 2 = u 1 + u 2 + u 3 Lecture 8

Syndrome Testing Describing the received n-tuples of U where e are potential errors in the received matrix As one might expect, use the check matrix to generate a the syndrome of r but from the check matrix if there are no bit errors, the result is a zero matrix! Lecture 8

Syndrome Testing If there are no bit error, the Syndrome results in a 0 matrix • If there are errors, the requirement of a linear block code is to have a one to one mapping between correctable errors and non-zero syndrome results. • Error correction requires the identification of the corresponding syndrome for each of the possible errors. – generate a 2^n x n array representing all possible received n- tuples – this is called the standard array Lecture 8

Standard Array Format (n,k) u1 = 0 u 2 u 3 L u 2k e2 + u1 e2 + u 2 + u 3 L e2 + u 2k e3 + u1 M e3 e3 + u 2k e + u 2n-k 1 e + u 2n-k 2 e + u 2n-k 3 e + u 2n-k 2k The actual codewords are placed in the top row. – The 1st code word is an all zeros codeword. It also defines the 1st coset that has zero errors • Each row is described as a coset with a coset leader describing a particular error. – for an n-tuple, there will be n - k coset leaders, one of which is zero errors. Lecture 8 42

Example of Standard Array Lecture 8 45

Decoding with the Standard Array The n-tuple received can be located somewhere in the standard array. If there is an error, the corrupted codeword is replaced by the codeword at the top of the column. –The standard array contains all possible n-tuples, it is 2n-k x 2k in size; therefore, all n -tuples are represented. – There are 2n-k cosets u 1 = 0 u 2 u 3 L u 2 k e 2 + u 1 e 2 + u 2 + u 3 + u e 3 + u 1 e 3 2 k M M M e + u e + u e + u 2 n -k 1 2 n -k 2 2 n -k 3 M e + u 2 n - k 2 k Lecture 8 46

The Syndrome of a Coset Computing the syndrome of the jth coset for the ith codeword The syndrome is identical for the entire coset – Thus, coset is really a name defined for “a set of numbers having a common feature” The syndrome uniquely defines the error pattern Lecture 8 47

The Syndrome of a Coset Error Pattern Syndrome 0000000 000 1000000 100 For the (7,4) code Error Pattern Syndrome 0000000 000 1000000 100 0100000 010 0010000 001 0001000 110 0000100 011 0000010 111 0000001 101 Lecture 8 48

Error Correct Now that we know that the syndrome identifies a coset, we can identify the coset and perform error correction regardless of the n-tuple transmitted. The procedure Calculate the Syndrome of r Locate the coset leader whose syd4om is identified This is the assumed corruption of a valid n-tuple Form the corrected codeword by “adding” the coset to the corrupted codeword n-tuple. Lecture 8 49

Hardware Implementation Let r = r0 r1 r2 r3 r4 r5 r6 ands = s0 s1 s2 From the H matrix for the (7,4) code: s0 = r0 + r3 + r5 + r6 s1 = r1 + r3 + r4 + r5 s2 = r2 + r4 + r5 + r6 From the table of syndromes and their corresponding correctable error patterns, a truth table can be constructed. A combinational logic circuit with s0 , s1 , s2 as input and e0 , e1 , e2 , e3 , e4 , e5 , e6 as outputs can be designed. Lecture 8 50

Hardware Implementation Error Pattern Syndrome 0000000 000 1000000 100 0100000 010 0010000 001 0001000 110 0000100 011 0000010 111 0000001 101 Lecture 8 51

Hamming Weight and Distance The Hamming weight of a code/codeword defines the performance • The Hamming weight is defined as the number of nonzero elements in U. – for binary, count the number of ones. • The Hamming difference between two codewords, d(U,V), is defined as the number of elements that differ. Lecture 8

Hamming Weight and Distance The Hamming weight of a code/codeword defines the performance • The Hamming weight is defined as the number of nonzero elements in U. – for binary, count the number of ones. • The Hamming difference between two codewords, d(U, V), is defined as the number of elements that differ. Lecture 8

Minimum Distance The minimum Hamming distance is of interest – dmin = 3 for the (6,3) example • Similar to distances between symbols for symbol constellations, the Hamming distance between codewords defines a code effective performance in detecting bit errors and correct them. – maximizing dmin for a set number of redundant bits is desired. – error-correction capability – error-detection capability Lecture 8

Hamming Distance Capability Error-correcting capability, t bits for (6,3) dmin=3: t = 1 – Codes that correct all possible sequences of t or fewer errors may also be able to correct for some t +1 errors. • see the last coset of (6,3) – 2 bit errors! – a t-error-correcting (n,k) linear code is capable of correcting 2n- k error patterns! – an upper bound on the probability of message error is Lecture 8

Hamming Distance Capability Error-detection capability – a block code with a minimum distance of dmin guarantees that all error patterns of dmin - 1 or fewer error can be detected. – for (6,3) dmin=3: e = 2 bits – The code may also be capable of detecting errors of dmin bits. – An (n, k) code is capable of detecting 2n-2k error patterns of length n. There are 2k-1 error patterns that turn one codeword into another and are thereby undetectable. All other patterns should produce non-zero syndrome Therefore we have the desired number of detectable error patterns (6,3)  64-8=56 detectable error patterns Lecture 8

Codeword Weight Distribution The weight distribution involves the number of codewords with any particular Hamming weight – for (6,3) 4 have dmin=3, 3 have d = 4 – If the code is used only for error detection, on a BSC, the probability that the decoder does not detect an error can be computed from the weight distribution of the code. for (6,3) A(0)=1, A(3)=4, A(4)=3, all else A(i)=0 Lecture 8

Visualization of (6,3) Codeword Spaces Lecture 8