- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
 - 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
 - 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
 - 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
 - 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
 - 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
 - 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
 
                        查看更多
                        
                    
                海明码的知识
                    编辑词条海明码
  1.海明码的概念
  海明码是一种可以纠正一位差错的编码。它是利用在信息位为k位,增加r位冗余位,构成一个n=k+r位的码字,然后用r个监督关系式产生的r个校正因子来区分无错和在码字中的n个不同位置的一位错。它必需满足以下关系式:
  2^r=n+1 或 2^r=k+r+1
  海明码的编码效率为:
  R=k/(k+r)
  式中 k为信息位位数
  r为增加冗余位位数 
  2.海明码的生成与接收
  特注:以下的+均代表异或
  方法一:
  1)海明码的生成。
  例1.已知:信息码为:0010。海明码的监督关系式为:
  S2=a2+a4+a5+a6
  S1=a1+a3+a5+a6
  S0=a0+a3+a4+a6
  求:海明码码字。
  解:1)由监督关系式知冗余码为a2a1a0。
  2)冗余码与信息码合成的海明码是:0010a2a1a0。
  设S2=S1=S0=0,由监督关系式得:
  异或运算:
  a2=a4+a5+a6=1
  a1=a3+a5+a6=0
  a0=a3+a4+a6=1
  因此,海明码码字为:0010101
  2)海明码的接收。
  例2.已知:海明码的监督关系式为:
  S2=a2+a4+a5+a6
  S1=a1+a3+a5+a6
  S0=a0+a3+a4+a6
  接收码字为:0011101(n=7)
  求:发送端的信息码。
  解:1)由海明码的监督关系式计算得S2S1S0=011。
  2)由监督关系式可构造出下面错码位置关系表: 
  S2S1S0
  000
  001
  010
  100
  011
  101
  110
  111
  错码位置
  无错
  a0
  a1
  a2
  a3
  a4
  a5
  a6
  3)由S2S1S0=011查表得知错码位置是a3。
  4)纠错--对码字的a3位取反得正确码字:0 0 1 0 1 0 1
  5)把冗余码a2a1a0删除得发送端的信息码:0010
  方法二:(不用查表,方便编程)
  1)海明码的生成(顺序生成法)。
  例3.已知:信息码为: 1 1 0 0 1 1 0 0  (k=8)
  求:海明码码字。
  解:1)把冗余码A、B、C、…,顺序插入信息码中,得海明码
  码字: A B 1 C 1 0 0 D 1 1 0 0 
  码位: 1 2 3 4 5 6 7 8 9 10 11 12 
  其中A,B,C,D分别插于2的k次方位(k=0,1,2,3)。码位分别为1,2,4,8。
  2)冗余码A,B,C,D的线性码位是:(相当于监督关系式)
  A-1,3,5,7,9,11;
  B-2,3,6,7,10,11; 
  C-4,5,6,7,12;(注 5=4+1;6=4+2;7=4+2+1;12=8+4)
  D-8,9,10,11,12。
  3)把线性码位的值的偶校验作为冗余码的值(设冗余码初值为0):
  A=∑(0,1,1,0,1,0)=1
  B=∑(0,1,0,0,1,0)=0
  C=∑(0,1,0,0,0) =1
  D=∑(0,1,1,0,0) =0
  4)海明码为:1 0 1 1 1 0 0 0 1 1 0 0
  2)海明码的接收。
  例4.已知:接收的码字为:1 0 0 1 1 0 0 0 1 1 0 0(k=8)
  求:发送端的信息码。
  解:1)设错误累加器(err)初值=0
  2)求出冗余码的偶校验和,并按码位累加到err中:
  A=∑(1,0,1,0,1,0)=1 err=err+20=1
  B=∑(0,0,0,0,1,0)=1 err=err+21=3
  C=∑(1,1,0,0,0) =0 err=err+0 =3
  D=∑(0,1,1,0,0) =0 err=err+0 =3
  由err≠0可知接收码字有错,
  3)码字的错误位置就是错误累加器(err)的值3。
  4)纠错--对码字的第3位值取反得正确码字:
  1 0 1 1 1 0 0 0 1 1 0 0
  5)把位于2的k次方位的冗余码删除得信息码:1 1 0 0 1 1 0 0 
   
海明码校验 
海明码校验
   海明码是一种多重(复式)奇偶检错系统。它将信息用逻辑形式编码,以便能够检错和纠错。用在海明码中的全部传输码字是由原来的信息和附加的奇偶校验位组成的。每一个这种奇偶位被编在传输码字的特定位置上。实现得合适时,这个系统对于错误的数位无论是原有信息位中的,还是附加校验位中的都能把它分离出来。 
   推导并使用长度为m位的码字的海明码,所需步骤如下: 
   1、确定最小的校验位数k,将它们记成D1、D2、…、Dk,每个校
                
原创力文档
                        

文档评论(0)