zoukankan      html  css  js  c++  java
  • 海明码

    海明码,又称汉明码,是一种线性纠错码,用于纠正数据。

    奇偶校验

    我们常听的数据校验,莫过于奇偶校验了。

    假设数据传过来01010101, 那么其中有1位作为校验位,如果数据中包含有奇数个1的话,则将奇偶位设定为1;反之,如果数据中有偶数个1的话,则将奇偶位设定为0。

    但是这个显然只能知道出错了,但是无法定位具体是哪一位出错了,因此海明码出现了!

    海明码

    我们用更多的位,作为校验位。

    我们有一个公式(如果我们需要一次传输 n 位数据,那么这时候需要 k 为校验位):2^k - 1 >= n + k

    显然,我们输入 n,我们就能算出 k 的值。

    举个栗子

    例如下图,我们需要传 15 位数据,套上公式(2^k - 1 >= 15 + k), 算出来 k 最小是 5 才满足。

    就是说这个时候,我们需要 5 为校验位;包括数据和校验位,总共会发出去 20 位。

    标志位的位置

    我们看到图中,标绿的地方就是我们的校验位,这些校验位并不是从1号位排到5号位这么简单,而是专门挑选 2^p 位来放置。

    我们把标志位设为 p1、p2、p4、p8、p16

    这是为了让标志位能最大程度地表示出编号:p1 * 2^0 + p2 * 2^1 + p4 *  2^2  + p8 *  2^3 + p16 * 2^4,这 5 个校验位的组合不同,不会出现重复的结果

    如果直接把校验位从1排到5,那就变成这样:p1 * 2^0 + p2 * 2^1 + p4 * (2^0 + 2^1) + p8 *  2^2 + p16 * (2^0 + 2^2),这 5 个校验位的组合不同会出现重复的结果

    标志位的含义

    既然 这 5 个校验位各自表示着 1 个编号位,我们看下图

    p1 代表了 二进制编号中第一位为 1 的位(第1、3、5、7、9、11、13、15、17、19位)

    p2 代表了 二进制编号中第二位为 1 的位(第2、3、6、7、10、11、14、15、18、19位)

    .....

    每一个校验位 px 的值就是对代表的这些位(除掉其中的校验位),进行异或的结果

    p1 =  d1 ⊕ d2  ⊕ d4  ⊕ d5  ⊕ d7  ⊕ d9  ⊕ d11  ⊕ d12  ⊕ d14 

    p2 =  d1 ⊕ d3  ⊕ d4  ⊕ d6  ⊕ d7  ⊕ d10  ⊕ d11  ⊕ d13  ⊕ d14 

    ...

    至此,数据就已经准备好了,可以发送过来了。然而知道现在,我们的主角海明码还没出现 。莫急等我继续说。

    异或

    我们知道异或,是2个2进制位的一种运算,相同取0,不相同取1。

    再算一遍校验位

    我们客户端接收到了上面 1 ~ 20 号的信息,用所有数据位再算一遍,按校验位的策略再算一次校验位,得到 p1'、p2'、p4'、p8'、p16'。

    得到海明码

    s1 = p1' ⊕  p1

    s2 = p2' ⊕  p2

    s3 = p4' ⊕  p4

    s4 = p8' ⊕  p8

    s5 = p16' ⊕  p16

    如果 s1 ~ s5 有出现非0,则表示有数据位出错了。

    而 s1 ~ s5 组成的编号,就是具体出错的那个位了!!

  • 相关阅读:
    【题解】Luogu P2081 [NOI2012]迷失游乐园
    【题解】Luogu P4436 [HNOI/AHOI2018]游戏
    【题解】Luogu P4438 [HNOI/AHOI2018]道路
    【题解】Luogu P1344 [USACO4.4]追查坏牛奶Pollutant Control
    【题解】Luogu P3674 小清新人渣的本愿
    Mysql之数据库存储引擎
    Linux之取消别名设置
    Linux之别名设置
    Mysql之设置用户指定ip地址操作数据库
    Linux之php编译安装5.6
  • 原文地址:https://www.cnblogs.com/amiezhang/p/11471007.html
Copyright © 2011-2022 走看看