Download presentation
Presentation is loading. Please wait.
Published byCecil Benson Modified over 9 years ago
1
EEC4113 Data Communication & Multimedia System Chapter 5: Error Control by Muhazam Mustapha, October 2011
2
Learning Outcome By the end of this chapter, students are expected to be able to mathematically understand and explain the various methods in error detections and corrections.
3
Chapter Content Type of Error Error Detection Error Correction
4
Type of Errors CO1
5
Types of Errors In digital transmission systems, an error occurs when a bit is altered between transmission and reception. –Binary 1 was transmitted but binary 0 is received, or vice versa. 2 general types of errors can occur: –Single bit errors –Burst errors CO1
6
Single Bit Error Isolated error condition. Alters one bit but does not affect nearby bits. Usually due to white noise. 0000001000001010 0 changed to 1 SentReceived CO1
7
Burst Error Contiguous sequence of bits The first and last bits and any number of intermediate bits are received in error 0100010001000011 Sent Received 0101110101000011 Bits corrupted by burst error Length of burst error (5 bits) CO1
8
Burst Error More common more difficult to deal with Can be caused by impulse noise & fading Effects of burst error are greater at higher data rates –Consider an impulse noise event of 1μs occurs At a data rate of 10 Mbps, resulting error burst is 10 bits At a data rate of 100 Mbps, resulting error burst is 100 bits CO1
9
Burst Error For reliable communication, error must be detected and corrected. Additional bits added by transmitter for error detection purposes at receiver –Called REDUNDANCY Some methods of error detection: –Parity Check –CRC CO1
10
Error Detection CO2
11
Parity Check Also known as Vertical Redundancy Check Single parity bit is attached to the bit stream to maintain either odd or even number of 1-s Example, for bit stream of 00110011 –Even parity: 0 00110011 –Odd parity: 1 00110011 CO2
12
Parity Check By convention, even parity is used for synchronous transmission and odd is for asynchronous. Even number of bit errors can never be detected. Most error are long enough to constitute more than just 1 bit – parity check is hardly enough CO2
13
Longitudinal Redundancy Check Data is arranged in rows and columns An extra row added containing column wise parity bits The LRC row is transmitted following the data rows. Since it contains parity check for bits at distance more than 1 bits, LRC is able to detect burst error. CO2
14
Longitudinal Redundancy Check 11100111 11011101 00111001 10101001 LRC (even parity) 10101010 11100111 11011101 00111001 10101001 10101010 send out CO2
15
Cyclic Redundancy Check (CRC) Most common, most powerful, error- detecting code CRC is used for detection of a single error, more than single error and burst error (when two or more consecutive bits in frame have changed) CRC uses modulo-2 addition to compute the Frame Check Sequence (FCS) CO2
16
Cyclic Redundancy Check (CRC) Modulo-2 arithmetic uses binary addition and subtraction without carry – which reduce to XOR operation. Example: 1111 + 1010 0101 1111 − 0101 1010 11001 × 11 11001 11001 101011 CO2
17
Cyclic Redundancy Check (CRC) Structure: T= Transmitted frame= n bits D= Data= k bits F= Frame Check Sequence (FCS)= n-k bits P= Predetermined divisor= n-k+1 bits FCSData Transmitted Frame k bits n bits n-k bits CO2
18
Cyclic Redundancy Check (CRC) At sender: –2 n−k D / P is computed using modulo-2 arithmetic, and the remainder is kept as F –Transmit data as 2 n−k D + F = T At receiver: –The received data T is divided by P using modulo-2 arithmetic. –If there is no remainder, then there is no error, otherwise there is. CO2
19
Cyclic Redundancy Check (CRC) Message, D = 1010001101 Pattern, P = 110101 Length of F = Length of P − 1 = 5 bits = n−k Hence 2 n−k D = 101000110100000 Compute 2 n−k D / P using modulo-2 arithmetic, then take the remainder as F (next slide) Example: CO2
20
Cyclic Redundancy Check (CRC) Example (cont): 1 0 1 0 0 0 1 1 0 1 0 0 0 0 0 1 1 0 1 0 1 1 1 1 0 1 1 1 1 0 1 0 1 1 1 1 0 1 0 1 1 0 1 0 1 1 1 1 1 1 0 1 1 0 1 0 1 1 0 1 1 0 0 1 1 0 1 0 1 1 1 0 0 1 0 1 1 0 1 0 1 0 1 1 1 0 1 1 0 1 0 1 0 1 1 0 Remainder (F) CO2
21
Cyclic Redundancy Check (CRC) The transmitted data is then, T = 2 n−k D + F Example (cont): 1 0 1 0 0 0 1 1 0 1 0 0 0 0 0 0 1 1 1 0 + 1 0 1 0 0 0 1 1 0 1 0 1 1 1 0 T CO2
22
Cyclic Redundancy Check (CRC) Example (cont): At receiver 1 0 1 0 0 0 1 1 0 1 0 1 1 1 0 1 1 0 1 0 1 1 1 1 0 1 1 1 1 0 1 0 1 1 1 1 0 1 0 1 1 0 1 0 1 1 1 1 1 1 0 1 1 0 1 0 1 1 0 1 1 1 1 1 1 0 1 0 1 0 0 0 0 0 1 1 0 1 0 1 0 1 1 0 Zero remainder CO2
23
CRC Pattern Convention The pattern (divisor) is often represented as polynomial instead of binaries. –For P = 1101101 x 6 +x 5 +x 3 +x 2 +1 Some standard polynomials in IEEE and ITU: –CRC-12 = x 12 +x 11 +x 3 +x 2 +x+1 –CRC-16 = x 16 +x 15 +x 2 +1 –CRC-CCITT = x 16 +x 12 +x 5 +1 –CRC-32 = x 32 +x 26 +x 23 +x 22 +x 16 +x 11 +x 10 +x 8 +x 7 +x 5 +x 4 +x 2 +x+1 CO1
24
Error Correction CO2
25
Error Correction In ARQ protocol, if errors detected, the only way to correct it is by re-sending. In some application this is not appropriate. Furthermore, if the sliding window is too small, the ARQ easily reduces to Stop- and-Wait and time is wasted waiting for time-out. CO2
26
Error Correction Re-transmission is costly in some application: –In high error rate environment, e.g. wireless link, this means many re-transmission –In long propagation delay link, e.g. satellite link, this means much longer wait Hence the need for error correcting codes. CO2
27
Error Correction Process At sender, the data will be added with forward error correction (FEC) code. At receiver, the data with FEC will be decoded with any of the following case: –No error detected –Error detected and correctable –Error detected but not correctable –Some error could not even be caught CO2
28
Error Correction Process Some error correcting schemes: –Multidimensional parity check (e.g. LRC) –Hamming Code –Reed-Solomon Code –Reed-Muller Code CO2
29
Multidimensional Parity Check LRC (2 dimensional) can be used to develop error correcting code. In each row there would be a parity check attached. An extra parity row would be added as normal. Any single bit error would be able to be corrected by checking the mismatch parity in row and column. CO2
30
LRC Error Correction 11100111 11011101 00101000 10101001 LRC (even parity) 10111011 even parity SENDER RECEIVER 11100111 11011101 00001000 10101001 10111011 error bit CO2
31
Hamming Code At sender: Frame bits are numbered starting from 1 Bit locations with only one binary 1 in its binary form is filled in with parity bits Other locations will be filled with data bits The parity bits will match the parity of the bits at locations with binary form having the binary 1 at same location. CO2
32
Hamming Code Data to send: 1001101 BitBit position Bit position (binary) Bit type 110001Parity 020010Parity 130011Data 040100Parity 050101Data 160110Data 170111Data 181000Parity 091001Data 0101010Data 1111011Data Even Parity Actual Frame sent: 10011100101 CO2
33
Hamming Code At receiver: The re-matched parities are the respective positions. Syndrome: –If the re-matching results in 0000, then there is no error –If the re-matching results in a bit location with one binary 1, then error is in parity location – ignore –If the re-matching results in a bit location with more than one binary 1, then error is in data location – toggle the error –If the re-matching results in a bit location beyond the used locations, then the error is not correctable CO2
34
Hamming Code At receiver BitBit position Bit position (binary) Bit type 110001Parity 020010Parity 130011Data 040100Parity 050101Data 060110Data 170111Data 181000Parity 091001Data 0101010Data 1111011Data Parity re-matching error 0110 Error at bit 6 CO2
Similar presentations
© 2024 SlidePlayer.com Inc.
All rights reserved.