久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3759|回復: 0
收起左側

基于MATLAB,用哈弗曼編碼對圖像進行編碼

[復制鏈接]
ID:104287 發表于 2016-1-30 20:25 | 顯示全部樓層 |閱讀模式
0.png

clear;
f0=imread('lena.jpg');
subplot(121)
imshow(uint8(f0));
xlabel('\fontsize{16}原始圖像');

f=abs(f0/4)-10;
[M,N]=size(f);

p=zeros(1,61);

for t=1:61
    count=0;
    for i=1:M
        for j=1:N
            if f(i,j)==t-1
                count=count+1;
            end
        end
    end
    p(t)=count;p0=p;
end

core=cell(61,1);
sign=zeros(61);

for hh=1:60
    re=M*N;
    for t=1:61
        if (p(t)<re)&(p(t)>0)
            re=p(t);
        end
    end
    t=1;
    while (p(t)~=re)&(t<61)
        t=t+1;
    end
    if sign(t,1)==0
        core{t}='0';
    else
        core{t}=['0',core{t}];
        i=1;
        while (sign(t,i)~=0)&(i<61)
            core{sign(t,i)}=['0',core{sign(t,i)}];
            i=i+1;
        end
    end
    p(t)=0;
    cou=t;

    re1=M*N;
    for t=1:61
        if (p(t)<re1)&(p(t)>0)
            re1=p(t);
        end
    end
    t=1;
    while (p(t)~=re1)&(t<61)
        t=t+1;
    end
    if sign(t,1)==0
        core{t}='1';
    else
        core{t}=['1',core{t}];
        i=1;
        while (sign(t,i)~=0)&(i<61)
            core{sign(t,i)}=['1',core{sign(t,i)}];
            i=i+1;
        end
    end
    p(t)=p(t)+re;
    cou1=t;
    i=1;
    while (sign(t,i)~=0)&(i<61)
        i=i+1;
    end
    sign(t,i)=cou;
    i=i+1;
    j=1;
    while (sign(cou,j)~=0)&(j<61)
        sign(t,i)=sign(cou,j);
        i=i+1;
        j=j+1;
    end
end  %產生huffman碼

fc=cell(M,N);
for i=1:M
    for j=1:N
        if f(i,j)<61
            fc{i,j}=core{f(i,j)+1};
        else
            fc{i,j}='0';
        end
    end
end %fc
imcore=char();
for i=1:M
    for j=1:N
        imcore=[imcore,fc{i,j}];
    end
end

save picture imcore core; %保存圖片碼流和編碼對應表

  1. clear;
  2. load  picture.mat %載入圖片碼流和編碼對應表
  3. Nc=size(core);
  4. Nic=size(imcore);
  5. flag=0;
  6. i=1;
  7. j=1;
  8. n=1;
  9. cz=char();
  10. f=zeros(128);
  11. for n=1:400930
  12.     if flag==0
  13.         cz=[cz,imcore(n)];
  14.     else
  15.         cz=imcore(n);
  16.         flag=0;
  17.     end
  18.     for t=1:61
  19.         if strcmp(cz,core{t})
  20.             f(j,i)=t;
  21.             flag=1;
  22.             if i>127;
  23.                 i=1;
  24.                 j=j+1;
  25.             else
  26.                 i=i+1;
  27.             end
  28.             break;
  29.         end
  30.     end
  31. end
  32. f=uint8(f*4+35);
  33. subplot(122)
  34. imshow(f);xlabel('\fontsize{16}解碼后的圖像');
復制代碼




tuxiang.rar (33.29 KB, 下載次數: 7)



回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产亚洲精品美女久久久久久久久久 | 久久国产欧美一区二区三区精品 | 在线视频 亚洲 | 欧美日韩在线看 | 精品一区二区在线视频 | 日韩精品极品视频在线观看免费 | 成人精品一区二区三区 | 99re免费| 在线免费亚洲视频 | 国产99久久久国产精品 | 一区视频在线播放 | 国产成人一区二区三区 | 国产免费观看一区 | 国产成人午夜高潮毛片 | 国产色 | 亚洲v日韩v综合v精品v | 日韩欧美亚洲综合 | 黄色一级视频免费 | 天堂一区二区三区 | 台湾佬成人网 | 亚洲国产二区 | 91天堂网| 久久精彩视频 | 一级国产精品一级国产精品片 | 日本精品一区二区三区在线观看 | 亚洲高清视频一区二区 | 日韩欧美国产精品一区二区三区 | 亚洲成人免费视频在线 | 波多野结衣一区二区 | 日韩av高清在线 | 色毛片| 日韩精品成人av | 涩涩视频网站在线观看 | 日韩理论电影在线观看 | 超碰欧美 | 日韩欧美一区二区在线播放 | 久草免费福利 | 日韩av免费在线电影 | 国产四区| 国产91在线观看 | 成人影院在线视频 |