⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 huffmanenco.m

📁 MATLAB编写的huffman编解码程序
💻 M
字号:
function enco = huffmanEnco(sig,dict)
%    
%    Encodes the input signal, sig, based on the code dictionary, dict. 
%    The code dictionary is generated using the huffmanDict function.
%--------------------------------------------------------------------------

% Make sure that the input symbols are in a cell array format
if (~iscell(sig) )
	[m,n] = size(sig);
	sig = mat2cell(sig, ones(1,m), ones(1,n) );
end

% Preallocate memory for enco
maxSize = 0;
dictLength = size(dict,1);
for i = 1 : dictLength
    tempSize = size(dict{i,2},2);
    if (tempSize > maxSize)
        maxSize = tempSize;
    end
end
enco = zeros(1, length(sig)*maxSize);

% Search the dictionary sequentially to find the code for the given signal
idxCode = 1;
for i = 1 : length(sig)
    tempcode = [];
    for j = 1 : dictLength
        if( sig{i} == dict{j,1} )
            tempcode = dict{j,2};
            break;
        end
    end 
    lenCode = length(tempcode);
    enco(idxCode : idxCode+lenCode-1) = tempcode;
    idxCode = idxCode + lenCode;
end

% Strip off the unused vector elements
enco = enco(1:idxCode-1);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -