海明码介绍
海明码介绍
概要
在我们日常生活中,很多设备都需要传输和存储数据,比如手机发短信、电脑保存文件、卫星发送照片。可是,数据传输和存储的过程中,经常会出现“小差错”,比如:信号干扰导致传过去的数字发生变化、存储芯片里某个位被意外翻转等等。这些小错误会让信息变得错误甚至没法用。
传统的错误检测方法只能告诉我们“有错”,却不知道错在哪儿,也不能自己修正。那么有没有什么办法除了检错以外还能纠错呢?必须有啊,这就是这篇文档要介绍的海明码。
一、什么是海明码
海明码(Hamming Code)是一种常见的错误检测和纠正码,用于在数据传输过程中检测和纠正错误。它由理查德·海明(Richard Hamming)于1950年提出,具有简单、高效的特点,在计算机通信和存储系统中得到广泛应用。海明码通过在数据中插入冗余位(校验位),使得接收方能够检测到并纠正单个位错误。
海明码的厉害之处就在于,它不仅能发现数据有错,还能准确地找到错在哪一位,然后帮我们把错误自动改正。这样一来,无论是手机、电脑还是卫星,都能更准确地传递和保存信息,让我们的生活更加顺畅和可靠。
二、海明码的基本原理
1. 基本原理
海明码基本思想是分组偶校验,由信息位(n)和校验位(k)组成,海明码的校验位计算公式:2^k >= n+k+1
- 2^k 表示:k 个校验位对应 2^k 种状态
- n + k + 1 表示:n + k 代表任何一位都可能出错,1 代表一种正确的状态
2. 计算海明码的具体步骤
1)确定海明码位数:n+k
2)通过信息位算出校验位:2^k >= n+k+1 已知n的值,计算出k的值
3)安排海明码的位置信息
校验位的位置编号为:2^(k-1),然后将将信息位填入剩余位置
4) 用异或运算算出校验位,得到最终的海明码
三、计算海明码举例
举例:信息位为4,内容为1011,计算出校验位以及海明码
1. 根据公式计算出校验位以及海明码位数
根据海明码的校验位计算公式:2^k >= n+k+1,n为4,k为3,则海明码位数为4+3=7
2. 安排海明码位置信息如下

说明:P表示校验位,D表示数据位
将海明码的位从左往右编号为第1位开始(从 1 开始编号,而不是从 0)。
在这些位中:
2 的幂次位置(即1、2、4、8...)为 校验位(P)
其他位置为信息位(D)
3. 计算校验位对应的二进制数
1)校验位对应各信息位二进制数为 1 的组合:
P1 对应的信息位编号: 3、5、7 (0001 最后一位是1的信息位)
P2 对应的信息位编号: 3、6、7 (0010 倒数第2位是1的信息位)
P3 对应的信息位编号: 5、6、7 (0100 倒数第3位是1的信息位)
2)将各信息位的值进行异或运算,求得校验位的值:
P1 -> 3/5/7-> D1⊕D2⊕D4-> 1⊕0⊕1-> 0
P2 -> 3/6/7-> D1⊕D3⊕D4 -> 1⊕1⊕1 -> 1
P3 -> 5/6/7 -> D2⊕D3⊕D4 -> 0⊕1⊕1-> 0
完善后的海明码位置信息如下:

最终海明码为:0110011

浙公网安备 33010602011771号