• 大小: 35KB
    文件类型: .zip
    金币: 1
    下载: 0 次
    发布日期: 2021-06-14
  • 语言: Matlab
  • 标签: lzw  

资源简介

matlab实现LZW码

资源截图

代码片段和文件信息

function [outputtable] = lzw2norm(vector)
%LZW2NORM   LZW Data Compression (decoder)
%   For vectors LZW2NORM(X) is the uncompressed vector of X using the LZW algorithm.
%   [...T] = LZW2NORM(X) returns also the table that the algorithm produces.
%
%   For matrices X(:) is used as input.
%
%   Input must be of uint16 type while the output is a uint8.
%   Table is a cell array each element containig the corresponding code.
%
%   This is an implementation of the algorithm presented in the article
%   http://www.dogma.net/markn/articles/lzw/lzw.htm
%
%   See also NORM2LZW


%   $Author: Giuseppe Ridino‘ $
%   $Revision: 1.0 $  $Date: 10-May-2004 14:16:08 $


% How it decodes:
%
% Read OLD_CODE
% output OLD_CODE
% CHARACTER = OLD_CODE
% WHILE there are still input characters DO
%     Read NEW_CODE
%     IF NEW_CODE is not in the translation table THEN
%         STRING = get translation of OLD_CODE
%         STRING = STRING+CHARACTER
%     ELSE
%         STRING = get translation of NEW_CODE
%     END of IF
%     output STRING
%     CHARACTER = first character in STRING
%     add translation of OLD_CODE + CHARACTER to the translation table
%     OLD_CODE = NEW_CODE
% END of WHILE


% ensure to handle uint8 input vector
if ~isa(vector‘uint16‘)
error(‘input argument must be a uint16 vector‘)
end

% vector as a row
vector = vector(:)‘;

% initialize table (don‘t use cellstr because char(10) will be turned to empty!!!)
table = cell(1256);
for index = 1:256
table{index} = uint16(index-1);
end

% initialize output
output = uint8([]);

code = vector(1);
output(end+1) = code;
character = code;
for index=2:length(vector)
element = vector(index);
if (double(element)+1)>length(table)
% add it to the table
string = table{double(code)+1};
string = [string character];
else
string = table{double(element)+1};
end
output = [output string];
character = string(1);
[tablecode] = addcode(table[table{double(code)+1} character]);
code = element;
end


% ###############################################
function code = getcodefor(substrtable)
code = uint16([]);
if length(substr)==1
code = substr;
else % this is to skip the first 256 known positions
for index=257:length(table)
if isequal(substrtable{index})
code = uint16(index-1);   % start from 0
break
end
end
end


% ###############################################
function [tablecode] = addcode(tablesubstr)
code = length(table)+1;   % start from 1
table{code} = substr;
code = uint16(code-1);    % start from 0

 属性            大小     日期    时间   名称
----------- ---------  ---------- -----  ----
     文件        2527  2004-05-10 14:49  lzw2norm.m
     文件         416  2004-05-10 15:32  lzw_demo1.m
     文件        2548  2004-05-10 14:49  norm2lzw.m
     文件         568  2004-04-23 14:21  Discalmer.txt
     文件        1260  2004-05-11 22:07  ReadMe.txt
     文件       32276  2004-05-11 22:06  lzw_docs.zip

评论

共有 条评论