Problem regarding image processing in binary image
2 views (last 30 days)
Show older comments
Adrian Lim
on 11 Jul 2018
Commented: KALYAN ACHARJYA
on 30 Jul 2018
I'm currently working on image processing on an image on streets. Here are the codes I'm currently using
C=im2double(img);
B=im2double(bgd);
maxchan=max(B,[],3);
threshmax = multithresh(maxchan,4);Qmax=imquantize(maxchan,threshmax);
bw=bwareafilt( Qmax==2,1);
bw=imclose(bw,strel('disk',10));
D=rgb2gray(bw.*(C-B));
thresh=multithresh(D,2);
result=bwareafilt( imquantize(D,thresh)>1, [10,inf]);
result2=imfill(result,'holes')
imshow(result2)
Then, I'll have a result as following
Are there any solutions to get a more complete car-shaped white blob and remove the lines on the road ?? This is because I'm attempting to count the number of the cars. There is another problem where if i take another picture with different lighting or different angle, the result of the image could be worse where i could not see any blobs. The images of the current image are attached as .m files. Thank you in advance. The other pictures where I could not extract anything are also attached.
0 Comments
Accepted Answer
Image Analyst
on 11 Jul 2018
I'd use imclose() first to connect some separate blobs, like the car split into two or 3 parts due to a luggage rack on the roof. Then use bwareaopen() or bwareafilt() to get rid of blobs smaller than a certain size.
4 Comments
Image Analyst
on 11 Jul 2018
Edited: Image Analyst
on 11 Jul 2018
Your segmentation algorithm is not robust enough. What have you tried? Have you tried the tracking stuff int he Computer Vision System Toolbox? Have you tried using Gaussian Mixture Models? Or even just taking a recent mode image to get the background? Sorry but I can't help you develop a robust turnkey car counting system - that could take months.
Some code is here: https://www.mathworks.com/help/vision/examples/detecting-cars-using-gaussian-mixture-models.html?prodcode=VP&language=en
and here:
More Answers (1)
KALYAN ACHARJYA
on 11 Jul 2018
%% To remove roads
LB=2000;
seg=bwareaopen(result2,LB);
figure, imshow(seg)
See Also
Categories
Find more on Image Processing and Computer Vision in Help Center and File Exchange
Products
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!