Geographic coordinate conversion

In geodesy, conversion among different geographic coordinate systems is made necessary by the different geographic coordinate systems in use across the world and over time. Coordinate conversion is composed of a number of different types of conversion: format change of geographic coordinates, conversion of coordinate systems, or transformation to different geodetic datums. Geographic coordinate conversion has applications in cartography, surveying, navigation and geographic information systems.

In geodesy, geographic coordinate conversion is defined as translation among different coordinate formats or map projections all referenced to the same geodetic datum. A geographic coordinate transformation is a translation among different geodetic datums. Both geographic coordinate conversion and transformation will be considered in this article.

This article assumes readers are already familiar with the content in the articles geographic coordinate system and geodetic datum.

Change of units and format
Informally, specifying a geographic location usually means giving the location's latitude and longitude. The numerical values for latitude and longitude can occur in a number of different units or formats:


 * sexagesimal degree: degrees, minutes, and seconds : 40° 26′ 46″ N 79° 58′ 56″ W
 * degrees and decimal minutes: 40° 26.767′ N 79° 58.933′ W
 * decimal degrees: +40.446 -79.982

There are 60 minutes in a degree and 60 seconds in a minute. Therefore, to convert from a degrees minutes seconds format to a decimal degrees format, one may use the formula


 * $$\rm{decimal\ degrees} = \rm{degrees} + \frac{\rm{minutes}}{60} + \frac{\rm{seconds}}{3600}$$.

To convert back from decimal degree format to degrees minutes seconds format,


 * $$ \begin{align}

\rm{absDegrees} & = | \rm{decimal\ degrees} | \\ \rm{floorAbsDegrees} & = \lfloor \rm{absDegrees} \rfloor \\ \rm{degrees} & = \sgn ( \rm{decimal\ degrees} ) \times \rm{floorAbsDegrees} \\ \rm{minutes} & = \lfloor 60 \times (\rm{absDegrees} - \rm{floorAbsDegrees})\rfloor \\ \rm{seconds} & = 3600 \times (\rm{absDegrees} - \rm{floorAbsDegrees}) - 60 \times \rm{minutes} \\ \end{align} $$ where $$\rm{absDegrees}$$ and $$\rm{floorAbsDegrees}$$ are just temporary variables to handle both positive and negative values properly.

Coordinate system conversion
A coordinate system conversion is a conversion from one coordinate system to another, with both coordinate systems based on the same geodetic datum. Common conversion tasks include conversion between geodetic and earth-centered, earth-fixed (ECEF) coordinates and conversion from one type of map projection to another.

From geodetic to ECEF coordinates


Geodetic coordinates (latitude $$\ \phi$$, longitude $$\ \lambda$$, height $$h$$) can be converted into ECEF coordinates using the following equation:


 * $$\begin{align}

X & = \left( N(\phi) + h\right)\cos{\phi}\cos{\lambda} \\ Y & = \left( N(\phi) + h\right)\cos{\phi}\sin{\lambda} \\ Z & = \left( \frac{b^2}{a^2} N(\phi) + h\right)\sin{\phi} \\ & = \left( (1 - e^2)      N(\phi) + h\right)\sin{\phi} \\ & = \left( (1 - f)^2      N(\phi) + h\right)\sin{\phi} \end{align}$$

where

N(\phi) = \frac{a^2}{\sqrt{a^2 \cos^2 \phi + b^2 \sin^2 \phi }} = \frac{a}{\sqrt{1 - e^2\sin^2\phi}} = \frac{a}{\sqrt{1 - \frac{e^2}{1 + \cot^2 \phi}}}, $$

and $$a$$ and $$b$$ are the equatorial radius (semi-major axis) and the polar radius (semi-minor axis), respectively. $$e^2 = 1 - \frac{b^2}{a^2}$$ is the square of the first numerical eccentricity of the ellipsoid. $$f = 1 - \frac{b}{a}$$ is the flattening of the ellipsoid. The prime vertical radius of curvature $$\, N(\phi) $$ is the distance from the surface to the Z-axis along the ellipsoid normal.

Properties
The following condition holds for the longitude in the same way as in the geocentric coordinates system:
 * $$\frac{X}{\cos\lambda} - \frac{Y}{\sin\lambda} = 0.$$

And the following holds for the latitude:
 * $$\frac{p}{\cos\phi} - \frac{Z}{\sin\phi} - e^2 N(\phi) = 0,$$

where $$p = \sqrt{X^2 + Y^2}$$, as the parameter $$h$$ is eliminated by subtracting
 * $$\frac{p}{\cos\phi} = N + h$$

and
 * $$\frac{Z}{\sin\phi} = \frac{b^2}{a^2}N + h.$$

The following holds furthermore, derived from dividing above equations:
 * $$\frac{Z}{p} \cot \phi = 1 - \frac{e^2 N}{N + h}.$$

Orthogonality
The orthogonality of the coordinates is confirmed via differentiation:
 * $$\begin{align}

\begin{pmatrix} dX \\ dY \\ dZ \end{pmatrix} &= \begin{pmatrix} -\sin\lambda & -\sin\phi \cos\lambda & \cos\phi \cos\lambda \\ \cos\lambda & -\sin\phi \sin\lambda & \cos\phi \sin\lambda \\ 0 & \cos\phi            & \sin\phi             \\ \end{pmatrix} \begin{pmatrix} dE \\ dN \\ dU \end{pmatrix}, \\[3pt] \begin{pmatrix} dE \\ dN \\ dU \end{pmatrix} &= \begin{pmatrix} \left(N(\phi) + h\right) \cos\phi &          0 & 0 \\ 0 & M(\phi) + h & 0 \\ 0 &          0 & 1 \\    \end{pmatrix} \begin{pmatrix} d\lambda \\ d\phi \\ dh \end{pmatrix}, \end{align}$$

where

M(\phi) = \frac{a\left(1 - e^2\right)}{\left(1 - e^2 \sin^2 \phi\right)^\frac{3}{2}} = N(\phi) \frac{1 - e^2}{1 - e^2\sin^2\phi} $$

(see also "Meridian arc on the ellipsoid").

Conversion for the longitude
The conversion of ECEF coordinates to longitude is:
 * $$\lambda = \operatorname{atan2}(Y,X)$$.

where atan2 is the quadrant-resolving arc-tangent function. The geocentric longitude and geodetic longitude have the same value; this is true for Earth and other similar shaped planets because they have a large amount of rotational symmetry around their spin axis (see triaxial ellipsoidal longitude for a generalization).

Unsophisticated conversion method for the latitude and height
The conversion for the latitude and height involves a circular relationship involving N, which is a function of latitude:
 * $$\frac{Z}{p} \cot \phi = 1 - \frac{e^2 N}{N + h}$$,
 * $$h=\frac{p}{\cos\phi} - N$$.

It can be solved iteratively, for example, starting with a first guess h≈0 then updating N. More elaborate methods are shown below. The procedure is, however, sensitive to small accuracy due to $$N$$ and $$h$$ being maybe 10$6$ apart.

Newton–Raphson method
The following Bowring's irrational geodetic-latitude equation, derived simply from the above properties, is efficient to be solved by Newton–Raphson iteration method:
 * $$\kappa - 1 - \frac{e^2 a\kappa}{\sqrt{p^2 + \left(1 - e^2\right) Z^2 \kappa^2}} = 0,$$

where $$\kappa = \frac{p}{Z} \tan \phi$$ and $$p = \sqrt{X^2 + Y^2}$$ as before. The height is calculated as:
 * $$\begin{align}

h &= e^{-2} \left(\kappa^{-1} - {\kappa_0}^{-1}\right) \sqrt{p^2 + Z^2 \kappa^2}, \\ \kappa_0 &\triangleq \left(1 - e^2\right)^{-1}. \end{align}$$

The iteration can be transformed into the following calculation:
 * $$\kappa_{i+1} = \frac{c_i + \left(1 - e^2\right) Z^2 \kappa_i^3}{c_i - p^2} = 1 + \frac{p^2 + \left(1 - e^2\right) Z^2 \kappa_i^3}{c_i - p^2},$$

where $$c_i = \frac{\left(p^2 + \left(1 - e^2\right) Z^2 \kappa_i ^2\right)^\frac{3}{2}}{ae^2} .$$

The constant $$\,\kappa_0$$ is a good starter value for the iteration when $$h \approx 0$$. Bowring showed that the single iteration produces a sufficiently accurate solution. He used extra trigonometric functions in his original formulation.

Ferrari's solution
The quartic equation of $$\kappa$$, derived from the above, can be solved by Ferrari's solution  to yield:

\begin{align} \zeta &= \left(1 - e^2\right)\frac{z^2}{a^2} ,\\[4pt] \rho &= \frac{1}{6}\left(\frac{p^2}{a^2} + \zeta - e^4\right) ,\\[4pt] s &= \frac{e^4 \zeta p^2}{4\rho^3 a^2} ,\\[4pt] t &= \sqrt[3]{1 + s + \sqrt{s(s + 2)}} ,\\[4pt] u &= \rho \left(t + 1 + \frac{1}{t}\right) ,\\[4pt] v &= \sqrt{u^2 + e^4 \zeta} ,\\[4pt] w &= e^2 \frac{u + v - \zeta}{2v} ,\\[4pt] \kappa &= 1 + e^2 \frac{\sqrt{u + v + w^2} + w}{u + v}. \end{align} $$

The application of Ferrari's solution
A number of techniques and algorithms are available but the most accurate, according to Zhu, is the following procedure established by Heikkinen, as cited by Zhu. This overlaps with above. It is assumed that geodetic parameters $$\{a,\, b,\, e\}$$ are known


 * $$\begin{align}

a &= 6378137.0 \text{    m. Earth Equatorial Radius} \\[3pt] b &= 6356752.3142 \text{     m. Earth Polar Radius} \\[3pt] e^2 &= \frac{a^2-b^2}{a^2} \\[3pt] e'^2 &= \frac{a^2 - b^2}{b^2} \\[3pt] p &= \sqrt{X^2 + Y^2} \\[3pt] F &= 54b^2 Z^2 \\[3pt] G &= p^2 + \left(1 - e^2\right)Z^2 - e^2\left(a^2 - b^2\right) \\[3pt] c &= \frac{e^4 Fp^2}{G^3} \\[3pt] s &= \sqrt[3]{1 + c + \sqrt{c^2 + 2c}} \\[3pt] k &= s + 1 + \frac{1}{s}\\[3pt] P &= \frac{F}{3 k^2 G^2} \\[3pt] Q &= \sqrt{1 + 2e^4 P} \\[3pt] r_0 &= \frac{-Pe^2 p}{1 + Q} + \sqrt{\frac{1}{2} a^2\left(1 + \frac{1}{Q}\right) - \frac{P\left(1 - e^2\right)Z^2}{Q(1 + Q)} - \frac{1}{2}Pp^2} \\[3pt] U &= \sqrt{\left(p - e^2 r_0\right)^2 + Z^2} \\[3pt] V &= \sqrt{\left(p - e^2 r_0\right)^2 + \left(1 - e^2\right)Z^2} \\[3pt] z_0 &= \frac{b^2 Z}{aV} \\[3pt] h &= U\left(1 - \frac{b^2}{aV}\right) \\[3pt] \phi &= \arctan\left[\frac{Z + e'^2 z_0}{p}\right] \\[3pt] \lambda &= \operatorname{arctan2}[Y,\, X] \end{align}$$

Note: arctan2[Y, X] is the four-quadrant inverse tangent function.

Power series
For small $e^{2}$ the power series
 * $$\kappa = \sum_{i\ge 0} \alpha_i e^{2i}$$

starts with
 * $$\begin{align}

\alpha_0 &= 1; \\ \alpha_1 &= \frac{a}{\sqrt{Z^2 + p^2}}; \\ \alpha_2 &= \frac{aZ^2\sqrt{Z^2 + p^2} + 2a^2 p^2}{2\left(Z^2 + p^2\right)^2}. \end{align}$$

Geodetic to/from ENU coordinates
To convert from geodetic coordinates to local tangent plane (ENU) coordinates is a two-stage process:


 * 1) Convert geodetic coordinates to ECEF coordinates
 * 2) Convert ECEF coordinates to local ENU coordinates

From ECEF to ENU
To transform from ECEF coordinates to the local coordinates we need a local reference point. Typically, this might be the location of a radar. If a radar is located at $$\left\{X_r,\, Y_r,\, Z_r\right\}$$ and an aircraft at $$\left\{X_p,\, Y_p,\, Z_p\right\}$$, then the vector pointing from the radar to the aircraft in the ENU frame is



\begin{bmatrix}x \\ y \\ z\end{bmatrix} = \begin{bmatrix} -\sin\lambda_r &           \cos\lambda_r           &         0 \\ -\sin\phi_r\cos\lambda_r & -\sin\phi_r\sin\lambda_r & \cos\phi_r \\ \cos\phi_r\cos\lambda_r & \cos\phi_r\sin\lambda_r & \sin\phi_r \end{bmatrix} \begin{bmatrix} X_p - X_r \\ Y_p - Y_r \\ Z_p - Z_r \end{bmatrix} $$

Note: $$\ \phi$$ is the geodetic latitude; the geocentric latitude is inappropriate for representing vertical direction for the local tangent plane and must be converted if necessary.

From ENU to ECEF
This is just the inversion of the ECEF to ENU transformation so



\begin{bmatrix}X_p \\ Y_p \\ Z_p\end{bmatrix} = \begin{bmatrix} -\sin\lambda_r & -\sin\phi_r\cos\lambda_r & \cos\phi_r\cos\lambda_r \\ \cos\lambda_r & -\sin\phi_r\sin\lambda_r & \cos\phi_r\sin\lambda_r \\ 0 &  \cos\phi_r            & \sin\phi_r \end{bmatrix} \begin{bmatrix}x \\ y \\ z\end{bmatrix} + \begin{bmatrix}X_r \\ Y_r \\ Z_r\end{bmatrix} $$

Conversion across map projections
Conversion of coordinates and map positions among different map projections reference to the same datum may be accomplished either through direct translation formulas from one projection to another, or by first converting from a projection $$A$$ to an intermediate coordinate system, such as ECEF, then converting from ECEF to projection $$B$$. The formulas involved can be complex and in some cases, such as in the ECEF to geodetic conversion above, the conversion has no closed-form solution and approximate methods must be used. References such as the DMA Technical Manual 8358.1 and the USGS paper Map Projections: A Working Manual contain formulas for conversion of map projections. It is common to use computer programs to perform coordinate conversion tasks, such as with the DoD and NGA supported GEOTRANS program.

Datum transformations
Transformations among datums can be accomplished in a number of ways. There are transformations that directly convert geodetic coordinates from one datum to another. There are more indirect transforms that convert from geodetic coordinates to ECEF coordinates, transform the ECEF coordinates from one datum to another, then transform ECEF coordinates of the new datum back to geodetic coordinates. There are also grid-based transformations that directly transform from one (datum, map projection) pair to another (datum, map projection) pair.

Helmert transformation
Use of the Helmert transform in the transformation from geodetic coordinates of datum $$A$$ to geodetic coordinates of datum $$B$$ occurs in the context of a three-step process:


 * 1) Convert from geodetic coordinates to ECEF coordinates for datum $$A$$
 * 2) Apply the Helmert transform, with the appropriate $$A\to B$$ transform parameters, to transform from datum $$A$$ ECEF coordinates to datum $$B$$ ECEF coordinates
 * 3) Convert from ECEF coordinates to geodetic coordinates for datum $$B$$

In terms of ECEF XYZ vectors, the Helmert transform has the form (position vector transformation convention and very small rotation angles simplification)



\begin{bmatrix} X_B \\ Y_B \\ Z_B \end{bmatrix} = \begin{bmatrix} c_x \\ c_y \\ c_z \end{bmatrix} + \left(1 + s \times 10^{-6}\right) \begin{bmatrix} 1 & -r_z & r_y \\ r_z &   1 & -r_x \\ -r_y & r_x &    1 \end{bmatrix} \begin{bmatrix} X_A \\ Y_A \\ Z_A \end{bmatrix}. $$

The Helmert transform is a seven-parameter transform with three translation (shift) parameters $$c_x,\, c_y,\, c_z$$, three rotation parameters $$r_x,\, r_y,\, r_z$$ and one scaling (dilation) parameter $$s$$. The Helmert transform is an approximate method that is accurate when the transform parameters are small relative to the magnitudes of the ECEF vectors. Under these conditions, the transform is considered reversible.

A fourteen-parameter Helmert transform, with linear time dependence for each parameter, can be used to capture the time evolution of geographic coordinates dues to geomorphic processes, such as continental drift and earthquakes. This has been incorporated into software, such as the Horizontal Time Dependent Positioning (HTDP) tool from the U.S. NGS.

Molodensky-Badekas transformation
To eliminate the coupling between the rotations and translations of the Helmert transform, three additional parameters can be introduced to give a new XYZ center of rotation closer to coordinates being transformed. This ten-parameter model is called the Molodensky-Badekas transformation and should not be confused with the more basic Molodensky transform.

Like the Helmert transform, using the Molodensky-Badekas transform is a three-step process:
 * 1) Convert from geodetic coordinates to ECEF coordinates for datum $$A$$
 * 2) Apply the Molodensky-Badekas transform, with the appropriate $$A\to B$$ transform parameters, to transform from datum $$A$$ ECEF coordinates to datum $$B$$ ECEF coordinates
 * 3) Convert from ECEF coordinates to geodetic coordinates for datum $$B$$

The transform has the form



\begin{bmatrix} X_B \\ Y_B \\ Z_B \end{bmatrix} = \begin{bmatrix} X_A \\ Y_A \\ Z_A \end{bmatrix} + \begin{bmatrix} \Delta X_A \\ \Delta Y_A \\ \Delta Z_A \end{bmatrix} + \begin{bmatrix} 1 & -r_z & r_y \\ r_z &   1 & -r_x \\ -r_y & r_x &    1 \end{bmatrix} \begin{bmatrix} X_A - X^0_A \\ Y_A - Y^0_A \\ Z_A - Z^0_A \end{bmatrix} + \Delta S \begin{bmatrix} X_A - X^0_A \\ Y_A - Y^0_A \\ Z_A - Z^0_A \end{bmatrix}. $$

where $$\left(X^0_A,\, Y^0_A,\, Z^0_A\right)$$ is the origin for the rotation and scaling transforms and $$\Delta S$$ is the scaling factor.

The Molodensky-Badekas transform is used to transform local geodetic datums to a global geodetic datum, such as WGS 84. Unlike the Helmert transform, the Molodensky-Badekas transform is not reversible due to the rotational origin being associated with the original datum.

Molodensky transformation
The Molodensky transformation converts directly between geodetic coordinate systems of different datums without the intermediate step of converting to geocentric coordinates (ECEF). It requires the three shifts between the datum centers and the differences between the reference ellipsoid semi-major axes and flattening parameters.

The Molodensky transform is used by the National Geospatial-Intelligence Agency (NGA) in their standard TR8350.2 and the NGA supported GEOTRANS program. The Molodensky method was popular before the advent of modern computers and the method is part of many geodetic programs.

Grid-based method


Grid-based transformations directly convert map coordinates from one (map-projection, geodetic datum) pair to map coordinates of another (map-projection, geodetic datum) pair. An example is the NADCON method for transforming from the North American Datum (NAD) 1927 to the NAD 1983 datum. The High Accuracy Reference Network (HARN), a high accuracy version of the NADCON transforms, have an accuracy of approximately 5 centimeters. The National Transformation version 2 (NTv2) is a Canadian version of NADCON for transforming between NAD 1927 and NAD 1983. HARNs are also known as NAD 83/91 and High Precision Grid Networks (HPGN). Subsequently, Australia and New Zealand adopted the NTv2 format to create grid-based methods for transforming among their own local datums.

Like the multiple regression equation transform, grid-based methods use a low-order interpolation method for converting map coordinates, but in two dimensions instead of three. The NOAA provides a software tool (as part of the NGS Geodetic Toolkit) for performing NADCON transformations.

Multiple regression equations
Datum transformations through the use of empirical multiple regression methods were created to achieve higher accuracy results over small geographic regions than the standard Molodensky transformations. MRE transforms are used to transform local datums over continent-sized or smaller regions to global datums, such as WGS 84. The standard NIMA TM 8350.2, Appendix D, lists MRE transforms from several local datums to WGS 84, with accuracies of about 2 meters.

The MREs are a direct transformation of geodetic coordinates with no intermediate ECEF step. Geodetic coordinates $$\phi_B,\, \lambda_B,\, h_B$$ in the new datum $$B$$ are modeled as polynomials of up to the ninth degree in the geodetic coordinates $$\phi_A,\, \lambda_A,\, h_A$$ of the original datum $$A$$. For instance, the change in $$\phi_B$$ could be parameterized as (with only up to quadratic terms shown)


 * $$\Delta \phi = a_0 + a_1 U + a_2 V + a_3 U^2 + a_4 UV + a_5 V^2 + \cdots$$

where
 * $$a_i,$$ parameters fitted by multiple regression
 * $$\begin{align}

U &= K(\phi_A - \phi_m) \\ V &= K(\lambda_A - \lambda_m) \\ \end{align}$$
 * $$K,$$ scale factor
 * $$\phi_m,\, \lambda_m,$$ origin of the datum, $$A.$$

with similar equations for $$ \Delta\lambda$$ and $$\Delta h$$. Given a sufficient number of $$(A,\, B)$$ coordinate pairs for landmarks in both datums for good statistics, multiple regression methods are used to fit the parameters of these polynomials. The polynomials, along with the fitted coefficients, form the multiple regression equations.