汉明码编码原理及校验方法分析

 更新时间:2021年09月16日 11:20:51   作者:祈祷ovo  
汉明码在传输的消息流中插入验证码,当计算机存储或移动数据时,可能会产生数据位错误,以侦测并更正单一比特错误。由于汉明编码简单,它们被广泛应用于内存RAM

1.奇偶校验

我们约定一串编码里1的个数是偶数个,那么这串编码里携带的信息就是对的,否则就是错的。我们可以在开头对这串编码加一位校验码实现奇偶校验。

例子:

我们想传输10010这串码,那么在传输的时候,就传010010,其中在开头的0就是校验位
我们想传输10000这串码,那么在传输的时候,就传110000,其中在开头的1就是校验位
两个例子的1的个数都是偶数。

2.汉明码

首先汉明码是采用奇偶校验的码。它采用了一种非常巧妙的方式,把这串数字分了组,通过分组校验来确定哪一位出现了错误。并且能对错误的位置进行改正

注意:

汉明码默认一串数据只错一位

在这里插入图片描述

汉明码怎么分组:

我们看到,其实有些数据是既在P1组又在P2组的。怎么分组,这个要记住,没啥原理了哈哈。要预先做的工作是,把表示位置的这个数,转化成二进制数,也就是:

第1个位置,变成第0001个位置;

第2个位置,变成第0010个位置;

第3个位置,变成第0011个位置;

第4个位置,变成第0100个位置;

第5个位置,变成第0101个位置;

第6个位置,变成第0110个位置;

那么,规定来了,

凡是位置符合这种形式的,XXX1,归到P1;

凡是位置符合这种形式的,XX1X,归到P2;

凡是位置符合这种形式的,X1XX,归到P3;

凡是位置符合这种形式的,1XXX,归到P4;

那么显然各个校验码也被分到各个组里面去了,而且,每个组只有一个校验码。

我举个例子:

我们想传这一组码:XX1X101X011

一共11位。

标X的是校验码的位置,我们暂时不知道它的值是多少。

位置在1,3,5,7,9,11的数据进到P1组。(你转换一下这些位置的二进制,就知道他们的位置符合XXX1)

位置在2,3,6,7,10,11的数据进到P2组。(位置符合XX1X)

位置在4,5,6,7的数据进到P3组。(位置符合X1XX)

位置在8,9,10,11的数据进到P4组。(位置符合1XXX)

那么确定了分组,校验码的值也就顺便确定下来了。

这样整个串的码就确定下来了。

校验码的位置:

这是规定,记住它,在采用汉明码的一串数据中,2的i次方的位置上,我们放校验码。

校验码是1,或者是0,使得校验码所在的组的1的个数是偶数。

如图:

绿色的位置是放校验码的地方,1,2,4,8,16……等等,2的i次方的地方。

在这里插入图片描述

校验码其实是每一个分组特有的,每个分组特有的也就只有校验码

从发送者的角度,我该怎么发用上汉明码的数据呢:

首先我们考虑我们到底要发多少位。假设校验码一共k位,我们想发的原始数据一共n位,要注意我们的校验码也要校验校验码错没错,所以,要校验的一共有k+n位,k位校验码可以检测2^k位的码,但是不能所以,校验码的位数要满足这个公式

2 k > k + n 2^k>k+n 2k>k+n,或者说 2 k − 1 ≥ k + n 2^{k}-1 \geq k+n 2k−1≥k+n

这样我们就能算出来要用多少校验码了。

其实哈,实际上不用这么麻烦,教科书总是那么复杂。假设你想发101011111,那你就先占下校验位,然后空着的位填你想发的数据就好。

占下1,2,4,8……等等位,看能占下多少位就可以,当然这个手算比较直观啦哈。

好,我假设你填完了,然后分好组,也确定了校验位的值了,那么发送出去啦~

我是接收者,我收到了一串汉明码,怎样用汉明码的性质来检错呢:

1.分组,分好P1,P2,P3……

2.分别对每个组校验,没有错的给它0,有错的给1.

3.记得第一个问题,汉明码的原理吗?你可能会想,3个组,我们可以画3个圈,可是100个组,这个圈可就太难画了啊!

这里有一个等价的方法,hamming真的太聪明了。

把P从大到小排列起来,得到一串1010,

for example:

     组别:         P5   P4   P3   P2   P1

     标志:         1    0     1    0    1

从大到小排列起来,标志排成了一串一零串。这个数就是出错的数据的位置。

本例中,10101位置上的位错了,换成十进制是第21个位置上的数错了。

然后,我们发现了它错误的位置,又因为它是二进制的,不是0就是1,所以,可以顺便把它纠错。

以上就是汉明码编码原理及校验方法分析的详细内容,更多关于汉明码编码及校验的资料请关注脚本之家其它相关文章!

相关文章

  • 史上最好用的远程桌面工具(附源码)

    史上最好用的远程桌面工具(附源码)

    今天给大家分享一款不错的远程控制工具向日葵远程桌面工具,支持多平台,跨网络,对向日葵远程桌面工具感兴趣的朋友跟随小编一起看看吧
    2021-05-05
  • 前端工程Monorepo项目管理方式

    前端工程Monorepo项目管理方式

    这篇文章主要介绍了现代前端越来越离不开的项目管理方式Monorepo的概念、MultiRepo的弊端、Monorepo的收益以及Monorepo的落地这几个角度来认识和学习Monorepo
    2022-07-07
  • 将来会是Python、Java、Golang三足鼎立的局面吗

    将来会是Python、Java、Golang三足鼎立的局面吗

    python的优势在于数据处理和人工智能等方向,所以go只可能吞噬Java的份额,很难撼动Python的奶酪,所以将来会是Python、Java、Golang三足鼎立的局面吗
    2019-04-04
  • 详解DES&3DES算法的原理以及C#和JS的实现

    详解DES&3DES算法的原理以及C#和JS的实现

    DES 全称为 Data Encryption Standard,即数据加密标准,是一种使用密钥加密的块算法。3DES 算法通过对 DES 算法进行改进,增加 DES 的密钥长度来避免类似的攻击。本文就来聊聊它们的原理与实现吧
    2023-03-03
  • 调用DeepSeek API的详细指南

    调用DeepSeek API的详细指南

    章详细介绍了如何在DeepSeek开放平台上获取API密钥,并使用Apifox进行API调试,步骤包括登录平台、创建和保存APIKey、配置Apifox环境变量、导入cURL并设置Authorization、发送请求以及根据需要修改参数实现对话和流式输出,需要的朋友可以参考下
    2025-02-02
  • Maui Blazor 使用摄像头实现代码

    Maui Blazor 使用摄像头实现代码

    由于Maui Blazor中界面是由WebView渲染,所以再使用Android的摄像头时无法去获取,因为原生的摄像头需要绑定界面组件,这篇文章主要介绍了Maui Blazor 使用摄像头实现,需要的朋友可以参考下
    2023-01-01
  • ASCII控制字符的介绍小结

    ASCII控制字符的介绍小结

    ASCII编码中第0-31个字符以及第127个字符都是不可见的,,但是它们都具有一些特殊功能,所以称为控制字符,本文主要介绍了ASCII控制字符的介绍小结
    2024-06-06
  • MobaXterm入门使用教程

    MobaXterm入门使用教程

    MobaXterm就是一款SSH客户端,它帮助我们在Windows操作系统下去连接并操作Linux服务器,本文主要介绍了MobaXterm入门使用教程,感兴趣的可以了解一下
    2023-05-05
  • TypeScript类型检查详谈及火爆原因

    TypeScript类型检查详谈及火爆原因

    这篇文章主要为大家介绍了TypeScript类型检查以及火爆原因,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • vscode中使用Autoprefixer3.0无效的解决方法

    vscode中使用Autoprefixer3.0无效的解决方法

    这篇文章主要介绍了vscode中使用Autoprefixer3.0无效的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06

最新评论