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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3624|回復: 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 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 久久婷婷av | 一区二区三区高清 | 欧美在线观看一区 | 久久久久久综合 | 亚洲一区二区久久 | 一级黄色影片在线观看 | 干出白浆视频 | 国产亚洲一区二区三区 | 欧美一级久久 | 久久一起草 | 国产精品成人久久久久 | 欧美1—12sexvideos | 国产精品视频久久 | 亚洲精品久久久久中文字幕欢迎你 | 高清欧美性猛交xxxx黑人猛交 | 成人免费视频在线观看 | 欧美色综合 | 日韩欧美在线观看视频 | 国产激情一区二区三区 | 国产亚洲精品久久久优势 | 亚洲444eee在线观看 | 日韩中文字幕视频在线观看 | 亚洲一区二区三区在线观看免费 | 免费看一区二区三区 | 亚洲欧美少妇 | 久久亚洲国产精品 | 国产精品a一区二区三区网址 | 国产成人精品一区二区三区在线观看 | 亚欧洲精品在线视频免费观看 | 国产在线激情视频 | 欧美日韩国产一区二区三区 | 久久综合九色综合欧美狠狠 | 国产日产欧产精品精品推荐蛮挑 | 欧州一区二区三区 | 亚洲欧洲在线看 | 四虎永久在线精品免费一区二 | 亚洲精品2区 | 亚洲国产成人在线视频 | 亚洲精选一区二区 | 日韩色在线 | 亚洲高清视频在线观看 |