Huffman编码(哈夫曼编码)的Matlab实现.doc

Huffman编码(哈夫曼编码)的Matlab实现.doc

ID:55952621

大小:23.00 KB

页数:4页

时间:2020-06-18

Huffman编码(哈夫曼编码)的Matlab实现.doc_第1页
Huffman编码(哈夫曼编码)的Matlab实现.doc_第2页
Huffman编码(哈夫曼编码)的Matlab实现.doc_第3页
Huffman编码(哈夫曼编码)的Matlab实现.doc_第4页
资源描述:

《Huffman编码(哈夫曼编码)的Matlab实现.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、clearallfprintf('Readingdata...')data=imread('cameraman.tif');data=uint8(data);%读入数据,并将数据限制为uint8fprintf('Done!')%编码压缩fprintf('compressingdata...');[zipped,info]=norm2huff(data);fprintf('Done!')%解压缩fprintf('compressingdata...');unzipped=huff2norm(zipped,info);fprintf(

2、'Done!')%测试是否无失真isOK=isequal(data(:),unzipped(:))%显示压缩效果whosdatazippedunzippedfunction[zipped,info]=norm2huff(vector)if~isa(vector,'uint8'),error('inputargumentmustbeauint8vector')endvector=vector(:)';%将输入向量转换为行向量f=frequency(vector);%计算个元素出现的概率simbols=find(f~=0);f=f(sim

3、bols);%将元素按出现的概率排列[f,sortindex]=sot(f);simbols=simbols(sortindex);%产生码字generatethecodewordasthe52bitsofadoublelen=length(simbols);simbols_index=num2cell(1:len);codeword_tmp=cell(len,1);whilelength(f)>1,index1=simbols_index{1};index2=simbols_index{2};codeword_tmp(index1)=a

4、ddnode(codeword_tmp(index1),uint8(0));codeword_tmp(index2)=addnode(codeword_tmp(index2),uint8(1));f=[sum(f(1:2))f(3:end)];simbols_index=[{[index1index2]}simbols_index(3:end)];%将数据重新排列,是两个节点的频率尽量与前一个节点的频率想当resortdatainordertohavetwonodeswithlowerfrequencyasfirstto[f,sortin

5、dex]=sort(f);simbols_index=simbols_index(sortindex);end%对应相应的元素与码字codeword=cell(256:1);codeword(simbols)=codeword_tmp;%计算总的字符串长度len=0;forindex=1:length(vector),len=len+length(codeword{double(vector(index))+1});end%产生01序列string=repmat(uint8(0),1,len);pointer=1;forindex=1:l

6、ength(vector),code=codeword{double(vector(index))+1};len=length(code);string(pointer+(0:len-1))=code;pointer=pointer+len;end%如果需要,加零len=length(string);pad=8-mod(len,8);ifpad>0,string=[stringuint8(zeros(1,pad))];end%保存实际有用的码字codeword=codeword(simbols);codelen=zeros(size(co

7、deword));weights=2.^(0:23);maxcodelen=0;forindex1:length(codeword),len=length(codeword{index});iflen>maxcodelen,maxcodelen=len;endiflen>0,code=sum(weights(codeword{index}==1));code=bitset(code,len+1);codeword{index}=code;codelen(index)=len;endendcodeword=[codeword{:}]%计算压

8、缩后的向量cols=length(string)/8;string=reshape(string,8,cols);weights=2.^(0:7);zipped=uint8(weights*d

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。