Давайте пройдемся по кодам и комментариям и попытаемся понять, как можно достичь цели, поставленной в вопросе.
%// Bounding box array, where the first and second columns denote the X-Y
%// location of the uppper-left corner pixel. The third and fourth columns
%// denote the extent of the repctive boxes along X and Y directions
%// respectively. Some random values are used here for demo purposes.
bb = [
12 10 10 5
15 20 14 12
135 60 11 4
20 30 10 7
20 30 13 13
20 30 13 14]
%// Tolerance in terms of the size difference betwen similar boxes that
%// is admissible as a less than or equal to value
tol = 2
%// Get X and Y direction limits for each box
xlims = [bb(:,1) bb(:,1) + bb(:,3)]
ylims = [bb(:,2) bb(:,2) + bb(:,4)];
%// Create a binary matrix that decides whether each box is in or out with
%// respect to all other boxes along both X and Y directions. Ones mean "in"
%// and zeros denote "out".
x1 = bsxfun(@ge,xlims(:,1),xlims(:,1)') & bsxfun(@le,xlims(:,1),xlims(:,2)')
x2 = bsxfun(@ge,xlims(:,2),xlims(:,1)') & bsxfun(@le,xlims(:,2),xlims(:,2)')
x12 = x1 | x2;
y1 = bsxfun(@ge,ylims(:,1),ylims(:,1)') & bsxfun(@le,ylims(:,1),ylims(:,2)')
y2 = bsxfun(@ge,ylims(:,2),ylims(:,1)') & bsxfun(@le,ylims(:,2),ylims(:,2)')
y12 = y1 | y2;
d1 = x12 & y12
%// Create another binary matrix based on sizes to decide for each box
%// what other boxes are "similar"
szmat = bb(:,[3 4])
v1 = abs(bsxfun(@minus,szmat,permute(szmat,[3 2 1])));
szmat_d = squeeze(all(v1<=tol,2));
%// Get a binary matrix based on combined decisions from X-Y incompatibility
%// and sizes. Please note for incompatibility, negation of d1 is needed.
out1 = ~d1 & szmat_d
out1(1:size(out1,1)+1:end)=0
out2 = mat2cell(out1,ones(1,size(out1,1)),size(out1,2))
out3 = cellfun(@find,out2,'uni',0)
Как использовать код -
out3
— это окончательный вывод, в котором содержится окончательное решение для каждого блока, какие другие блоки похожи и не перекрываются. Для проверки посмотрим, какие еще ящики подходят под эти критерии для ящика 1, выполнив - out3{1}
. Он выводит 3
и 4
, что означает, что блоки 3 и 4 являются такими блоками для блока 1. Это можно проверить вручную, просмотрев значения в массиве ограничивающих блоков bb
.
person
Divakar
schedule
22.05.2014