Image Analysis - Inside Bounding Circle

12 vues (au cours des 30 derniers jours)
Conor O'Keeffe
Conor O'Keeffe le 29 Mai 2021
Commenté : Conor O'Keeffe le 30 Mai 2021
Hi
I have this binary image and am wondering is there a function to calculate the maximum circle fully on the inside of a shape similar to below

Réponse acceptée

Image Analyst
Image Analyst le 30 Mai 2021
Compute the distance transform with bwdist(). The max value is the largest radius that a circle could fit inside the blob. Use bwdist(~mask) instead of bwdist(mask).
Full demo below:
clc; % Clear command window.
fprintf('Running %s.m ...\n', mfilename);
clear; % Delete all variables.
close all; % Close all figure windows except those created by imtool.
workspace; % Make sure the workspace panel is showing.
peaksImage = peaks(300);
subplot(2, 2, 1);
imshow(peaksImage, []);
title('Peaks Image', 'FontSize', 16)
impixelinfo
mask = peaksImage > 3;
subplot(2, 2, 2);
imshow(mask)
title('Mask Image', 'FontSize', 16)
edtImage = bwdist(~mask);
subplot(2, 2, 3);
imshow(edtImage, []);
title('EDT Image', 'FontSize', 16)
labeledImage = bwlabel(mask);
% Find radii of each blob
props = regionprops(mask, edtImage, 'MaxIntensity')
allRadii = [props.MaxIntensity]
subplot(2, 2, 2);
for k = 1 : length(props)
% Find the max of the edt Image. It may not be at the centroid!
thisBlob = ismember(labeledImage, k);
thisPeaks = peaksImage .* thisBlob;
[r, c] = find(thisPeaks == max(thisPeaks(:)));
x = c(1);
y = r(1);
xy(k, 1) = x;
xy(k, 2) = y;
str = sprintf('Radius = %.2f', allRadii(k));
text(x, y, str, 'FontSize', 12, 'Color', 'y');
end
viscircles(xy, allRadii);
fprintf('Done running %s.m\n', mfilename);
  1 commentaire
Conor O'Keeffe
Conor O'Keeffe le 30 Mai 2021
Thats exatcly it, thanks a mil!!

Connectez-vous pour commenter.

Plus de réponses (1)

Matt J
Matt J le 29 Mai 2021
Modifié(e) : Matt J le 29 Mai 2021
Use bwboundaries() to get the boundary coordinates and use incircle() from here:

Catégories

En savoir plus sur Image Processing Toolbox dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by