




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上赫夫曼編碼設(shè)計(jì)原理赫夫曼(Huffman)編碼是1952年提出的,是一種比較經(jīng)典的信息無(wú)損熵編碼,該編碼依據(jù)變長(zhǎng)最佳編碼定理,應(yīng)用Huffman算法而產(chǎn)生。Huffman編碼是一種基于統(tǒng)計(jì)的無(wú)損編碼。設(shè)信源X的信源空間為:其中,現(xiàn)用二進(jìn)制對(duì)信源X中的每一個(gè)符號(hào)(i=1,2,N)進(jìn)行編碼。根據(jù)變長(zhǎng)最佳編碼定理,Huffman編碼步驟如下:(1)將信源符號(hào)xi按其出現(xiàn)的概率,由大到小順序排列。(2)將兩個(gè)最小的概率的信源符號(hào)進(jìn)行組合相加,并重復(fù)這一步驟,始終將較大的概率分支放在上部,直到只剩下一個(gè)信源符號(hào)且概率達(dá)到1.0為止;(3)對(duì)每對(duì)組合的上邊一個(gè)指定為1,下邊一個(gè)指
2、定為0(或相反:對(duì)上邊一個(gè)指定為0,下邊一個(gè)指定為1);(4)畫出由每個(gè)信源符號(hào)到概率1.0處的路徑,記下沿路徑的1和0;(5)對(duì)于每個(gè)信源符號(hào)都寫出1、0序列,則從右到左就得到非等長(zhǎng)的Huffman碼。Huffman編碼的特點(diǎn)是:(1)Huffman編碼構(gòu)造程序是明確的,但編出的碼不是唯一的,其原因之一是兩個(gè)概率分配碼字“0”和“1”是任意選擇的(大概率為“0”,小概率為“1”,或者反之)。第二原因是在排序過(guò)程中兩個(gè)概率相等,誰(shuí)前誰(shuí)后也是隨機(jī)的。這樣編出的碼字就不是唯一的。(2)Huffman編碼結(jié)果,碼字不等長(zhǎng),平均碼字最短,效率最高,但碼字長(zhǎng)短不一,實(shí)時(shí)硬件實(shí)現(xiàn)很復(fù)雜(特別是譯碼),而且
3、在抗誤碼能力方面也比較差。(3)Huffman編碼的信源概率是2的負(fù)冪時(shí),效率達(dá)100%,但是對(duì)等概率分布的信源,產(chǎn)生定長(zhǎng)碼,效率最低,因此編碼效率與信源符號(hào)概率分布相關(guān),故Huffman編碼依賴于信源統(tǒng)計(jì)特性,編碼前必須有信源這方面的先驗(yàn)知識(shí),這往往限制了哈夫曼編碼的應(yīng)用。(4)Huffman編碼只能用近似的整數(shù)位來(lái)表示單個(gè)符號(hào),而不是理想的小數(shù),這也是Huffman編碼無(wú)法達(dá)到最理想的壓縮效果的原因。設(shè)計(jì)程序clearload woman; %讀入圖像數(shù)據(jù)%X=imread('girl.bmp','bmp');data=uint8(X);zipped,inf
4、o=huffencode(data); %調(diào)用Huffman編碼程序進(jìn)行壓縮unzipped=huffdecode(zipped,info,data);%調(diào)用Huffman編碼程序進(jìn)行解碼%顯示原始圖像和經(jīng)編碼后的圖像,顯示壓縮比,并計(jì)算均方根誤差得erms=0,表示是Huffman是無(wú)失真編碼subplot(121);imshow(data);subplot(122);imshow(unzipped);%erms=compare(data(:),unzipped(:)cr=info.ratiowhos data unzipped zipped%huffencode函數(shù)對(duì)輸入矩陣vector進(jìn)
5、行Huffman編碼,返回%編碼后的向量(壓縮后數(shù)據(jù))及相關(guān)信息function zipped,info=huffencode(vector)%輸入和輸出都是unit8格式%info返回解碼需要的機(jī)構(gòu)信息%info.pad是添加的比特?cái)?shù)%info.huffcodes是Huffman碼字%info.rows是原始圖像行數(shù)%info.cols是原始圖像行數(shù)%info.length是原始圖像數(shù)據(jù)長(zhǎng)度%info.maxcodelen是最長(zhǎng)碼長(zhǎng)if isa(vector,'uint8') error('input argument must be a uint8 vector
6、39;);endm,n=size(vector);vector=vector(:)'f=frequency(vector); %計(jì)算各符號(hào)出現(xiàn)的概率symbols=find(f=0);f=f(symbols);f,sortindex=sort(f); %將符號(hào)按照出現(xiàn)的概率大小排序symbols=symbols(sortindex);len=length(symbols);symbols_index=num2cell(1:len);codeword_tmp=cell(len,1);while length(f)>1 %生產(chǎn)Huffman樹,得到碼字編碼表 index1=symbo
7、ls_index1; index2=symbols_index2; codeword_tmp(index1)=addnode(codeword_tmp(index1),uint8(0); codeword_tmp(index2)=addnode(codeword_tmp(index2),uint8(1); f=sum(f(1:2) f(3:end); symbols_index=index1,index2 symbols_index(3:end); f,sortindex=sort(f); symbols_index=symbols_index(sortindex);endcodeword=c
8、ell(256,1);codeword(symbols)=codeword_tmp;len=0;for index=1:length(vector) %得到整個(gè)圖像所有比特?cái)?shù) len=len+length(codeworddouble(vector(index)+1);endstring=repmat(uint8(0),1,len);pointer=1;for index=1:length(vector) %對(duì)輸入圖像進(jìn)行編碼 code=codeworddouble(vector(index)+1; len=length(code); string(pointer+(0:len-1)=code
9、; pointer=pointer+len;endlen=length(string);pad=8-mod(len,8); %非8整數(shù)倍時(shí),最后補(bǔ)pad個(gè)0if pad>0 string=string uint8(zeros(1,pad);endcodeword=codeword(symbols);codelen=zeros(size(codeword);weights=2.(0:23);maxcodelen=0;for index=1:length(codeword) len=length(codewordindex); if len>maxcodelen maxcodelen=
10、len; end if len>0 code=sum(weights(codewordindex=1); code=bitset(code,len+1); codewordindex=code; codelen(index)=len; endendcodeword=codeword:;%計(jì)算壓縮后的向量cols=length(string)/8;string=reshape(string,8,cols);weights=2.(0:7);zipped=uint8(weights*double(string);%碼表存儲(chǔ)到一個(gè)稀疏矩陣huffcodes=sparse(1,1);for ind
11、ex=1:nnz(codeword) huffcodes(codeword(index),1)=symbols(index);end%填寫解碼時(shí)所需的結(jié)構(gòu)信息info.pad=pad;info.huffcodes=huffcodes;info.ratio=cols./length(vector);info.length=length(vector);info.maxcodelen=maxcodelen;info.rows=m;info.cols=n;%huffdecode函數(shù)對(duì)輸入矩陣vector進(jìn)行Huffman編碼,%返回解壓后的圖像數(shù)據(jù)function vector=huffdecode
12、(zipped,info,image)ifisa(zipped,'uint8') error('input argument must be a uint8 vector');end%產(chǎn)生0,1序列,每位占一個(gè)字節(jié)len=length(zipped);string=repmat(uint8(0),1,len.*8);bitindex=1:8;for index=1:lenstring(bitindex+8.*(index-1)=uint8(bitget(zipped(index),bitindex);endstring=logical(string(:)'
13、;);len=length(string);%開(kāi)始解碼weights=2.(0:51);vector=repmat(uint8(0),1,info.length);vectorindex=1;codeindex=1;code=0;for index=1:len code=bitset(code,codeindex,string(index); codeindex=codeindex+1; byte=decode(bitset(code,codeindex),info); if byte>0 vector(vectorindex)=byte-1; codeindex=1; code=0;
14、vectorindex=vectorindex+1; endend%vector=reshape(vector,info.rows,info.cols);%函數(shù)addnode添加節(jié)點(diǎn)function codeword_new=addnode(codeword_old,item)codeword_new=cell(size(codeword_old);for index=1:length(codeword_old) codeword_newindex=item codeword_oldindex;end%函數(shù)frequency計(jì)算各符號(hào)出現(xiàn)的概率function f=frequency(vect
15、or)ifisa(vector,'uint8') error('input argument must be a uint8 vector');endf=repmat(0,1,256);len=length(vector);for index=0:255 f(index+1)=sum(vector=uint8(index);endf=f./len;%函數(shù)decode返回碼字對(duì)應(yīng)的符號(hào)function byte=decode(code,info)byte=info.huffcodes(code);(1)對(duì)圖像 woman 進(jìn)行編碼cr = 0.6291 Name
16、Size Bytes Class Attributes data 256x256 65536 uint8 unzipped 1x65537 65537 uint8 zipped 1x41226 41226 uint8 (2) 對(duì)圖像 cameraman.tif 進(jìn)行編碼cr = 0.8806 Name Size Bytes Class Attributes data 256x256 65536 uint8 unzipped 1x65537 65537 uint8 zipped 1x57712 57712 uint8 cr =0.8708 Name Size Bytes Class Attribu
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 業(yè)人員培訓(xùn)管理制度
- 網(wǎng)安支隊(duì)設(shè)備管理制度
- 社區(qū)日常消防管理制度
- 專業(yè)自主與管理制度
- 電商公司公物管理制度
- 群眾文藝社團(tuán)管理制度
- 產(chǎn)科手衛(wèi)生管理制度
- 禁止超限運(yùn)輸管理制度
- 小商超閉環(huán)管理制度
- 小兒推拿師管理制度
- 2025年北京市高考英語(yǔ)試卷真題(含答案解析)
- 國(guó)家開(kāi)放大學(xué)本科《商務(wù)英語(yǔ)4》一平臺(tái)機(jī)考真題及答案(第四套)
- 2024年湖北省中考地理生物試卷(含答案)
- 2024年甘肅省天水市中考生物·地理試題卷(含答案)
- GA 1016-2012槍支(彈藥)庫(kù)室風(fēng)險(xiǎn)等級(jí)劃分與安全防范要求
- 2022年小學(xué)六年級(jí)畢業(yè)監(jiān)測(cè)科學(xué)素養(yǎng)測(cè)試題試卷 (含答題卡)
- 行政賠償與行政補(bǔ)償課件
- 繼電器接觸器控制的基本線路.ppt
- 最新國(guó)家開(kāi)放大學(xué)電大《國(guó)際私法》機(jī)考3套真題題庫(kù)及答案2
- (完整版)《普通心理學(xué)-彭聃齡》知識(shí)要點(diǎn)
評(píng)論
0/150
提交評(píng)論