《信息论》实验指导书—-应用MATLAB软件实现(共25页).doc
《《信息论》实验指导书—-应用MATLAB软件实现(共25页).doc》由会员分享,可在线阅读,更多相关《《信息论》实验指导书—-应用MATLAB软件实现(共25页).doc(25页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上 信息与编码理论上机实验指导书 应用MATLAB软件实现 UPC通信工程系前 言 本实验系列是采用MATLAB软件,主要针对信息论基础课程中的相关内容进行的实验。 MATLAB是一完整的并可扩展的计算机环境,是一种进行科学和工程计算的交互式程序语言。它的基本数据单元是不需要制定维数的矩阵,它可直接用于表达数学的算式和技术概念,解决同样的数值计算问题,使用MATLAB要比使用Basic、Fortran和C语言等提高效率许多倍。MATLAB还是一种有利的教学工具,在大学的线性代数课程以及其它领域的高一级课程的教学中,已称为标准的教学工具。 该指导书共安排了4个实验,现就一
2、些情况作简要说明:各实验要求学生在MATLAB系统上尽量独立完成,弄懂。实验内容紧扣课程教学内容的各主要基本概念,希望同学们在完成每个实验后,对所学的内容起到巩固和加深理解的作用。每个实验做完后必须交一份实验报告。恳请各位实验老师和同学在实验中提出宝贵意见,以利于以后改进提高。 目 录 实验一 离散信源及其信息测度.3实验二 离散信道及其容量.6实验三 无失真信源编码.8实验四 有噪信道编码.10附录 部分常用MATLAB命令.12实验一 离散信源及其信息测度一、实验目的离散无记忆信源是一种最简单且最重要的信源,可以用完备的离散型概率空间来描述。本实验通过计算给定的信源的熵,加深对信源及其扩展
3、信源的熵的概念的理解。二、实验环境windows XP,MATLAB 三、实验原理信源输出的各消息的自信息量的数学期望为信源的信息熵,表达式如下 信源熵是信源的统计平均不确定性的描述,是概率函数的函数。四、实验内容 1、有条100字符英文信息,假定其中每字符从26个英文字母和1个空格中等概选取,那么每条信息提供的信息量为多少?若将27个字符分为三类,9个出现概率占2/7,13个出现概率占4/7,5个出现占1/7,而每类中符号出现等概,求该字符信源的信息熵。 2、二进制通信系统使用0、1,由于存在失真,传输会产生误码,用符号表示下列事件:u0:一个0发出;u1:一个1发出;v0:一个0收到;v1
4、:一个1收到;给定下列概率:p(u0)=1/2,p(v0|u0)=3/4,p(v0|u1)=1/2。求:(a)已知发出一个0,求收到符号后得到的信息量;(b)已知发出的符号,求收到符号后得到的信息量; 3、给定离散无记忆信源X,其概率空间为 求该信源的熵和其二次、三次扩展信源的熵。(编写一M函数文件:function H_X1,H_X2,H_X3=t03(X1,P1)%t03 求信源和其二次、三次扩展信源的熵%输入为X1,P1,分别为信源符号和概率阵%输出为原离散信源的熵H_X1和二次、三次扩展信源的熵H_X2、H_X3 4、某离散二维平稳信源的概率空间:X1X2P00 01 02 10 11
5、 12 20 21 221/4 1/18 0 1/18 1/3 1/18 0 1/18 7/36= 设发出的符号只与前一个符号有关。求:(a)认为信源符号之间无依赖性时,信源X的信息熵H(X);(b)认为有依赖性时的条件熵H(X2X1);(c)联合熵H(X1X2);(d)根据以上三者之间的关系,验证结果的正确性。 5、有两个二元随机变量X和Y,它们的联合概率分布函数如下表: Y X01 01/8 3/81 3/8 1/8同时定义另一随机变量Z=X*Y,试求:a、熵H(X),H(Z),H(X,Z)和H(X,Y,Z);b、条件熵H(X|Y),H(X|Z),H(Y|X,Z);c、互信息I(X;Y),
6、I(X;Z),I(X;Y|Z); 五、实验过程每个实验项目包括:1)设计思路2)实验中出现的问题及解决方法;1)设计思路1、每字符从26 个英文字母和1 个空格中等概选取,一共100 个字符,那么可以组成27100 条消息,每条消息出现的概率是1/(27100),由自信息量公式可得每条消息的自信息量。2、求出各种条件概率,将其代入信息量公式计算信息量。3、离散无记忆信源X 熵,可将其概率代入信息熵的计算公式得到,二次,三次扩展信源,可先求出其概率空间。4.由离散二维平稳信源的概率空间,及信息熵,条件熵,联合熵的公式,可得到我们要的结果。5、计算各种情况的概率,X 的概率,Y 的概率,Z=XY
7、联合概率等,然后代入公式求解。6、程序代码:clear all,clc;%test1.1%有条100 字符英文信息,假定其中每字符从26 个英文字母和1 个空格中等概选取%求每条信息提供的信息量H1=log2(27100)%test1.2%事件:u0:一个0 发出;u1:一个1 发出; v0:一个0 收到;v1:一个1 收到;%给定下列概率:p(u0)=1/2,p(v0|u0)=3/4,p(v0|u1)=1/2p_u0=1/2;p_v0_u0=3/4;p_v0_u1=1/2;p_v1_u0=1-p_v0_u0;%(a)已知发出一个0,求收到符号后得到的信息量;H_V_u0=p_v0_u0*lo
8、g2(p_v0_u0)-p_v1_u0*log2(p_v1_u0);%(b)已知发出的符号,求收到符号后得到的信息量p_u1=1-p_u0;p_v1_u1=1-p_v0_u1;p_u0v0=p_v0_u0*p_u0;p_u0v1=p_v1_u0*p_u0;p_u1v0=p_v0_u1*p_u1;p_u1v1=p_v1_u1*p_u1;H_V_U=-p_u0v0*log2(p_v0_u0)-p_u0v1*log2(p_v1_u0)-p_u1v0*log2(p_v0_u1)-p_u1v1*log2(p_v1_u1)%test1.3c=0.3,0.7;y1,y2,y3=t05(c)%信源的熵和其二次
9、、三次扩展信源的熵%test1.4P_X1X2=1/4 1/18 0;1/18 1/3 1/18;0 1/18 7/36;%联合分布%(a)认为信源符号之间无依赖性时,信源X 的信息熵H(X);P_X=sum(P_X1X2);H_X=sum(-P_X.*log2(P_X);fprintf(X 的信源熵: H_X=%6.3fn,H_X);%(b)认为有依赖性时的条件熵H(X2X1);P_X1_X2=P_X1X2(:,1)/P_X(1),P_X1X2(:,2)/P_X(2),P_X1X2(:,3)/P_X(3);%条件矩阵P_X1_X2(find(P_X1_X2=0)=1;%将0 换为1H_X1_
10、X2=sum(-P_X1X2.*log2(P_X1_X2);fprintf(X 的条件熵: n H_X1_X2=%6.3fn,H_X1_X2);%(c)联合熵H(X1X2)P_X1X2(find(P_X1X2=0)=1;%将0 换为1H_X1X2=sum(-P_X1X2.*log2(P_X1X2);fprintf(X 的联合熵: n H_X1X2=%6.3fn,H_X1X2);%test1.5%有两个二元随机变量X 和Y,同时定义另一随机变量Z=X*Y,试求:% a、熵H(X),H(Z),H(X,Z)和H(X,Y,Z);% b、条件熵H(X|Y),H(Y|X,Z);% c、互信息I(X;Y),
11、I(X;Y|Z);功能函数t03:function H_X1,H_X2,H_X3=t03(X1,P1)%t03%输入为X1,P1,分别为信源符号和概率阵%输出为原离散信源的熵和扩展信源的熵X2=X_grow(2);p0=0.7;p1=1-p0;H_X1=sum(-P1.*log2(P1);l=length(X1);P=zeros(1:l2);for i=1:l2l1=length(find(X2(i,:);P2(i)=p0(l-l1)*p1l1;endH_X2=sum(-P2.*log2(P2);%-function s=X_grow(n)s=zeros(2n,n);for i=2:2nj=n
12、;%for j=6:-1:1s(i,:)=s(i-1,:);s(i,j)=s(i-1,j)+1;for j=n:-1:1if (s(i,j)=2)s(i,j)=0;s(i,j-1)=s(i,j-1)+1;endendEnd功能函数t05:function H_X1,H_X2,H_X3=t05(P1)H_X1=sum(-P1.*log2(P1);x=zeros(1,length(P1)2);y=zeros(1,length(P1)3);a=1;b=1;for i=1:length(P1)for j=1:length(P1)x(a)=P1(i)*P1(j);a=a+1;endendH_X2=sum
13、(-x.*log2(x);for i=1:length(P1)for j=1:length(P1)for k=1:length(P1)y(b)=P1(i)*P1(j)*P1(k);b=b+1;endendendH_X2=sum(-x.*log2(x);H_X3=sum(-y.*log2(y);部分结果:H1 =475.4888H_V_U =0.9056y1 =0.8813y2 =1.7626y3 =2.6439X 的信源熵: H_X= 1.543X 的条件熵:H_X1_X2= 0.209X 的条件熵:H_X1_X2= 0.472X 的条件熵:H_X1_X2= 0.191X 的联合熵:H_X1X
14、2= 0.732X 的联合熵:H_X1X2= 0.992X 的联合熵:H_X1X2= 0.6912)实验中出现的问题及解决方法;实验中遇到的问题有很多,如各种概率空间的计算,弄混,概念不清楚,公式不熟悉,对信息论的定理概念及意义不理解,不能灵活运用。对于各种概率的计算,需要准确分析,然后逐一进行计算。信息论的定理概念及意义,翻书查阅,尽可能的熟悉,理解,并加以运用。六、实验总结通过实验,回顾了各种概率的求解方法,该实验主要是计算消息的信息量,信息熵。在实验过程中,不断地学习查阅课本,巩固了上课的知识,对所学的定理和公式有了更加深刻的认识和理解。实验二 离散信道及其容量一、实验目的1、 理解离散
15、信道容量的内涵;2、 掌握求二元对称信道(BSC)互信息量和容量的设计方法;3、 掌握二元扩展信道的设计方法并会求其平均互信息量。二、实验环境windows XP,MATLAB 7三、实验原理若某信道输入的是N维序列x,其概率分布为q(x),输出是N维序列y,则平均互信息量记为I(X;Y),该信道的信道容量C定义为。四、实验内容 1、给定BSC信道,信源概率空间为 0.6 0.4XP= 信道矩阵 求该信道的I(X;Y)和容量,画出I(X;Y)和、C和p的关系曲线。 2 、编写一M脚本文件t03.m,实现如下功能: 在任意输入一信道矩阵P后,能够判断是否离散对称信道,若是,求出信道容量C。 3、
16、已知X=(0,1,2);Y=(0,1,2,3),信源概率空间和信道矩阵分别为XPx 0.3 0.5 0.2= 0.1 0.3 0 0.60.3 0.5 0.2 00.1 0.7 0.1 0.1P= 求: 平均互信息量; 4、 对题(1)求其二次扩展信道的平均互信息I(X;Y)。五、实验过程每个实验项目包括:1)设计思路2)实验中出现的问题及解决方法;1)设计思路1、信道容量( )max (X; Y)q xC = I,因此要求给定信道的信道容量,只要知道该信道的最大互信息量,即求信道容量就是求信道互信息量的过程。程序代码:clear all,clc;w=0.6;w1=1-w;p=0.01;XP
17、= 0.6 0.4p1=1-p;save data1 p p1;I_XY=(w*p1+w1*p)*log2(1/(w*p1+w1*p)+(w*p+w1*p1)*log2(1/(w*p+w1*p1)- .(p*log2(1/p)+p1*log2(1/p1);C=1-(p*log2(1/p)+p1*log2(1/p1);fprintf(互信息量:%6.3fn信道容量:%6.3f,I_XY,C);p=eps:0.001:1-eps;p1=1-p;C=1-(p.*log2(1./p)+p1.*log2(1./p1);subplot(1,2,1),plot(p,C),xlabel(p),ylabel(C
18、);load data1;w=eps:0.001:1-eps;w1=1-w;I_XY=(w.*p1+w1.*p).*log2(1./(w.*p1+w1.*p)+(w.*p+w1.*p1).*log2(1./(w.*p+w1.*p1)- .(p.*log2(1./p)+p1.*log2(1./p1);subplot(1,2,2),plot(w,I_XY)xlabel(w),ylabel(I_XY);实验结果:互信息量:0.891信道容量:0.919I(X;Y)和 、C和p的关系曲线图:0 0.5 100.10.20.30.40.50.60.70.80.91pC0 0.5 100.10.20.30
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 信息论 实验 指导书 应用 MATLAB 软件 实现 25
限制150内