现在时间是:
当前位置:首 页 >> Matlab>> 教学区>> 文章列表

彩色图片的压缩

作者:17074159   发布时间:2019-05-25 17:39:51   浏览次数:94

clc
clear all
I=imread('C:Program Files (x86)gakatakaStudentrecvtets.jpg');
imshow(I);
%quaternion representation
[m,n]=size(I(:,:,1));
A0=zeros(m,n);
A1=double(I(:,:,1));
A2=double(I(:,:,2));
A3=double(I(:,:,3));
A=[A0 A2 A1 A3];
%svd
[U S V]=svdQ(A);
k=1;
Sx=S(1:k,1:k);
while(sum(sum(Sx))/sum(sum(S))<0.95)
    J=timesQ(U(:,[1:k,m+1:m+k,2*m+1:2*m+k,3*m+1:3*m+k]),[Sx,zeros(k,3*k)]);
    J=timesQ(J,transQ(V(:,[1:k,n+1:n+k,2*n+1:2*n+k,3*n+1:3*n+k])));
    %refactor
    [jm,jn]=size(J);
    jn=jn/4;
    X(:,:,2)=J(:,jn+1:2*jn);
    X(:,:,1)=J(:,2*jn+1:3*jn);
    X(:,:,3)=J(:,3*jn+1:4*jn);
    figure;
    imshow(uint8(X));
    k=k+1;
    Sx=S(1:k,1:k);
end

注:while循环的作用

若压缩后的图形与原图值的比即压缩后图片清晰度小于0.95,继续执行循环,直到清晰度>=0.95

以此保证压缩后图片的清晰度

 







上一篇:没有了    下一篇:没有了

Copyright ©2020    计算数学达人 All Right Reserved.

技术支持:自助建站 | 领地网站建设 |短信接口 |燕窝 版权所有 © 2005-2020 lingw.net.粤ICP备16125321号 -5