Compare commits
No commits in common. "7014e9308ccfb0048b27b2f7f34a914fc2b38ad6" and "d4e913b5e2f4ffdef0963a546f23fc3e21d858e0" have entirely different histories.
7014e9308c
...
d4e913b5e2
@ -73,7 +73,7 @@ public class OurApplication {
|
|||||||
frame.pack();
|
frame.pack();
|
||||||
applet.init();
|
applet.init();
|
||||||
applet.start();
|
applet.start();
|
||||||
frame.setSize(1350,800);
|
frame.setSize(1000,800);
|
||||||
frame.setVisible(true);
|
frame.setVisible(true);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -349,18 +349,18 @@ public class DirectedGraph<T extends VertexMarking, U extends EdgeMarking> exten
|
|||||||
// Den nächsten Knoten, der am wenigsten kostet, besuchen
|
// Den nächsten Knoten, der am wenigsten kostet, besuchen
|
||||||
WrapperElement<T> nextVertex = queue.poll();
|
WrapperElement<T> nextVertex = queue.poll();
|
||||||
|
|
||||||
// Falls Knoten schon besucht
|
|
||||||
if(!visited.get(nextVertex.getElement())){
|
|
||||||
// Knoten als besucht makieren
|
// Knoten als besucht makieren
|
||||||
visited.put(nextVertex.getElement(), true);
|
visited.put(nextVertex.getElement(), true);
|
||||||
textDescription = "Visit " + nextVertex.getElement().getName();
|
|
||||||
|
|
||||||
// Logging
|
// Logging
|
||||||
|
textDescription = "Visit " + nextVertex.getElement().getName();
|
||||||
System.out.println(textDescription);
|
System.out.println(textDescription);
|
||||||
if (nextVertex.getElement().getScreenVertex().getColor() != Color.RED) {
|
if (nextVertex.getElement().getScreenVertex().getColor() != Color.RED) {
|
||||||
nextVertex.getElement().getScreenVertex().setColor(Color.BLUE);
|
nextVertex.getElement().getScreenVertex().setColor(Color.BLUE);
|
||||||
}
|
}
|
||||||
this.logList.add(new OurLogElement(step, textDescription, 0, this.getScreenGraphCopy()));
|
this.logList.add(new OurLogElement(step, textDescription, 0, this.getScreenGraphCopy()));
|
||||||
}
|
|
||||||
|
|
||||||
// Wenn Weg gefunden, brich ab
|
// Wenn Weg gefunden, brich ab
|
||||||
if (nextVertex.getElement() == n2) {
|
if (nextVertex.getElement() == n2) {
|
||||||
@ -445,7 +445,7 @@ public class DirectedGraph<T extends VertexMarking, U extends EdgeMarking> exten
|
|||||||
* @param n2 the ending vertex
|
* @param n2 the ending vertex
|
||||||
* @return the shortest distance from n1 to n2, or -1 if no path is found
|
* @return the shortest distance from n1 to n2, or -1 if no path is found
|
||||||
*/
|
*/
|
||||||
public double getShortestPathAStar(MarkedVertex<T> n1, MarkedVertex<T> n2) {
|
public int getShortestPathAStar(MarkedVertex<T> n1, MarkedVertex<T> n2) {
|
||||||
|
|
||||||
// Erstellt Hashmap um Distanz von Startnoten zu jedem Knoten auf dem Graph zu tracken
|
// Erstellt Hashmap um Distanz von Startnoten zu jedem Knoten auf dem Graph zu tracken
|
||||||
// Erstellt Hashmap um zu tracken welche Knoten schon besucht wurden
|
// Erstellt Hashmap um zu tracken welche Knoten schon besucht wurden
|
||||||
@ -453,11 +453,11 @@ public class DirectedGraph<T extends VertexMarking, U extends EdgeMarking> exten
|
|||||||
// Initialisierung aller Distanzen auf UNENDLICH (= -1)
|
// Initialisierung aller Distanzen auf UNENDLICH (= -1)
|
||||||
// Initialisierung, dass kein Knoten besucht wurde
|
// Initialisierung, dass kein Knoten besucht wurde
|
||||||
// Initialisierung aller Vorgänger auf null
|
// Initialisierung aller Vorgänger auf null
|
||||||
HashMap<MarkedVertex<T>, Double> distance = new HashMap<>();
|
HashMap<MarkedVertex<T>, Integer> distance = new HashMap<>();
|
||||||
HashMap<MarkedVertex<T>, Boolean> visited = new HashMap<>();
|
HashMap<MarkedVertex<T>, Boolean> visited = new HashMap<>();
|
||||||
HashMap<MarkedVertex<T>, MarkedVertex<T>> predecessors = new HashMap<>();
|
HashMap<MarkedVertex<T>, MarkedVertex<T>> predecessors = new HashMap<>();
|
||||||
for (MarkedVertex<T> i: this.getAllVertexes()) {
|
for (MarkedVertex<T> i: this.getAllVertexes()) {
|
||||||
distance.put(i, -1.0);
|
distance.put(i, -1);
|
||||||
visited.put(i, false);
|
visited.put(i, false);
|
||||||
predecessors.put(i, null);
|
predecessors.put(i, null);
|
||||||
}
|
}
|
||||||
@ -467,15 +467,15 @@ public class DirectedGraph<T extends VertexMarking, U extends EdgeMarking> exten
|
|||||||
|
|
||||||
// Distanz zu Startknoten auf 0
|
// Distanz zu Startknoten auf 0
|
||||||
// Weg zu Startknoten in die Schlange aufnehmen
|
// Weg zu Startknoten in die Schlange aufnehmen
|
||||||
distance.put(n1, 0.0);
|
distance.put(n1, 0);
|
||||||
queue.add(new WrapperElement<>(n1, 0));
|
queue.add(new WrapperElement<>(n1, 0));
|
||||||
|
|
||||||
// Variable, die Distanz zwischen aktuellem Knoten und Nachfolger speichert
|
// Variable, die Distanz zwischen aktuellem Knoten und Nachfolger speichert
|
||||||
double dist = 0;
|
int dist = 0;
|
||||||
// Variable, die Distanz zwischen dem potenziell nächsten Knoten und dem Zielknoten speichert
|
// Variable, die Distanz zwischen dem potenziell nächsten Knoten und dem Zielknoten speichert
|
||||||
double airDist = 0;
|
int airDist = 0;
|
||||||
// Variable, die Distanz zwischen dem aktuellen Knoten bis zum Endknoten speichert
|
// Variable, die Distanz zwischen dem aktuellen Knoten bis zum Endknoten speichert
|
||||||
double distToFinish = 0;
|
int distToFinish = 0;
|
||||||
// Zähler für LogList
|
// Zähler für LogList
|
||||||
int step = 0;
|
int step = 0;
|
||||||
// String für den Description Inhalt
|
// String für den Description Inhalt
|
||||||
@ -492,19 +492,17 @@ public class DirectedGraph<T extends VertexMarking, U extends EdgeMarking> exten
|
|||||||
// Den nächsten Knoten, der am wenigsten kostet, besuchen
|
// Den nächsten Knoten, der am wenigsten kostet, besuchen
|
||||||
WrapperElement<T> nextVertex = queue.poll();
|
WrapperElement<T> nextVertex = queue.poll();
|
||||||
|
|
||||||
|
|
||||||
// Falls Knoten schon besucht
|
|
||||||
if(!visited.get(nextVertex.getElement())){
|
|
||||||
// Knoten als besucht makieren
|
// Knoten als besucht makieren
|
||||||
visited.put(nextVertex.getElement(), true);
|
visited.put(nextVertex.getElement(), true);
|
||||||
textDescription = "Visit " + nextVertex.getElement().getName();
|
|
||||||
|
|
||||||
// Logging
|
// Logging
|
||||||
|
textDescription = "Visit " + nextVertex.getElement().getName();
|
||||||
System.out.println(textDescription);
|
System.out.println(textDescription);
|
||||||
if (nextVertex.getElement().getScreenVertex().getColor() != Color.RED) {
|
if (nextVertex.getElement().getScreenVertex().getColor() != Color.RED) {
|
||||||
nextVertex.getElement().getScreenVertex().setColor(Color.BLUE);
|
nextVertex.getElement().getScreenVertex().setColor(Color.BLUE);
|
||||||
}
|
}
|
||||||
this.logList.add(new OurLogElement(step, textDescription, 0, this.getScreenGraphCopy()));
|
this.logList.add(new OurLogElement(step, textDescription, 0, this.getScreenGraphCopy()));
|
||||||
}
|
|
||||||
|
|
||||||
// Wenn Weg gefunden, brich ab
|
// Wenn Weg gefunden, brich ab
|
||||||
if (nextVertex.getElement() == n2) {
|
if (nextVertex.getElement() == n2) {
|
||||||
@ -533,8 +531,8 @@ public class DirectedGraph<T extends VertexMarking, U extends EdgeMarking> exten
|
|||||||
if (j.getSource() == nextVertex.getElement() && j.getDestination() == i) {
|
if (j.getSource() == nextVertex.getElement() && j.getDestination() == i) {
|
||||||
|
|
||||||
//Berechnung der Heuristik über die Luftdistanz des nächsten Knoten zum Zielknoten
|
//Berechnung der Heuristik über die Luftdistanz des nächsten Knoten zum Zielknoten
|
||||||
airDist = Math.sqrt(Math.pow((i.getCords()[0] - n2.getCords()[0]), 2)
|
airDist = (int) Math.sqrt(Math.pow((i.getCords()[0] - n2.getCords()[0]), 2)
|
||||||
+ Math.pow((i.getCords()[1] - n2.getCords()[1]), 2)) / 100;
|
+ Math.pow((i.getCords()[1] - n2.getCords()[1]), 2));
|
||||||
|
|
||||||
// Berechne Distanz zu nächstem Knoten
|
// Berechne Distanz zu nächstem Knoten
|
||||||
EdgeWeightMarking marking = (EdgeWeightMarking) j.getMarking();
|
EdgeWeightMarking marking = (EdgeWeightMarking) j.getMarking();
|
||||||
@ -556,7 +554,7 @@ public class DirectedGraph<T extends VertexMarking, U extends EdgeMarking> exten
|
|||||||
distance.put(i, dist);
|
distance.put(i, dist);
|
||||||
|
|
||||||
// Logging
|
// Logging
|
||||||
textDescription = "Add " + i.getName() + " with " + distToFinish + " weight to queue.";
|
textDescription = "Add " + i.getName() + " with " + dist + " weight to queue.";
|
||||||
System.out.println(textDescription);
|
System.out.println(textDescription);
|
||||||
if (i.getScreenVertex().getColor() != Color.RED) {
|
if (i.getScreenVertex().getColor() != Color.RED) {
|
||||||
i.getScreenVertex().setColor(Color.YELLOW);
|
i.getScreenVertex().setColor(Color.YELLOW);
|
||||||
|
@ -8,59 +8,6 @@ public class ExampleGraphs {
|
|||||||
|
|
||||||
public DirectedGraph<VertexMarking, EdgeMarking> example1() {
|
public DirectedGraph<VertexMarking, EdgeMarking> example1() {
|
||||||
|
|
||||||
/*
|
|
||||||
* Erstellt einen Beispielgraphen (Beispiel 4), der sich ideal für die Demonstration der Funktionsweise
|
|
||||||
* des Dijkstra- und A*-Algorithmus eignet. Der Graph enthält eine Vielzahl von Knoten, die durch
|
|
||||||
* gewichtete Kanten verbunden sind. Dies ermöglicht es, den kürzesten Weg von einem Startknoten zu einem
|
|
||||||
* Zielknoten effizient zu berechnen und die Unterschiede zwischen den beiden Algorithmen in der
|
|
||||||
* Pfadfindung zu veranschaulichen.
|
|
||||||
*
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
DirectedGraph<VertexMarking, EdgeMarking> example4 = new DirectedGraph<>();
|
|
||||||
|
|
||||||
// Erstellung der Knoten mit Koordinaten
|
|
||||||
MarkedVertex<VertexMarking> A = new MarkedVertex<>(50, 250, "Start", null, null);
|
|
||||||
MarkedVertex<VertexMarking> B = new MarkedVertex<>(150, 150, "B", null, null);
|
|
||||||
MarkedVertex<VertexMarking> C = new MarkedVertex<>(150, 350, "C", null, null);
|
|
||||||
MarkedVertex<VertexMarking> D = new MarkedVertex<>(250, 100, "D", null, null);
|
|
||||||
MarkedVertex<VertexMarking> E = new MarkedVertex<>(250, 250, "E", null, null);
|
|
||||||
MarkedVertex<VertexMarking> F = new MarkedVertex<>(350, 200, "F", null, null);
|
|
||||||
MarkedVertex<VertexMarking> G = new MarkedVertex<>(450, 300, "G", null, null);
|
|
||||||
MarkedVertex<VertexMarking> H = new MarkedVertex<>(450, 100, "Ende", null, null);
|
|
||||||
|
|
||||||
|
|
||||||
// Hinzufügen der Knoten zum Graphen
|
|
||||||
example4.addVertex(A);
|
|
||||||
example4.addVertex(B);
|
|
||||||
example4.addVertex(C);
|
|
||||||
example4.addVertex(D);
|
|
||||||
example4.addVertex(E);
|
|
||||||
example4.addVertex(F);
|
|
||||||
example4.addVertex(G);
|
|
||||||
example4.addVertex(H);
|
|
||||||
|
|
||||||
// Erstellung der Kanten mit Gewichtungen
|
|
||||||
example4.addEdge(new MarkedEdge<>("AB", A, B, new EdgeWeightMarking(4)));
|
|
||||||
example4.addEdge(new MarkedEdge<>("AC", A, C, new EdgeWeightMarking(2)));
|
|
||||||
example4.addEdge(new MarkedEdge<>("BC", B, C, new EdgeWeightMarking(5)));
|
|
||||||
example4.addEdge(new MarkedEdge<>("BD", B, D, new EdgeWeightMarking(10)));
|
|
||||||
example4.addEdge(new MarkedEdge<>("CD", C, D, new EdgeWeightMarking(3)));
|
|
||||||
example4.addEdge(new MarkedEdge<>("CE", C, E, new EdgeWeightMarking(7)));
|
|
||||||
example4.addEdge(new MarkedEdge<>("DE", D, E, new EdgeWeightMarking(2)));
|
|
||||||
example4.addEdge(new MarkedEdge<>("DF", D, F, new EdgeWeightMarking(2)));
|
|
||||||
example4.addEdge(new MarkedEdge<>("EF", E, F, new EdgeWeightMarking(5)));
|
|
||||||
example4.addEdge(new MarkedEdge<>("EG", E, G, new EdgeWeightMarking(10)));
|
|
||||||
example4.addEdge(new MarkedEdge<>("FG", F, G, new EdgeWeightMarking(3)));
|
|
||||||
example4.addEdge(new MarkedEdge<>("FH", F, H, new EdgeWeightMarking(6)));
|
|
||||||
example4.addEdge(new MarkedEdge<>("GH", G, H, new EdgeWeightMarking(1)));
|
|
||||||
|
|
||||||
return example4;
|
|
||||||
}
|
|
||||||
|
|
||||||
public DirectedGraph<VertexMarking, EdgeMarking> example2() {
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Beispiel 1 zeigt ein Gitter aus Knoten und Kanten, bei dem jeder Knoten mit
|
* Beispiel 1 zeigt ein Gitter aus Knoten und Kanten, bei dem jeder Knoten mit
|
||||||
* seinen horizontal und vertikal benachbarten Knoten verbunden ist. Alle Kanten
|
* seinen horizontal und vertikal benachbarten Knoten verbunden ist. Alle Kanten
|
||||||
@ -71,6 +18,8 @@ public class ExampleGraphs {
|
|||||||
* Demonstrieren, wie der A*-Algorithmus durch gezieltere Suche effizienter ist
|
* Demonstrieren, wie der A*-Algorithmus durch gezieltere Suche effizienter ist
|
||||||
* als der Dijkstra-Algorithmus in einem strukturierten Gittergraphen.
|
* als der Dijkstra-Algorithmus in einem strukturierten Gittergraphen.
|
||||||
*
|
*
|
||||||
|
* Startknoten: A
|
||||||
|
* Endknoten: Y
|
||||||
*/
|
*/
|
||||||
|
|
||||||
DirectedGraph<VertexMarking, EdgeMarking> example1 = new DirectedGraph<>();
|
DirectedGraph<VertexMarking, EdgeMarking> example1 = new DirectedGraph<>();
|
||||||
@ -114,7 +63,7 @@ public class ExampleGraphs {
|
|||||||
graph.addEdge(backwardEdge);
|
graph.addEdge(backwardEdge);
|
||||||
}
|
}
|
||||||
|
|
||||||
public DirectedGraph<VertexMarking, EdgeMarking> example3() {
|
public DirectedGraph<VertexMarking, EdgeMarking> example2() {
|
||||||
DirectedGraph<VertexMarking, EdgeMarking> example2 = new DirectedGraph<>();
|
DirectedGraph<VertexMarking, EdgeMarking> example2 = new DirectedGraph<>();
|
||||||
|
|
||||||
|
|
||||||
@ -124,6 +73,8 @@ public class ExampleGraphs {
|
|||||||
* Der andere Weg (unten) hat mehr Knoten mit höherer Gewichtung der Kanten. Der Algorithmus sollte zuerst den oberen
|
* Der andere Weg (unten) hat mehr Knoten mit höherer Gewichtung der Kanten. Der Algorithmus sollte zuerst den oberen
|
||||||
* Weg erkunden, bis er die hohe Gewichtung der letzten Kante des unteren Wegs berücksichtigt.
|
* Weg erkunden, bis er die hohe Gewichtung der letzten Kante des unteren Wegs berücksichtigt.
|
||||||
*
|
*
|
||||||
|
* Startknoten: A
|
||||||
|
* Endknoten: E
|
||||||
*/
|
*/
|
||||||
|
|
||||||
MarkedVertex A = new MarkedVertex<>(100, 100, "Start", null, null);
|
MarkedVertex A = new MarkedVertex<>(100, 100, "Start", null, null);
|
||||||
@ -156,13 +107,15 @@ public class ExampleGraphs {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
public DirectedGraph<VertexMarking, EdgeMarking> example4() {
|
public DirectedGraph<VertexMarking, EdgeMarking> example3() {
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Beispiel 3 zeigt ein Labyrinth mit vier horizontalen Wegen, die jeweils aus vier Knoten bestehen.
|
* Beispiel 3 zeigt ein Labyrinth mit vier horizontalen Wegen, die jeweils aus vier Knoten bestehen.
|
||||||
* Jeder Weg führt zum Endpunkt E1, E2, E3 bzw. E4. Ziel ist es zu zeigen, dass die Algorithmen auch
|
* Jeder Weg führt zum Endpunkt E1, E2, E3 bzw. E4. Ziel ist es zu zeigen, dass die Algorithmen auch
|
||||||
* potenziell falsche Wege erkunden können, bevor sie den richtigen Endpunkt erreichen.
|
* potenziell falsche Wege erkunden können, bevor sie den richtigen Endpunkt erreichen.
|
||||||
*
|
*
|
||||||
|
* Startknoten: A
|
||||||
|
* Endknoten: E2
|
||||||
*/
|
*/
|
||||||
|
|
||||||
DirectedGraph<VertexMarking, EdgeMarking> example3 = new DirectedGraph<>();
|
DirectedGraph<VertexMarking, EdgeMarking> example3 = new DirectedGraph<>();
|
||||||
@ -234,6 +187,63 @@ public class ExampleGraphs {
|
|||||||
|
|
||||||
return example3;
|
return example3;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public DirectedGraph<VertexMarking, EdgeMarking> example4() {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Erstellt einen Beispielgraphen (Beispiel 4), der sich ideal für die Demonstration der Funktionsweise
|
||||||
|
* des Dijkstra- und A*-Algorithmus eignet. Der Graph enthält eine Vielzahl von Knoten, die durch
|
||||||
|
* gewichtete Kanten verbunden sind. Dies ermöglicht es, den kürzesten Weg von einem Startknoten zu einem
|
||||||
|
* Zielknoten effizient zu berechnen und die Unterschiede zwischen den beiden Algorithmen in der
|
||||||
|
* Pfadfindung zu veranschaulichen.
|
||||||
|
*
|
||||||
|
* Startknoten: A
|
||||||
|
* Zielknoten: H
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
DirectedGraph<VertexMarking, EdgeMarking> example4 = new DirectedGraph<>();
|
||||||
|
|
||||||
|
// Erstellung der Knoten mit Koordinaten
|
||||||
|
MarkedVertex<VertexMarking> A = new MarkedVertex<>(50, 250, "Start", null, null);
|
||||||
|
MarkedVertex<VertexMarking> B = new MarkedVertex<>(150, 150, "B", null, null);
|
||||||
|
MarkedVertex<VertexMarking> C = new MarkedVertex<>(150, 350, "C", null, null);
|
||||||
|
MarkedVertex<VertexMarking> D = new MarkedVertex<>(250, 100, "D", null, null);
|
||||||
|
MarkedVertex<VertexMarking> E = new MarkedVertex<>(250, 250, "E", null, null);
|
||||||
|
MarkedVertex<VertexMarking> F = new MarkedVertex<>(350, 200, "F", null, null);
|
||||||
|
MarkedVertex<VertexMarking> G = new MarkedVertex<>(450, 300, "G", null, null);
|
||||||
|
MarkedVertex<VertexMarking> H = new MarkedVertex<>(450, 100, "Ende", null, null);
|
||||||
|
|
||||||
|
|
||||||
|
// Hinzufügen der Knoten zum Graphen
|
||||||
|
example4.addVertex(A);
|
||||||
|
example4.addVertex(B);
|
||||||
|
example4.addVertex(C);
|
||||||
|
example4.addVertex(D);
|
||||||
|
example4.addVertex(E);
|
||||||
|
example4.addVertex(F);
|
||||||
|
example4.addVertex(G);
|
||||||
|
example4.addVertex(H);
|
||||||
|
|
||||||
|
// Erstellung der Kanten mit Gewichtungen
|
||||||
|
example4.addEdge(new MarkedEdge<>("AB", A, B, new EdgeWeightMarking(4)));
|
||||||
|
example4.addEdge(new MarkedEdge<>("AC", A, C, new EdgeWeightMarking(2)));
|
||||||
|
example4.addEdge(new MarkedEdge<>("BC", B, C, new EdgeWeightMarking(5)));
|
||||||
|
example4.addEdge(new MarkedEdge<>("BD", B, D, new EdgeWeightMarking(10)));
|
||||||
|
example4.addEdge(new MarkedEdge<>("CD", C, D, new EdgeWeightMarking(3)));
|
||||||
|
example4.addEdge(new MarkedEdge<>("CE", C, E, new EdgeWeightMarking(7)));
|
||||||
|
example4.addEdge(new MarkedEdge<>("DE", D, E, new EdgeWeightMarking(2)));
|
||||||
|
example4.addEdge(new MarkedEdge<>("DF", D, F, new EdgeWeightMarking(2)));
|
||||||
|
example4.addEdge(new MarkedEdge<>("EF", E, F, new EdgeWeightMarking(5)));
|
||||||
|
example4.addEdge(new MarkedEdge<>("EG", E, G, new EdgeWeightMarking(10)));
|
||||||
|
example4.addEdge(new MarkedEdge<>("FG", F, G, new EdgeWeightMarking(3)));
|
||||||
|
example4.addEdge(new MarkedEdge<>("FH", F, H, new EdgeWeightMarking(6)));
|
||||||
|
example4.addEdge(new MarkedEdge<>("GH", G, H, new EdgeWeightMarking(1)));
|
||||||
|
|
||||||
|
return example4;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -412,6 +412,6 @@ public abstract class Graph<T extends VertexMarking, U extends EdgeMarking> {
|
|||||||
* @param n2 Destination vertex.
|
* @param n2 Destination vertex.
|
||||||
* @return Length of the shortest path between the vertices.
|
* @return Length of the shortest path between the vertices.
|
||||||
*/
|
*/
|
||||||
public abstract double getShortestPathAStar(MarkedVertex<T> n1, MarkedVertex<T> n2);
|
public abstract int getShortestPathAStar(MarkedVertex<T> n1, MarkedVertex<T> n2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -58,7 +58,7 @@ class WrapperElement<T extends VertexMarking> {
|
|||||||
// ATTRIBUTE
|
// ATTRIBUTE
|
||||||
|
|
||||||
private MarkedVertex<T> element;
|
private MarkedVertex<T> element;
|
||||||
private double priority;
|
private int priority;
|
||||||
|
|
||||||
|
|
||||||
// KONSTRUKTOR
|
// KONSTRUKTOR
|
||||||
@ -69,7 +69,7 @@ class WrapperElement<T extends VertexMarking> {
|
|||||||
* @param element The marked vertex to wrap.
|
* @param element The marked vertex to wrap.
|
||||||
* @param priority The priority associated with the element.
|
* @param priority The priority associated with the element.
|
||||||
*/
|
*/
|
||||||
public WrapperElement(MarkedVertex<T> element, double priority) {
|
public WrapperElement(MarkedVertex<T> element, int priority) {
|
||||||
this.element = element;
|
this.element = element;
|
||||||
this.priority = priority;
|
this.priority = priority;
|
||||||
}
|
}
|
||||||
@ -92,7 +92,7 @@ class WrapperElement<T extends VertexMarking> {
|
|||||||
*
|
*
|
||||||
* @return The priority.
|
* @return The priority.
|
||||||
*/
|
*/
|
||||||
public double getPriority() {
|
public int getPriority() {
|
||||||
return this.priority;
|
return this.priority;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -130,6 +130,6 @@ class WrapperComparator<T extends VertexMarking> implements Comparator<WrapperEl
|
|||||||
* priority is less than, equal to, or greater than the second element's priority.
|
* priority is less than, equal to, or greater than the second element's priority.
|
||||||
*/
|
*/
|
||||||
public int compare(WrapperElement<T> element1, WrapperElement<T> element2) {
|
public int compare(WrapperElement<T> element1, WrapperElement<T> element2) {
|
||||||
return Double.compare(element1.getPriority(), element2.getPriority());
|
return Integer.compare(element1.getPriority(), element2.getPriority());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -253,18 +253,17 @@ public class UndirectedGraph<T extends VertexMarking, U extends EdgeMarking> ext
|
|||||||
// Den nächsten Knoten, der am wenigsten kostet, besuchen
|
// Den nächsten Knoten, der am wenigsten kostet, besuchen
|
||||||
WrapperElement<T> nextVertex = queue.poll();
|
WrapperElement<T> nextVertex = queue.poll();
|
||||||
|
|
||||||
// Falls Knoten schon besucht
|
|
||||||
if(!visited.get(nextVertex.getElement())){
|
|
||||||
// Knoten als besucht makieren
|
// Knoten als besucht makieren
|
||||||
visited.put(nextVertex.getElement(), true);
|
visited.put(nextVertex.getElement(), true);
|
||||||
textDescription = "Visit " + nextVertex.getElement().getName();
|
|
||||||
|
|
||||||
// Logging
|
// Logging
|
||||||
|
textDescription = "Visit " + nextVertex.getElement().getName();
|
||||||
System.out.println(textDescription);
|
System.out.println(textDescription);
|
||||||
if (nextVertex.getElement().getScreenVertex().getColor() != Color.RED) {
|
if (nextVertex.getElement().getScreenVertex().getColor() != Color.RED) {
|
||||||
nextVertex.getElement().getScreenVertex().setColor(Color.BLUE);
|
nextVertex.getElement().getScreenVertex().setColor(Color.BLUE);
|
||||||
}
|
}
|
||||||
this.logList.add(new OurLogElement(step, textDescription, 0, this.getScreenGraphCopy()));
|
this.logList.add(new OurLogElement(step, textDescription, 0, this.getScreenGraphCopy()));
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// Wenn Weg gefunden, brich ab
|
// Wenn Weg gefunden, brich ab
|
||||||
@ -350,7 +349,7 @@ public class UndirectedGraph<T extends VertexMarking, U extends EdgeMarking> ext
|
|||||||
* @param n2 The ending vertex of the shortest path.
|
* @param n2 The ending vertex of the shortest path.
|
||||||
* @return The length of the shortest path between n1 and n2.
|
* @return The length of the shortest path between n1 and n2.
|
||||||
*/
|
*/
|
||||||
public double getShortestPathAStar(MarkedVertex<T> n1, MarkedVertex<T> n2) {
|
public int getShortestPathAStar(MarkedVertex<T> n1, MarkedVertex<T> n2) {
|
||||||
|
|
||||||
// Erstellt Hashmap um Distanz von Startnoten zu jedem Knoten auf dem Graph zu tracken
|
// Erstellt Hashmap um Distanz von Startnoten zu jedem Knoten auf dem Graph zu tracken
|
||||||
// Erstellt Hashmap um zu tracken welche Knoten schon besucht wurden
|
// Erstellt Hashmap um zu tracken welche Knoten schon besucht wurden
|
||||||
@ -358,11 +357,11 @@ public class UndirectedGraph<T extends VertexMarking, U extends EdgeMarking> ext
|
|||||||
// Initialisierung aller Distanzen auf UNENDLICH (= -1)
|
// Initialisierung aller Distanzen auf UNENDLICH (= -1)
|
||||||
// Initialisierung, dass kein Knoten besucht wurde
|
// Initialisierung, dass kein Knoten besucht wurde
|
||||||
// Initialisierung aller Vorgänger auf null
|
// Initialisierung aller Vorgänger auf null
|
||||||
HashMap<MarkedVertex<T>, Double> distance = new HashMap<>();
|
HashMap<MarkedVertex<T>, Integer> distance = new HashMap<>();
|
||||||
HashMap<MarkedVertex<T>, Boolean> visited = new HashMap<>();
|
HashMap<MarkedVertex<T>, Boolean> visited = new HashMap<>();
|
||||||
HashMap<MarkedVertex<T>, MarkedVertex<T>> predecessors = new HashMap<>();
|
HashMap<MarkedVertex<T>, MarkedVertex<T>> predecessors = new HashMap<>();
|
||||||
for (MarkedVertex<T> i: this.getAllVertexes()) {
|
for (MarkedVertex<T> i: this.getAllVertexes()) {
|
||||||
distance.put(i, -1.0);
|
distance.put(i, -1);
|
||||||
visited.put(i, false);
|
visited.put(i, false);
|
||||||
predecessors.put(i, null);
|
predecessors.put(i, null);
|
||||||
}
|
}
|
||||||
@ -372,15 +371,15 @@ public class UndirectedGraph<T extends VertexMarking, U extends EdgeMarking> ext
|
|||||||
|
|
||||||
// Distanz zu Startknoten auf 0
|
// Distanz zu Startknoten auf 0
|
||||||
// Weg zu Startknoten in die Schlange aufnehmen
|
// Weg zu Startknoten in die Schlange aufnehmen
|
||||||
distance.put(n1, 0.0);
|
distance.put(n1, 0);
|
||||||
queue.add(new WrapperElement<>(n1, 0));
|
queue.add(new WrapperElement<>(n1, 0));
|
||||||
|
|
||||||
// Variable, die Distanz zwischen aktuellem Knoten und Nachfolger speichert
|
// Variable, die Distanz zwischen aktuellem Knoten und Nachfolger speichert
|
||||||
double dist = 0;
|
int dist = 0;
|
||||||
// Variable, die Distanz zwischen dem potenziell nächsten Knoten und dem Zielknoten speichert
|
// Variable, die Distanz zwischen dem potenziell nächsten Knoten und dem Zielknoten speichert
|
||||||
double airDist = 0;
|
int airDist = 0;
|
||||||
// Variable, die Distanz zwischen dem aktuellen Knoten bis zum Endknoten speichert
|
// Variable, die Distanz zwischen dem aktuellen Knoten bis zum Endknoten speichert
|
||||||
double distToFinish = 0;
|
int distToFinish = 0;
|
||||||
// Zähler für LogList
|
// Zähler für LogList
|
||||||
int step = 0;
|
int step = 0;
|
||||||
// String für den Description Inhalt
|
// String für den Description Inhalt
|
||||||
@ -397,18 +396,18 @@ public class UndirectedGraph<T extends VertexMarking, U extends EdgeMarking> ext
|
|||||||
// Den nächsten Knoten, der am wenigsten kostet, besuchen
|
// Den nächsten Knoten, der am wenigsten kostet, besuchen
|
||||||
WrapperElement<T> nextVertex = queue.poll();
|
WrapperElement<T> nextVertex = queue.poll();
|
||||||
|
|
||||||
// Falls Knoten schon besucht
|
|
||||||
if(!visited.get(nextVertex.getElement())){
|
|
||||||
// Knoten als besucht makieren
|
// Knoten als besucht makieren
|
||||||
visited.put(nextVertex.getElement(), true);
|
visited.put(nextVertex.getElement(), true);
|
||||||
textDescription = "Visit " + nextVertex.getElement().getName();
|
|
||||||
|
|
||||||
// Logging
|
// Logging
|
||||||
|
textDescription = "Visit " + nextVertex.getElement().getName();
|
||||||
System.out.println(textDescription);
|
System.out.println(textDescription);
|
||||||
if (nextVertex.getElement().getScreenVertex().getColor() != Color.RED) {
|
if (nextVertex.getElement().getScreenVertex().getColor() != Color.RED) {
|
||||||
nextVertex.getElement().getScreenVertex().setColor(Color.BLUE);
|
nextVertex.getElement().getScreenVertex().setColor(Color.BLUE);
|
||||||
}
|
}
|
||||||
this.logList.add(new OurLogElement(step, textDescription, 0, this.getScreenGraphCopy()));
|
this.logList.add(new OurLogElement(step, textDescription, 0, this.getScreenGraphCopy()));
|
||||||
}
|
|
||||||
|
|
||||||
// Wenn Weg gefunden, brich ab
|
// Wenn Weg gefunden, brich ab
|
||||||
if (nextVertex.getElement() == n2) {
|
if (nextVertex.getElement() == n2) {
|
||||||
@ -437,8 +436,8 @@ public class UndirectedGraph<T extends VertexMarking, U extends EdgeMarking> ext
|
|||||||
if (j.getSource() == nextVertex.getElement() && j.getDestination() == i) {
|
if (j.getSource() == nextVertex.getElement() && j.getDestination() == i) {
|
||||||
|
|
||||||
//Berechnung der Heuristik über die Luftdistanz des nächsten Knoten zum Zielknoten
|
//Berechnung der Heuristik über die Luftdistanz des nächsten Knoten zum Zielknoten
|
||||||
airDist = Math.sqrt(Math.pow((i.getCords()[0] - n2.getCords()[0]), 2)
|
airDist = (int) Math.sqrt(Math.pow((i.getCords()[0] - n2.getCords()[0]), 2)
|
||||||
+ Math.pow((i.getCords()[1] - n2.getCords()[1]), 2)) / 100;
|
+ Math.pow((i.getCords()[1] - n2.getCords()[1]), 2));
|
||||||
|
|
||||||
// Berechne Distanz zu nächstem Knoten
|
// Berechne Distanz zu nächstem Knoten
|
||||||
EdgeWeightMarking marking = (EdgeWeightMarking) j.getMarking();
|
EdgeWeightMarking marking = (EdgeWeightMarking) j.getMarking();
|
||||||
@ -457,7 +456,7 @@ public class UndirectedGraph<T extends VertexMarking, U extends EdgeMarking> ext
|
|||||||
distance.put(i, dist);
|
distance.put(i, dist);
|
||||||
|
|
||||||
// Logging
|
// Logging
|
||||||
textDescription = "Add " + i.getName() + " with " + distToFinish + " weight to queue.";
|
textDescription = "Add " + i.getName() + " with " + dist + " weight to queue.";
|
||||||
System.out.println(textDescription);
|
System.out.println(textDescription);
|
||||||
if (i.getScreenVertex().getColor() != Color.RED) {
|
if (i.getScreenVertex().getColor() != Color.RED) {
|
||||||
i.getScreenVertex().setColor(Color.YELLOW);
|
i.getScreenVertex().setColor(Color.YELLOW);
|
||||||
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Loading…
Reference in New Issue
Block a user