matlab反量化,matlab jpeg反量化

满意答案

02ae427d08e371d7e90d5b995e828d6d.png

WendyDounts

2013.11.13

02ae427d08e371d7e90d5b995e828d6d.png

采纳率:47%    等级:12

已帮助:11517人

%读入指定途径的图像

rgb=imread('图像所在加上盘符'); %RGB转换为YUV,即YCbCr

yuv=rgb2ycbcr(rgb);

%将得到的YUV转换为可进行数学运算的double类型,原来为uint8 类型

yuv=double(yuv);

%分别提取其中的Y,U,V矩阵

y=yuv(:,:,1);

u=yuv(:,:,2);

v=yuv(:,:,3);

%设定量化步长

eql=8;

%设定块操作时dct矩阵

T = dctmtx(8);

%将Y,U,V矩阵分割为8*8 的小块,并对每个小块进行DCT变换

y_dct=blkproc(y,[8,8],'P1*x*P2',T, T');

u_dct=blkproc(u,[8,8],'P1*x*P2',T, T');

v_dct=blkproc(v,[8,8],'P1*x*P2',T, T');

%将得到的DCT系数除以量化步长

y_dct=y_dct/eql;

u_dct=u_dct/eql;

实验七 JEPG图像编码

85

v_dct=v_dct/eql;

%将量化后的系数四舍五入

y_dct_c=fix(y_dct);

u_dct_c=fix(u_dct);

v_dct_c=fix(v_dct);

%反量化

y_dct_c=y_dct_c*eql;

u_dct_c=u_dct_c*eql;

v_dct_c=v_dct_c*eql;

%进行DCT反变换

y_idct=blkproc(y_dct_c,[8,8],'P1*x*P2', T^-1,(T')^-1);

u_idct=blkproc(u_dct_c,[8,8],'P1*x*P2', T^-1,(T')^-1);

v_idct=blkproc(v_dct_c,[8,8],'P1*x*P2', T^-1,(T')^-1);

%恢复为YUV矩阵,转换为uint8 类型,

yuv(:,:,1)=y_idct;

yuv(:,:,2)=u_idct;

yuv(:,:,3)=v_idct;

yuv=uint8(yuv);

%YUV转换为RGB

rgb1=ycbcr2rgb(yuv);

%显示两幅图像

subplot(211),imshow(rgb),title('原始图像');

subplot(212),imshow(rgb1),title('处理后图像');

00分享举报

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值