Checksums & CRCs Book Pointers
Philip Koopman, Understanding Checksums & Cyclic Redundancy
Codes, 2024, ISBN 9798876380579
Source code with examples:
- --
- --
- https://en.wikipedia.org/wiki/Coding_theory
- --
- --
- --
- --
- --
- --
- --
- --
- --
- --
- --
- --
- https://en.wikipedia.org/wiki/Telephone_exchange_names
- --
- https://en.wikipedia.org/wiki/Hash_function
- --
- https://en.wikipedia.org/wiki/Luhn_algorithm
- --
- --
- https://patents.google.com/patent/US2950048A/en
- https://en.wikipedia.org/wiki/ISBN#ISBN-13_check_digit_calculation
- --
- https://www.wolframalpha.com/input?i=0984449000+isbn
- --
- --
- --
- --
- https://www.cbp.gov/sites/default/files/documents/in_bond_check_1.pdf
- https://en.wikipedia.org/wiki/International_Bank_Account_Number#Modulo_operation_on_IBAN
- --
- https://en.wikipedia.org/wiki/Universal_Product_Code#Check_digit_calculation
- https://en.wikipedia.org/wiki/ABA_routing_transit_number
- https://en.wikipedia.org/wiki/Check_digit
- --
- --
- --
- --
- --
- --
- --
- https://en.wikipedia.org/wiki/Dependability#Threats
- https://en.wikipedia.org/wiki/Probability#Independent_events
- https://www.wolframalpha.com/input?i=f%3D3+%3B+n%3D100+%3B+b%3D1e-6%3B+X%3D%28b**f%29%3B+Y%3D%28%281-b%29**%28n-f%29%29%3B+Z%3Dcombin%28n%2Cf%29%3B++X*Y*Z
- --
- --
- https://en.wikipedia.org/wiki/Hamming_weight
- http://www.pcg-random.org
- https://en.wikipedia.org/wiki/Monte_Carlo_method
- --
- --
- --
- https://en.wikipedia.org/wiki/Hamming_distance
- --
- --
- --
- --
- --
- https://en.wikipedia.org/wiki/Hamming_code
- https://en.wikipedia.org/wiki/Parity_bit
- https://en.wikipedia.org/wiki/Hamming_weight
- https://en.wikipedia.org/wiki/Longitudinal_redundancy_check
- https://en.wikipedia.org/wiki/Adder_(electronics)
- --
- https://en.wikipedia.org/wiki/Two%27s_complement
- --
- https://en.wikipedia.org/wiki/Adder_(electronics)#Adders_supporting_multiple_bits
- https://en.wikipedia.org/wiki/Ones'_complement
https://en.wikipedia.org/wiki/Signed_number_representations
- --
- --
- --
- --
- --
- --
- http://en.wikipedia.org/wiki/Adler-32
- --
- --
- --
- http://en.wikipedia.org/wiki/Adler-32
- --
- https://en.wikipedia.org/wiki/Fletcher%27s_checksum#Caution_on_modulus
- --
- --
- --
- --
- --
- https://www.wolframalpha.com/input?i=0x12345600+mod+0xFD
- https://www.wolframalpha.com/input?i=%28%28%28%28%28%28%28%28%280x12%29*+0x100%29%2B+0x34%29mod+0xFD%29*+0x100%29%2B0x56%29+mod+0xFD%29*+0x100%29%2B+0x00%29+mod+0xFD
- https://www.wolframalpha.com/input?i=%28%28%280x12*0x1000000%29mod+0xFD%29%2B%280x345600%29%29+mod+0xFD
- https://www.wolframalpha.com/input?i=0x7800000000+mod+0xFD
- https://www.wolframalpha.com/input?i=%28%280x78+mod+0xFD%29*0x100000000%29mod+0xFD
- https://www.wolframalpha.com/input?i=%28%28%28%280x78+mod+0xFD%29+*+0x10000%29+mod+0xFD%29+*+0x10000%29+mod+0xFD
- https://www.wolframalpha.com/input?i=%28%28%28%28%28%28%28%280x78+mod+0xFD%29*0x100%29mod+0xFD%29*0x100%29mod0xFD%29*0x100%29mod0xFD%29*0x100%29mod0xFD
- https://www.wolframalpha.com/input?i=0x7800000000+mod+0xFFEF
- https://www.wolframalpha.com/input?i=%28%280x78mod+0xFFEF%29+*+0x10000+mod+0xFFEF%29+*+0x10000+mod+0xFFEF
- https://www.wolframalpha.com/input?i=%28%28%28%280x78mod+0xFFEF%29*0x100mod0xFFEF%29*0x100mod0xFFEF%29*0x100mod0xFFEF%29*0x100mod0xFFEF
- https://www.wolframalpha.com/input?i=%28%28%28%28%28%28%28%280x78mod+0xFFEF%29*0x10mod0xFFEF%29*0x10mod0xFFEF%29*0x10mod0xFFEF%29*0x10mod0xFFEF%29*0x10mod0xFFEF%29*0x10mod0xFFEF%29*0x10mod0xFFEF%29*0x10mod0xFFEF
- --
- --
- https://wolframalpha.com/input?i=0x080200+mod+0xCD
- https://www.wolframalpha.com/input?i=0x1000+mod+0xC3
- --
- --
- --
- --
- --
- --
- --
- https://en.wikipedia.org/wiki/Cyclic_redundancy_check
https://en.wikipedia.org/wiki/Polynomial_long_division
https://en.wikipedia.org/wiki/GF(2)
https://en.wikipedia.org/wiki/Mathematics_of_cyclic_redundancy_checks
- --
- https://en.wikipedia.org/wiki/Byte#History_of_the_conflicting_definitions
- https://en.wikipedia.org/wiki/CAN_bus#Data_frame
- --
- --
- https://en.wikipedia.org/wiki/Finite_field
- --
- --
- A video illustrating this division example can be found here:
https://youtu.be/1t3DacyL5HA and
here:
https://archive.org/details/L600-crc-operation-examples-division-and-shift-register
- https://en.wikipedia.org/wiki/Long_division
- --
- --
- --
- --
- --
- --
- --
- https://users.ece.cmu.edu/~koopman/crc/crc32.html
- https://reveng.sourceforge.io/crc-catalogue/all.htm
- https://en.wikipedia.org/wiki/Endianness
- --
- --
- --
- --
- --
- --
- --
- --
- --
- --
- --
- --
- --
- https://users.ece.cmu.edu/~koopman/crc/crc32.html
- https://www.google.com/search?q=0x17b01bd
- --
- --
- --
- --
- --
- https://www.wolframalpha.com/input?i=factor+%281x**3%2B0x**2%2B0x%2B1%29+over+GF%282%29
- https://www.wolframalpha.com/input?i=factor+x8+%2Bx7+%2Bx6+%2Bx3+%2Bx2+%2Bx+%2B1+over+GF%282%29
- https://www.wolframalpha.com/input?i=factor+x8+%2Bx4+%2Bx3+%2Bx+%2B1+over+GF%282%29
- https://www.wolframalpha.com/input?i=factor+x8%2Bx5%2Bx3%2Bx2%2Bx%2B1+over+GF%282%29
- https://www.wolframalpha.com/input?i=factor+x8+%2Bx5+%2Bx4+%2Bx2+%2Bx+%2B1+over+GF%282%29
- https://www.wolframalpha.com/input?i=factor+x8+%2Bx6+%2Bx3+%2B1+over+GF%282%29
- https://en.wikipedia.org/wiki/Primitive_polynomial_(field_theory)
- https://en.wikipedia.org/wiki/Exponentiation_by_squaring
- https://users.ece.cmu.edu/~koopman/lfsr/
- https://en.wikipedia.org/wiki/Superposition_principle
- --
- --
- --
- https://www.wolframalpha.com/input?i=factor%28x8%2Bx5%2Bx3%2Bx2%2Bx%2B1%29+over+gf%282%29
- https://www.wolframalpha.com/input?i=factor+%28x5%2Bx3%2Bx%2B1%29+over+GF%282%29
- https://www.wolframalpha.com/input?i=k%3D16%3B+2**%28k-1%29+-+k+-+1
- --
- --
- https://en.wikipedia.org/wiki/Mathematics_of_cyclic_redundancy_checks#Reciprocal_polynomials
- --
- --
- --
- --
- --
- https://en.wikipedia.org/wiki/Enumerator_polynomial#MacWilliams_identity
- --
- --
- --
- https://en.wikipedia.org/wiki/CAN_bus
- --
- https://www.wolframalpha.com/input?i=BitXor%5B0x8E%2C0x47%2C0xAD%2C0xD8%2C0x6C%2C0x36%2C0x1B%5D
- --
- https://www.wolframalpha.com/input?i=BitXor%5B0x13d%2C0x1a3%2C0x1ec%2C0x0f6%2C0x07b%5D
- --
- https://en.wikipedia.org/wiki/Binomial_distribution
- --
- --
- https://www.rfc-editor.org/rfc/rfc1624
- --
- --
- https://www.wolframalpha.com/input?i=factor+%28x32%2Bx28%2Bx25%2Bx19%2Bx18%2Bx16%2Bx15%2Bx13%2Bx10%2Bx8%2Bx6%2Bx5%2Bx4%2Bx%2B1%29+over+gf%282%29
- --
- https://en.wikipedia.org/wiki/Big_O_notation
- --
- https://en.wikipedia.org/wiki/Computational_complexity_theory
- https://en.wikipedia.org/wiki/Hash_table
- --
- https://en.wikipedia.org/wiki/Hash_collision
- https://en.wikipedia.org/wiki/Hash_table#Open_addressing
- --
- --
- --
- --
- --
- --
- --
- --
- --
- --
- --
- https://www.wolframalpha.com/input?i=n%3D100%3Bf%3D3%3BB%3D1e-5%3B+++X%3D%28B**f%29%3B+Y%3D%28%281-B%29**%28n-f%29%29%3B+Z%3Dcombination%28n%2Cf%29%3B++X*Y*Z
- https://betterembsw.blogspot.com/2012/02/can-protocol-vulnerabilities.html
- https://www.wolframalpha.com/input?i=n%3D100%3Bf%3D6%3BB%3D1e-2%3B+++X%3D%28B**f%29%3B+Y%3D%28%281-B%29**%28n-f%29%29%3B+Z%3Dcombination%28n%2Cf%29%3B++X*Y*Z++*+1000+*+3600
- https://reveng.sourceforge.io/
- https://en.wikipedia.org/wiki/Cyclic_redundancy_check#Data_integrity
- --
- https://users.ece.cmu.edu/~koopman/ece649/lectures/23_flexray.pdf
- https://en.wikipedia.org/wiki/Train_communication_network
- https://en.wikipedia.org/wiki/CAN_bus#Bit_stuffing
- --
- https://en.wikipedia.org/wiki/8b/10b_encoding
- https://en.wikipedia.org/wiki/64b/66b_encoding
- https://en.wikipedia.org/wiki/Line_code
- --
- https://en.wikipedia.org/wiki/Scrambler#Additive_(synchronous)_scramblers
- --
- --
- https://en.wikipedia.org/wiki/Single-event_upset
- Arazi (1988) https://archive.org/details/commonsenseappro0000araz
- Baicheva et al. (1998)
https://doi.org/10.1016/S0140-3664(98)00165-0
https://www.researchgate.net/publication/222584690_On_the_cyclic_redundancy-check_codes_with_8-bit_redundancy
- Baicheva et al. (2000) https://doi.org/10.1049/ip-com:20000649
https://www.researchgate.net/publication/3350132_On_the_cyclic_redundancy-check_codes_of_16-bit_redundancy
- Barr (1999) https://barrgroup.com/tech-talks/checksums-and-crcs
- Boudreau et al. (1994) https://doi.org/10.1147/rd.386.0651
- Braun & Waldvogel (2001)
https://doi.org/10.1109/HPSR.2001.923602
https://www.researchgate.net/publication/2400251_Fast_incremental_CRC_updates_for_IP_over_ATM_networks
- Castabnoli et al. (1993) https://doi.org/10.1109/26.231911
https://ia600704.us.archive.org/view_archive.php?archive=/24/items/wikipedia-scholarly-sources-corpus/10.1109%252F08IAS.2008.237.zip&file=10.1109%252F26.231911.pdf
- Castagnoli et al. (1990) https://doi.org/10.1109/26.46536
- Cideciyan & Gustlin (2012)
https://grouper.ieee.org/groups/802/3/bj/public/jul12/cideciyan_01_0712.pdf
- Cook (2022) https://reveng.sourceforge.io/ /
https://reveng.sourceforge.io/crc-catalogue/
- Driscoll et al. (2009)
https://www.faa.gov/sites/faa.gov/files/aircraft/air_cert/design_approvals/air_software/AR-09-24.pdf
https://users.ece.cmu.edu/~koopman/pubs/faa09-24_data_network_evaluation_criteria_handbook.pdf
- Feldmeier (1995) https://doi.org/10.1109/90.477710
- Fiorini et al. (1994)
https://dl.acm.org/doi/10.1145/205511.205521
https://www.researchgate.net/publication/234829693_Can_we_trust_in_HDLC
- Fletcher (1982) https://doi.org/10.1109/TCOM.1982.1095369
- Fujiwara et al. (1985) https://doi.org/10.1109/TCOM.1985.1096340
- Fujiwara et al. (1989) https://doi.org/10.1109/26.35380
- Funk (1982) https://doi.org/10.1109/TCOM.1982.1095367
- Funk (1996) https://doi.org/10.1109/26.476086
- Jain (1990) https://doi.org/10.1109/26.58757
- James (2005) http://doi.org/10.17863/CAM.11801
- Jiao & Schwiebert (2001)
https://doi.org/10.1109/ICCCN.2001.956312
- Klove (2007) ISBN-10 9812705864
- Koopman (2002) https://doi.org/10.1109/DSN.2002.1028931
https://users.ece.cmu.edu/~koopman/networks/dsn02/dsn02_koopman.pdf
- Koopman & Chakravarty (2004)
https://doi.org/10.1109/DSN.2004.1311885
- Koopman et al. (2015)
https://users.ece.cmu.edu/~koopman/pubs/faa15_tc-14-49.pdf
- Koopman (2023) https://arxiv.org/abs/2302.13432
- Leung-Yan-Choeng & Hellman (1976)
https://doi.org/10.1109/TIT.1976.1055515
- Leung-Yan-Choeng et al. (1979)
https://doi.org/10.1109/TIT.1979.1055991
- Lin & Costello (1983) ISBN 013283796X
- MacWilliams (1963)
https://doi.org/10.1002/j.1538-7305.1963.tb04003.x
https://archive.org/details/bstj42-1-79
- Maxino & Koopman (2009)
https://doi.org/10.1109/TDSC.2007.70216
https://users.ece.cmu.edu/~koopman/pubs/maxino09_checksums.pdf
- McAuley (1994) https://doi.org/10.1109/90.282604
- Nguyen (2005) https://doi.org/10.1109/TC.2005.7
- Paulitsch et al. (2005) https://doi.org/10.1109/DSN.2005.31
https://users.ece.cmu.edu/~koopman/pubs/paultisch05_dsn_crc_ultradependable.pdf
- Peterson & Brown (1961)
https://doi.org/10.1109/JRPROC.1961.287814
- Plank (2013)
https://www.usenix.org/publications/login/december-2013-volume-38-number-6/erasure-codes-storage-systems-brief-primer
- Peterson & Weldon (1972) ISBN 9780262527316
https://archive.org/details/errorcorrectingc00pete/page/n5/mode/2up
- Ramabadran & Gaitonde (1988) https://doi.org/10.1109/40.7773
- Ray & Koopman (2006) https://doi.org/10.1109/DSN.2006.30
https://users.ece.cmu.edu/~koopman/pubs/ray06_crcalgorithms.pdf
- Sarwate (1988) https://dl.acm.org/doi/10.1145/63030.63037
- Sheinwald et al. (2002) https://datatracker.ietf.org/doc/rfc3385/
- Stone et al. (1998) https://doi.org/10.1109/90.731187
http://ccr.sigcomm.org/archive/1995/conf/partridge.pdf
- Stone & Partridge (2000)
https://doi.org/10.1145/347057.347561
- Sweeney (2002) ISBN 047084356X
- Wells (1998) ISBN 0139613277
- Witzke (1984)
https://open.library.ubc.ca/soa/cIRcle/collections/ubctheses/831/items/1.0096199
- Williams (1993) http://ross.net/crc/download/crc_v3.txt
https://web.archive.org/web/20240203182343/http://ross.net/crc/download/crc_v3.txt
- Youssef et al. (2006) https://doi.org/10.1109/EDCC.2006.5
Changes made to versions as indicated below:
- Version 1.1.1:
- Figures 10.9, 10.10, 10.11: the BER actually shown is 1e-9; caption should
be changed from 1e-6 to 1e-9.
- Version 1.1.2:
- E-book formatting issues; no changes to printed version.
- Version 1.1.3:
- Added to glossary: Longitudinal Redundancy Check (LRC): a
single-sum checksum using an XOR operation rather than integer addition
- Clarification on page 43, Table 4.1 caption: "Gray highlighting is
just for row delineation."
- Clarification on page 149: After "This is slightly awkward because it
frees up two bits in the check value", add "(one bit for each of SumA
and SumB)"
- Clarification on page 150: "One of these is filled with that
calculated parity bit"=> "One of these is filled with a parity bit
calculated over both the data word and rest of the check value"
- Clarification on page 183: "4-byte"=> "4-byte
(32-bit)"
- Clarification on page 183: "23-byte"=> "23-byte
(184-bit)"
- Page 255: 'all an "1"'=> 'an all "1"'
- Pages 274-276, section 10.15.3.2. "BitCount(valuez)
<=2)"=> "BitCount(valuex) <=2)" in outer
loop of code snippets
- Page 296, figure 11.13 caption: "sparce"=> "sparse"
- Version 1.1.4:
- Page 257 top of page: "behavior or shorter."=> "behavior
or shorter for polynomials not divisible by (x+1)."
- Page 294 section 11.4.2: "detect all bursts less than the number of
bits in the check value"=> "detect any single burst fault up to k
bits in length for a k-bit check value"
- Figure 11.11 caption: data is for a 130-byte code word
- All figures in Chapter 11 and figure 12.1: added caption clarification of
"(Lower on vertical axis is better.)"
E-book hints:
- The e-book should view fine on a monochrome display. However, the book
makes extensive use of color, so a color display will provide a better
experience.
- If images seem small or text spacing looks weird, consider switching to
landscape orientation for that portion of the book. (We have converted most
space-sensitive text to images to avoid issues, but on small screens there can
still be some sections where landscape just works better.)
- On some e-book readers pop-up footnotes do not have URL links active. If
you go to the "all footnotes" view the link will be there and will be
active. This is a reader issue and not something that can be fixed in the
e-book itself.
- We have seen some odd number alignment behavior on Lithium viewer, but the
e-book passes the Smashwords validation test and it seems to be an issue with
that viewer rather than the e-book source files.