Stone duality
Template:Howto Geographic coordinates consist of latitude and longitude.
Ways of writing coordinates
All of the following are valid and acceptable ways to write geographic coordinates:
- 40:26:46.302N 079:58:55.903W
- 40°26′46″N 079°58′56″W
- 40d 26′ 46″ N 079d 58′ 56″ W
- 40.446195N 79.982195W
- 40.446195, -79.982195
- 40.446195,-79.982195
- 40° 26.7717, -79° 58.93172
- N40:26:46.302 W079:58:55.903
- N40°26′46″ W079°58′56″
- N40d 26′ 46″ W079d 58′ 56″
- N40.446195 W79.982195
Coordinates in this encyclopedia are generally written as Template:Coord.
Basic forms
There are three basic forms of a coordinate.
- Coordinate containing degrees (integer), minutes (integer), and seconds (integer, or real number) (DMS).
- Coordinate containing degrees (integer) and minutes (real number) (MinDec).
- Coordinate containing only degrees (real number) (DegDec).
All forms of coordinates are capable of representing the same amount of data and the same precision. Depending on which type of coordinate you are provided with, and which type you would like to work with, you may have to do some conversion.
Components of a typical coordinate
In its most simple form a coordinate is just a number of degrees. The tricky part comes in when you need to differentiate North/South latitude or West/East longitude, or make the number more digestible by writing it with minutes and seconds instead of as a decimal number.
Degrees
The degrees portion of the coordinate is always going to be the easiest to figure out. The degrees is always the left-most whole number. For example:
40:26:46N 40 W79°58′56" -79
A sphere is divided into 360 degrees. The number space is divided into two halves, East and West in the case of longitude and North and South in the case of latitude. The maximum ranges are as follows:
Longitude 180 W = -180 180 E = 180
Latitude 90 N = 90 90 S = -90
Technically you could have latitudes greater than 90 or less than -90, but this is an ambiguous case, since there would be an equivalent coordinate with an inverse longitude.
The minimal case is that you have only degrees:
40.446195 or 40.446195N
Minutes
Minutes are an optional component, as is implied by the minimal case of degrees. If there is no minutes component, the degrees component contains the entire precision of the coordinate and there must not be a seconds component. Minutes are actually the numerator component of a fraction with denominator 60 of one degree.
With the same examples as above:
40:26:46N 26 W079°58′56" 58
Seconds
Seconds are also an optional component, and can only exist if the minutes component also exists. Seconds are the numerator component of a fraction with denominator 60 of one minute.
40:26:46N 46 W079°58′56 56
To convert, 56 seconds is equal to minutes.
Putting it all together
Conversion from DMS to Decimal Degree
Given a DMS (Degrees, Minutes, Seconds) coordinate such as W079°58′56″, convert it to a number of decimal degrees using the following method:
- Calculate the total number of seconds:
58′56″ = (58*60 + 56) = 3536 seconds. - The fractional part is the total number of seconds divided by 3600:
3536 / 3600 = ~0.982222 - Add fractional degrees to whole degrees to produce the final result:
79 + 0.982222 = 79.982222 - Since it is a West longitude coordinate, negate the result.
- The final result is -79.982222.
Conversion from MinDec to Decimal Degree
Given a MinDec (Degrees, Minutes, Decimal Minutes) coordinate such as 79°58.93172W, convert it to a number of decimal degrees using the following method:
- The integer number of degrees is the same (79)
- The decimal degrees is the decimal minutes divided by 60 (58.93172/60 = ~0.982195)
- Add the two together (79 + 0.982195= 79.982195)
- For coordinates ind the western (or southern) hemisphere, negate the result.
- The final result is -79.982195
Conversion from Decimal Degree to DMS
Given a decimal longitudinal coordinate such as -79.982195 it will be necessary to know whether it is a latitudinal or longitudinal coordinate in order to fully convert it. The method is as follows:
- Subtract the whole number portion of the coordinate, leaving the fractional part. The whole number is the number of degrees. In the example of -79.982195: -79 degrees.
- Multiply the remaining fractional part by 60. This will produce a number of minutes in the whole number portion. In the example: 0.982195 x 60 = 58.9317 => 58 minutes.
- Multiply the fractional part of the number of minutes by 60, producing a number of seconds. 0.9317 x 60 = 55.903 => 55.903 seconds. It is possible to keep the entire number, truncate to the decimal 55 or round to the decimal 56.
- Depending on whether the source number was a latitudinal or longitudinal coordinate, and the sign of the number, add the N/S/E/W specifier. The following table shows the possibilities:
Type Dir. Sign Test Lat. N + > 0 Lat. S - < 0 Long. E + > 0 Long. W - < 0
A latitude of 0°0′0″ (at The Equator) is neither North nor South. Similarly, a longitude of 0°0′0″ (at the Prime Meridian) is neither East nor West. These are referred to as zero latitude and zero longitude, respectively. A longitude of 180°0′0″ (the 180th meridian) is neither East nor West. This is the basis for the International Date Line when referring to the Earth.
- The final result for the above example is: W 79°58′56″.
Programmatical conversion
The most common programmatical use of these processes is to display a coordinate to an end user in the more common DMS form instead of decimal form. Below is a piece of pseudocode to convert from decimal degrees to degrees, minutes, and seconds:
function deg_to_dms ( degfloat ) Input must be non-negative: if degfloat < 0 error end if Compute degrees, minutes and seconds: deg ← integerpart ( degfloat ) minfloat ← 60 * ( degfloat - deg ) min ← integerpart ( minfloat ) secfloat ← 60 * ( minfloat - min ) Round seconds to desired accuracy: secfloat ← round( secfloat, digits ) After rounding, the seconds might become 60. These two if-tests are not necessary if no rounding is done. if secfloat = 60 min ← min + 1 secfloat ← 0 end if if min = 60 deg ← deg + 1 min ← 0 end if Return output: return ( deg, min, secfloat ) end function
Java Implementation
// Input a double latitude or longitude in the decimal format
// e.g. -79.982195
String decimalToDMS(double coord) {
String output, degrees, minutes, seconds;
// gets the modulus the coordinate divided by one (MOD1).
// in other words gets all the numbers after the decimal point.
// e.g. mod := -79.982195 % 1 == 0.982195
//
// next get the integer part of the coord. On other words the whole number part.
// e.g. intPart := -79
double mod = coord % 1;
int intPart = (int)coord;
//set degrees to the value of intPart
//e.g. degrees := "-79"
degrees = String.valueOf(intPart);
// next times the MOD1 of degrees by 60 so we can find the integer part for minutes.
// get the MOD1 of the new coord to find the numbers after the decimal point.
// e.g. coord := 0.982195 * 60 == 58.9317
// mod := 58.9317 % 1 == 0.9317
//
// next get the value of the integer part of the coord.
// e.g. intPart := 58
coord = mod * 60;
mod = coord % 1;
intPart = (int)coord;
if (intPart < 0) {
// Convert number to positive if it's negative.
intPart *= -1;
}
// set minutes to the value of intPart.
// e.g. minutes = "58"
minutes = String.valueOf(intPart);
//do the same again for minutes
//e.g. coord := 0.9317 * 60 == 55.902
//e.g. intPart := 55
coord = mod * 60;
intPart = (int)coord;
if (intPart < 0) {
// Convert number to positive if it's negative.
intPart *= -1;
}
// set seconds to the value of intPart.
// e.g. seconds = "55"
seconds = String.valueOf(intPart);
// I used this format for android but you can change it
// to return in whatever format you like
// e.g. output = "-79/1,58/1,56/1"
output = degrees + "/1," + minutes + "/1," + seconds + "/1";
//Standard output of D°M′S″
//output = degrees + "°" + minutes + "'" + seconds + "\"";
return output;
}
/*
* Conversion DMS to decimal
*
* Input: latitude or longitude in the DMS format ( example: W 79° 58' 55.903")
* Return: latitude or longitude in decimal format
* hemisphereOUmeridien => {W,E,S,N}
*
*/
public double DMSToDecimal(String hemisphereOUmeridien,double degres,double minutes,double secondes)
{
double LatOrLon=0;
double signe=1.0;
if((hemisphereOUmeridien.equals("W"))||(hemisphereOUmeridien.equals("S"))) {signe=-1.0;}
LatOrLon = signe*(Math.floor(degres) + Math.floor(minutes)/60.0 + secondes/3600.0);
return(LatOrLon);
}
See also
- Wikipedia : Obtaining geographic coordinates
- Mimee : An online coordinate converter
- PROJ.4 : A library for performing conversions between cartographic projections
External links
- Batch Lat/Long Converter (from DDD to DMM and DMS) using the algorithm explained here
- Easy-to-use online converter with UTM support
- GeoTrans 2.4.2 A geographic translator application for Linux/Unix/Windows that supports 25 coordinate systems and 200 datums
- Online converter with tutorial and notes about most frequent user errors
- Online converter which can understand many different notations
- Plexscape WS Advanced free online tool for coordinate conversion, fully interactive with Google Maps - Supports more than 3,000 coordinate systems and 400 datums worldwide
- Programing: Decimalize Latitude Longitude in Python, Ruby