data:image/s3,"s3://crabby-images/7fef2/7fef2d24aef34a668bfa7b3feb411c309d2107e5" alt=""
The image that would be segmented (test image):
data:image/s3,"s3://crabby-images/36b29/36b29ca1301ce014457722b68b0f3d2f110ed2da" alt=""
data:image/s3,"s3://crabby-images/4f7c5/4f7c5c04e68217e39229e594100d2d107607497a" alt=""
A. Probability Function Estimation
In this method, we assumed a gaussian distribution for the r and g of the sample patch. Therefore, the probability that a pixel with chromaticity r belongs to the region of interest is:
data:image/s3,"s3://crabby-images/eedd2/eedd2a60aa63c3bec9cfd5ad3196c60c012cfa34" alt=""
Using this equation and the test and sample image, I obtained the following image:
data:image/s3,"s3://crabby-images/1017a/1017a637ba7879a5cb9b68b2bc1600373f51c984" alt=""
B. Histogram Backprojection
For this method, we first calculated the 2D histogram of the sample patch. For each pixel in the test image, we substitute the frequency value of the r and g from the 2D histogram of the patch.
The figure below shows the histogram of the sample patch superimposed on the NCC.
data:image/s3,"s3://crabby-images/369b3/369b3ebcfad19ad7f96ad1611b256a26fbff4f94" alt=""
data:image/s3,"s3://crabby-images/d9698/d9698dd107f6e11d2594f0e7bfeae2829ffcf4e2" alt=""
//Scilab code
im = imread("sample--.jpg");
im2 = imread("image.jpg");
ave = im(:, :, 1) + im(:, :, 2) + im(:, :, 3);
r = im(:, :, 1)./ave;
g = im(:, :, 2)./ave;
b = im(:, :, 3)./ave;
ave = im2(:, :, 1) + im2(:, :, 2) + im2(:, :, 3);
ri = im2(:, :, 1)./ave;
gi = im2(:, :, 2)./ave;
bi = im2(:, :, 3)./ave;
mr = mean(r);
mg = mean(g);
stdr = stdev(r);
stdg = stdev(g);
pr = (1/(stdr*sqrt(2*%pi)))*exp(-((ri - mr).^2)./(2*stdr));
pg = (1/(stdg*sqrt(2*%pi)))*exp(-((gi - mg).^2)./(2*stdg));
prpg = pr.*pg;
scf(0);
imshow(prpg, []);
//Histogram Backprojection
//2D Histogram
r = r*255;
g = g*255;
imsize = size(r);
recurrence = zeros(256,256);
for i = 1:imsize(1)
for j = 1:imsize(2)
//x and y were re-oriented so that index (1, 1) would be at the origin of the
//normalize chromaticity plot
x = abs(255 - round(g(i, j)) + 1);
y = round(r(i, j)) + 1;
recurrence(x, y) = recurrence(x, y) + 1;
end
end
scf(1)
imshow(log(recurrence + 0.0000001), []);
//Histogram end
ri = ri*255;
gi = gi*255;
im3 = zeros(size(prpg));
imsize2 = size(ri);
for i = 1:imsize2(1)
for j = 1:imsize2(2)
x = abs(255 - round(gi(i, j)) + 1);
y = round(ri(i, j)) + 1;
im3(i, j) = recurrence(x, y);
end
end
scf(2);
imshow(im3);
//code end
I give myself a grade of 10 since I was able to do it properly ^_^
Collaborators: Raf Jaculbia
No comments:
Post a Comment