Radius and coordinates of the center for a big circle in a bidimensional image

2 vues (au cours des 30 derniers jours)
I have a bidimensional (N x N) matrix of pixels like the one shown in the attached figure. Black areas contain zero values, while other areas contain random non-zero values. How could I determine the radius (in pixels) and coordinates of the center for the big circle? Consider that its center doesn't correspond to the center of the matrix, like in the figure.

Réponse acceptée

Image Analyst
Image Analyst le 11 Fév 2016
Modifié(e) : Image Analyst le 11 Fév 2016
Get a binary image by thresholding. Then fill holes, label, and call regionprops().
binaryImage = grayImage > 10; % or whatever value works.
% Fill holes
binaryImage = imfill(binaryImage, 'holes');
% Label
labeledImage = bwlabel(binaryImage);
% Measure
measurements = regionprops(labeledImage, 'EquivDiameter');
% Extract
theRadius = measurements.EquivDiameter / 2;
By the way, instead of the very verbose and overly complicated "bidimensional (N x N) matrix of pixels", most people would simply just say "2D image".
  1 commentaire
matnewbie
matnewbie le 11 Fév 2016
Thanks for your answer. I modified the original post, since I forgot to say that I am also interested in determining the coordinates of the center for the big circle. Is it possible to obtain the same results without using functions from the Image Processing Toolbox? Since I have a matrix of values, is it possible to find the coordinates of the center by minimizing the number of black pixels (zero values) from the edges of the black square?

Connectez-vous pour commenter.

Plus de réponses (1)

Anand
Anand le 11 Fév 2016
You can use the awesome imfindcircles function to do this as well.
Here's some code that should help:
% Read the image
I = imread('http://www.mathworks.com/matlabcentral/answers/uploaded_files/45140/figformatlab.png');
% Find circles in the image
radiusRange = [20 30]; % You need an approximate range of what you expect the radius to be.
[centers,radii] = imfindcircles(I, radiusRange, 'ObjectPolarity', 'dark','Sensitivity',.9);
% Display found circles
imshow(I)
viscircles(centers,radii);
The variables centers and radii hold what you are looking for.

Community Treasure Hunt

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

Start Hunting!

Translated by