(最新版)信息论与编码实验报告.docx

上传人:b****9 文档编号:45495 上传时间:2022-10-01 格式:DOCX 页数:32 大小:213.65KB
下载 相关 举报
(最新版)信息论与编码实验报告.docx_第1页
第1页 / 共32页
(最新版)信息论与编码实验报告.docx_第2页
第2页 / 共32页
(最新版)信息论与编码实验报告.docx_第3页
第3页 / 共32页
(最新版)信息论与编码实验报告.docx_第4页
第4页 / 共32页
(最新版)信息论与编码实验报告.docx_第5页
第5页 / 共32页
点击查看更多>>
下载资源
资源描述

(最新版)信息论与编码实验报告.docx

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

(最新版)信息论与编码实验报告.docx

实验报告

课程名称:

信息论与编码

姓名:

系:

专业:

年级:

学号:

指导教师:

职称:

年月日

目录

实验一信源熵值的计算

实验二Huffman信源编码

实验三Shannon编码

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

实验五率失真函数

实验六差错控制方法

实验七汉明编码

实验一信源熵值的计算

一、实验目的

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编码的原理及实现过程,并

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

当前位置:首页 > 幼儿教育 > 家庭教育

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1