How can I find circle diameter using arc ?
Show older comments
I need to find the diameter of a circle. However, the whole circle is not visible in the image, only the arc is shown. How can i find the diameter of the circle using this arc alone ?

Accepted Answer
More Answers (4)
sloppydisk
on 3 Jun 2018
0 votes
Take three points on the arc, draw lines between them and take the bissectors of those lines, where they meet is the center O. The radius is the distance from any of the points to the center O.

10 Comments
Syed Sameer Ul Hasan
on 3 Jun 2018
Edited: Syed Sameer Ul Hasan
on 3 Jun 2018
sloppydisk
on 4 Jun 2018
I would probably do something like this:
rgbImage = imread('002.jpg');
grayImage = rgb2gray(rgbImage);
% take edge
bw = edge(grayImage, 'canny', .2);
% clean up edge
[X, Y] = meshgrid(1:size(bw, 2), flip(1:size(bw, 1)));
bw(Y<50|Y>.8*max(Y)) = 0;
figure(1)
imshow(bw) % show edge
bw = flip(bw);
[y, x] = find(bw); % take indices of edge
figure(2)
plot(x, y) % plot edge
[z, r] = fitcircle([x y]); % do fit giving center z and radius r
t = linspace(0, 2*pi, 50);
xfit = z(1) + r*cos(t); yfit = z(2) + r*sin(t);
hold on
plot(xfit, yfit) % plot fit of edge
hold off
X = ['Radius is ',num2str(r), ' pixels'];
disp(X)
Syed Sameer Ul Hasan
on 4 Jun 2018
sloppydisk
on 4 Jun 2018
Yeah I used that one, I linked to it in my comment. How do you know it's not correct? In my fit plot it fits the data closely.
Syed Sameer Ul Hasan
on 4 Jun 2018
sloppydisk
on 4 Jun 2018
Did you also multiply by two to go from radius to diameter? Otherwise I don't know what's wrong.
Syed Sameer Ul Hasan
on 4 Jun 2018
John D'Errico
on 5 Jun 2018
Edited: John D'Errico
on 5 Jun 2018
Note that is a moderately poor way to compute approximate circle radius, especially if the arc is not a perfect circle. You are taking two points as normals off of a bumpy & vaguely circular arc, extending lines. So to find the intersection of two lines that are defined by noisy estimates, will generate a noisy result, but worse, the intersection computation will exaggerate that noise. The bast case would be if you had multiple normal vectors to that curve, with the most useful information probably arising when the lines were orthogonal.
Higher quality tools that compute a circular arc will try to use the entire curve, not just effectively two points form that curve.
Syed Sameer Ul Hasan
on 5 Jun 2018
sloppydisk
on 5 Jun 2018
@John D'Errico Yes the picture was only meant as an example to show the general principle of getting the center geometrically. In my example code I did use a least squares fit using the entire curve from fitcircle.m from the file exchange.
Image Analyst
on 4 Jun 2018
0 votes
Threshold, extract largest blob with bwareafilt(), find perimeter with bwboundaries(), then use the FAQ http://matlab.wikia.com/wiki/FAQ#How_can_I_fit_a_circle_to_a_set_of_XY_data.3F
1 Comment
Syed Sameer Ul Hasan
on 4 Jun 2018
John D'Errico
on 5 Jun 2018
Edited: John D'Errico
on 5 Jun 2018
0 votes
Use the entire curve if possible. Well, all of it that you have. Not just a couple of isolated points.
Extract points from the entire accessible arc, as (x,y) pairs. At this point, it becomes a pure circle fitting problem.
Some years ago, I wrote a circle fitting tool. It tries to produce a fit that does as well as possible, even allowing the use of various solvers like backslash, pinv, or robustfit as alternatives. However, there are many algorithms one might postulate. I'll admit, I'm not in love with the one listed in the FAQ, but it is not that bad either. In some quick tests, it was comparable to the one I wrote. So if your data truly comes from a circle, you probably won't do too much better. And your data should not be too noisy since that arc is quite clear.
Can I do better than that though? Were I to try to do a bit better, I might look to using a maximum likelihood estimation, assuming noise in both x and y on each point. But your data is not that noisy, not that crappy that it is worth the effort.
So where will any "problems" arise? They will come from deviations from pure circularity. Thus, is that arc a perfectly circular arc, with a perfectly fixed radius? I doubt it. In fact, I'll bet that the largest amount of error in your circle parameter estimates come from those deviations from circularity, thus, lack of fit to a true circle, rather than from noise in the fit.
If that is true, then what does it mean to try to do better, fitting a circle perfectly to data that is not perfectly circular? There is a limit beyond which the fit becomes an exercise in absurdity. How can you improve things to best effect? Do a better job of extracting those points on the perimeter of the circle. Improving your data is always a good idea, because that means the algorithms meant to post-process the data will have a far easier time of it.
I would look carefully at the data you have. Compare it to the fit you estimate. Does it have systematic patterns in the residuals between your data and the circle fit. If you see patterns, that means your largest problem lies in lack of fit. And if my conjecture is true, then you won't improve things by making a better circle fit.
Christine Tobler
on 5 Jun 2018
0 votes
There's a recent blog post by Loren on fitting a sine wave to a picture by eye:
This won't give you best accuracy, but could be a nice way of doing the fit by hand, and verifying if the final circle you choose fits the picture well.
Categories
Find more on Image Processing Toolbox in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!