校验码——海明码及码距,码距
相关文章:
校验码——码距 https://blog.csdn.net/weixin_44330072/article/details/106860286
校验码——奇偶校验码 https://blog.csdn.net/weixin_44330072/article/details/106859838
校验码——CRC循环冗余校验码 https://blog.csdn.net/weixin_44330072/article/details/106859961
其实校验码就是在码距的原理上产生的,码距越大校验能力,纠错能力越强,所以奇偶校验码、海明码、CRC码究其原理都是利用一系列规则提升一段码字的码距而已。
一、海明校验 (Hamming Code)
我们在前面指出过要能纠正信息字中的单个错误,所需的最小距离为3。实现这种纠正的方法之一是海明码。
海明码是一种多重(复式)奇偶检错系统。它将信息用逻辑形式编码,以便能够检错和纠错。用在海明码中的全部传输码字是由原来的信息和附加的奇偶校验位组成的。每一个这种奇偶位被编在传输码字的特定位置上。实现得合适时,这个系统对于错误的数位无论是原有信息位中的,还是附加校验位中的都能把它分离出来。
推导并使用长度为m位的码字的海明码,所需步骤如下:
1、确定最小的校验位数k,将它们记成、、…、,每个校验位符合不同的奇偶测试规定。
2、原有信息和k个校验位一起编成长为m+k位的新码字。选择k校验位(0或1)以满足必要的奇偶条件。
3、对所接收的信息作所需的k个奇偶检查。
4、如果所有的奇偶检查结果均为正确的,则认为信息无错误。
如果发现有一个或多个错了,则错误的位由这些检查的结果来唯一地确定。
校验位数的位数:
推求海明码时的一项基本考虑是确定所需最少的校验位数k。考虑长度为m位的信息,若附加了k 个校验位,则所发送的总长度为m+k。在接收器中要进行k个奇偶检查,每个检查结果或是真或是伪。这个奇偶检查的结果可以表示成一个k位的二进字,它可以确定最多2k种不同状态。这些状态中必有一个其所有奇偶测试试都是真的,它便是判定信息正确的条件。于是剩下的(2k-1)种状态,可以用来判定误码的位置。于是导出下一关系:
码字格式:
从理论上讲,校验位可放在任何位置,但习惯上校验位被安排在1、2、4、8、…的位置上。
图5列出了m=4,k=3时,信息位和校验位的分布情况。
码字位置
校验位 x x x
信息位 x x x x
复合码字
图5 海明码中校验位和信息位的定位
校验位的确定:
k个校验位是通过对m+k位复合码字进行奇偶校验而确定的。
其中: 位负责校验海明码的第1、3、5、7、…(、、、、…)位,(包括 自己)
负责校验海明码的第2、3、6、7、…(、、、、…)位,(包括 自己)
负责校验海明码的第4、5、6、7、…(、、、、…)位,(包括 自己)
对m=4,k=3,偶校验的例子,只要进行三次偶性测试。这些测试(以A、B、C表示)在图6所示各位的位置上进行。
海明码 | 码位类型 | 海明码下标 | 校验位组 |
1 | |||
2 | |||
3=1+2 | , | ||
4 | |||
5=1+4 | , | ||
6=2+4 | , | ||
7=1+2+4 | ,, |
图6 奇偶校验位置
因此可得到三个校验方程及确定校验位的三个公式:
公式 = ⊕ ⊕ ⊕ = 0 得 = ⊕ ⊕
公式 = ⊕ ⊕ ⊕ = 0 得 = ⊕ ⊕
公式 = ⊕ ⊕ ⊕ = 0 得 = ⊕ ⊕
若四位信息码为1001,利用这三个公式可求得三个校验位P1、P2、P3值。和海明码,如图7则表示了信息码为1001时的海明码编码的全部情况。而图8中则列出了全部16种信息(D1D2D3D4=0000~1111)的海明码。
海明码 | 码位类型 | 信息码 | 校验位 | 编码后的海明码 |
0 | 0 | |||
0 | 0 | |||
1 | 1 | |||
1 | 1 | |||
0 | 0 | |||
0 | 0 | |||
1 | 1 |
图7 四位信息码的海明编码
0 | 0 | 0 | 0 | 0 | 0 | 0 |
1 | 1 | 0 |
1 |
0 | 0 | 1 |
0 | 1 | 0 | 1 | 0 | 1 | 0 |
1 | 0 | 0 | 0 | 0 | 1 | 1 |
1 | 0 | 0 | 1 | 1 | 0 | 0 |
0 | 1 | 0 | 0 | 1 | 0 | 1 |
1 | 1 | 0 | 0 | 1 | 1 | 0 |
0 | 0 | 0 | 1 | 1 | 1 | 1 |
1 | 1 | 1 | 0 | 0 | 0 | 0 |
0 | 0 | 1 | 1 | 0 | 0 | 1 |
1 | 0 | 1 | 1 | 0 | 1 | 0 |
0 | 1 | 1 | 0 | 0 | 1 | 1 |
0 | 1 | 1 | 1 | 1 | 0 | 0 |
1 | 0 | 1 | 0 | 1 | 0 | 1 |
0 | 0 | 1 | 0 | 1 | 1 | 0 |
1 | 1 | 1 | 1 | 1 | 1 | 1 |
图8 未编码信息的海明码
上面是发送方的处理。
在接收方,也可根据这三个校验方程对接收到的信息进行同样的奇偶测试:
= ⊕ ⊕ ⊕ = 0
= ⊕ ⊕ ⊕ = 0
= ⊕ ⊕ ⊕ = 0
若三个校验方程都成立,即方程式右边都等于0,则说明没有错。若不成立即方程式右边不等于 0,说明有错。从三个方程式右边的值,可以判断哪一位出错。例如,如果第3位数字反了,则C=0(此方程没有B3),A=B=1(这两个方程有B3)。可构成二进数CBA,以A为最低有效位,则错误位置就可简单地用二进数CBA=011指出。
同样,若三个方程式右边的值为001,说明第1位出错。若三个方程式右边的值为100,说明第4位出错。
海明码的码距应该是3,所以能纠正1位出错。而奇偶校验码的码距才是2,只能发现1位出错,但不能纠正(不知道那一位错)。无校验的码距是1,它出任何一位出错后还是合法代码,所以也就无法发现出错。
这是关于海明码的经典说法,即码距为3,可以发现2位,或者纠正1位错。应满足2k-1≥m+k。
但在清华的王爱英主编的《计算机组成与结构》(该书已成为国内的权威)中还提出了一种码距为4的海明码,可以发现2位,并且纠正1位错。应满足2(k-1)≥m+k。
由于王爱英书上对这两种概念没有很仔细解释(特别对码距为3的海明码),过渡很突然。有些书简单抄袭时没有仔细消化,所以出现一些概念错。对于一般码距为3的海明码,应该是“可以发现2位,或者纠正1位错”,而不是“可以发现2位,并且纠正1位错”。在试题中出现过类似的错误。
校验码——海明码及码距,码距相关推荐
- 校验码(海明校验,CRC冗余校验,奇偶校验)
循环冗余校验码 CRC码利用生成多项式为k个数据位产生r个校验位进行编码,其编码长度为n=k+r所以又称 (n,k)码. CRC码广泛应用于数据通信领域和磁介质存储系统中. CRC理论非常复杂,一般书 ...
- java 奇偶校验_校验码(海明校验,CRC冗余校验,奇偶校验)
循环冗余校验码 CRC码利用生成多项式为k个数据位产生r个校验位进行编码,其编码长度为n=k+r所以又称 (n,k)码. CRC码广泛应用于数据通信领域和磁介质存储系统中. CRC理论非常复杂,一般书 ...
- 海明检验码和循环冗余校验码
海明校验码: 在原有数据位的情况下增加k位校验位,当某一位校验位出错时会引起相关校验位值的变化,进而判断出错位置 求解步骤: 1.确定检验位个数,需要满足2的k次方大于或等于n+k+1(n为信息位,k ...
- 公民身份号码是一种由18位数字组成的特征组合码,其排列顺序从左至右依次为:6位数字地址码、8位数字出生日期码,3位数字顺序码和1位数字校验码(校验码若为10则用字符X来表示)。编写程序从键盘输入一个
#include <stdio.h> int main() {int add,year,month,day;/*定义地址码,年月日*/int shunxuma;/*定义顺序码*/char ...
- 从本质看海明码——海明码的由来
从本质看海明码--海明码的由来 陈冠斌 1.奇偶校验以及奇偶校验错误率 奇偶校验:每一位(包括校验位)都进行异或运算,结果为0 如x1~x7,y0 (数据位为x1~x7,校验位为y0),则 x1 xo ...
- Android 源码分析之 EventBus 的源码解析
1.EventBus 的使用 1.1 EventBus 简介 EventBus 是一款用于 Android 的事件发布-订阅总线,由 GreenRobot 开发,Gihub 地址是:EventBus. ...
- js 生成二维码_QRcode.js 生成二维码
github官方文档指路:https://github.com/soldair/node-qrcode#options QRcode方法介绍: 这里只介绍后三种常用方法的使用: 1.toCanvas ...
- 【Android 事件分发】ItemTouchHelper 源码分析 ( OnItemTouchListener 事件监听器源码分析 二 )
Android 事件分发 系列文章目录 [Android 事件分发]事件分发源码分析 ( 驱动层通过中断传递事件 | WindowManagerService 向 View 层传递事件 ) [Andr ...
- 【Android 事件分发】ItemTouchHelper 源码分析 ( OnItemTouchListener 事件监听器源码分析 )
Android 事件分发 系列文章目录 [Android 事件分发]事件分发源码分析 ( 驱动层通过中断传递事件 | WindowManagerService 向 View 层传递事件 ) [Andr ...
- 【OkHttp】OkHttp 源码分析 ( OkHttpClient.Builder 构造器源码分析 )
OkHttp 系列文章目录 [OkHttp]OkHttp 简介 ( OkHttp 框架特性 | Http 版本简介 ) [OkHttp]Android 项目导入 OkHttp ( 配置依赖 | 配置 ...
最新文章
- R语言构建回归模型并获取对于新数据预测的预测区间实战:给出预测区间而不是一个具体的预测值、置信区间与预测区间的异同
- 随机密码生成python_每日一课 | Python 中生成 0 到 9 之间的随机整数
- js date 加一天_你不一定了解的js数据类型
- hdu4415 不错的想法题
- 【Python】青少年蓝桥杯_每日一题_7.11_画太阳
- python数据结构 树_python数据结构之二叉树的统计与转换实例
- Redis缓存数据库服务器
- [Flexbox] Using order to rearrange flexbox children
- python解一元三次方程_python/sympy求解矩阵方程的方法
- 时间选择插件ClockPicker
- windows 服务 定时程序 跑不出数据
- JAVA读注册表获取My Document等目录
- Atitit. 提升可读性推荐标准规范解决方案 关于编程语言的v5 docx
- SQL分页查询的写法总结-MySQL、SQL Server、Oracle
- 体验火热的Python抢票神器,先让你50个加速包
- 群雄当立,逐鹿分布(二)Paxos传说之败走拜占庭
- Redis基础:哨兵模式下主节点宕机的自动对应
- 一键检测Linux VPS/服务器配置、IO、国内节点下载测速
- 小白用户的福音——win10系统云重装
- 【allegro 17.4软件操作保姆级教程三】布局操作基础二