-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathcombinePart.m
96 lines (80 loc) · 3.02 KB
/
combinePart.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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
function targets = combinePart(parts)
global labels beta save;
lbl2part = cell(max(labels(:)), 1);
for ii = 1:length(parts)
for jj = parts(ii).nodes
lbl2part{jj} = [lbl2part{jj}, ii];
end
end
labels(labels > length(lbl2part)) = 0;
count = 1;
searched = []; dist_p = -1 * ones(length(parts));
for ii = 1:length(parts)
% disp(ii);
if ismember(ii, searched)
continue;
end
p = parts(ii);
if p.type == 's'
continue;
end
cur_tar = initialTarget(p);
cur_tar.p = ii;
showRBBx(cur_tar);
searched = [searched, ii];
scale = 1;
skipped_part = 0;
while scale < 5
search_bbx = [mean(p.endp, 1) - scale / 2 * cur_tar.l, scale*cur_tar.l, scale*cur_tar.l];
% search_rbbx = R2BBx(search_bbx, 'r');
% showRBBx(search_rbbx, {'Faces', 1:5,'FaceColor', 'none', 'Edgecolor', [0.5 0 0], 'LineWidth', 2});
% scanline = [search_rbbx(1,:); mean(p.endp, 1); [0.8, 0.2] * search_rbbx(1:2, :)];
%
% cdata = [ 1 0.8 0]' * [1 0 0];
% c = {'Faces', [1 2 3], 'FaceColor','interp',...
% 'FaceVertexCData',cdata,...
% 'EdgeColor', 'none'};
% showRBBx(scanline, c);
[search_rangeX, search_rangeY] = zoomIn(search_bbx, save);
nbrs = labels(search_rangeX, search_rangeY);
nbrs = setdiff(unique(nbrs(:)), 0);
nbrs = setdiff(unique([lbl2part{nbrs}]), searched);
nbrs = setdiff(nbrs, skipped_part);
terminated = false;
while ~terminated && ~isempty(nbrs)
terminated = true;
search_ps = parts(nbrs);
% compactness
comp = compactness(cur_tar, search_ps);
[comp, ids] = sort(comp, 'descend');
nbrs = nbrs(ids);
% density
for jj = 1:length(comp)
dense = 0;
nbr_part = nbrs(jj);
for cur_part = cur_tar.p
if dist_p(nbr_part, cur_part) == -1
dist_p(nbr_part, cur_part) = partDist(parts(nbr_part), parts(cur_part));
dist_p(cur_part, nbr_part) = dist_p(nbr_part, cur_part);
end
dense = dense + dist_p(nbr_part, cur_part) * parts(cur_part).l;
end
dense = dense / length(cur_tar.p) / cur_tar.l;
if dense * beta < comp(jj)
[~, cur_tar] = compactness(cur_tar, parts(nbr_part), true);
cur_tar.p = [cur_tar.p, nbr_part];
cur_tar.ds = cur_tar.ds + dense;
showRBBx(parts(nbr_part));
searched = [searched, nbr_part];
nbrs(jj) = [];
terminated = false;
break;
end
end
end
skipped_part = union(skipped_part, nbrs);
scale = scale + 1;
end
targets(count) = cur_tar;
count = count + 1;
end