汉明距离讲解

汉明距离的计算

码字A为 10001001
码字B为 10110001
那么不同的字符数为3,汉明距离就是3

不难看出,汉明距离就是两个码不同的数的个数。

最小汉明距离

在一个码组集合中,任意两个码字之间对应位上码元取值不同的位的数目定义为这两个码字之间的汉明距离。即
d(x,y)= ∑ x i ⊕ y i \sum{x_i} \oplus {y_i} xiyi
这里i=0,1,…n-1,x,y都是n位的编码,⊕表示异或
例如:(00)与(01)的距离是1,(110)和(101)的距离是2。在一个码组集合中,任意两个编码之间汉明距离的最小值称为这个码组的最小汉明距离。最小汉明距离越大,码组越具有抗干扰能力。
下面我们用d表示码组的最小汉明距离。

  1. 当码组用于检测错误时,设可检测e个位的错误,则 d ≥ e + 1 d \geq e+1 de+1
    \quad 设有两个距离为d的码字A和B,如果A出现了e个错误,则A变成了以A为圆心,e位半径的球体表面的码字。为了能够准确地分辨出这些码字既不是A也不是B,那么A误码后变成的球面上的点与B至少应该有一位距离(如果B在球面上或在球面内部则无法分辨出到底B是不是A的错误码),即A与B之间的最小距离 d ≥ e + 1 d \geq e+1 de+1
  2. 若码组用于纠错,设可纠错t个位的错误,则 d ≥ 2 ∗ t + 1 d \geq 2*t+1 d2t+1
    \quad 设有码字A和B,如果A出现了t个错误,B也出现了t各错误,则A码变成以A为圆心,t为半径的球面上的码字;B码变成以B为圆心,t为半径的球面上的码字。为了在出现t个错之后仍能分辨一个码字到底是属于A的错码还是属于B的错码,A,B为球心的两个球面应该不相交,即球心A,B之间距离应该大于2t,所以d>=2t+1。
  3. 如果码组用于纠正t个错,检测e个错,则 d ≥ e + t + 1 d \geq e+t+1 de+t+1
    \quad 这里e>t,这种检错纠错方式结合的情况同上述两个情况类似。当码字出现t个或者小于t个错时,系统按照纠错方式工作。当码字出现超过t个错而小于等于e个错时,系统按照检错方式工作;当A出现e个错,B出现t个错时,既要纠正B的错,又要发现A的错,则以A为球心,e为半径的球和以B为球心,t为半径的球应该不相交,所以A,B之间的距离应该大于等于e+t+1,即 d ≥ e + t + 1 d \geq e+t+1 de+t+1

汉明距离纠错

n位的码字可以用n维空间的超立方体的一个顶点来表示。两个码字之间的汉明距离就是超立方体两个顶点之间的一条边,而且是这两个顶点之间的最短距离。

在这里插入图片描述
以这张图为例,n=3时,三维的正方体。
需要纠错时,码表如图二所示,包含{000,011,101,110}这四个码,当且仅当出现1位错误时,都可以检测出来,而需要查出是哪个出错了就略显麻烦。

于是需要图三,只包含{001,110}两个码,如果错误位数是1的话,那么它原来的就是距离它最近的那个码,这一点是可以类推到高维的。

例题

在这里插入图片描述
这题因为传输过来的码与 第二个 码汉明距离最小,所以原来就是它了。

参考文献https://baike.baidu.com/item/%E6%B1%89%E6%98%8E%E8%B7%9D%E7%A6%BB/475174?fr=aladdin

  • 24
    点赞
  • 132
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

总想玩世不恭

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值