Merge commit 'origin'
[ailab2.git] / src / GraphNode.java
blobc58d2ce76e79e84848a22c778251d218583d2d5b
1 import java.util.Vector;
2 import java.util.Hashtable;
3 import java.util.Enumeration;
5 /**
6 * GraphNode, used by Graph to keep track of the nodes
7 * in a network and to make a routing table.
9 * @author "Anton Johansson" <anton.johansson@gmail.com>
10 * @author "Victor Zamanian" <victor.zamanian@gmail.com>
12 public class GraphNode implements Comparable {
13 private int maxNeighbours;
14 private Hashtable neighbours;
15 private String name;
16 private int x;
17 private int y;
18 private Double distanceToGoal;
19 private boolean visited;
20 private Double distance;
21 private GraphNode parent;
23 /**
24 * Creates a new GraphNode instance.
26 * @param name The name of the node.
27 * @param maxNeighbours The maximum amount of
28 * neighbours the node can have.
30 public GraphNode(String name, int x, int y, int maxNeighbours) {
31 this.name = name;
32 this.x = x;
33 this.y = y;
34 this.visited = false;
35 this.maxNeighbours = maxNeighbours;
36 neighbours = new Hashtable(maxNeighbours);
39 /**
40 * Adds a neighbour to this node.
42 * @param node The neighbour node to be added.
43 * @param weight The weight of the potential edge between
44 * this node and the new neighbour.
46 public void addNeighbour(GraphNode node, Double weight) {
47 neighbours.put(node, /*(Integer)*/ weight);
50 public void deleteNeighbour(GraphNode node) {
51 neighbours.remove(node);
54 /**
55 * Inspects the weight of the potential edge between this
56 * node and one of its neighbours.
58 * @param node The neighbour of this node.
59 * @return The weight of the potential edge.
61 public Double getWeight(GraphNode node) {
62 return (Double) neighbours.get(node);
65 /**
66 * Visists this node--sets its visited attribute to true.
68 public void visit() {
69 this.visited = true;
72 /**
73 * Inspects whether this node has been visited or not.
75 * @return true if this node has been visited, else false.
77 public boolean isVisited() {
78 return this.visited;
81 /**
82 * Inspects all the neighbours (nodes) of this node.
84 * @return An Enumeration of all neighbours of this node..
86 public Enumeration getNeighbours() {
87 return neighbours.keys();
90 /**
91 * Inspects the NAME address of this node.
93 * @return The NAME address of this node.
95 public String getName() {
96 return this.name;
99 /**
100 * Sets the distance to this node from the root node in
101 * the process of Dijkstras shortest-path algorithm.
103 * @param distance The distance to this node.
105 public void setDistance(Double distance) {
106 this.distance = distance;
110 * Inspects the distance from this node to the root node. See "setDistance."
112 * @return The distance from this node to the root node.
114 public Double getDistance() {
115 return this.distance;
119 * Sets this node's parent node. Used in Dijkstras algorithm.
121 * @param parent The parent to be set.
123 public void setParent(GraphNode parent) {
124 this.parent = parent;
128 * Inspects this node's parent.
130 * @return The parent node of this parent.
132 public GraphNode getParent() {
133 return this.parent;
137 * Access to this nodes x-coordinate.
139 * @return the x-coordinate of this node.
141 public int getX() {
142 return this.x;
146 * Access to this nodes y-coordinate.
148 * @return the y-coordinate of this node.
150 public int getY() {
151 return this.y;
155 * Calculate and return the distance to x- y-coordinates
157 * @param node the Node to calculate distance to
158 * @return distance to the node provided
160 public Double setDistanceToGoal(GraphNode goal) {
161 return this.distanceToGoal = Math.hypot((this.x - goal.getX()),
162 (this.y - goal.getY()));
166 * Retun the distance to Goal.
168 * @return the distance to goal.
170 public Double getDistanceToGoal() {
171 return this.distanceToGoal;
175 * Compares this node to another graph node.
177 * @param node The node to compare this node to.
178 * @return 0 if the addresses match, a positive integer if
179 * this node has a higher NAME address than the other node,
180 * and a negative integer if this node has a lower NAME address
181 * than the other node.
183 public int compareTo(Object node) {
184 return distance.compareTo(((GraphNode) node).getDistance());
187 public String toString() {
188 String returnString = name + "\n";
189 for (Enumeration e = getNeighbours(); e.hasMoreElements();) {
190 GraphNode neighbour = (GraphNode) e.nextElement();
191 returnString += " " + neighbour.getName()
192 + ", traveltime: " + this.getWeight(neighbour) +"\n";
194 return returnString;