Sunday, June 29, 2008
Strawberries & Kiwi Photomosaic -Completed!
After struggling for hours trying to figure out where my one little and annoying error hid, I am relieved and excited that my fruit photomosaic worked. Thanks to Saajida who helped me to realized that one of my 10 images that I used below had reverted back to the original size. I'm telling you Octave loves playing games. However, I am very pleased with this image. Now, that I know how to create photomosaics, I am eager to create a family photomosaic ...that is when I have some free time!
Step 1: Original Image (400x400)
Step 2: I shrunk and enlarged my original image and then I reduced the image to 27 colours. This part was easy!
Step 3: The 10 Images Used
All 10 images had to be resized and saved as ".png" file. This probably took the most time. My photomosaic did not require all 27 possible colours therefore, I only selected colour images that were need in my image of strawberries and kiwi. I tried to display the photos in a nice, uniform order unfortunately, the same image that game me problems in the photomosaics, continued to produce errors when placing it into a matrix for display. Here are the 10 images that I used to produce my fruit photomosaic.
Step 4: Octave Commands
M(:,:,1)=ones(10);M(:,:,2)=ones(10);M(:,:,3)=ones(10);M1=imread("black2.png");M2=imread("green4.png");M3=imread("burgundy3.png");M4=imread("purple3.png");M5=imread("huntergree3.png");M6=imread("green_beans3.png");M7=imread("rose3.png");M8=imread("pink3.png");M9=imread("banana3.png");M10=imread("pineapple4.png");M11=[M1,M2,M,M,M,M,M,M,M,M3,M,M4,M5,M,M,M6,M,M,M7,M,M,M,M8,M,M9,M10,M];M41(:,:,1)=42;M41(:,:,2)=42;M41(:,:,3)=42;M42(:,:,1)=42;M42(:,:,2)=42;M42(:,:,3)=128;M43(:,:,1)=42;M43(:,:,2)=42;M43(:,:,3)=214;M44(:,:,1)=42;M44(:,:,2)=128;M44(:,:,3)=42;M45(:,:,1)=42;M45(:,:,2)=128;M45(:,:,3)=128;M46(:,:,1)=42;M46(:,:,2)=128;M46(:,:,3)=214;M47(:,:,1)=42;M47(:,:,2)=214;M47(:,:,3)=42;M48(:,:,1)=42;M48(:,:,2)=214;M48(:,:,3)=128;M49(:,:,1)=42;M49(:,:,2)=214;M49(:,:,3)=214;M50(:,:,1)=128;M50(:,:,2)=42;M50(:,:,3)=42;M51(:,:,1)=128;M51(:,:,2)=42;M51(:,:,3)=128;M52(:,:,1)=128;M52(:,:,2)=42;M52(:,:,3)=214;M53(:,:,1)=128;M53(:,:,2)=128;M53(:,:,3)=42;M54(:,:,1)=128;M54(:,:,2)=128;M54(:,:,3)=128;M55(:,:,1)=128;M55(:,:,2)=128;M55(:,:,3)=214;M56(:,:,1)=128;M56(:,:,2)=214;M56(:,:,3)=42;M57(:,:,1)=128;M57(:,:,2)=214;M57(:,:,3)=128;M58(:,:,1)=128;M58(:,:,2)=214;M58(:,:,3)=214;M59(:,:,1)=214;M59(:,:,2)=42;M59(:,:,3)=42;M60(:,:,1)=214;M60(:,:,2)=42;M60(:,:,3)=128;M61(:,:,1)=214;M61(:,:,2)=42;M61(:,:,3)=214;M62(:,:,1)=214;M62(:,:,2)=128;M62(:,:,3)=42;M63(:,:,1)=214;M63(:,:,2)=128;M63(:,:,3)=128;M64(:,:,1)=214;M64(:,:,2)=128;M64(:,:,3)=214;M65(:,:,1)=214;M65(:,:,2)=214;M65(:,:,3)=42;M66(:,:,1)=214;M66(:,:,2)=214;M66(:,:,3)=128;M67(:,:,1)=214;M67(:,:,2)=214;M67(:,:,3)=214;M12=[M41,M42,M43,M44,M45,M46,M47,M48,M49,M50,M51,M52,M53,M54,M55,M56,M57,M58,M59,M60,M61,M62,M63,M64,M65,M66,M67];M13=imread("fruit3.png");s=10;for i=1:10:400;for j=1:10:400for m=1:27;if M13(i,j,:)==M12(1,m,:);M13(i:i+s-1,j:j+s-1,:)=M11(1:10,(m-1)*s+1:m*s,:);end;end;end;end;
imshow(double(M13)/255);
Sunday, June 22, 2008
Brightness and Contrast
The following image is of a darkroom. It is virtually impossible to see anything.
Through the use of GIMP, I was able to change the brightness of the image by using colours and then going to curves in the GIMP program.
In the following image, I changed the constrast. Although it is still fairly blurry, one can see the room, countertop and the device box on top of the countertop. I'm assuming the box is where the film is processed??? You can see that the door to the box is opened. Pretty cool! Now let's see if I can do the same in Matlab??????
Saturday, June 21, 2008
Photomosaic Mickey Mouse
After reviewing many, many images, I have decided to use the Mickey Mouse image. This image provided a lot of contrast which I believe will define the colours more easily.
The size of the original image is 425, 300, 3.
Step 2:
I reduced the image by a factor of 0.1 using the nearest neighbour method. After speaking to my buddy, Saajida, and reviewing the dicussion board in facebook, I decided to save all my images with a '.png' extensions.
The reduced size of this image is 42,30,3.
Step 3:
I enlarged my shrunken image in step 2 by double the original size.
The enlarged image size is 840, 600,3.
Step 4:
I have reduced my image to 27 colours using the following command: B=floor(double(A)/86)*86+42;
My image surprised me. The original white background displays a grey tone when I reduced the colours. Furthermore, there were not many significant colour change. The reduced colour looks very similar to the original colours.
Since there didn't seem a huge change in the colour tones I reduced the colour of my original sized image. As you can see there is not a lot of change. I believe this occurred because my image displays more of the primary colours.
Original image reduced to 27 colours
Step 5:
Here are the 27 possible colours. They are in reverse starting with colour(214,214,214....42,42,42). I was fooling around with the various colours and although the colours are not displayed in a nice template form, I thought it would be foolish to redo the colours since the colours are visible. Now the fun begins....
Step 6:
Collecting images.....I originally had different Walt Disney characters, but with varying image sizes and skewing the rows and columns didn't help. So I decided after days of work, I would try using one image in 27 different colours.
Step 7
Replacing the small images into the large image. Well, not what I expected. I'm not too sure why the image turned out the way it did. I have been on the computer for 14 hours and I have tried to resolve the problem,. I have even tried to replace the large image of Mickey with different images. I still get straight lines throught my image. My other thought was that perhaps there is something in the image that I could not see and in fact the pixels are being replaced properly. Either way after all that work, I was very disappointed with the results. I am going to try another one. Octave commands for this image are listed below.
OCTAVE COMMANDS USED
cd c:\users\tim\pictures
M((,:,1)=ones(10);M(:,:,2)=ones(10);M(:,:,3)=ones(10);
M1=imread("lion2(42,42,42).png");M11=floor(double(M1)/86)*86+42;M2=imread("lion2(42,42,214).png");M12=floor(double(M2)/86)*86+42;M3=imread("lion2(128,42,42).png");M13=floor(double(M3)/86)*86+42;M4=imread("lion2(214,42,42).png");M14=floor(double(M4)/86)*86+42;M5=imread("lion2(214,128,42).png");M15=floor(double(M5)/86)*86+42;M6=imread("lion2(214,214,42).png");M16=floor(double(M6)/86)*86+42;M7=imread("teresa.png");
M8=[M11,M,M12,M,M,M,M,M,M,M13,M,M,M,M,M,M,M,M,M14,M,M,M15,M,M,M16,M,M7];
M41(:,:,1)=42;M41(:,:,2)=42;M41(:,:,3)=42
M42(:,:,1)=42;M42(:,:,2)=42;M42(:,:,3)=128;
M43(:,:,1)=42;M43(:,:,2)=42;M43(:,:,3)=214;
M44(:,:,1)=42;M44(:,:,2)=128;M44(:,:,3)=42;
M45(:,:,1)=42;M45(:,:,2)=128;M45(:,:,3)=128;
M46(:,:,1)=42;M46(:,:,2)=128;M46(:,:,3)=214;
M47(:,:,1)=42;M47(:,:,2)=214;M47(:,:,3)=42;
M48(:,:,1)=42;M48(:,:,2)=214;M48(:,:,3)=128;
M49(:,:,1)=42;M49(:,:,2)=214;M49(:,:,3)=214;
M50(:,:,1)=128;M50(:,:,2)=42;M50(:,:,3)=42;
M51(:,:,1)=128;M51(:,:,2)=42;M51(:,:,3)=128;
M52(:,:,1)=128;M52(:,:,2)=42;M52(:,:,3)=214;
M53(:,:,1)=128;M53(:,:,2)=128;M53(:,:,3)=42;
M54(:,:,1)=128;M54(:,:,2)=128;M54(:,:,3)=128;
M55(:,:,1)=128;M55(:,:,2)=128;M55(:,:,3)=214;
M56(:,:,1)=128;M56(:,:,2)=214;M56(:,:,3)=42;
M57(:,:,1)=128;M57(:,:,2)=214;M57(:,:,3)=128;
M58(:,:,1)=128;M58(:,:,2)=214;M58(:,:,3)=214;
M59(:,:,1)=214;M59(:,:,2)=42;M59(:,:,3)=42;
M60(:,:,1)=214;M60(:,:,2)=42;M60(:,:,3)=128;
M61(:,:,1)=214;M61(:,:,2)=42;M61(:,:,3)=214;
M62(:,:,1)=214;M62(:,:,2)=128;M62(:,:,3)=42;
M63(:,:,1)=214;M63(:,:,2)=128;M63(:,:,3)=128;
M64(:,:,1)=214;M64(:,:,2)=128;M64(:,:,3)=214;
M65(:,:,1)=214;M65(:,:,2)=214;M65(:,:,3)=42;
M66(:,:,1)=214;M66(:,:,2)=214;M66(:,:,3)=128;
M67(:,:,1)=214;M67(:,:,2)=214;M67(:,:,3)=214;
M9=[M41,M42,M43,M44,M45,M46,M47,M48,M49,M50,M51,M52,M53,M54,M55,M56,M57,M58,M59,M60,M61,M62,M63,M64,M65,M66,M67];
M10=imread("mic3.png");
s=10;
for i=1:10:840;
for j=1:10:600;
for m=1:27;
if M10(i,j,:)==M9(1,m,:);
M10(i:i+s-1,j:j+s-1,:)=M8(1:10,(m-1)*s+1:m*s,:);
end; end; end; end;
imshow(double(M10)/255);
Well, I thought I would try my original image (strawberries and kiwis). I also decided to struggle through resizing different images to replace into my fruit image. Well, sad to say, I ran into another brick wall. I hoping to resolve this problem very soon also!
Thursday, June 12, 2008
Assignment 10 "Unswirl Stars" (Optional)
Octave Codes
function [outpic]=swirl(inpic,r,gamma);
inpic=double(inpic);
gamma=gamma*pi/180;
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<1);>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;
rp=floor(newx);
s=floor(newy);
for k=1:3;
outpic(x,y,k)=[1-newx+rp,newx-rp]*[inpic(rp,s,k),inpic(rp,s+1,k);inpic(rp+1,s,k),inpic(rp+1,s+1,k)]*[1-newy+s;newy-s];
end;
end;
end;
end;
end;
A=imread('star1.jpg');
B=swirl(A,180,-540);
imshow(double(B)/255);
Jennifer Aniston
Fabio (r=150, gamma=540)
Tuesday, June 10, 2008
Assignment #9
Question 2: Method 1: Convert images to images with only 27 colours
A=imread('picture1.jpg');
B=floor(double(A)/85)*128;
imshow(B/256);
Picture1
Question 3: Convert images to greyscale images
A=imread('picture1.jpg');
B=(A(:,:,1)+A(:,:,2)+A(:,:,3))/3;
imshow(B);
Question 4: Greyscale image with only 64 intensity values
A=imread('picture1.jpg');
C=floor(B/4)*4;
imshow(C);
Sunday, June 8, 2008
Assignment 8 Question 5
Mp = floor(size(picture,1)*f);
Np = floor(size(picture,2)*f);
smallimage(:,:,1)=zeros(Mp,Np);
smallimage(:,:,2)=zeros(Mp,Np);
smallimage(:,:,3)=zeros(Mp,Np);
for i = 1:(Mp-1);
for j = 1:(Np-1);
a=round(i/f);
b=round(j/f);
smallimage(i+1,j+1,:)=picture(a+1,b+1,:);
end;
end;
endfunction;
Octave commands:
A=imread('blueyellow.jpg');
pic1=shrink2(pic,0.2);
pic2=shrink2(pic,0.4);
pic3=shrink2(pic,0.6);
pic4=shrink2(pic,0.8);
A(52:460,77:690,:)=pic4;
A(103:409,154:613,:)=pic3;
A(154:357,231:537,:)=pic2;
A(205:306,308:460,:)=pic1;
imshow(double(A)/255);
Assignment 8 Question 4
According to Chapter 2 in the text, p. 67, although, bilinear interpolation gives a more favourable image when compared to the original. Programs such as GIMP and Photoshop must work in bicubic interpolation which yields a higher contrast and smoother colour transition than bilinear interpolation when compared to the original image.
Assignment 8 Question 3
picture=double(picture);
Mp=floor(size(picture,1)*f);
Np=floor(size(picture,2)*f);
for i=0:(Mp-1);
for j=0:(Np-1);
a=(i/f);
b=(j/f);
r=floor(a);
s=floor(b);
if (r>0) & (r<256)>0) & (s<256); for k=1:3; smallimage(i,j,k)=[1-a+r,a-r]*[picture(r,s,k),picture(r,s+1,k); picture(r+1,s,k), picture(r+1,s+1,k)]*[1-b+s; b-s]; end; end; end; end; endfunction;
From assignment 7 spectrum.jpg (f=0.75) size(80 149 3)
(f=1.25) size(99 185 3)
(f=0.25) size(26 49 3)
(f=2) size (51 97 3)
From assignment 7 picture1.jpg
(f=0.75) size (112 119 3)
(f=1.25) size (139 147 3)
(f=0.25) size (36 39 3)
(f=2) size (71 77 3)
(f=0.1) size (14 15 3)
(f=2) size( 27 29 3)
(f=0.25) size(38 39 3)
(f=2) size (75 77 3)
(f=0.1) size (14 15 3)
(f=2) size (27 29 3)