matlab 二元Huffman编码

%huffman编码的MATLAB实现(基于0、1编码):
clc;
clear;
A=[5,3,1,6,2];%原概率序列
A=A/sum(A);
A=fliplr(sort(A));%按降序排列
T=A;
[m,n]=size(A);
B=zeros(n,n-1);%空的编码表(矩阵)
for i=1:n
    B(i,1)=T(i);%生成编码表的第一列
end
r=B(i,1)+B(i-1,1);%最后两个元素相加
T(n-1)=r;
T(n)=0;
T=fliplr(sort(T));
t=n-1;
for j=2:n-1%生成编码表的其他各列
    for i=1:t
        B(i,j)=T(i);
    end
        K=find(T==r);
        B(n,j)=K(end);%从第二列开始,每列的最后一个元素记录特征元素在
%该列的位置
        r=(B(t-1,j)+B(t,j));%最后两个元素相加
        T(t-1)=r;
        T(t)=0;
        T=fliplr(sort(T));
        t=t-1;
end
B;%输出编码表
QBC1=sym('[0,1]');%给最后一列的元素编码
QBC=QBC1;
t=3;
d=1;
for j=n-2:-1:1%从倒数第二列开始依次对各列元素编码
    for i=1:t-2
        if i>1 & B(i,j)==B(i-1,j)
            d=d+1;
        else
            d=1;
        end
        B(B(n,j+1),j+1)=-1;
        temp=B(:,j+1);

        x=find(temp==B(i,j));
        QBC(i)=QBC1(x(d));
    end
    y=B(n,j+1);
    QBC(t-1)=[char(QBC1(y)),'0'];
    QBC(t)=[char(QBC1(y)),'1'];
    t=t+1;
    QBC1=QBC;
end
    A%排序后的原概率序列
    QBC%编码结果
for i=1:n
    [a,b]=size(char(QBC(i)));
    L(i)=b;
end
avlen=sum(L.*A)%平均码长 
H1=log2(A);
H=-A*(H1')%熵
P=H/avlen%编码效率

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值