diff options
| author | Bdale Garbee <bdale@gag.com> | 2012-09-12 20:01:22 -0600 | 
|---|---|---|
| committer | Bdale Garbee <bdale@gag.com> | 2012-09-12 20:01:22 -0600 | 
| commit | 3b612efcd1dddc6a3d59012f7ed57754b1f798c2 (patch) | |
| tree | 18d50713491ef96c5c127a309f870efb6c33f98d /altoslib/AltosGreatCircle.java | |
| parent | e076773c1693e2a62bb828dee71c04c20dbab0a5 (diff) | |
| parent | 01eb36408d7e0e826b431fcc1d3b2deb23607e0b (diff) | |
Merge branch 'new-debian' into debian
Conflicts:
	ChangeLog
	debian/altos.install
	debian/changelog
	debian/control
	debian/copyright
	debian/dirs
	debian/docs
	debian/menu
	debian/rules
	src/Makefile
Diffstat (limited to 'altoslib/AltosGreatCircle.java')
| -rw-r--r-- | altoslib/AltosGreatCircle.java | 101 | 
1 files changed, 101 insertions, 0 deletions
| diff --git a/altoslib/AltosGreatCircle.java b/altoslib/AltosGreatCircle.java new file mode 100644 index 00000000..76b71859 --- /dev/null +++ b/altoslib/AltosGreatCircle.java @@ -0,0 +1,101 @@ +/* + * Copyright © 2010 Keith Packard <keithp@keithp.com> + * + * 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; version 2 of the License. + * + * 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, write to the Free Software Foundation, Inc., + * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. + */ + +package org.altusmetrum.AltosLib; + +import java.lang.Math; + +public class AltosGreatCircle { +	public double	distance; +	public double	bearing; + +	double sqr(double a) { return a * a; } + +	static final double rad = Math.PI / 180; +	static final double earth_radius = 6371.2 * 1000;	/* in meters */ + +	public static final int BEARING_LONG = 0; +	public static final int BEARING_SHORT = 1; +	public static final int BEARING_VOICE = 2; + +	public String bearing_words(int length) { +		String [][] bearing_string = { +			{ +				"North", "North North East", "North East", "East North East", +				"East", "East South East", "South East", "South South East", +				"South", "South South West", "South West", "West South West", +				"West", "West North West", "North West", "North North West" +			}, { +				"N", "NNE", "NE", "ENE", +				"E", "ESE", "SE", "SSE", +				"S", "SSW", "SW", "WSW", +				"W", "WNW", "NW", "NNW" +			}, { +				"north", "nor nor east", "north east", "east nor east", +				"east", "east sow east", "south east", "sow sow east", +				"south", "sow sow west", "south west", "west sow west", +				"west", "west nor west", "north west", "nor nor west " +			} +		}; +		return bearing_string[length][(int)((bearing / 90 * 8 + 1) / 2)%16]; +	} + +	public AltosGreatCircle (double start_lat, double start_lon, +				 double end_lat, double end_lon) +	{ +		double lat1 = rad * start_lat; +		double lon1 = rad * -start_lon; +		double lat2 = rad * end_lat; +		double lon2 = rad * -end_lon; + +		double d_lon = lon2 - lon1; + +		/* From http://en.wikipedia.org/wiki/Great-circle_distance */ +		double vdn = Math.sqrt(sqr(Math.cos(lat2) * Math.sin(d_lon)) + +				       sqr(Math.cos(lat1) * Math.sin(lat2) - +					   Math.sin(lat1) * Math.cos(lat2) * Math.cos(d_lon))); +		double vdd = Math.sin(lat1) * Math.sin(lat2) + Math.cos(lat1) * Math.cos(lat2) * Math.cos(d_lon); +		double d = Math.atan2(vdn,vdd); +		double course; + +		if (Math.cos(lat1) < 1e-20) { +			if (lat1 > 0) +				course = Math.PI; +			else +				course = -Math.PI; +		} else { +			if (d < 1e-10) +				course = 0; +			else +				course = Math.acos((Math.sin(lat2)-Math.sin(lat1)*Math.cos(d)) / +						   (Math.sin(d)*Math.cos(lat1))); +			if (Math.sin(lon2-lon1) > 0) +				course = 2 * Math.PI-course; +		} +		distance = d * earth_radius; +		bearing = course * 180/Math.PI; +	} + +	public AltosGreatCircle(AltosGPS start, AltosGPS end) { +		this(start.lat, start.lon, end.lat, end.lon); +	} + +	public AltosGreatCircle() { +		distance = 0; +		bearing = 0; +	} +} | 
