海明码编码计算和纠错、CRC校检码计算

一、海明码检错/纠错基本思想

海明码(Hamming Code)是一个能够有多个校验位。具有检測并纠正一位错误代码的纠错码,所以也仅用于信道特性比較好的环境中。如以太局域网。它的检错、纠错基本思想例如以下:
(1)将有效信息按某种规律分成若干组,每组安排一个校验位通过异或运算进行校验。得出详细的校验码
(2)在接收端相同通过异或运算看各组校验结果是否正确,并观察出错的校校组。或者多个出错的校验组的共同校验位。得出详细的出错比特位。
(3)对错误位取反来将其纠正。

二、海明码计算

海明码计算要按下面步骤来进行:计算校验码位数→确定校验码位置→确定校验码
1.计算校检码位数
  计算公式: m + k + 1 ≤ 2k (其中 m 是有效信息位数,k表示加入校检码的位数)

比如:10011101需要的校检码位数?此时,m = 8,带入公式得:8+k+1≤ 2k,所以 k = 4。(怎么算的?枚举,枚举,枚举......_,就是估计带入去算!)。101101100又需要多少位校检码呢?(还是4位)。
2.确定校检码位置
  海明码的校检码的位置必须在2n(n从0开始)。也就是从左边开始第1、2、4、8、16......).
根据第一步我们知道10011101需要4位校检码,那么校检码就在1、2、4、8的位置上。把有效信息按位置填入相应位(不是校检位),校检位暂时留空,于是得到下图:

1 2 3 4 5 6 7 8 9 10 11 12
1 0 0 1 1 1 0 1

3.计算各位校检码
  为了说明先直接画图。
由于是4位校检位,直接写出4位2进制的表。

8 4 2 1
1 0 0 0 1
2 0 0 1 0
3 0 0 1 1
4 0 1 0 0
5 0 1 0 1
6 0 1 1 0
7 0 1 1 1
8 1 0 0 0
9 1 0 0 1
10 1 0 1 0
11 1 0 1 1
12 1 1 0 0
13 1 1 0 1
14 1 1 1 0
15 1 1 1 1

(1)第1位要填什么?从上表找出1这列全1对应的十进制数:1、3、5、7、9、11、13、15(1没有就不算),看第一个表中,3、5、7、9、11中分别是1、0、1、1、0为奇数,所以第一位应该填 1(假设采用偶校检)。
(2)第2位要填什么?从上表找出2这列全1对应的十进制数2、3、6、7、10、11(2没有)再对应第一个表中为10110,数1个数为奇数,所以第二位填 1。
(3)第4位看4这列对应全1的 4、5、6、7、12(4没有)对应第一个表0011,1个个数为偶数,所以填 0。
(4)第8位看8这列对应全1的 8、9、10、11、12(8没有)对应第一个表为1101,所以填 1。
(5)最后校检码为 1101。
(6)将校检码插入信息码

1 2 3 4 5 6 7 8 9 10 11 12
1 1 1 0 0 0 1 1 1 1 0 1

总结:第n位校检码校检的码位,从自己开始校检n位,然后空n位,在校检n位。
例如:
第2位校检2、3、(空)、(空)、6、7、(空)、(空)、10、11 ......
第4位校检4、5、6、7、(空)、(空)、(空)、(空)、12、13、14、15 ......

【例】二进制码 101101100,求它的海明编码?
1.计算k,m = 9,m + k + 1 ≤ 2k,所以k = 4。
2.确定校检码位置:

1 2 3 4 5 6 7 8 9 10 11 12 13
1 0 1 1 0 1 1 0 0

3.确定校检码
(1)第1位,找到(1)、3、5、7、9、11、13位,为101010,1为奇数,填1.
(2)第2位,找到(2)、3、6、7、10、11位,为11111,1为奇数,填1.
(3)第4位,找到(4)、5、6、7、12、13位,为01100,1为偶数,填0.
(4)第8位,找到(8)、9、10、11、12、13、(14)、(15)位、为01100,1为偶数,填0,
(5)校检码为1100.

4.所以插入了校检码的信息码:1110011001100。

三、纠错
  依然根据上面的例题,我们将11位上改为0.也就是:

1 2 3 4 5 6 7 8 9 10 11 12 13
1 1 1 0 0 1 1 0 0 1 0 0 0

<em>由于信息只有13位,下面()中的位数没有,只是为了方便理解其分组</em>

(1)第1位,找到1、3、5、7、9、11、13位,为1101000,1为奇数,错误.
(2)第2位,找到2、3、6、7、10、11位,为111110,1为奇数,错误.
(3)第4位,找到4、5、6、7、12、13、(14)、(15)位,为001100,1为偶数,正确.
(4)第8位,找到8、9、10、11、12、13、(14)、(15)位、为001000,1为奇数,错误。
所以出错位数应该是 1+2+8=11位,将第11位0改为1即可纠正错误!

<h2>三、CRC校检码</h2>

CRC的实现原理十分易于硬件实现,因此被广泛的应用于计算机网络上的差错控制。CRC校验码需根据CRC生成多项式进行。

1.根据多项式确定代码 P 以及R的位数(R位数 = P位数 -1)。
2.在信息 M 后面加 0,加 0 的个数等于 R位数.
3.用 M 对 P 做模2除法(也就是按位做异或)得到余数r。
4.余数 r 不够 R位数,则在高位补0,得到的数即校检码。

异或:0 ⊕ 0 = 0;0 ⊕ 1 = 1;1 ⊕ 0 = 1;1 ⊕ 1 = 0;运算数相同结果为0,不同结果为1

【例】现假设选择的CRC生成多项式为G(X) = X4 + X3 + 1,要求出二进制序列10110011的CRC校验码。
(1)更具多项式确定代码P以及R的位数
多项式为G(X) = X4 + X3 + 1,那么

X4 X3 X2 X1 X0(=1)
1 1 0 0 1

也就是代码P = 11001,P为5位,R位数则为5 - 1 = 4位。
(2)在信息 M 后面加 0,加 0 的个数等于 R位数.
M = 10110011,那么加 4 位 0 后得到 101100110000.
(3)用 M 对 P 做模2除法(由于不关心商多少,直接去掉除法上面商部分_)。

模2除法

(4)将计算出来的CRC校验码添加在原始帧的后面,真正的数据帧为101100110100,再把这个数据帧发送到接收端。
(5)接收端收到数据帧后,用上面选定的除数,用模2除法除去,验证余数是否为0,如果为0,则说明数据帧没有出错。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352