Info

이 질문은 마감되었습니다. 편집하거나 답변을 올리려면 질문을 다시 여십시오.

Does anyone know how I could find out the number of ends an arbitrary shape has e.g. an 'x' that is displayed in an image.

조회 수: 3 (최근 30일)
Does anyone know how I could find out the number of ends an arbitrary shape has e.g. an 'x' or a straight line. I use regionprops -> pixelList to extract a the points describing the shape from a BW image.

답변 (1개)

Guillaume
Guillaume 2017년 7월 13일
sum(bwmorph(bwmorph(yourbinaryimage, 'skel'), 'endpoints'))
Should give you what you want. For more information, see bwmorph.
  댓글 수: 4
Jan
Jan 2017년 7월 13일
편집: Jan 2017년 7월 13일
The values are coming from regionprops->PixelList .
@MP: And now you are looking for coordinates in X and Y, which have less then 2 4- or 8-connected neighbors only. Correct?
Guillaume
Guillaume 2017년 7월 14일
Ah, alright. If the binary image has not been skeletonised before the call to regionprop then it's going to be very difficult to find the end points from the coordinate vectors. If the image has beem skeletonised before regionprops then the end points are those pixels with just one neighbours.
One way of finding pixels with just one neighbours would be to compute the cheesboard distance matrix between all the pixels (with pdist2 if you have the stats toolbox, manually otherwise), keep only the ones in that matrix. The end points are those pixels with just one one in the row (or column), e.g.:
pixels = [1 1;1 2; 2 3; 3 3];
chessdist = max(abs(pixels(:, 1) - pixels(:, 1)'), abs(pixels(:, 2) - pixels(:, 2)')); %requires R2016b or later, or use pdist2
endpoints = pixels(sum(chessdist == 1) == 1, :)
But honestly, using bwmorph would be simpler. If the image is no longer available, I would recreate it from the list of pixels:
img = zeros(max(pixels(:, 2)), max(pixels(:, 1)));
img(sub2ind(size(img), pixels(:, 2), pixels(:, 1))) = 1;
[endpoints(:, 2), endpoints(:, 1)] = find(bwmorph(bwmorph(img, 'skel'), 'endpoints'))

이 질문은 마감되었습니다.

Community Treasure Hunt

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

Start Hunting!

Translated by