实验6-BCH循环码的编码与译码的matlab实现_第1页
实验6-BCH循环码的编码与译码的matlab实现_第2页
实验6-BCH循环码的编码与译码的matlab实现_第3页
实验6-BCH循环码的编码与译码的matlab实现_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、精选优质文档-倾情为你奉上实验6 BCH循环码的编码与译码一、实验内容用VC或Matlab软件编写循环BCH码的编码与译码程序。利用程序对教科书的例题做一个测试。二、实验环境1. 计算机2. Windows 2000 或以上3. Microsoft Visual C+ 6.0 或以上4. Matlab 6.0或以上三、实验目的1. 通过BCH循环码的编码与译码程序的编写,彻底了解并掌握循环BCH的编码与译码原理2. 通过循环BCH码的编码与译码程序的编写,提高编程能力。四、实验要求1. 提前预习实验,认真阅读实验原理以及相应的参考书。2. 对不同信道的进行误码率分析。特别是对称信道,画出误码性

2、能图。即信道误码率与循环汉明码之间的关系。3. 认真填写实验报告。五、实验原理1. 循环BCH的编码与译码原理(略)2. 循环BCH的程序实现。六、实验步骤bch_en_decode.m文件function bch_en_decode() code=bch155 code=code+randerr(5,15,1:3); code=rem(code,2); code=gf(code) %随机产生1-3位错误 decode=debch155(code)end function decode=debch155(code) code=gf(code); M=4; code = gf(code.x,M)

3、; m , n=size(code);decode=; code1=; for i=1:m ;code1=code(i,:); M=code1.m;T2=6;N=15; S = code1* (gf(2,M,code1.prim_poly).(N-1:-1:0'*(1:T2); LambdaX = gf(1 zeros(1,T2),M,code1.prim_poly); Tx = 0 1 zeros(1,T2-1); L=0; for k = 1:T2; LambdaXTemp = LambdaX; Delta = S(k) - LambdaXTemp(1+1:L)*(S(k-1:L)

4、' if Delta.x; LambdaX = LambdaXTemp - Delta*Tx; if 2*L < k; L = k-L; Tx = LambdaXTemp/Delta; end; end; Tx = 0 Tx(1:T2); end; LambdaXValue = LambdaX.x; LambdaX = gf(LambdaXValue(1:max(find(LambdaXValue), M, code1.prim_poly); errLoc_int = roots(LambdaX);errLoc = log(errLoc_int); for i = 1:lengt

5、h(errLoc); errorMag = 1; code1(N-errLoc(i) = code1(N-errLoc(i) - errorMag; end; decode=decode;code1; end; ccode = gf(decode.x); decoded = ccode(:,1:5);end function yout=bch155(x) %定义函数k=5; %信息码位,BCH(15,5)if nargin<1 x2=randint(5,k); n=5; msg=x2 %判断输入信息 ,若未输入,系统自动产生5组信息码,并显示出信息位elseif rem(length(x

6、),k)=0;n=length(x)/k;x2=; %判断msg是否为K的整数倍,并把输入码员分组 for i=0:n-1 x2=x2;x(i*k+1) x(i*k+2) x(i*k+3) x(i*k+4) x(i*k+5); end if rem(length(x),k)>0 %把输入码员补零并分组 x=x,zeros(size(1:k-rem(length(x),k); n=length(x)/k;x2=; for i=0:n-1 x2=x2;x(i*k+1) x(i*k+2) x(i*k+3) x(i*k+4) x(i*k+5); end endendik=eye(5) zeros

7、(5,10); %输入信息码扩展x3=x2*ik;yout=;for i=1:n g=1 0 1 0 0 1 1 0 1 1 1; w,yo=deconv(x3(i,:),g); %产生余式 yo=abs(rem(yo,2); yout=yout;yo;endyout=yout+x3; %产生信息码end运行结果:msg = 1 1 0 1 0 0 1 1 0 1 0 1 0 0 0 1 1 1 0 1 0 0 1 0 0code = 1 1 0 1 0 1 1 0 0 1 0 0 0 1 1 0 1 1 0 1 1 1 0 0 0 0 1 0 1 0 0 1 0 0 0 1 1 1 1 0

8、1 0 1 1 0 1 1 1 0 1 0 1 1 0 0 1 0 0 0 1 0 0 1 0 0 0 1 1 1 1 0 1 0 1 1 code = GF(2) array. Array elements = 1 1 0 1 0 1 0 1 0 1 0 0 0 1 1 0 1 1 1 1 1 1 0 0 0 0 1 0 1 0 0 0 0 0 0 1 1 1 1 0 0 0 1 1 0 1 1 0 0 1 0 1 1 1 0 1 0 0 0 1 0 0 1 1 0 0 1 1 1 1 0 1 0 1 1 decode = GF(24) array. Primitive polynomial = D4+D+1 (19 decimal) Array elements = 1 1 0 1 0 1 1 0 0 1 0 0 0 1

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论