error coding
play

Error Coding Transmission process may introduce errors into a - PowerPoint PPT Presentation

Error Coding Transmission process may introduce errors into a message. Single bit errors versus burst errors Detection: Requires a convention that some messages are invalid Hence requires extra bits An (n,k) code has


  1. Error Coding Transmission process may introduce errors into a  message. Single bit errors versus burst errors  Detection:  Requires a convention that some messages are invalid  Hence requires extra bits  An (n,k) code has codewords of n bits with k data bits and  r = (n-k) redundant check bits Correction  Forward error correction: many related code words map to  the same data word Detect errors and retry transmission 

  2. Parity 1-bit error detection with parity  Add an extra bit to a code to ensure an even (odd) number  of 1s Every code word has an even (odd) number of 1s  111 011 01 11 010 110 Parity Valid Encoding: code words 00 White – invalid 000 10 100 (error) 001 101

  3. Voting 1-bit error correction with voting  Every codeword is transmitted n times  111 011 Voting: 010 110 Valid White – correct to 1 code 0 1 words 000 Blue - correct to 0 100 001 101

  4. Basic Concept: Hamming Distance Hamming distance of two bit  1 0 1 1 0 HD=2 strings = number of bit 1 1 0 1 0 positions in which they differ. If the valid words of a code  have minimum Hamming distance D, then D-1 bit errors can be detected. If the valid words of a code  have minimum Hamming distance D, then [(D-1)/2] bit errors can be corrected.

  5. Examples Parity  111 011 01 11 010 110 Parity Valid Encoding: code words 00 White – invalid 000 10 100 (error) 001 101 Voting  111 011 Voting: 010 110 Valid White – correct to 1 code 0 1 words 000 Blue - correct to 0 100 001 101

  6. Digital Error Detection Techniques Two-dimensional parity  Detects up to 3-bit errors  Good for burst errors  IP checksum  Simple addition  Simple in software  Used as backup to CRC  Cyclic Redundancy Check (CRC)  Powerful mathematics  Tricky in software, simple in hardware  Used in network adapter 

  7. Two-Dimensional Parity Use 1-dimensional parity  Add one bit to a 7-bit code to ensure an  even/odd number of 1s Add 2nd dimension  Add an extra byte to frame  Bits are set to ensure even/odd number of  1s in that position across all bytes in frame Comments  Catches all 1-, 2- and 3-bit and most 4-bit  errors

  8. Two-Dimensional Parity Use 1-dimensional parity  Add one bit to a 7-bit code to ensure an  even/odd number of 1s Add 2nd dimension  0101001 Add an extra byte to frame  1101001 Bits are set to ensure even/odd number of  1s in that position across all bytes in frame Data 1011110 Comments  0001110 Catches all 1-, 2- and 3-bit and most 4-bit  errors 0110100 1011111

  9. Two-Dimensional Parity Use 1-dimensional parity  Add one bit to a 7-bit code to ensure an  Parity even/odd number of 1s Bits Add 2nd dimension  0101001 1 Add an extra byte to frame  1101001 0 Bits are set to ensure even/odd number of  1s in that position across all bytes in frame Data 1011110 1 Comments  0001110 1 Catches all 1-, 2- and 3-bit and most 4-bit  errors 0110100 1 1011111 0 1111011 0 Parity Byte

  10. Internet Checksum Idea  Add up all the words  Transmit the sum  Internet Checksum  Use 1’s complement addition on 16bit codewords  Example  Codewords: -5 -3  1’s complement binary: 1010 1100  1’s complement sum 1000  Comments  Small number of redundant bits  Easy to implement  Not very robust 

  11. IP Checksum u_short cksum(u_short *buf, int count) { register u_long sum = 0; while (count--) { sum += *buf++; if (sum & 0xFFFF0000) { /* carry occurred, so wrap around */ sum &= 0xFFFF; sum++; } } return ~(sum & 0xFFFF); }

  12. Cyclic Redundancy Check (CRC) Goal  Maximize protection, Minimize extra bits  Idea  Add k bits of redundant data to an n-bit message  N-bit message is represented as a n-degree polynomial with each bit in  the message being the corresponding coefficient in the polynomial Example  Message = 10011010  Polynomial  = 1 ∗ x 7 + 0 ∗ x 6 + 0 ∗ x 5 + 1 ∗ x 4 + 1 ∗ x 3 + 0 ∗ x 2 + 1 ∗ x + 0 = x 7 + x 4 + x 3 + x

  13. CRC Select a divisor polynomial C(x) with degree k  Example with k = 3:  C(x) = x 3 + x 2 + 1  Transmit a polynomial P(x) that is evenly divisible  by C(x) P(x) = M(x) + k bits 

  14. CRC - Sender Steps  T(x) = M(x) by x k (zero extending)  Find remainder, R(x), from T(x)/C(x)  P(x) = T(x) – R(x) ⇒ M(x) followed by R(x)  Example  x 7 + x 4 + x 3 + x M(x) = 10011010 =  C(x) = 1101 = x 3 + x 2 + 1  T(x) = 10011010000  R(x) = 101  P(x) = 10011010101 

  15. CRC - Receiver Receive Polynomial P(x) + E(x)  E(x) represents errors  E(x) = 0, implies no errors  Divide (P(x) + E(x)) by C(x)  If result = 0, either  No errors (E(x) = 0, and P(x) is evenly divisible by C(x))  (P(x) + E(x)) is exactly divisible by C(x), error will not be  detected

  16. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message

  17. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 10011010000 Message plus k zeros

  18. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k zeros k + 1 bit check sequence c, equivalent to a degree-k polynomial

  19. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k zeros k + 1 bit check sequence c, equivalent to a degree-k polynomial

  20. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros k + 1 bit check sequence c, equivalent to a degree-k polynomial

  21. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros 1001 k + 1 bit check sequence c, equivalent to a degree-k polynomial

  22. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros 1001 k + 1 bit check 1101 sequence c, equivalent to a degree-k polynomial

  23. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros 1001 k + 1 bit check 1101 sequence c, equivalent to a 1000 degree-k polynomial

  24. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros 1001 k + 1 bit check 1101 sequence c, equivalent to a 1000 1101 degree-k polynomial

  25. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros 1001 k + 1 bit check 1101 sequence c, equivalent to a 1000 1101 degree-k polynomial 1011

  26. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros 1001 k + 1 bit check 1101 sequence c, equivalent to a 1000 1101 degree-k polynomial 1011 1101

  27. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros 1001 k + 1 bit check 1101 sequence c, equivalent to a 1000 1101 degree-k polynomial 1011 1101 1100

  28. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros 1001 k + 1 bit check 1101 sequence c, equivalent to a 1000 1101 degree-k polynomial 1011 1101 1100 1101

  29. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros 1001 k + 1 bit check 1101 sequence c, equivalent to a 1000 1101 degree-k polynomial 1011 1101 1100 1101 1000

  30. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros 1001 k + 1 bit check 1101 sequence c, equivalent to a 1000 1101 degree-k polynomial 1011 1101 1100 1101 1000 1101

  31. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros 1001 k + 1 bit check 1101 sequence c, equivalent to a 1000 1101 degree-k polynomial 1011 1101 1100 1101 1000 1101 101

  32. CRC – Example Encoding C(x) = x 3 + x 2 + 1 = 1101 Generator M(x) = x 7 + x 4 + x 3 + x = 10011010 Message 1101 10011010000 Message plus k 1101 zeros 1001 k + 1 bit check 1101 sequence c, equivalent to a 1000 1101 degree-k polynomial 1011 1101 1100 1101 1000 1101 Remainder 101 m mod c

Download Presentation
Download Policy: The content available on the website is offered to you 'AS IS' for your personal information and use only. It cannot be commercialized, licensed, or distributed on other websites without prior consent from the author. To download a presentation, simply click this link. If you encounter any difficulties during the download process, it's possible that the publisher has removed the file from their server.

Recommend


More recommend