# bwboundaries: Explanation of a example

8 vues (au cours des 30 derniers jours)
Zynk le 5 Fév 2015
Commenté : Image Analyst le 7 Sep 2021
This simple example is given in the Matlab Documentation:
BW = im2bw(I, graythresh(I));
B = bwboundaries(BW,'noholes');
for k = 1:length(B)
boundary = B{k};
end
Even if I can see the result and why we need the loop, I don't fully get to understand what exactly is doing the "for" loop, I wouldn't know how to explain how it works. Can someone help me? Thank you
##### 0 commentairesAfficher -2 commentaires plus anciensMasquer -2 commentaires plus anciens

Connectez-vous pour commenter.

### Réponse acceptée

Image Analyst le 5 Fév 2015
If you have 10 blobs, you would get 10 boundaries. It gets the k'th boundary with this line
boundary = B{k};
And then it gets the x and y coordinates. Think of it like this
for k = 1 : length(B)
thisBoundary = B{k}; % Get k'th boundary
x = thisBoundary(:, 2);
y = thisBoundary(:, 1);
plot(x, y, 'w', 'LineWidth', 2);
end
The 'w' means to plot in white color, and the line width is the thickness of the line it's using to plot the boundary in the overlay above the image.
##### 1 commentaireAfficher -1 commentaires plus anciensMasquer -1 commentaires plus anciens
Zynk le 5 Fév 2015
Thanks, I understood why I needed the loop in order to plot,but not exactly how it was getting the boundary or why. Now it is clear.

Connectez-vous pour commenter.

### Plus de réponses (2)

Anand le 5 Fév 2015
I assume you are talking about Example 1 in the documentation.
BW = im2bw(I, graythresh(I));
[B,L] = bwboundaries(BW,'noholes');
imshow(label2rgb(L, @jet, [.5 .5 .5]))
hold on
for k = 1:length(B)
boundary = B{k};
plot(boundary(:,2), boundary(:,1), 'w', 'LineWidth', 2)
end
The for loop here is used in order to plot a white outline displaying the boundaries on the image.
##### 4 commentairesAfficher 2 commentaires plus anciensMasquer 2 commentaires plus anciens
Suresh D le 7 Sep 2021
plot(boundary(:,2), boundary(:,1), 'w', 'LineWidth', 2)
Image Analyst le 7 Sep 2021
boundary is an n-by-2 array of the row, column coordinates, in other words
[row1, col1;
row2, col2;
...
rown, coln];
which is
[y1, x1;
y2, x2;
...
yn, xn]
so boundary(:,2) is a column vector of all the x values and boundary(:,1) is a column vector of all the y values. So the plot command is essentially
plot(x, y, 'w', 'LineWidth', 2);
which will draw a white line between all the boundary points.

Connectez-vous pour commenter.

Babu Sankhi le 22 Juil 2020
For my images I got the boundaries only for the very good contrast png images not for the less contrast images. Is there any way to get boundary even for the images with less contrast? In addition to that I want to find the distance between center and boundary(left/right) for several images. Is there any helpful codes/function so that I can find those distances more precisely?
Thank you
##### 4 commentairesAfficher 2 commentaires plus anciensMasquer 2 commentaires plus anciens
Image Analyst le 25 Juil 2020
You can use bwdist(). Attach your original image in a new question if you still need help.
Babu Sankhi le 26 Juil 2020
Thank you analyst for your help. But bwdist() did not give any difinite value in my case so I am still stucked with that . I have attached my original microscopy image and the code I used to get the boudaries of desired region of image . After that my problem is to find the distance between right most points of innner(green) and outer(Red) boundaries . It means I have to find the distance between A and B in in resulting png.
thank you

Connectez-vous pour commenter.

### Catégories

En savoir plus sur Blocked Images 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