-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpath_finder_gen.pde
122 lines (105 loc) · 3.27 KB
/
path_finder_gen.pde
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
import com.hamoid.*;
VideoExport vid;
float w, h;
int ncols = 50;
int nrows = 50;
Spot[][] grid = new Spot[nrows][ncols];
ArrayList<Spot> OpenSet = new ArrayList<Spot>();
ArrayList<Spot> ClosedSet = new ArrayList<Spot>();
Spot current;
Spot start = new Spot(0, 0);
Spot end = new Spot(49, 49);
int cost = 0;
int obstacle_percentage = 20;
void setup() {
size(600, 600);
frameRate(80);
w = 600/ncols;
h = 600/nrows;
// Setup for video export
vid = new VideoExport(this);
// Initalize the grid
color c = 200;
for (int i = 0; i < ncols; i++) {
for (int j = 0; j < nrows; j++) {
grid[i][j] = new Spot(i, j);
grid[i][j].show(c);
}
}
// Initalizing start and end spots
start.obstacle = false;
end.obstacle = false;
start.show(#ff0000);
end.show(#00ff00);
OpenSet.add(start); // First element in OpenSet is the start position
start.gscore = 0;
start.fscore = dist(start, end);
// ------Neighbours function debug-----
// ArrayList<Spot> neigh = new ArrayList<Spot>();
// neigh = getneighbours(grid[5][5]);
// color col = #ffff00;
// for (int i = 0; i < neigh.size(); i++) {
// Spot s = neigh.get(i);
// s.c = col;
// s.show();
// }
vid.startMovie();
}
void draw() {
if (OpenSet.size() > 0) {
// Main body of the algorithm
int win_index = getwinner(OpenSet); // Find element in OpenSet with lowest fscore
Spot current = OpenSet.get(win_index);
//print(current.i, current.j);
current.show(#0000ff);
if (current.i == end.i && current.j == end.j) {
print("\nDestination arrived");
end.camefrom_i = current.camefrom_i;
end.camefrom_j = current.camefrom_j;
//recreatepath(current);
print("\nCost: ", cost);
print("\nTime: ", frameCount/frameRate);
vid.endMovie();
noLoop();
} else {
OpenSet.remove(win_index); // Remove the current element as it will be checked in this interation
ClosedSet.add(current);
for (int i = 0; i < ClosedSet.size(); i++) {
Spot s = ClosedSet.get(i);
s.show(#f1f1f1); // Spots already evaluated turn GREY
}
ArrayList<Spot> neighbours = new ArrayList<Spot>();
neighbours = getneighbours(current);
// Test
if (isinarraylist(neighbours, end) == true) {
print("\nEnd has been found!");
}
for (int i = 0; i < neighbours.size(); i++) {
Spot neighbour = neighbours.get(i);
neighbour.show(#ffff00);
if (isinarraylist(ClosedSet, neighbour) == false && neighbour.obstacle == false) {
float tentative_gscore = current.gscore + dist(current, neighbour);
if (tentative_gscore < neighbour.gscore) {
neighbour.camefrom_i = current.i;
neighbour.camefrom_j = current.j;
neighbour.gscore = tentative_gscore;
neighbour.fscore = tentative_gscore + dist(neighbour, end);
print("\nUpdating fscore: ", neighbour.fscore);
if (isinarraylist(OpenSet, neighbour) == false) {
OpenSet.add(neighbour);
}
}
current.show(#0000ff);
recreatepath(current);
}
}
print("\n---------");
}
} else {
print("\nPath not found");
noLoop();
}
start.show(#ff0000);
end.show(#00ff00);
vid.saveFrame();
}