信息论与编码实验报告.docx

上传人:b****1 文档编号:13787238 上传时间:2023-06-17 格式:DOCX 页数:35 大小:181.04KB
下载 相关 举报
信息论与编码实验报告.docx_第1页
第1页 / 共35页
信息论与编码实验报告.docx_第2页
第2页 / 共35页
信息论与编码实验报告.docx_第3页
第3页 / 共35页
信息论与编码实验报告.docx_第4页
第4页 / 共35页
信息论与编码实验报告.docx_第5页
第5页 / 共35页
信息论与编码实验报告.docx_第6页
第6页 / 共35页
信息论与编码实验报告.docx_第7页
第7页 / 共35页
信息论与编码实验报告.docx_第8页
第8页 / 共35页
信息论与编码实验报告.docx_第9页
第9页 / 共35页
信息论与编码实验报告.docx_第10页
第10页 / 共35页
信息论与编码实验报告.docx_第11页
第11页 / 共35页
信息论与编码实验报告.docx_第12页
第12页 / 共35页
信息论与编码实验报告.docx_第13页
第13页 / 共35页
信息论与编码实验报告.docx_第14页
第14页 / 共35页
信息论与编码实验报告.docx_第15页
第15页 / 共35页
信息论与编码实验报告.docx_第16页
第16页 / 共35页
信息论与编码实验报告.docx_第17页
第17页 / 共35页
信息论与编码实验报告.docx_第18页
第18页 / 共35页
信息论与编码实验报告.docx_第19页
第19页 / 共35页
信息论与编码实验报告.docx_第20页
第20页 / 共35页
亲,该文档总共35页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

信息论与编码实验报告.docx

《信息论与编码实验报告.docx》由会员分享,可在线阅读,更多相关《信息论与编码实验报告.docx(35页珍藏版)》请在冰点文库上搜索。

信息论与编码实验报告.docx

信息论与编码实验报告

实验报告

 

课程名称:

信息论与编码

姓名:

系:

专业:

年级:

学号:

指导教师:

职称:

 

年月日

 

实验一信源熵值的计算

一、实验目的

1进一步熟悉信源熵值的计算

2熟悉Matlab编程

二、实验原理

熵(平均自信息)的计算公式

MATLAB实现:

;或者

流程:

第一步:

打开一个名为“nan311”的TXT文档,读入一篇英文文章存入一个数组temp,为了程序准确性将所读内容转存到另一个数组S,计算该数组中每个字母与空格的出现次数(遇到小写字母都将其转化为大写字母进行计数),每出现一次该字符的计数器+1;

第二步:

计算信源总大小计算出每个字母和空格出现的概率;

最后,通过统计数据和信息熵公式计算出所求信源熵值(本程序中单位为奈特nat)。

程序流程图:

三、实验内容

1、写出计算自信息量的Matlab程序

2、已知:

信源符号为英文字母(不区分大小写)和空格。

输入:

一篇英文的信源文档。

输出:

给出该信源文档的中各个字母与空格的概率分布,以及该信源的熵。

四、实验环境

MicrosoftWindows7

Matlab6.5

五、编码程序

#include"stdio.h"

#include

#include

#defineN1000

intmain(void)

{

chars[N];

inti,n=0;

floatnum[27]={0};

doubleresult=0,p[27]={0};

FILE*f;

char*temp=newchar[485];

f=fopen("nan311.txt","r");

while(!

feof(f)){

fread(temp,1,486,f);}

fclose(f);

s[0]=*temp;

for(i=0;i

{

s[i]=temp[i];

}

for(i=0;i

{

if(s[i]=='')

num[26]++;

elseif(s[i]>='a'&&s[i]<='z')

num[s[i]-97]++;

elseif(s[i]>='A'&&s[i]<='Z')

num[s[i]-65]++;

}

printf("文档中各个字母出现的频率:

\n");

for(i=0;i<26;i++)

{

p[i]=num[i]/strlen(s);

printf("%3c:

%f\t",i+65,p[i]);

n++;

if(n==3)

{

printf("\n");

n=0;

}

}

p[26]=num[26]/strlen(s);

printf("空格:

%f\t",p[26]);

printf("\n");

for(i=0;i<27;i++)

{

if(p[i]!

=0)

result=result+p[i]*log(p[i]);

}

result=-result;

printf("信息熵为:

%f",result);

printf("\n");

return0;

}

六、求解结果

其中nan311.txt中的文档如下:

Thereisnohatewithoutfear.Hateiscrystallizedfear,fear’sdividend,fearobjectivized.Wehatewhatwefearandsowherehateis,fearislurking.Thuswehatewhatthreatensourperson,ourvanityandourdreamsandplansforourselves.Ifwecanisolatethiselementinwhatwehatewemaybeabletoceasefromhating.

七、实验总结

通过这次实验,我们懂得了不必运行程序时重新输入文档就可以对文档进行统计,既节省了时间而且也规避了一些输入错误。

在实验中,我们进一步了解到信源熵的计算,理论和实践的结合让我们对这个知识点了解的更加深刻了。

 

实验二Huffman信源编码

一、实验目的

1.理解信源的最优变长编码的基本思想。

2.熟练掌握Huffman信源编码方法。

二、设计原理

设信源S={s1,s2,…..,sq},其对应的概率分布为P(si)={p1,p2,p3,….,pq},则其编码步骤如下:

(1)将q个信源符号按递减方式排列。

(2)用0、1码符分别表示概率最小的两个信源符号,并将这两个符号合并成一个新的符号,从而得到q-1个符号的新信源成为S信源的缩减信源S1。

(3)将缩减信源S1中的符号仍按递减顺序排列,再将最小两个概率相加,合并成一个符号,并分别用0、1码表示,这样有形成了q-2个缩减信源S2。

(4)依次继续下去,直到缩减信源只剩下两个符号为止,将最后两个符号用0、1分别表示。

(5)从最后一次缩减信源开始,向前返回,沿信源缩减过程的反方向取出所编的马元。

三、实验内容

计算定信源和输入信号字母表的Huffman编码,并计算Huffman编码的平均码长。

实验具体要求如下:

信源字母表的概率分布为:

P={0.15,0.12,0.2,0.08,0.04,0.18,0.02,0.09,0.04,0.02,0.06}

输入信号字母表:

U={0,1,2};

1.独立设计信源和输入信号字母表进行Huffman编码,其中信源字母表元素个数要求是8以上,信号字母表元素个数是2以上;

2.输出Huffman编码的平均码长。

四、实验环境

MicrosoftWindows7

Matlab6.5

五、编码程序

MATLAB编码:

function[h,L]=huffman(p,r)

%变量p为符号出现概率所组成的概率向量

%返回值h为利用Huffman编码算法编码后最后得到编码结果

%返回值L为进行Huffman编码后所得编码的码字长度

iflength(find(p<0))~=0

error('Notaprob.vector,negativecomponent(s)');

end

%判断概率向量中是否有0元素,有0元素程序显示出错,终止运行

if(sum(p,2)>1)

error('Notaprob.vector,componentsdonotaddupto1');

end

%判断所有符号出现概率之和是否大于1,如果大于1程序显示出错,终止运行

a=length(p);%测定概率向量长度,将长度值赋给变量n

k=fix((a-1)/(r-1));

l1=a-k*r+k;

q=zeros(1,a);

m=zeros(k+1,a);

mp=m;

q=p;

[m(1,:

),mp(1,:

)]=sort(q);

if(l1>1)

s=sum(m(1,1:

l1),2);

q=[s,m(1,(l1+1):

a),ones(1,l1-1)];

[m(2,:

),mp(2,:

)]=sort(q);

else

m(2,:

)=m(1,:

);

mp(2,:

)=1:

1:

a;

end

fori=3:

k+1

s=sum(m(i-1,1:

r),2);

q=[s,m(i-1,r+1:

a),ones(1,r-1)];

[m(i,:

),mp(i,:

)]=sort(q);

end

n1=m;

n2=mp;

fori=1:

k+1

n1(i,:

)=m(k+2-i,:

);

n2(i,:

)=mp(k+2-i,:

);

end

m=n1;

mp=n2;

c=cell(k+1,a);

forj=1:

r

c{1,j}=num2str(j-1);

end

fori=2:

k

p1=find(mp(i-1,:

)==1);

forj=1:

r

c{i,j}=strcat(c{i-1,p1},int2str(j-1));

end

forj=(r+1):

(p1+r-1)

c{i,j}=c{i-1,j-r};

end

forj=(p1+r):

a

c{i,j}=c{i-1,j-r+1};

end

end

ifl1==1

forj=1:

a

c{k+1,j}=c{k,j};

end

else

p1=find(mp(k,:

)==1);

forj=1:

l1

c{k+1,j}=strcat(c(k,p1),int2str(j-1));

end

forj=(l1+1):

(p1+l1)

c{k+1,j}=c{k,mp(1,j-l1)};

end

forj=(p1

(1)+l1+1):

a

c{k+1,j}=c{k,mp(1,j-l1+1)};

end

end

forj=1:

a

l(j)=length(c{k+1,j});

end

h=cell(1,a);

forj=1:

a

h{1,j}=c{k+1,j};

end

L=sum(l.*m(k+1,:

));%求平均码长

2、在MATLAB命令窗口中输入:

p=[0.15,0.12,0.2,0.08,0.04,0.18,0.02,0.09,0.04,0.02,0.06];

r=3;

[h,L]=huffman(p,r).

六、运行结果

得出的结论为:

概率

编码

概率

编码

0.15

2120

0.02

11

0.12

2121

0.09

12

0.2

2122

0.04

20

0.08

210

0.02

22

0.04

211

0.06

0

0.18

10

L=2.0600

七、实验总结

在huffman编码的过程中,我们运用了平时熟悉的数学软件MATLAB的运行来实现,把书本上huffman的算法运用编程来实现。

通过这次实验,使我更加清晰地理解huffman编码的原理及实现过程,并且能够在MATLAB中熟练地进行编码运行。

实验三Shannon编码

一、实验目的

1、熟悉离散信源的特点;

2、学习仿真离散信源的方法

3、学习离散信源平均信息量的计算方法

4、熟悉Matlab编程

二、实验原理

给定某个信源符号的概率分布,通过以下的步骤进行香农编码

1、信源符号按概率从大到小排列;

2、确定满足下列不等式的整数码长

3、为了编成唯一可译码,计算第i个消息的累加概率:

4、将累加概率

变换成二进制数;

5、取

二进制数的小数点后

位即为该消息符号的二进制码字。

三、实验内容

1、写出计算自信息量的Matlab程序

2、写出计算离散信源平均信息量的Matlab程序。

3、将程序在计算机上仿真实现,验证程序的正确性并完成习题。

四、实验环境

MicrosoftWindows7

Matlab6.5

五、编码程序

计算如下信源进行香农编码,并计算编码效率:

MATLAB程序:

(1)a=[0.20.180.190.150.170.10.01];

k=length(a);y=0;

fori=1:

k-1

forn=i+1:

k

if(a(i)

t=a(i);

a(i)=a(n);

a(n)=t;

end

end

end

s=zeros(k,1);b=zeros(k,1);

form=1:

k

s(m)=y;

y=y+a(m);

b(m)=ceil(-log2(a(m)));

z=zeros(b(m),1);

x=s(m);

p=b2d10(x);

forr=1:

b(m)

z(r)=p(r);

end

disp('Êä³ö½á¹ûΪ£º')

disp('³öʸÅÂÊ'),disp(a(m))

disp('ÇóºÍ½á¹û'),disp(s(m))

disp('±àÂëλÊý'),disp(b(m))

disp('×îÖÕ±àÂë'),disp(z')

end

(2)functiony=b2d10(x)

fori=1:

8

temp=x.*2;

if(temp<1)

y(i)=0;

x=temp;

else

x=temp-1;

y(i)=1;

end

end

(3)p=[0.20.190.180.170.150.10.01];

sum=0;sum1=0;

fori=1:

7

a(i)=-log2(p(i));

K(i)=ceil(a(i));

R(i)=p(i)*K(i);

sum=sum+R(i);

c(i)=a(i)*p(i);

sum1=sum1+c(i);

end

K1=sum;

H=sum1;

Y=H/K1;

disp('ƽ¾ùÐÅÏ¢Á¿'),disp(H)

disp('ƽ¾ùÂ볤'),disp(K1)

disp('±àÂëЧÂÊ'),disp(Y)

六、实验结果

输出结果为:

出事概率0.2000,求和结果0,编码位数3,最终编码000

出事概率0.1900,求和结果0.2000,编码位数3,最终编码001

出事概率0.1800,求和结果0.3900,编码位数3,最终编码011

出事概率0.1700,求和结果0.5700,编码位数3,最终编码100

出事概率0.1500,求和结果0.7400,编码位数3,最终编码101

出事概率0.1000,求和结果0.8900,编码位数4,最终编码1110

出事概率0.0100,求和结果0.9900,编码位数7,最终编码1111110

编码效率:

平均信息量2.6087

平均码长3.1400

编码效率0.8308

七、实验总结

通过本次的实验,掌握了Shannon编码的实验原理以及编码过程。

Shannon编码中,对概率的排序是最基本的,如果没有将其按照从大到小的顺序排序,则经过MATLAB的程序运行后,将出现错误。

在运用MATLAB编程的过程中,调用了各种函数,实现了编程。

通过与队友的讨论,不但让我们更快的完成MATLAB编码,也深深体会到只有将大家的智慧融合起来,才能更快更好的解决难题。

 

实验四信道容量的迭代算法

一、实验目的

1、进一步熟悉信道容量的迭代算法;

2、学习如何将复杂的公式转化为程序;

3、熟悉程序设计语言的数值计算程序和调试技术。

二、实验原理

(1)初始化信源分布

(一般初始化为均匀分布),置迭代计数器k=0,设信道容量相对误差门限为

>0,可设;

(2)

(3)

(4)

(5)如果

,转向(7);

(6)置迭代序号

,转向

(2);

(7)输出

的结果;

(8)停止。

三、实验内容

1、已知:

信源符号个数r、新宿符号个数s、信道转移概率矩阵P;

2、输入:

任意的一个信道转移概率矩阵,信源符号个数、信宿符号个数和每一个具体的转移概率在运行时从键盘输入;

3、输出:

最佳信源分布P*,信道容量C。

四、实验环境

MicrosoftWindows7、

Matlab6.5

五、编码程序

aa.m文件:

clear;

r=input('输入信源个数:

');

s=input('输入信宿个数:

');

deta=input('输入信道容量的精度:

');

Q=rand(r,s);%创建m*n随机分布矩阵

A=sum(Q,2);

B=repmat(A,1,s);

disp('信源转移概率矩阵:

'),p=Q./B%信源转移概率矩阵

i=1:

1:

r;

q(i)=1/r;

disp('原始信源分布:

'),q

c=-10e-8;

C=repmat(q',1,s);

fork=1:

1:

100000

m=p.*C;%后验概率的分子部分

a=sum(m);%后验概率的分母部分

su1=repmat(a,r,1);

t=m./su1;%后验概率矩阵

D=exp(sum(p.*log(t),2));%信源分布的分子部分

su2=sum(D);%信源分布的分母部分

q=D/su2;%信源分布

C=repmat(q,1,s);

c(k+1)=log(sum(exp(sum(p.*log(t),2))))/log

(2);

kk=abs(c(k+1)-c(k))/c(k+1);

if(kk<=0.000001)

break;

end

end

disp('最大信道容量时的信源分布:

q='),disp(q')

disp('最大信道容量:

c='),disp(c(k+1))

六、实验结果结果

1)检验:

运行aa.m

输入信源的个数:

2

输入信宿的个数:

3

输入信道容量的精度:

0.000001

信宿转移概率矩阵:

p=0.50000.30000.2000

0.30000.50000.2000

原始信源分布:

q=0.50000.5000

最佳信源分布:

q=0.50000.5000

最大信道容量:

c=0.0365

2)计算信源个数为3,信宿个数为5的信道容量:

运行aa.m

输入信源的个数:

3

输入信宿的个数:

5

输入信道容量的精度:

0.000001

信宿转移概率矩阵:

p=0.04840.13850.30580.28450.2227

0.21040.24710.10770.37620.0585

0.34300.08000.18080.34280.0534

原始信源分布:

q=0.33330.33330.3333

最佳信源分布:

q=0.46910.17940.3515

最大信道容量:

c=0.1559

七、实验总结

通过实验,我们对信道容量的理解更加深刻了。

信道容量是指信道能无错误传送的最大信息率。

信道的输入、输出都取值于离散符号集,且都用一个随机变量来表示的信道就是离散单符号信道。

由于信道中存在干扰,因此输入符号在传输中将会产生错误,这种信道干扰对传输的影响可用传递概率来描述。

为了评价实际信道的利用率,应具体计算已给信道的容量。

这是一个求最大值的问题。

由于互信息对输入符号概率而言是凸函数,其极值将为最大值,因此这也就是求极值的问题。

对于离散信道,P(x)是一组数,满足非负性和归一性等条件,可用拉格朗日乘子法求得条件极值。

对于连续信道,P(x)是一函数,须用变分法求条件极值。

实验过程中,我们虽然也遇到了很多困难,但也正是因为如此,我们才能发现自己基础的薄弱点,学的更有方向。

对于编程方面,我们也有了很大的提升。

 

实验五率失真函数

一、实验目的

验证率失真函数的极值特性,理解相关参数的变化对率失真函数的影响。

二、实验原理

(1)输入S,d的初始值、条件概率、输出分布等值;

(2)计算输出分布

(3)进入迭代,标志为0或者误差大于指定eps则迭代,否则退出迭代;

(4)计算一个互信息

(5)计算一个条件概率分布

(6)重算一次(4),并计算

(7)重算(3)-(7)步骤,直到退出迭代;

三、实验环境

MicrosoftWindows7、

VisualStudio2005profession

四、编码程序

#include

#include

#include

usingnamespacestd;

//Definesomeglobalvar

constintM=10;//M元信源

constdoubleS=-50;//迭代算法中的中间量,S越小,允许最大失真度D越小,当S很小时(例如-100),R(D)=H(X)

staticintd[M][M];//失真函数

staticdoubleq[M],Pji[M][M];//输出分布和条件概率分布

staticdoublePi[M]={0.4,0.1,0.25,0.1,0.05,0.05,0.01,0.02,0.005,0.015};//初始化信源的概率分布

constintsystemDefine=2;//定义进制(默认为2进制,结果为bit,为e时,结果为nat)

constdoubleeps=1e-8;//允许误差

 

//计算输出分布(qj)

voidcalcOutDistribution()

{

inti,j;

for(j=0;j

{

q[j]=0;

for(i=0;i

{

q[j]+=Pi[i]*Pji[i][j];

}

}

}

//计算条件概率分布pji

voidcalcProbabilityDistribution()

{

inti,j,k;

doubletemp=0;

for(i=0;i

{

temp=0;

for(k=0;k

{

temp=temp+q[k]*exp(S*d[i][k]);

}

for(j=0;j

{

//设定一个初始的条件概率分布

Pji[i][j]=q[j]*exp(S*d[i][j])/temp;

}

}

}

//取得R(r,r)=I(qj;Pji)【实际上就是根据互信息量公式求互信息】

doublegetSelfInformation()

{

inti,j;

doubleI=0;

for(i=0;i

{

for(j=0;j

{

I+=Pi[i]*Pji[i][j]*log(Pji[i][j]/q[j])/log(systemDefine);//求互信息量

}

}

returnI;

}

intmain(intargc,char*argv[])

{

doubleprobabilityCount=0.0;//概率和

for(intk=0;k

{

probabilityCount+=Pi[k];

}

//和不为1,说明概率有错误

if(fabs(probabilityCount-1.0)>eps)

{

cout<<"概率和不为1

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 自然科学 > 物理

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2