How do you find a centroid of an image?

I am trying to find the centroid of a binary image using region props but I keep receiving the error "Field reference for multiple structure elements that is followed by more reference blocks is an error". Here is my code for finding the centroid:
measurements = regionprops(bw, 'Centroid');
hold on;
plot(measurements.Centroid(1), measurements.Centroid(2), 'r+', 'MarkerSize', 120, 'LineWidth', 1);
hold off;
imshow(bw)
Any help would be appreciated thank you

1 commentaire

Image Analyst
Image Analyst le 6 Août 2014
Do you want the centroid of the whole, entire image, or of individual blobs in the image? You asked about the whole image but your code seems to indicate you maybe want centroids of individual blobs. Of course the centroid of the whole image is at the center, and the "Weighted centroid" depends on the gray levels in the image.

Connectez-vous pour commenter.

 Réponse acceptée

Image Analyst
Image Analyst le 5 Août 2014
Maybe try
centroids = [measurements.Centroid];
xCentroids = centroids(1:2:end);
yCentroids = centroids(2:2:end);
plot(xCentroids, yCentroids, .............

2 commentaires

Rish
Rish le 5 Août 2014
Thank you for your help. When I tried this a line graph showed up without the image. I am not sure why though.
Image Analyst
Image Analyst le 6 Août 2014
Modifié(e) : Image Analyst le 6 Août 2014
If you want the markers to be over the image, put "hold on" before plot(). You must have removed it for some reason.
hold on; % Prevent plot() from blowing away image.
plot(..........., 'r+'........
It looks like you used 'b-' in your call to plot because I see blue lines instead of red plus signs.

Connectez-vous pour commenter.

Plus de réponses (6)

Nade Sritanyaratana
Nade Sritanyaratana le 5 Août 2014
The example at the end of the regionprops documentation has an elegant use of the cat function, which might be able to fix the error you are getting.
measurements = regionprops(bw, 'Centroid');
imshow(bw);
centroids = cat(1,measurements.Centroid);
hold on;
plot(centroids(:,1), centroids(:,2), 'r+', 'MarkerSize', 120, 'LineWidth', 1);
hold off;

4 commentaires

Rish
Rish le 5 Août 2014
Thank you for your help. I tried this code and it plots lines but it doesn't just plot the centroid line, instead it plots multiple different lines. Any way to isolate just the centroid line?
Image Analyst
Image Analyst le 6 Août 2014
Your markers are too big - 120. Try something like 10 or 15 instead.
Rujal
Rujal le 7 Fév 2016
Modifié(e) : Rujal le 7 Fév 2016
I have used this code
but I want to find mid point between two centroids. for that I have used
mid= mean(centroids); plot(mid,'r*');
and the result is:
but I want to find midpoint between two centroids of objects. I would be thankful if someone helps me.
You can't do that because centroids is [x1,y1,x2,y2,x3,y3,x4,y4,.....] You need to extract x and y separately:
xCenters = centroids(1:2:end);
yCenters = centroids(2:2:end);
Then you can pick out which two blobs you want to find the midpoint between and average them. For example
xMid = (xCenters(1)+xCenters(2))/2;
yMid = (yCenters(1)+yCenters(2))/2;
hold on;
plot(xMid, yMid, 'r+', 'LineWidth', 2, 'MarkerSize', 20);

Connectez-vous pour commenter.

Rish
Rish le 6 Août 2014

0 votes

Thank you very much guys. I really appreciate your help and I figured it out.
hallouma amari
hallouma amari le 12 Mai 2015
Modifié(e) : Image Analyst le 12 Mai 2015
help me too please
this is my error
Field reference for multiple structure elements that is followed by more reference blocks is an error.
img2=imread('56.png');
se=strel('disk',3);
J=imclose(img2,se);
J=rgb2gray(J);
M=imadjust(J);
B=0; %initialisation
[R C]=size(J);
measurements = regionprops(J, 'Centroid');
x2=measurements.Centroid(1);
y2=measurements.Centroid(2);
bw = bwboundaries(J);
boundary = bw{1};
x1=boundary(:,1);
y1=boundary(:,2);
x1 = x1-x2;
y1 = y1-y2;

1 commentaire

Try like what I showed:
centroids = [measurements.Centroid];
xCentroids = centroids(1:2:end);
yCentroids = centroids(2:2:end);
% Compute distances of perimeter to centroid of blob #1
bw = bwboundaries(J);
boundary = bw{1};
x1=boundary(:,1);
y1=boundary(:,2);
deltaXs = x1 - xCentroids(1);
deltaYs = y1 - yCentroids(1);

Connectez-vous pour commenter.

somia gupta
somia gupta le 10 Mai 2016

0 votes

i want to find the centroid of an image in matlab ??? need help for the code for head pose detection
vinoba
vinoba le 11 Mar 2017

0 votes

How to find centroid of each and every blob(objects) in a binary image?

1 commentaire

See my Image Segmentation Tutorial in my File Exchange: http://www.mathworks.com/matlabcentral/fileexchange/?term=authorid%3A31862
Basically
[labledImage, numBlobs] = bwlabel(binaryImage);
props = regionprops(labeledImage, 'Centroid', 'WeightedCentroid');
You get a structure array with both types of centroids for every region.

Connectez-vous pour commenter.

tanuwyot
tanuwyot le 25 Oct 2017

0 votes

How to locate the nucleus centroid and extract the seven HU moments value ? Please help me

Community Treasure Hunt

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

Start Hunting!

Translated by