Part 3 Data Link Layer
Chapter 10 Error Detection and Correction Chapter 11 Data Link Control
Chapter 12 Multiple Access
Chapter 13 Wired LANs: Ethernet Chapter 14 Wireless LANs
Chapter 15 Connecting LANs, Backbone Networks, and Virtual LANs Chapter 16 Wireless WANs: Cellular Telephones and Satellite Networks Chapter 17 SONET/SDH
Chapter 10 Error Detection and Correction
1. Introduction 2. Block Coding
3. Linear Block Codes 4. Cyclic Codes
Type of Errors
• An electromagnetic signal is subject to interference from
heat, magnetism, and other forms of electricity
• Single-bit error: 0
1 or 1
0
Single-Bit Error
• Only one bit of a given data unit is changed
Burst Error
• Two or more bits in the data unit have changed
• Burst error does not necessarily mean that the errors occur in consecutive bits
• Most likely to happen in a serial transmission
Redundancy
• Error detection uses the concept of
redundancy
, which
Error Control
• Detection Versus Correction
– Detection: error ? yes or no
– Correction: Need to know the exact number of bits that
are corrupted, and their location in the message
• Forward Error Correction Versus Retransmission
– Retransmission (resending) : Backward error correction
• Coding for redundancy
Modular Arithmetic
• In modulo-N arithmetic, we use only the integers in the range 0 to N-1, inclusive.
Block Coding
• Divide the message into blocks, each of Divide the message into blocks, each of kk bits, called bits, called datawords.datawords.
• Add Add rr redundant bits to each block to make the length n = k + r. The re redundant bits to each block to make the length n = k + r. The re sulting n-bit blocks are called
sulting n-bit blocks are called codewordscodewords • Example: 4B/5B block coding Example:
– k = 4 and n = 5.
Error Detection in Block Coding
• Example:
Error Detection: Example
• Assume the sender encodes the dataword 01 as 011 and sends it to the receiver. Consider the following cases:
1. The receiver receives 011 which is a valid codeword. The receiver extracts the dataword 01 from it.
2. The codeword is corrupted during transmission, and 111 is receive d. This is not a valid codeword and is discarded.
3. The codeword is corrupted during transmission, and 000 is receive d. This is a valid codeword. The receiver incorrectly extracts the d ataword 00. Two corrupted bits have made the error undetectable.
Error Correction in Block Coding
• Example:
Error Correction: Example
• Assume the dataword is 01. The sender creates the codeword 0101 1. The codeword is corrupted during transmission, and 01001 is rec eived. First, the receiver finds that the received codeword is not in t he table. This means an error has occurred. The receiver, assuming that there is only 1 bit corrupted, uses the following strategy to gue ss the correct dataword
1. Comparing the received codeword with the first codeword in the ta ble (01001 versus 00000), the receiver decides that the first codewo rd is not the one that was sent because there are two different bits. (the same for third or fourth one in the table)
Hamming Distance
• The Hamming distance between two words is the number of diff erences between corresponding bits.
• Example: Hamming distance d(10101, 11110) is 3
• The minimum Hamming distance is the smallest Hamming dist ance between all possible pairs in a set of words
Hamming Distance
• Three parameters to define the coding schemes – Codeword size n
– Dataword size k
– The minimum Hamming distance dmin
• Coding scheme C(n, k) with a separate expression for dmin
• Hamming distance and error
– Hamming distance between the received codeword and the sent codeword is the number of bits that are corrupted
• Minimum distance for error detection
Minimum Hamming Distance: Example
• The minimum Hamming distance in Table 10.1 is 2. This code guar antees detection of only a single error.
For example, if the third codeword (101) is sent and one error occu rs, the received codeword does not match any valid codeword. If tw o errors occur, however, the received codeword may match a valid codeword and the errors are not detected.
• In Table 10.2, it has dmin = 3. This code can detect up to two errors.
Geometric Concept for Finding d
minfor Error
Detection
Geometric Concept for Finding d
minfor Error
Correction
Linear Block Codes
•
Almost all block codes used today belong to a subset c
Almost all block codes used today belong to a subset c
alled linear block codes.
alled linear block codes.
•
A linear block code is a code in which the exclusive O
A linear block code is a code in which the exclusive O
R (addition modulo-2) of two valid codewords creates
R (addition modulo-2) of two valid codewords creates
another valid codeword
another valid codeword
•
The minimum Hamming distance is the number of 1s i
The minimum Hamming distance is the number of 1s i
n the nonzero valid codeword with the smallest numbe
n the nonzero valid codeword with the smallest numbe
r of 1s
Linear Block Code: Parity-Check Code
Encoder and Decoder for Parity-Check Code
Linear Block Code: Hamming Code
Hamming Code
• rr00 = a = a22 + a + a11 + a + a00 modulo-2modulo-2 • rr11 = a = a33 + a + a22 + a + a11 modulo-2modulo-2 • rr22 = a = a11 + a + a00 + a + a33 modulo-2modulo-2
Logical Decision by Decoder
• Let us trace the path of three datawords from the sender to the desti nation:
1 The dataword 0100 becomes the codeword 0100011. The codeword 0100011 is received. The syndrome is 000, the final dataword is 01 00.
2. The dataword 0111 becomes the codeword 0111001. The codeword 0011001 received. The syndrome is 011. After flipping b2 (changin g the 1 to 0), the final dataword is 0111.
Cyclic Code: CRC
• Cyclic codes are special linear block codes with one extra property.Cyclic codes are special linear block codes with one extra property. • If a codeword is cyclically shifted (rotated), the result is another If a codeword is cyclically shifted (rotated), the result is another
codeword
codeword
Hardware Implementation
• One of the advantages of CRC is that the encoder/decoder can easily and cheaply be implemented in hardware
Hardware Implementation: Divisor
1. The divisor is repeatedly XORed with part of the dividend
2. The divisor has n – k + 1 bits which either are predefined or are all 0s 3. Only n – k bits of the divisor is needed in the XOR operation. The left
Simulate the Division Process in Hardware
1. We assume that the remainder is originally all 0s
2. AT each time click (arrival of 1 bit from augmented dataword), we repeat the following two actions a. We use the leftmost bit to make a decision about the divisor
CRC Encoder Design Using Shift Registers
• Simplification
– We do not need to keep the intermediate values of the
remainder bits; only the final bits. We need only 3 registers instead of 24
Polynomials
• Degree of a polynomial: the highest power in the polynomial
Polynomial Operation
• Adding and subtracting polynomials
(x
5+ x
4+ x
2) + (x
6+ x
4+ x
2)
x
6+ x
5• Multiplying two polynomials
(x
5+ x
3+ x
2+ x) (x
2+ x
1+ 1)
= x
7+ x
6+ x
5+x
5+ x
4+ x
3+
x
4+ x
3+ x
2+ x
3+ x
2+ x
=x
7+ x
6+ x
3+ x
• Dividing one polynomial by another
• Shifting
Shifting left 3 bits: 10011 becomes 10011000
CRC Division Using Polynomials
Cyclic Code Analysis
• f(x) is a polynomial with binary coefficients
Dataword: d(x) Codeword: c(x) Generator: g(x)
Syndrome: s(x) Error: e(x)
• In a cyclic code,
1. If s(x) ≠ 0, one or more bits is corrupted. 2. If s(x) = 0, either
a. No bit is corrupted. Or
b. Some bits are corrupted, but the decoder failed to detect them • Received codeword = c(x) + e(x)
Received codeword/g(x) = c(x)/g(x) + e(x)/g(x)
Error Detection
• Single-bit error
If the generator has more than one term and the coefficient of x0 is 1,
all single errors can be caught.
• Two isolated single-bit error
If a generator cannot divide xt + 1 (t between 0 and n – 1), then all iso
Example 1
• Which of the following g(x) values guarantees that a single-bit error is caught? For each case, what is the error that cannot be caught?
a. x + 1 b. x3 c. 1
Solution
a. No xi can be divisible by x + 1. Any single-bit error can be caught. b. If i is equal to or greater than 3, xi is divisible by g(x). All single-bit e
rrors in positions 1 to 3 are caught.
Example 2
• Find the status of the following generators related to two isolated, sin gle-bit errors.
a. x + 1 b. x4 + 1 c. x7 + x 6+ 1 d. x15 + x14 + 1
Solution
a. This is a very poor choice for a generator. Any two errors next to eac h other cannot be detected.
b. This generator cannot detect two errors that are four positions apart. c. This is a good choice for this purpose.
Error Detection
• Odd numbers of errors
A generator that contains a factor of x + 1 can detect all odd-numbered errors
• Burst errors
❏ All burst errors with L ≤ r will be detected.
❏ All burst errors with L = r + 1 will be detected with probability 1 – (1/2)r–1.
Example 3
• Find the suitability of the following generators in relation to burst errors of different lengths.
a. x6 + 1 b. x18 + x7 + x + 1 c. x32 + x23 + x7 + 1
Solution
a. This generator can detect all burst errors with a length less than or equal to 6 bits; 3 out of 100 burst errors with length 7 will slip by; 16 out of 1000 burst errors of length 8 or more will slip by.
Summary and Standard Polynomials
• A good polynomial generator needs to have the following characteristi cs:
1. It should have at least two terms.
2. The coefficient of the term x0 should be 1.
3. It should not divide xt + 1, for t between 2 and n − 1.
Checksum
• Tendency is to replace the checksum with a CRC
• Not as strong as CRC in error-checking capability
• One’s complement arithmetic
– We can represent unsigned numbers between 0 and
2
n– 1 using only n bits
– If the number has more than n bits, the extra leftmost
bits need to be added to the n rightmost bits
(wrapping)
Checksum: Example
Internet Checksum
Sender site:
1. The message is divided into 16-bit words. 2. The value of the checksum word is set to 0.
3. All words including the checksum are added using one’s complement addition.
4. The sum is complemented and becomes the checksum. 5. The checksum is sent with the data.
Receiver site:
1. The message (including checksum) is divided into 16-bit words. 2. All words are added using one’s complement addition.