Monday, June 30, 2008
Photomosaic (3)
A=imread('flower.jpg');
>> image(A);
size(A)
ans =
600 400 3
>> B=decrease4(A,20/600,20/400);
image(B)
size(B)
ans =
20 20 3
>> B=255*B;
C=floor(B/86)*86+42;
image(double(C)/255)
I tried to decrease the size of my image to 20x20, but it did not look good.
So I stayed with 40x40.
B=decrease4(A,40/600,40/400);
image(B)
size(B)
ans =
40 40 3
>> image(B)
>>
>>
>> B=255*B;
C=floor(B/86)*86+42;
image(double(C)/255)
>> D=increase2v(C,15);
>> image(D)
Above my 27 colours.
Sunday, June 29, 2008
Photomosaic (2)
PROJECT- PHOTOMOSAIC
Tuesday, June 24, 2008
Assignment # 8, question 4 and 5 (finished)
If we enlarge an image beyond its original size, GIMP calculates the missing pixels by interpolation, but it does not add any new detail. The more an image is enlarged, the more blurred it becomes. The appearance of an enlarged image depends upon the interpolation method we choose.
To change the image size, either some pixels have to be removed or new pixels must be added. The process you use determines the quality of the result. The Interpolation drop down list provides a selection of available methods of interpolating the color of pixels in a scaled image:
Interpolation
• None: No interpolation is used. Pixels are simply enlarged or removed, as they are when zooming. This method is low quality, but very fast.
• Linear: This method is relatively fast, but still provides fairly good results.
• Cubic: The method that produces the best results, but also the slowest method.
Sinc (Lanczos 3): New with GIMP-2.4, this method gives less blur in important resizings.
http://docs.gimp.org/en/gimp-image-scale.html
Question # 5
>> A=imread('Start.jpg');
>> B=decrease2(A,.8);
C=decrease2(A,.6);
D=decrease2(A,.4);
E=decrease2(A,.2);
>>
>> size(A)
ans =
512 768 3
>> size(B)
ans =
409 614 3
>> size(C)
ans =
307 460 3
>> size(D)
ans =
204 307 3
>> size(D)
ans =
204 307 3
>> B=255*B;
C=255*C;
D=255*D;
E=255*E;
A(52:size(B,1)+(52-1),77:size(B,2)+(77-1),:)=B;
A(52*2:size(C,1)+(52*2-1),77*2:size(C,2)+(77*2-1),:)=C;
A(52*3:size(D,1)+(52*3-1),77*3:size(D,2)+(77*3-1),:)=D;
A(52*4:size(E,1)+(52*4-1),77*4:size(E,2)+(77*4-1),:)=E;
image(A)
Assignment 8, question # 3
We may use the same function that we used in assignment #7:
function[B]=increase3(A,f)
A=double(A)/255
p=floor(size(A,1)*f);
q=floor(size(A,2)*f);
for i=0:p-1
for j=0:q-1
c=i/f;
d=j/f;
r=floor(c);
s=floor(d);
if(r>0)&(r<256)&(s>0)&(s<256)
for k=1:3
B(i,j,k)=[1-c+r,c-r]*[A(r,s,k),A(r,s+1,k);
A(r+1,s,k),A(r+1,s+1,k)]*[1-d+s;d-s];
end
end
end
end
A=imread('toyboy.jpg.');
B=decrease3(A,.75);
C=increase(B,4/3);
> image(255*C)
>> size(A)
ans =
160 128 3
>> size(B)
ans =
119 95 3
>> size(C)
ans =
157 125 3
Very similar codes for 2 other pictures.
Assignment 8 - Question # 2
The nearest neighbor approximation
function[B]=increase2v(A,f)
A=double(A)/255;
m=size(A,1);n=size(A,2);
p=floor(f*m);
q=floor(f*n);
for i=0:p-1;
for j=0:q-1;
a=round(i/f);
b=round(j/f);
if ((a<=m-1)&(b<=n-1))
B(i+1,j+1,:)=A(a+1,b+1,:);
end
end
end
commands for pictures:
A=imread('bittersweet.jpg');
B=decrease2(A,.75);
>> C=increase2v(B,4/3);
>> image(C)
>> image(255*C)
size(A)
ans =
107 160 3
>> size(B)
ans =
80 120 3
size(C)
ans =
106 160 3
A=imread('bittersweet.jpg');
>> B=decrease2(A,.25);
>> C=increase2v(B,1/.25);
>> image(C)
>> image(255*C)
>> size(A)
ans =
107 160 3
>> size(B)
ans =
26 40 3
>> size(C)
ans =
102 158 3
>> A=imread('bittersweet.jpg');
>> B=decrease2(A,.1);
>> C=increase2v(B,1/.1);
>> image(C);
>> image(255*C)
>> size(A)
ans =
107 160 3
>> size(B)
ans =
10 16 3
>> size(C)
ans =
95 155 3
Sunday, June 15, 2008
Assignment # 10
unswirled
The code:
function[B]= unswirl(inpic,r,gamma)
inpic=double(inpic)/255;
cx=size(inpic,1)/2;
cy =size(inpic,2)/2;
for x=1:size(inpic,1)
for y=1:size(inpic,2)
d=sqrt((x-cx)^2+(y-cy)^2);
if ((d>r)|(d&gl1))
B(x,y,:)=inpic(x,y,:);
else
if (y>cy)
theta=acos((x-cx)/d);
else
theta=-acos((x-cx)/d);
end
fr=(d/r)^2*(1-d/r)^2*16;
newx=d*cos(theta+gamma*fr)+cx
newy=d*sin(theta+gamma*fr)+cy
ro=floor(newx);
s=floor(newy);
for k=1:3
B(x,y,k)=[1-newx+ro,newx-ro]*[inpic(ro,s,k),inpic(ro,s+1,k);inpic(ro+1,s,k),inpic(ro+1,s+1,k)]*[1-newy+s;newy-s];
end
end
end
end
end
inpic=imread('swirled1.jpg');
image(unswirl(inpic,180,(-3*pi))
Second image:
Code:
function[B]= unswirl(inpic,r,gamma)
inpic=double(inpic);
cx=size(inpic,1)/2;
cy =size(inpic,2)/2;
for x=1:size(inpic,1)
for y=1:size(inpic,2)
d=sqrt((x-cx)^2+(y-cy)^2);
if ((d>r)|(d&gl1))
B(x,y)=inpic(x,y);
else
if (y>cy)
theta=acos((x-cx)/d);
else
theta=-acos((x-cx)/d);
end
fr=(d/r)^2*(1-d/r)^2*16;
newx=d*cos(theta+gamma*fr)+cx
newy=d*sin(theta+gamma*fr)+cy
ro=floor(newx);
s=floor(newy);
B(x,y)=[1-newx+ro,newx-ro]*[inpic(ro,s),inpic(ro,s+1);
inpic(ro+,s),inpic(ro+1,s+1)]*[1-newy+s;newy-s];
end
end
end
inpic=imread('swirled # 2.jpg');
colormap(gray(256));
image(unswirl2(inpic,150,(3*pi)))
Saturday, June 14, 2008
Assignment # 7 - part two (finished)
images using method 3
Method 1- average over all pixels in the destination point:
Code:
function [B]=decrease1(A,f)
A=double(A)/255;
p=floor(size(A,1)*f);
q=floor(size(A,2)*f);
for i=1:3 B(:,:,i)=zeros(p,q);
end
for i=0:p-1
for j=0:q-1
for x=floor(i/f):ceil((i+1)/f)-1
for y=floor(j/f):ceil((j+1)/f)-1
ival=A(x+1,y+1,:);
if (x<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
B(i+1,j+1,:)=B(i+1,j+1,:)+ival;
end
F=imread('raimbowfb.jpg');
image(decrease1(F,.75))
F=imread('raimbowfb.jpg');
image(decrease1(F,.25))
F=imread('raimbowfb.jpg');
image(decrease1(F,.1))
A=imread('bittersweet.jpg');
image(decrease1(A,.75))
>> A=imread('bittersweet.jpg');
image(decrease1(A,.25))
>> A=imread('bittersweet.jpg');
image(decrease1(A,.1)
F=imread('toyboy.jpg');
image(decrease1(F,.1))
>> F=imread('toyboy.jpg');
image(decrease1(F,.25))
For an image toyboy shrunk by a factor of.75, I had to change a second line of the code of the function:
function [B]=decrease1(A,f)
A=double(A)/256;
F=imread('toyboy.jpg');
image(decrease1(F,.75))
Method # 3
Bilinear interpolation of the larger image
Code:
function[B]=decrease3(A,f)
A=double(A)/255
p=floor(size(A,1)*f);
q=floor(size(A,2)*f);
for i=0:p-1
for j=0:q-1
c=i/f;
d=j/f;
r=floor(c);
s=floor(d);
if(r>0)&(r<256)&(s>0)&(s&lgt256)
for k=1:3
B(i,j,k)=[1-c+r,c-r]*[A(r,s,k),A(r,s+1,k);
A(r+1,s,k),A(r+1,s+1,k)]*[1-d+s;d-s];
end
end
end
end
A=imread('rainbowfb.jpg'
image(decrease3(A,.75))
image(decrease3(A,.25))
image(decrease3(A,.1))
A=imread('bittersweet.jpg');
image(decrease3(A,.75))
image(decrease3(A,.25))
image(decrease3(A,.1))
A=imread('toyboy.jpg');
image(decrease3(A,.75))
image(decrease3(A,.25))
image(decrease3(A,.1))
Pictures obtained using method 3- bilinear interpolation seem to be the most clear.
Wednesday, June 11, 2008
Assignment # 9
A=imread('bitter.jpg');
B=floor(A/64)*85;
image(B)
A=imread('toyboy.jpg');
>> B=floor(A/64)*85;
>> image(B)
Question # 3
> A=int16(imread('bitter.jpg'));
>> B=(A(:,:,1)+A(:,:,2)+A(:,:,3))/3;
>> colormap(gray(256));
>> image(B)
Question # 2
a) first option
A=imread('bittersweet.jpg');
>> B=floor((A+64)/128)*128;
>> image(B)
A=imread('toyboy.jpg');
>> B=floor((A+64)/128)*128;
>> image(B)
b) second option
A=imread('bittersweet.jpg');
B=floor(A/85)*128;
image(B)
Question # 4
A=int16(imread('bittersweet.jpg'));
B=(A(:,:,1)+A(:,:,2)+A(:,:,3))/3;
C=floor(B/4)*4;
>> colormap(gray(256));
>> image(C)
A=int16(imread('toyboy.jpg'));
>> B=(A(:,:,1)+A(:,:,2)+A(:,:,3))/3;
C=floor(B/4)*4;
colormap(gray(256));
image(C)
Question # 5
A=int16(imread('toyboy.jpg'));
>> B=(A(:,:,1)+A(:,:,2)+A(:,:,3))/3;
C=floor(B/16)*16;
colormap(gray(256));
image(C)
A=int16(imread('.jpg'));
>> B=(A(:,:,1)+A(:,:,2)+A(:,:,3))/3;
C=floor(B/16)*16;
colormap(gray(256));
image(C)
Assignment #8
Code for shrinking x and y by different factors(average over all pixels in the destination point)
function [B]=decrease4(A,f1,f2)
A=double(A)/255;
p=floor(size(A,1)*f1);
q=floor(size(A,2)*f2);
for i=1:3 B(:,:,i)=zeros(p,q);
end
for i=0:p-1
for j=0:q-1
for x=floor(i/f1):ceil((i+1)/f1)-1
for y=floor(j/f2):ceil((j+1)/f2)-1
ival=A(x+1,y+1,:);
if (x<i/f1) ival=ival*(1+x-i/f1);
end
if(x+1>(i+1)/f1) ival=ival*(1-(x+1)+(i+1)/f1);
end
if(y<j/f2) ival=ival*(1+y-j/f2);
end
if (y+1>(j+1)/f2) ival =ival*(1-(y+1)+(j+1)/f2);
end
B(i+1,j+1,:)=B(i+1,j+1,:)+ival;
end
end
B(i+1,j+1,:)=B(i+1,j+1,:)/(1/f1)/(1/f2);
end
end
A=imread('bittersweet.jpg');
>> image(decrease4(A,1,.5))
a) f1=1, f2=.5
b)f1=.5, f2=1
c) f1=.2 f2=.8
Tuesday, June 10, 2008
Assignment #7 -part one
Function:( in Matlab, thanks to Violetta)
function[B]=decrease2(A,f)
A=double(A)/255;
p=floor(size(A,1)*f);
q=floor(size(A,2)*f);
for i=1:p
for j=1:q
a= round(i/f); b=round(j/f);
B(i,j,:)=A(a,b,:);
end
end
A=imread('rainbowfb.jpg');
>> image(decrease2(A,.75))
A=imread('rainbowfb.jpg');
image(decrease2(A,.25))
A=imread('rainbowfb.jpg');
image(decrease2(A,.1))
f=0.1
A=imread('bittersweet.jpg');
image(decrease2(A,.25))
image(decrease2(A,.75))
image(decrease2(A,.25))
image(decrease2(A,.1))
Sunday, June 1, 2008
ASSIGNMENT # 6
bigT=255*ones(256);
bigT(30:79,64:191)=zeros(50,128);
bigT(50:199,111:146)=zeros(150,36);
bigT1=ones(256);
for x=1:256
for y =1:256
u=x*cos(3*pi/4)+y*sin(3*pi/4);
v=-x*sin(3*pi/4)+y*cos(3*pi/4);
a=u; b=mod(v-u,256)+1;
r=floor(a);s=floor(b);
if((r>0)&(r,256)&(s>0)&(s<256))>
endif
endfor
endfor
imshow(bigT1/255);
imshow(double(bigT1)/255)
#3
a)
compute the average colour for R = ones(100), G= tril(ones (100)0, B=zeros(100);
A(:,:,1)=ones(100);
A(:,:,2)=tril(ones(100));
A(:,:,3)=zeros(100);
B=255*A;
imshow(B)
To get the average colour:
A(:,:,1)=ones(100);
A(:,:,2)=tril(ones(100));
A(:,:,3)=zeros(100);
B=255*A;
size(A)
sum(sum(A))/100/100
C(:,:,1)=1*ones(100);
C(:,:,2)=0.50500*ones(100);
C(:,:,3)=zeros(100);
imshow(C)
images:
b) the rainbow picture we made in assignment #4
pkg load image;
cd C:\;
A=imread(“rainbow.jpg”);
imshow(double(A)/255)
size (A)
sum(sum(A))/(303*376)
B(:,:,1)=221.79*(ones(256));
B(:,:,2)=220.09*(ones(256));
B(:,:,3)=213.46*(ones(256));
imshow(B)
c)
pkg load image;
cd C:\;
A=imread(“biter.jpg”);
imshow(double(A)/255)
'
size (A)
ans =
107 160 3
sum(sum(A))/(107*160)
ans(:,:,1) = 82.482
ans(:,:,2) = 98.460
ans(:,:,3) = 14.894
ans/256
B=ones(256);
B(:,:,1) = 0.32346*ones(256);
B(:,:,2) = 0.38612*ones(256);
B(:,:,3) = 0.058407*ones(256);
imshow(B)
The average colour is the "mixed" green of all greens of this picture.
d)
pkg load image;
cd C:\;
A=imread("toyboy.jpg");
size(A)
ans =
160 128 3
sum(sum(A))/(160*128)
ans =
ans(:,:,1) = 30.857
ans(:,:,2) = 46.076
ans(:,:,3) = 62.843
ans/256
ans =
ans(:,:,1) = 0.12054
ans(:,:,2) = 0.17998
ans(:,:,3) = 0.24548
C=ones(256);
C(:,:,1)=0.12054*ones(256);
C(:,:,2)=0.17998*ones(256);
C(:,:,3)=0.24548*ones(256);
imshow(C)
The average colour is the mixture of "blues" in this picture.
#2