Finding the "center" of an extended ring

1 回表示 (過去 30 日間)
Dominik Rhiem
Dominik Rhiem 2024 年 8 月 12 日
コメント済み: Matt J 2024 年 8 月 13 日
I have been experimenting with the image processing toolbox's function "imfindcircles", and it works well. However, there is one issue: I have an extended big ring in the image where I want to recognise its "center" instead of the outer end of the ring (see attached figure, where the outer end is plotted with viscircles and the center and radius found by imfindcircles).
This is also mirrored in the data itself: both the inner and outer end of the big ring have a lower intensity than its center. Is there a way to force "imfindcircles" to use the ring of maximum intensity? (Note that I have applied a thresholding to my image, otherwise the gradient at the ring ends would not be as harsh, and imfindcircles would struggle to differentiate between the ring and artifacts neighbouring the ring.)
Or is there maybe an alternative that includes a second step? After all, the circle center is properly recognised, so I can maybe vary the radius slightly? Maybe I could add up all the values of pixels that would lie on the circle, and see where that reaches its maximum. Is there an easy way to do something like that?
openfig findcircle-test.fig
ans =
Figure (1) with properties: Number: 1 Name: '' Color: [1 1 1] Position: [3.2978e+03 523.4000 468 411.2000] Units: 'pixels' Use GET to show all properties
  3 件のコメント
Matt J
Matt J 2024 年 8 月 13 日
編集済み: Matt J 2024 年 8 月 13 日
both the inner and outer end of the big ring...
Perhaps you mean the inner and outer "edge" of the annulus?
...have a lower intensity than its center.
Perhaps you mean the midline of the annulus, rather than the center?
Dominik Rhiem
Dominik Rhiem 2024 年 8 月 13 日
@Matt J yes, sorry about the confusing terminology, you are absolutely right. I was unsure whether or not to call it an "edge" and unaware of the term "midline", but those are what I meant.

サインインしてコメントする。

採用された回答

Matt J
Matt J 2024 年 8 月 13 日
編集済み: Matt J 2024 年 8 月 13 日
load Image
BW0=BW;
A=bwareafilt( imfill(BW,'holes'),1);
BW=imclose(A.*BW, strel('disk',3));
B=bwconvhull(~(~A|BW));
midline=bwskel(BW&~B); %midline of annulus
imshow(BW0+midline,[])
  2 件のコメント
Dominik Rhiem
Dominik Rhiem 2024 年 8 月 13 日
This looks really good and is pretty much what I meant, thank you. Do you have any suggestions to get the (average) radius of the "midline ring"?
Matt J
Matt J 2024 年 8 月 13 日
Yes, you can use circularFit() from this FEX download,
[y,x]=find(midline);
cfit=circularFit([x,y]')

サインインしてコメントする。

その他の回答 (0 件)

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by