-
Notifications
You must be signed in to change notification settings - Fork 104
/
Copy pathDetectLoopClosure.m
58 lines (40 loc) · 1.16 KB
/
DetectLoopClosure.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
function map = DetectLoopClosure(map, scan, hits, Tmax, Rmax, pixelSize)
% Remove recent keyscans
s = 0;
k = length(map.keyscans);
while k>1 && s<50
k = k-1;
dT = DiffPose(map.keyscans(k).pose, map.keyscans(k+1).pose);
s = s + norm(dT(1:2));
end
% We have no intention to close a loop with an error larger than Tmax
dear = 0;
pose = map.keyscans(end).pose;
for l = k : -1 : 1
dp = DiffPose(map.keyscans(l).pose, pose);
if norm(dp(1:2)) < Tmax+1
dear = l;
break;
end
end
if dear < 1
return;
end
% ===== Now we try to detect a loop closure seriouly =====
% Extract a refrence map around current scan
ndear = map.keyscans(dear).iEnd;
dearPoints = map.points(1:ndear, :);
refMap = ExtractLocalMap(dearPoints, pose, scan, Tmax+4);
scoreThresh = sum(hits) * 0.8;
countThresh = sum(hits==0) * 0.6;
% Brute force scan matching
refGrid = OccuGrid(refMap, pixelSize);
resol = [0.05, 0.05, deg2rad(0.5)];
[bestPose, bestHits] = BruteMatch(refGrid, scan, pose, resol, Tmax, Rmax);
if sum(bestHits<4) > countThresh
disp('lAlAlAlA!');
pose
bestPose
sum(bestHits)
pause(1);
end