/*
* Copyright (C) 2011-2012 Dr. John Lindsay <jlindsay@uoguelph.ca>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package whitebox.structures;
/**
*
* @author Dr. John Lindsay email: jlindsay@uoguelph.ca
*/
public class XYZPoint implements Comparable<XYZPoint> {
public double x;
public double y;
public double z;
public XYZPoint(double X, double Y, double Z) {
x = X;
y = Y;
z = Z;
}
public double getSquareDistance(XYZPoint other) {
return (x - other.x) * (x - other.x) + (y - other.y) * (y - other.y) + (z - other.z) * (z - other.z);
}
public double getDistance(XYZPoint other) {
return Math.sqrt(getSquareDistance(other));
}
@Override
public int compareTo(XYZPoint cell) {
final int BEFORE = -1;
final int EQUAL = 0;
final int AFTER = 1;
if (this.z < cell.z) {
return BEFORE;
} else if (this.z > cell.z) {
return AFTER;
}
if (this.x < cell.x) {
return BEFORE;
} else if (this.x > cell.x) {
return AFTER;
}
if (this.y < cell.y) {
return BEFORE;
} else if (this.y > cell.y) {
return AFTER;
}
return EQUAL;
}
}