forked from egeyosunkaya/ImageAnalysis
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmergePixels.m
37 lines (30 loc) · 1.2 KB
/
mergePixels.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
function [sets , mergedSet , mergedIndex] = mergePixels(I, edgeImg, labels ,numlabels, graphDistances ,colorHists, oHists , sets,labelIndices)
minDist = Inf;
numSets = length(sets);
labelCounts = zeros(1,numlabels);
for i = 1:numlabels
labelCounts(1,i) = nnz(labels == i);
end
for i = 1:numSets
for j = i+1:numSets
set1 = sets{1,i};
set2 = sets{1,j};
if (~isempty(set1) && ~isempty(set2))
d = complexityAdaptiveDistance(I,edgeImg, labels,labelCounts , graphDistances ,colorHists,oHists, numlabels, set1 , set2, labelIndices);
if(d < minDist)
set1Index = i;
set2Index = j;
minDist = d;
end
end
%disp(sprintf("%d of %d || i = %f , j = %f , dist = %f" , (i-1) * numSets + j , double(numSets*numSets) , i , j , d));
end
end
if (set1Index > 0 && set2Index > 0)
%disp(sprintf("Merged Sets : %d and %d length of first: %d , second: %d" , set1Index , set2Index , length(sets{1,set1Index}) , length(sets{1,set2Index})));
sets{1,set1Index} = cat(2,sets{1,set1Index},sets{1,set2Index});
sets(:,set2Index) = [];
mergedSet = sets{1,set1Index};
mergedIndex = set1Index;
end
end