- 5
- 0
- 约1.45千字
- 约 4页
- 2020-12-04 发布于四川
- 举报
哈夫曼编码及Matlab实现
哈夫曼编码是一种所得码字是异前置的变长码,其平均码长最短,被称为最佳变长码,也称为哈夫曼编码。
其具体编码方法如下:
(1)将信源信息(符号)按概率大小排队;
(2)从最小概率的两个消息开始编码,并给予一定的编码规则,如小概率的下支路编为1(或0),大概率的上支路变为0(或1),若两者概率相等,仍是下支路为1上支路为0;
(3)将已经编码的两个消息对应概率合并,并重新按概率大小排队,重复步骤(2);
(4)重复步骤(3),直至合并概率归一为止;
(5)变成的变长码是按后出先编方式,即从概率归一的树根沿编码路线逆行至对应的消息。
实验内容:
给定离散信源:
对其进行哈夫曼编码,其理论结果如下:
消息
(U)
概率
(p)
编码
(C)
0.20
0.20 0.26 0.35 0.39 0.61 1.0
0.19 0.20 0.26 0.35 0.39
0.18 0.19 0.20 0.26
0.17 0.18 0.19
0.15 0.17
0.11
10
0.19
11
0.18
000
0.17
001
0.15
010
0.10
0110
0.01
0111
哈夫曼编码Matlab代码:
p=[0.2,0.19,0.18,0.17,0.15,0.1,0.01];
p=sort(p,descend);%降序排列
H=sum(-p.*log2(p));%求得信息熵
n=length(p);%离散信源长度
q=p;
m=zeros(n-1,n);
for i=1:n-1%对第一行进行编码
[q,l]=sort(q);
m(i,:)=[l(1:n-i+1),zeros(1,i-1)];
q=[q(1)+q(2),q(3:n),1];
end
for i=1:n-1
c(i,:)=blanks(n*n);
end
c(n-1,n)=1;
c(n-1,2*n)=0;
for i=2:n-1
c(n-i,1:n-1)=c(n-i+1,n*(find(m(n-i+1,:)==1))...
-(n-2):n*(find(m(n-i+1,:)==1)));
c(n-i,n)=1;%在支路的第一个元素最后补1
c(n-i,n+1:2*n-1)=c(n-i,1:n-1);
c(n-i,2*n)=0;%在支路的第一个元素最后补0
for j=1:i-1
c(n-i,(j+1)*n+1:(j+2)*n)=c(n-i+1,...
n*(find(m(n-i+1,:)==j+1)-1)+1:n*find(m(n-i+1,:)==j+1));%分配码字
end
end
for i=1:n
h(i,1:n)=c(1,n*(find(m(1,:)==i)-1)+1:find(m(1,:)==i)*n);
ll(i)=length(find(abs(h(i,:))~=32));%计算每一个哈夫曼编码的长度
end
L=sum(p.*ll);%求得平均码长
t=H/L;%求得编码效率
运行结果:
该结果与理论结果相符,满足实验要求。
您可能关注的文档
最近下载
- 北师大版初中数学七年级下册平行线的判定与性质专题练习和答案.pdf VIP
- 剧本杀剧本之渡厄( 5-6人开放).doc VIP
- 全科医学 1以人为中心的健康照顾.ppt VIP
- 财务竣工决算的编制.doc VIP
- 哪吒V汽车说明书.docx VIP
- DB31_T 1648-2025 元器件抗辐射性能评估指南.docx VIP
- 每日听书《什么是权力》导读.pdf VIP
- 六年级数学下册分数计算专项练习题(每日一练,共17份).pdf VIP
- DGJ32 J157-2013 居住建筑标准化外窗系统应用技术规程-全国各省建筑标准.pdf VIP
- 2026-2030中国抽水蓄能行业需求规模及未来投资方向预测研究报告.docx
原创力文档

文档评论(0)