How can I find circle diameter using arc ?

조회 수: 18(최근 30일)
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 ?

채택된 답변

Image Analyst
Image Analyst 2018년 6월 5일
See attached demo.
  댓글 수: 6
Image Analyst
Image Analyst 2018년 6월 6일
Yes, use a higher resolution camera, and include more of the circle. Improve your lighting. And, depending on the situation and geometry, using a telecentric lens ( a special type of lens that uses parallel rays of light) might help.

댓글을 달려면 로그인하십시오.

추가 답변(4개)

sloppydisk 2018년 6월 3일
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.
Or if you want to do it algebraically take a look at this link .
  댓글 수: 10
sloppydisk 2018년 6월 5일
@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
Image Analyst 2018년 6월 4일
Threshold, extract largest blob with bwareafilt(), find perimeter with bwboundaries(), then use the FAQ
  댓글 수: 1
Syed Sameer Ul Hasan
Syed Sameer Ul Hasan 2018년 6월 4일
Thank you for your reply Image Analyst. I have seen this faq before but didn't understand the working and imputs of this function. If you could please do that it would be very helpful for me

댓글을 달려면 로그인하십시오.

John D'Errico
John D'Errico 2018년 6월 5일
편집: John D'Errico 2018년 6월 5일
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
Christine Tobler 2018년 6월 5일
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.


Find more on Image Processing and Computer Vision 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!

Translated by