function [smallimage]=shrink2(girl,f);
Mp = floor(size(girl,1)*f);
Np = floor(size(girl,2)*f);
smallimage(:,:,1) = zeros(Mp-1,Np-1);
smallimage(:,:,2) = zeros(Mp-1,Np-1);
smallimage(:,:,3) = zeros(Mp-1,Np-1);
for i=0:(Mp-1);
for j=0:(Np-1);
a=floor((i/f)+1);
b=floor((j/f)+1);
if (a>0)&(a<(size(girl,1)))&(b>0)&(b<(size(girl,2)));
smallimage(i+1,j+1,:)=girl(a,b,:);
end;
end;
end;
endfunction;
To show the image on Octave, I used these commands:
A=imread("girl.jpg");
B=shrink2(A,f);
C=double(B)/255;
imwrite("girl75.jpg",C(:,:,1),C(:,:,2),C(:,:,3))
Using this command, you can differ the f factor and receive these scale reductions.
f=0.75 f=0.25 f=0.1
data:image/s3,"s3://crabby-images/071d7/071d7d7bb397478eed4bfb24246b358642f70685" alt=""
data:image/s3,"s3://crabby-images/9a1fe/9a1feeb081942b88abf3b4b57fa22f760bd909a3" alt=""
data:image/s3,"s3://crabby-images/86fc4/86fc4ca87dcc488215dbfc0a3a694a946d903ea1" alt=""
The same was done for the other two pictures.
data:image/s3,"s3://crabby-images/c66d7/c66d7162eb60acefe73b8e1be09a86e6728b66a9" alt=""
data:image/s3,"s3://crabby-images/25837/258370428b4d2ef5e1cde4fc2aa0e5973d879f4d" alt=""
data:image/s3,"s3://crabby-images/eb7a6/eb7a64ae2922f14ab685fe47b6298556a353db85" alt=""
data:image/s3,"s3://crabby-images/a6a37/a6a37dd6a530b9c6d634e67ab41c7747cb3d0e50" alt=""
data:image/s3,"s3://crabby-images/76a8c/76a8cb81e5d79602bbb9fa7730144534e36d86d0" alt=""
data:image/s3,"s3://crabby-images/9c765/9c7657f65d76296b383ab2de2c69f140fee9adaa" alt=""
Method 3 - Bilinear Interpolation
function [smallimage]=shrink3(girl,f);
girl=double(imread("girl.jpg"));
Mp = floor(size(girl,1)*f);
Np = floor(size(girl,2)*f);
smallimage(:,:,1) = zeros(Mp-1,Np-1);
smallimage(:,:,2) = zeros(Mp-1,Np-1);
smallimage(:,:,3) = zeros(Mp-1,Np-1);
for i = 0:(Mp-1);
for j = 0:(Np-1);
a = i/f;
b = j/f;
r = floor(a);
s = floor(b);
if (r greaterthan 0)&(r lessthan256)&(s greaterthan 0)&(s lessthan256);
for k=1:3;
smallimage(i,j,k) = [1–a+r,a–r]*[girl(r,s,k), girl(r,s+1,k); girl(r+1,s,k),girl(r+1,s+1,k)]*[1–b+s;b–s];
end;
end;
end;
end;
endfunction;
data:image/s3,"s3://crabby-images/d543b/d543ba51ddb599f5dac36f0d11ce0267dde0ca30" alt=""
data:image/s3,"s3://crabby-images/08a4e/08a4e5e0577e588f7eb7932634cda20989a43c54" alt=""
The next two pics and their f factor shrink.
data:image/s3,"s3://crabby-images/f14df/f14dff75dc2112a8667ae64598392e5974df70e6" alt=""
data:image/s3,"s3://crabby-images/a8f40/a8f40fdc3d3ea3e5bc862fd812b2b300bb840091" alt=""
data:image/s3,"s3://crabby-images/f44cb/f44cba788907a29174e7ce06e8f2e4b2b78b7c89" alt=""
data:image/s3,"s3://crabby-images/1dea9/1dea96f8d7ee50347375e585a1d7586e71d6e259" alt=""
data:image/s3,"s3://crabby-images/63a8c/63a8c4e774ed5e8def7070a5c7be01a6011c3ecb" alt=""
data:image/s3,"s3://crabby-images/82169/8216971b9446ff3de069b533c4b3b843b3f7afcd" alt=""
Method 1 : Average over all pixels.
function [smallimage]=shrink1(girl,f);
girl=double(imread("girl.jpg"));
Mp = floor(size(girl,1)*f);
Np = floor(size(girl,2)*f);
smallimage(:,:,1) = zeros(Mp,Np);
smallimage(:,:,2) = zeros(Mp,Np);
smallimage(:,:,3) = zeros(Mp,Np);
for i = 0 : (Mp – 1);
for j = 0 : (Np – 1);
for x =floor(i/f): ceil((i + 1)/f)-1;
for y =floor(j/f): ceil((j + 1)/f)-1;
ival=girl(x+1,y+1,:);
if (x lessthan (i/f));
ival=ival*(1+x–(i/f));
end;
if ((x + 1) > ((i + 1)/f));
ival = ival * (1 – (x + 1)+((i + 1)/f));
end;
if (y < (j/f)); ival = ival * (1 + y – (j/f)); end; if ((y + 1) > ((j + 1)/f));
ival = ival * (1 – (y + 1)+((j + 1)/f));
end;
smallimage(i+1,j+1,:) = smallimage(i+1,j+1,:) + ival;
end;
end;
smallimage(i+1,j+1,:)=smallimage(i+1,j+1,:)/(1/f)^2;
end;
end;
endfunction;
to show image:
A=imread('picturename.jpg');
B=shrink1(A,f);
C=double(B)/255;
imwrite("end.jpg",C(:,:,1),C(:,:,2),C(:,:,3))
These are the pics of "girl.jpg" with f factors 0.75, 0.25, and 0.10 respectively.
data:image/s3,"s3://crabby-images/b6c13/b6c1379e14bc1a3fac600b01afae900872d00f6c" alt=""
data:image/s3,"s3://crabby-images/73e1b/73e1b2d214ab1f22ea509831423fe7d90fc364fd" alt=""
data:image/s3,"s3://crabby-images/bd7af/bd7afe76895cbe7727dd43835fdfe51a8ce37a23" alt=""
Here are the two other pics with their shrink factors using the average method.
data:image/s3,"s3://crabby-images/3df2a/3df2a028c92f62ef621b75f29af2f97609628bda" alt=""
data:image/s3,"s3://crabby-images/7c95f/7c95f4a0d25a2060ba5ea373d629e95338ef8c12" alt=""
data:image/s3,"s3://crabby-images/04c56/04c56dd383ab480db7272bea62487d9274636566" alt=""
data:image/s3,"s3://crabby-images/45878/4587817e2e15a4c4501ef12ebf67c5220f3cd45e" alt=""
data:image/s3,"s3://crabby-images/745d4/745d41ad0a730fc4d71e05c82a692066b284c430" alt=""
data:image/s3,"s3://crabby-images/f16f7/f16f7bf1f1265b9d9ce493830b37a6dcc958ceaf" alt=""
No comments:
Post a Comment