-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbug1.m
61 lines (52 loc) · 2.11 KB
/
bug1.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
% Define Environment
boundary = [0, 0; 10, 0; 10, 10; 0, 10];
obstacle1 = [3, 0; 7, 0; 7, 4; 3, 4]; % Lower obstacle
obstacle2 = [3, 6; 7, 6; 7, 10; 3, 10]; % Upper obstacle (bridge)
% Start and Goal Position
start = [1, 5];
goal = [9, 9];
% Visualization
figure;
hold on;
fill(obstacle1(:,1), obstacle1(:,2), [0.7, 0.7, 0.7]); % Lower obstacle
fill(obstacle2(:,1), obstacle2(:,2), [0.7, 0.7, 0.7]); % Upper obstacle
plot(boundary([1:end 1],1), boundary([1:end 1],2), 'k-'); % Boundary
plot(start(1), start(2), 'ro', 'LineWidth', 2);
plot(goal(1), goal(2), 'go', 'LineWidth', 2);
axis equal;
grid on;
% Parameters
stepSize = 0.1;
robotPos = start;
hitPoint = [];
followBoundary = false;
while norm(robotPos - goal) > 0.1
if ~followBoundary
direction = (goal - robotPos) / norm(goal - robotPos);
nextPos = robotPos + stepSize * direction;
if inpolygon(nextPos(1), nextPos(2), obstacle1(:,1), obstacle1(:,2)) || ...
inpolygon(nextPos(1), nextPos(2), obstacle2(:,1), obstacle2(:,2))
followBoundary = true;
hitPoint = robotPos;
direction = [-direction(2), direction(1)]; % Rotate 90 degrees
disp('Obstacle hit! Following the boundary.');
end
else
direction = (robotPos - hitPoint) / norm(robotPos - hitPoint);
direction = [-direction(2), direction(1)]; % Rotate 90 degrees
nextPos = robotPos + stepSize * direction;
% Check if the robot can move directly to the goal
lineToGoal = [robotPos; goal];
[xi, yi] = polyxpoly(lineToGoal(:,1), lineToGoal(:,2), obstacle1(:,1), obstacle1(:,2));
[xi2, yi2] = polyxpoly(lineToGoal(:,1), lineToGoal(:,2), obstacle2(:,1), obstacle2(:,2));
if isempty(xi) && isempty(xi2) && norm(nextPos - hitPoint) > stepSize
followBoundary = false;
disp('Clear path to goal detected, resuming direct navigation.');
end
end
robotPos = robotPos + stepSize * direction;
plot(robotPos(1), robotPos(2), 'b.');
pause(0.05);
end
disp('Goal reached!');
title('Robot Navigation Path with Bridge Obstacle');