data:image/s3,"s3://crabby-images/443a1/443a13d9ba134738e0fccd059efb894232c4f149" alt=""
The first thing I did was to get the Fourier transform of the image so that I can make an appropriate filter. Since I wanted to remove the table, I created a filter which would block all the horizontal and vertical lines (shown below).
data:image/s3,"s3://crabby-images/fce74/fce740cfd480ec325f6250ec153e34793f3682b3" alt=""
data:image/s3,"s3://crabby-images/0876d/0876d2d48ea30dad988f586ecdc2708cb4feabc8" alt=""
Since have no program that can estimate the best threshold, I estimated it using trial and error. After thresholding:
data:image/s3,"s3://crabby-images/d4cff/d4cff9cff07914b1570a75fb5dd66951144588ba" alt=""
Most of the table lines are now gone but some lines still remain in the left side of the image :( And also, most of the text are now unreadable (they were quite unreadable to begin with) and the text in the fourth column are now gone since they were written lightly.
To further enhance the image, I used the opening and closing operators with a 2x2 structuring element. Also to make the width of the letters 1 pixel, I eroded the image with a 2x1 structuring element.
data:image/s3,"s3://crabby-images/fc94a/fc94a63b3eda4eb2681d311cb772cf0ec2272962" alt=""
data:image/s3,"s3://crabby-images/6d9ad/6d9ad13d893d9e20a86df3e85949f6ba268dfea9" alt=""
//Scilab code
image1 = imread("text-fft-filter3.bmp") - 1;
image2 = imread("text.bmp") - 1;
se1 = imread("se1.bmp"); //a 2x1 structuring element
se2 = imread("se3.bmp"); // a 2x2 structuring element
fftimage1 = fftshift(image1);
fftimage2 = fft2(image2);
image1_2 = fftimage1.*fftimage2;
infft = fft2(image1_2);
fimage = real(infft);
fimage = (fimage/max(fimage)) * 255;
[x, y] = histogram(fimage);
scf(1);
imshow(fimage, []);
//bar(x,y)
threshold = (find(y == max(y), 1) - 30)/255;
image = im2bw(fimage, threshold);
scf(2);
imshow(image, [])
image = abs(image - 1);
//Opening
image = dilate(erode(image, se2, [1,1]), se2, [1,1]);
//Closing
image = erode(dilate(image, se2, [1,1]), se2, [1,1]);
image = erode(image, se1, [1,1]);
scf(3);
imshow(image, []);
labeled = bwlabel(image, 4);
scf(4);
imshow(labeled, []);
//end of code
For this activity, I give myself a grade of 9 since I can't find the proper threshold for the image.
Collaborators: None
1 comment:
Hello Ed,
Indeed it is hard to find a fixed global threshold. What is usually done is to select an optimum threshold per sub-block of the image. So then it becomes a local thresholding.
Post a Comment