海明编码实验报告

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

海明编码实验报告

学科专业:计算机科学与技术

姓名:

学号:

指导教师:

天津工业大学计算机科学与技术学院

二零一零年十二月

一.海明编码原理

海明码是一种可以纠正一位差错发现两位差错的编码。它是利用在信息位为k 位,增加r位冗余位,构成一个n=k+r位的码字,然后用r个监督关系式产生的r个校正因子来区分无错和在码字中的n个不同位置的一位错。它必需满足以下关系式:

2r>=n+1 或 2r>=k+r+1

海明码的编码效率为:

R=k/(k+r)

式中 k为信息位位数

r为增加冗余位位数

2.海明码的生成与接收

二.海明编码方法

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分别插于2k位(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)海明码的接收。

例.已知:接收的码字为:"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)=1err=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

(怎么快速计算出数值3是编程的重点)

4)纠错--对码字的第3位值取反得正确码字:

"1 0 1 1 1 0 0 0 1 1 0 0"

5)把位于2k位的冗余码删除得信息码:"1 1 0 0 1 1 0 0" 3)发现两位差错(关键在于如何监测具有两位的错误)

P5=∑(1,2,3,4,5,6,7,8,9,10,11,12)

S5=∑(1,2,3,4,5,6,7,8,9,10,11,12,P5)

如果err≠0且S5=0是两位错

三.程序

import java.applet.*;

import java.awt.*;

import java.awt.event.*;

public class Haiming extends Applet implements ActionListener{ Label fsxx;

Label xybm;

Label xdbm;

Label xdgr;

Label xdym;

Label cc;

Label xyym;

Label sdxx;

TextField tfxx;

TextField txybm;

TextField txdbm;

TextField txdgr;

TextField txdym;

TextField tcc;

TextField txyym;

TextField tsdxx;

public void init(){

fsxx = new Label("发送信息:");

xybm = new Label("信源编码:");

xdbm = new Label("信道编码:");

xdgr = new Label("信道干扰:");

xdym = new Label("信道译码:");

cc = new Label("一/二错:");

xyym = new Label("信源译码:");

sdxx = new Label("收到信息:");

tfxx = new TextField(30);

txybm = new TextField(30);

txdbm = new TextField(30);

txdgr = new TextField(30);

txdym = new TextField(30);

tcc = new TextField(30);

txyym = new TextField(30);

tsdxx = new TextField(30);

setLayout(new GridLayout(8,2));

add(fsxx);add(tfxx);

add(xybm);add(txybm);

add(xdbm);add(txdbm);

add(xdgr);add(txdgr);

add(xdym);add(txdym);

add(cc);add(tcc);

add(xyym);add(txyym);

add(sdxx);add(tsdxx);

tfxx.addActionListener(this);

txdgr.addActionListener(this);

}

public void actionPerformed(ActionEvent e){

String sfsxx,erjz,sxdbm,sxdgr,sxdym;

int sjs,i,count = 0,j = 0,m = 0,count1 = 0,count2 = 0,count3 = 0;

double err = 0,sum = 0;

相关文档
最新文档