我试图在所有重叠的较小边界框周围绘制一个外边界框。 整个图像中可能存在许多这些区域。
例如
到目前为止,我有一个叫做rects的矩形向量。
overlaps = rectint(rects, rects);我检查彼此重叠的地方,并且因为它将与自身进行比较,我删除对角线如下:
overlaps(logical(eye(size(overlaps)))) = 0;然后找到重叠的位置
[r,c] = find(overlaps > 0);但是,我不知道如何处理这个,因为它不是返回的方形矩阵中的简单双向映射,因为区域中可能存在多个重叠。
任何有关我如何进行的建议将不胜感激。
谢谢
I am trying to draw an outer bounding box, around all smaller bounding boxes that are overlapping. There may be many of these regions within the entire image.
e.g.
So far I have my vector of rectangles called rects.
overlaps = rectint(rects, rects);Where I check of overlaps with each other, and because it will compare with itself I remove the diagonal as follows:
overlaps(logical(eye(size(overlaps)))) = 0;Then find the locations of the overlaps
[r,c] = find(overlaps > 0);However, I am not sure how to deal with this as it is not a simple bi directional mapping in the square matrix returned, as there can be multiple overlaps in the area.
Any suggestions on how I can proceed would be greatly appreciated.
Thanks
最满意答案
这里是一些随机矩形的例子:
% Generate fake data, 3 rects with format [x,y,w,h]: rects=20+randi(60,3,4); % plot the rects : for n=1:size(rects,1) rectangle('Position',rects(n,:)); end % get min max xmin=min(rects(:,1)); ymin=min(rects(:,2)); xmax=max(rects(:,1)+rects(:,3)); ymax=max(rects(:,2)+rects(:,4)); % define outer rect: outer_rect=[xmin ymin xmax-xmin ymax-ymin]; hold on rectangle('Position',outer_rect,'EdgeColor','r','LineStyle',':');here's and example with some random rectangles:
% Generate fake data, 3 rects with format [x,y,w,h]: rects=20+randi(60,3,4); % plot the rects : for n=1:size(rects,1) rectangle('Position',rects(n,:)); end % get min max xmin=min(rects(:,1)); ymin=min(rects(:,2)); xmax=max(rects(:,1)+rects(:,3)); ymax=max(rects(:,2)+rects(:,4)); % define outer rect: outer_rect=[xmin ymin xmax-xmin ymax-ymin]; hold on rectangle('Position',outer_rect,'EdgeColor','r','LineStyle',':');更多推荐
发布评论