File: Distance.java

package info (click to toggle)
gpsprune 17-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 3,984 kB
  • ctags: 5,218
  • sloc: java: 39,403; sh: 25; makefile: 17; python: 15
file content (58 lines) | stat: -rw-r--r-- 1,700 bytes parent folder | download | duplicates (6)
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
package tim.prune.data;

import tim.prune.config.Config;

/**
 * Class to provide distance constants and functions
 */
public abstract class Distance
{
	// Geographical constants
	/** Earth radius in metres */
	private static final double EARTH_RADIUS_M = 6372795.0;


	/**
	 * Convert the given angle in radians into a distance
	 * @param inAngDist angular distance in radians
	 * @return distance in currently configured distance units
	 */
	public static double convertRadiansToDistance(double inAngDist)
	{
		return convertRadiansToDistance(inAngDist, Config.getUnitSet().getDistanceUnit());
	}

	/**
	 * Convert the given angle in radians into a distance
	 * @param inAngDist angular distance in radians
	 * @param inUnit distance units
	 * @return distance in specified distance units
	 */
	public static double convertRadiansToDistance(double inAngDist, Unit inUnit)
	{
		// Multiply by appropriate factor
		return inAngDist * EARTH_RADIUS_M * inUnit.getMultFactorFromStd();
	}

	/**
	 * Convert the given distance into an angle in radians
	 * @param inDist distance to convert in the current distance units
	 * @return angular distance in radians
	 */
	public static double convertDistanceToRadians(double inDist)
	{
		return convertDistanceToRadians(inDist, Config.getUnitSet().getDistanceUnit());
	}

	/**
	 * Convert the given distance into an angle in radians
	 * @param inDist distance to convert in the current distance units
	 * @param inUnit distance unit
	 * @return angular distance in radians
	 */
	public static double convertDistanceToRadians(double inDist, Unit inUnit)
	{
		// Divide by appropriate factor
		return inDist / EARTH_RADIUS_M / inUnit.getMultFactorFromStd();
	}
}