This file is indexed.

/usr/share/doc/geographiclib/html/rhumb.html is in geographiclib-tools 1.37-3.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.8"/>
<title>GeographicLib: Rhumb lines</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<script type="text/x-mathjax-config">
  MathJax.Hub.Config({
    extensions: ["tex2jax.js"],
    jax: ["input/TeX","output/HTML-CSS"],
});
</script><script src="/usr/share/javascript/mathjax/MathJax.js/MathJax.js"></script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td style="padding-left: 0.5em;">
   <div id="projectname">GeographicLib
   &#160;<span id="projectnumber">1.37</span>
   </div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.8 -->
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>Main&#160;Page</span></a></li>
      <li class="current"><a href="pages.html"><span>Related&#160;Pages</span></a></li>
      <li><a href="namespaces.html"><span>Namespaces</span></a></li>
      <li><a href="annotated.html"><span>Classes</span></a></li>
      <li><a href="files.html"><span>Files</span></a></li>
    </ul>
  </div>
</div><!-- top -->
<div class="header">
  <div class="headertitle">
<div class="title"><a class="el" href="classGeographicLib_1_1Rhumb.html" title="Solve of the direct and inverse rhumb problems. ">Rhumb</a> lines </div>  </div>
</div><!--header-->
<div class="contents">
<div class="textblock"><center> Back to <a class="el" href="triaxial.html">Geodesics on a triaxial ellipsoid</a>. Forward to <a class="el" href="transversemercator.html">Transverse Mercator projection</a>. Up to <a class="el" href="index.html#contents">Contents</a>. </center><p>The <a class="el" href="classGeographicLib_1_1Rhumb.html" title="Solve of the direct and inverse rhumb problems. ">Rhumb</a> and <a class="el" href="classGeographicLib_1_1RhumbLine.html" title="Find a sequence of points on a single rhumb line. ">RhumbLine</a> classes together with the <a href="RhumbSolve.1.html">RhumbSolve</a> utility perform rhumb line calculations. A rhumb line (also called a loxodrome) is a line of constant azimuth on the surface of the ellipsoid. It is important for historical reasons because sailing with a constant compass heading is simpler than sailing the shorter geodesic course; see Osborne (2013). My interest in this problem was piqued by Botnev and Ustinov (2014) who discuss various techniques to improve the accuracy of rhumb line calculations. The items of interest here are:</p><ul>
<li>Review of accurate formulas for the auxiliary latitudes.</li>
<li>Using divided differences to compute \(\mu_{12}/\psi_{12}\) maintaining full accuracy. Two cases are treated:<ul>
<li>If \(f\) is small, Kr&uuml;ger's series for the transverse Mercator projection relate \(\chi\) and \(\mu\).</li>
<li>For arbitrary \(f\), the divided difference formula for incomplete elliptic integrals of the second relates \(\beta\) and \(\mu\).</li>
</ul>
</li>
<li>Extending Clenshaw summation to compute the divided difference of a trigonometric sum.</li>
</ul>
<p>Jump to</p><ul>
<li><a class="el" href="rhumb.html#rhumbform">Formulation of the rhumb line problem</a></li>
<li><a class="el" href="rhumb.html#rhumblat">Determining the auxiliary latitudes</a></li>
<li><a class="el" href="rhumb.html#divideddiffs">Use of divided differences</a></li>
<li><a class="el" href="rhumb.html#dividedclenshaw">Clenshaw evaluation of differenced sums</a></li>
</ul>
<p>References:</p><ul>
<li>F. W. Bessel, <a href="http://dx.doi.org/10.1002/asna.201011352">The calculation of longitude and latitude from geodesic measurements (1825)</a>, Astron. Nachr. 331(8), 852-861 (2010); translated by C. F. F. Karney and R. E. Deakin; preprint: <a href="http://arxiv.org/abs/0908.1824">arXiv:0908.1824</a>.</li>
<li>V.A. Botnev, S.M. Ustinov, <a href="http://ntv.spbstu.ru/fulltext/T3.198.2014_05.PDF">Metody reshenija prjamoj i obratnoj geodezicheskih zadach s vysokoj tochnost'ju</a> (Methods for direct and inverse geodesic problems solving with high precision), St. Petersburg State Polytechnical University Journal 3(198), 49&ndash;58 (2014).</li>
<li>K. E. Engsager and K. Poder, <a href="http://icaci.org/files/documents/ICC_proceedings/ICC2007/documents/doc/THEME 2/oral 1/2.1.2 A HIGHLY ACCURATE WORLD WIDE ALGORITHM FOR THE TRANSVE.doc">A highly accurate world wide algorithm for the transverse Mercator mapping (almost)</a>, Proc. XXIII Intl. Cartographic Conf. (ICC2007), Moscow (2007).</li>
<li>F. R. Helmert, <a href="http://geographiclib.sf.net/geodesic-papers/helmert80-en.pdf">Mathematical and Physical Theories of Higher Geodesy, Part 1 (1880)</a>, Aeronautical Chart and Information Center (St. Louis, 1964), Chaps. 5&ndash;7.</li>
<li>W. M. Kahan and R. J. Fateman, <a href="http://www.cs.berkeley.edu/~fateman/papers/divdiff.pdf">Symbolic computation of divided differences</a>, SIGSAM Bull. 33(3), 7&ndash;28 (1999) DOI: <a href="http://dx.doi.org/10.1145/334714.334716">10.1145/334714.334716</a>.</li>
<li>C. F. F. Karney, <a href="http://dx.doi.org/10.1007/s00190-011-0445-3">Transverse Mercator with an accuracy of a few nanometers</a>, J. Geodesy 85(8), 475&ndash;485 (Aug. 2011); addenda: <a href="http://geographiclib.sourceforge.net/tm-addenda.html">tm-addenda.html</a>; preprint: <a href="http://arxiv.org/abs/1002.1417">arXiv:1002.1417</a>; resource page: <a href="http://geographiclib.sf.net/tm.html">tm.html</a>.</li>
<li>C. F. F. Karney, <a href="http://dx.doi.org/10.1007/s00190-012-0578-z">Algorithms for geodesics</a>, J. Geodesy 87(1), 43&ndash;55 (Jan. 2013); DOI: <a href="http://dx.doi.org/10.1007/s00190-012-0578-z">10.1007/s00190-012-0578-z</a>; addenda: <a href="http://geographiclib.sf.net/geod-addenda.html">geod-addenda.html</a>; resource page: <a href="http://geographiclib.sf.net/geod.html">geod.html</a>.</li>
<li>L. Kr&uuml;ger, <a href="http://dx.doi.org/10.2312/GFZ.b103-krueger28">Konforme Abbildung des Erdellipsoids in der Ebene</a> (Conformal mapping of the ellipsoidal earth to the plane), Royal Prussian Geodetic Institute, New Series 52, 172 pp. (1912).</li>
<li>T. H. Meyer and C. M. Rollins, The direct and indirect problem for loxodromes, Navigation 58(1), 1&ndash;6 (2011).</li>
<li>P. Osborne, <a href="http://www.mercator99.webspace.virginmedia.com/">The Mercator Projections</a> (2013), &sect;2.5 and &sect;6.5.</li>
</ul>
<h1><a class="anchor" id="rhumbform"></a>
Formulation of the rhumb line problem</h1>
<p>The rhumb line can formulated in terms of three types of latitude, the isometric latitude \(\psi\) (this serves to define the course of rhumb lines), the rectifying latitude \(\mu\) (needed for computing distances along rhumb lines), and the parametric latitude \(\beta\) (needed for dealing with rhumb lines that run along a parallel). These are defined in terms of the geographical latitude \(\phi\) by </p><p class="formulaDsp">
\[ \begin{aligned} \frac{d\psi}{d\phi} &amp;= \frac{\rho}R, \\ \frac{d\mu}{d\phi} &amp;= \frac{\pi}{2M}\rho, \\ \end{aligned} \]
</p>
<p> where \(\rho\) is the meridional radius of curvature, \(R = a\cos\beta\) is the radius of a circle of latitude, and \(M\) is the length of a quarter meridian (from the equator to the pole).</p>
<p><a class="el" href="classGeographicLib_1_1Rhumb.html" title="Solve of the direct and inverse rhumb problems. ">Rhumb</a> lines are straight in the Mercator projection, which maps a point with geographical coordinates \( (\phi,\lambda) \) on the ellipsoid to a point \( (\psi,\lambda) \). The azimuth \(\alpha_{12}\) of a rhumb line from \( (\phi_1,\lambda_1) \) to \( (\phi_2,\lambda_2) \) is thus given by </p><p class="formulaDsp">
\[ \tan\alpha_{12} = \frac{\lambda_{12}}{\psi_{12}}, \]
</p>
<p> where the quadrant of \(\alpha_{12}\) is determined by the signs of the numerator and denominator of the right-hand side, \(\lambda_{12} = \lambda_2 - \lambda_1\), \(\psi_{12} = \psi_2 - \psi_1\), and, typically, \(\lambda_{12}\) is reduced to the range \([-\pi,\pi]\) (thus giving the course of the <em>shortest</em> rhumb line).</p>
<p>The distance is given by </p><p class="formulaDsp">
\[ \begin{aligned} s_{12} &amp;= \frac {2M}{\pi} \mu_{12} \sec\alpha_{12} \\ &amp;= \frac {2M}{\pi} \frac{\mu_{12}}{\psi_{12}} \sqrt{\lambda_{12}^2 + \psi_{12}^2}, \end{aligned} \]
</p>
<p> where \(\mu_{12} = \mu_2 - \mu_1\). This relation is indeterminate if \(\phi_1 = \phi_2\), so we take the limits \(\psi_{12}\rightarrow0\) and \(\mu_{12}\rightarrow0\) and apply L'H&ocirc;pital's rule to yield </p><p class="formulaDsp">
\[ \begin{aligned} s_{12} &amp;= \frac {2M}{\pi} \frac{d\mu}{d\psi} \left|\lambda_{12}\right|\\ &amp;=a \cos\beta \left|\lambda_{12}\right|, \end{aligned} \]
</p>
<p> where the last relation is given by the defining equations for \(\psi\) and \(\mu\).</p>
<p>This provides a complete solution for rhumb lines. This formulation entirely encapsulates the ellipsoidal shape of the earth via the auxiliary latitudes; thus in the <a class="el" href="classGeographicLib_1_1Rhumb.html" title="Solve of the direct and inverse rhumb problems. ">Rhumb</a> class, the ellipsoidal generalization is handled by the <a class="el" href="classGeographicLib_1_1Ellipsoid.html" title="Properties of an ellipsoid. ">Ellipsoid</a> class where the auxiliary latitudes are defined.</p>
<h1><a class="anchor" id="rhumblat"></a>
Determining the auxiliary latitudes</h1>
<p>Here we brief develop the necessary formulas for the auxiliary latitudes.</p>
<p><b>Isometric latitude:</b> The equation for \(\psi\) can be integrated to give </p><p class="formulaDsp">
\[ \psi = \sinh^{-1}\tan\phi - e\tanh^{-1}(e \sin\phi), \]
</p>
<p> where \(e = \sqrt{f(2-f)}\) is the eccentricity of the ellipsoid. To invert this equation (to give \(\phi\) in terms of \(\psi\)), it is convenient to introduce the variables \(\tau=\tan\phi\) and \(\tau&#39; = \tan\chi = \sinh\psi\) ( \(\chi\) is the conformal latitude) which are related by (Karney, 2011) </p><p class="formulaDsp">
\[ \begin{aligned} \tau&#39; &amp;= \tau \sqrt{1 + \sigma^2} - \sigma \sqrt{1 + \tau^2}, \\ \sigma &amp;= \sinh\bigl(e \tanh^{-1}(e \tau/\sqrt{1 + \tau^2}) \bigr). \end{aligned} \]
</p>
<p> The equation for \(\tau&#39;\) can be inverted to give \(\tau\) in terms of \(\tau&#39;\) using Newton's method with \(\tau_0 = \tau&#39;/(1-e^2)\) as a starting guess; and, of course, \(\phi\) and \(\psi\) are then given by </p><p class="formulaDsp">
\[ \begin{aligned} \phi &amp;= \tan^{-1}\tau,\\ \psi &amp;= \sinh^{-1}\tau&#39;. \end{aligned} \]
</p>
<p> This allows conversions to and from \(\psi\) to be carried out for any value of the flattening \(f\); these conversions are implemented by <a class="el" href="classGeographicLib_1_1Ellipsoid.html#ae1f6a98b2d595dcafe00320f1171115f">Ellipsoid::IsometricLatitude</a> and <a class="el" href="classGeographicLib_1_1Ellipsoid.html#a48544e529746b1cf11b49d360debcf1e">Ellipsoid::InverseIsometricLatitude</a>. (For prolate ellipsoids, \(f\) is negative and \(e\) is imaginary, and the equation for \(\sigma\) needs to be recast in terms of the tangent function.)</p>
<p>For small values of \(f\), Engsager and Poder (2007) express \(\chi\) as a trigonometric series in \(\phi\). This series can be reverted to give a series for \(\phi\) in terms of \(\chi\). Both series can be efficiently evaluated using Clenshaw summation and this provides a fast non-iterative way of making the conversions.</p>
<p><b>Parametric latitude:</b> This is given by </p><p class="formulaDsp">
\[ \tan\beta = (1-f)\tan\phi, \]
</p>
<p> which allows rapid and accurate conversions; these conversions are implemented by <a class="el" href="classGeographicLib_1_1Ellipsoid.html#ae62fb1d29ef6df343f483d8e6e7a1712">Ellipsoid::ParametricLatitude</a> and <a class="el" href="classGeographicLib_1_1Ellipsoid.html#ae38062b94fc183d080fd2fc9853d7623">Ellipsoid::InverseParametricLatitude</a>.</p>
<p><b>Rectifying latitude:</b> Solving for distances on the meridian is naturally carried out in terms of the parametric latitude instead of the geographical latitude. This leads to a simpler elliptic integral which is easier to evaluate and to invert. Helmert (1880, &sect;5.11) notes that the series for meridian distance in terms of \(\beta\) converge faster than the corresponding ones in terms of \(\phi\).</p>
<p>In terms of \(\beta\), the rectifying latitude is given by </p><p class="formulaDsp">
\[ \mu = \frac{\pi}{2E(ie&#39;)} E(\beta,ie&#39;), \]
</p>
<p> where \(e&#39;=e/\sqrt{1-e^2}\) is the second eccentricity and \(E(k)\) and \(E(\phi,k)\) are the complete and incomplete elliptic integrals of the second kind; see <a href="http://dlmf.nist.gov/19.2.ii">http://dlmf.nist.gov/19.2.ii</a>. These can be evaluated accurately for arbitrary flattening using the method given in <a href="http://dlmf.nist.gov/19.36.i">http://dlmf.nist.gov/19.36.i</a>. To find \(\beta\) in terms of \(\mu\), Newton's method can be used (noting that \(dE(\phi,k)/d\phi = \sqrt{1 - k^2\sin^2\phi}\)); for a starting guess use \(\beta_0 = \mu\) (or use the first terms in the reverted series; see below). These conversions are implemented by <a class="el" href="classGeographicLib_1_1Ellipsoid.html#a9c50dff5532999b39b865d19c71041b7">Ellipsoid::RectifyingLatitude</a> and <a class="el" href="classGeographicLib_1_1Ellipsoid.html#a4fb5fe4e7605d3c4132adf511a300238">Ellipsoid::InverseRectifyingLatitude</a>.</p>
<p>If the flattening is small, \(\mu\) can be expressed as a series in various ways. The most economical series is in terms of the second flattening \( n = f/(2-f)\) and was found by Bessel (1825); see Eq. 5.5.7 of Helmert (1880). Helmert (1880, Eq. 5.6.8) also gives the reverted series (finding \(\beta\) given \(\mu\)). These series are used by the <a class="el" href="classGeographicLib_1_1Geodesic.html" title="Geodesic calculations ">Geodesic</a> class where the coefficients are \(C_{1j}\) and \(C_{1j}&#39;\); see Eqs. (18) and (21) of Karney (2013) and <a class="el" href="geodesic.html#geodseries">Expansions for geodesics</a>. (Make the replacements, \(\sigma\rightarrow\beta\), \(\tau\rightarrow\mu\), \(\epsilon\rightarrow n\), to convert the notation of the geodesic problem to the problem at hand.) The series are evaluated by Clenshaw summation.</p>
<p>These relations allow inter-conversions between the various latitudes \(\phi\), \(\psi\), \(\chi\), \(\beta\), \(\mu\) to be carried out simply and accurately. The approaches using series apply only if \(f\) is small. The others apply for arbitrary values of \(f\).</p>
<h1><a class="anchor" id="divideddiffs"></a>
Use of divided differences</h1>
<p>Despite our ability to compute latitudes accurately, the way that distances enter into the solution involves the ratio \(\mu_{12}/\psi_{12}\); the numerical calculation of this term is subject to catastrophic round-off errors when \(\phi_1\) and \(\phi_2\) are close. A simple solution, suggested by Meyer and Rollins (2011), is to extend the treatment of rhumb lines along parallels to this case, i.e., to replace the ratio by the derivative evaluated at the midpoint. (Meyer and Rollins only offer this solution when dealing with the inverse problem; but it can also be applied with the direct problem.) However this is not entirely satisfactory: you have to pick the transition point where the derivative takes over from the ratio of differences; and, near this transition point, many bits of accuracy will be lost (I estimate that about 1/3 of bits are lost, leading to errors on the order of 0.1 mm for double precision). Note too that this problem crops up even in the spherical limit.</p>
<p>It turns out that we can do substantially better than this and maintain full double precision accuracy. Indeed Botnev and Ustinov provide formulas which allow \(\mu_{12}/\psi_{12}\) to be computed accurately (but the formula for \(\mu_{12}\) applies only for small flattening).</p>
<p>Here I give a more systematic treatment using the algebra of <em>divided differences</em>. Many readers will be already using this technique, e.g., when writing, for example, </p><p class="formulaDsp">
\[ \frac{\sin(2x) - \sin(2y)}{x-y} = 2\frac{\sin(x-y)}{x-y}\cos(x+y). \]
</p>
<p> However, Kahan and Fateman (1999) provide an extensive set of rules which allow the technique to be applied to a wide range of problems. (The classes <a class="el" href="classGeographicLib_1_1LambertConformalConic.html" title="Lambert conformal conic projection. ">LambertConformalConic</a> and <a class="el" href="classGeographicLib_1_1AlbersEqualArea.html" title="Albers equal area conic projection. ">AlbersEqualArea</a> use this technique to improve the accuracy.)</p>
<p>To illustrate the technique, consider the relation between \(\psi\) and \(\chi\), </p><p class="formulaDsp">
\[ \psi = \sinh^{-1}\tan\chi. \]
</p>
<p> The divided difference operator is defined by </p><p class="formulaDsp">
\[ \Delta[f](x,y) = \begin{cases} df(x)/dx, &amp; \text{if $x=y$,} \\ \displaystyle\frac{f(x)-f(y)}{x-y}, &amp; \text{otherwise.} \end{cases} \]
</p>
<p> Many of the rules for differentiation apply to divided differences; in particular, we can use the chain rule to write </p><p class="formulaDsp">
\[ \frac{\psi_1 - \psi_2}{\chi_1 - \chi_2} = \Delta[\sinh^{-1}](\tan\chi_1,\tan\chi_2) \times \Delta[\tan](\chi_1,\chi_2). \]
</p>
<p>Kahan and Fateman catalog the divided difference formulas for all the elementary functions. In this case, we need </p><p class="formulaDsp">
\[ \begin{aligned} \Delta[\tan](x,y) &amp;= \frac{\tan(x-y)}{x-y} (1 + \tan x\tan y),\\ \Delta[\sinh^{-1}](x,y) &amp;= \frac1{x-y} \sinh^{-1}\biggl(\frac{(x-y)(x+y)}{x\sqrt{1+y^2}+y\sqrt{1+x^2}}\biggr). \end{aligned} \]
</p>
<p> The crucial point in these formulas is that the right hand sides can be evaluated accurately even if \(x-y\) is small. (I've only included the basic results here; Kahan and Fateman supplement these with the derivatives if \(x-y\) vanishes or the direct ratios if \(x-y\) is not small.)</p>
<p>To complete the computation of \(\mu_{12}/\psi_{12}\), we now need \((\mu_1 - \mu_2)/(\chi_1 - \chi_2)\), i.e., we need the divided difference of the function that converts the conformal latitude to rectifying latitude. We could go through the chain of relations between these quantities. However, we can take a short cut and recognize that this function was given as a trigonometric series by Kr&uuml;ger (1912) in his development of the transverse Mercator projection. This is also given by Eqs. (5) and (35) of Karney (2011) with the replacements \(\zeta \rightarrow \mu\) and \(\zeta&#39; \rightarrow \chi\). The coefficients appearing in this series and the reverted series Eqs. (6) and (36) are already computed by the <a class="el" href="classGeographicLib_1_1TransverseMercator.html" title="Transverse Mercator projection. ">TransverseMercator</a> class. The series can be readily converted to divided difference form (see the example at the beginning of this section) and Clenshaw summation can be used to evaluate it (see below).</p>
<p>The approach of using the series for the transverse Mercator projection limits the applicability of the method to \(\left|f\right|\lt 0.01\). If we want to extend the method to arbitrary flattening we need to compute \(\Delta[E](x,y;k)\). The necessary relation is the "addition
theorem" for the incomplete elliptic integral of the second kind given in <a href="http://dlmf.nist.gov/19.11.E2">http://dlmf.nist.gov/19.11.E2</a>. This can be converted in the followinging divided difference formula </p><p class="formulaDsp">
\[ \Delta[E](x,y;k) =\begin{cases} \sqrt{1 - k^2\sin^2x}, &amp; \text{if $x=y$,} \\ \displaystyle \frac{E(x,k)-E(y,k)}{x-y}, &amp; \text{if $xy \le0$,}\\ \displaystyle \biggl(\frac{E(z,k)}{\sin z} - k^2 \sin x \sin y\biggr)\frac{\sin z}{x-y}, &amp;\text{otherwise,} \end{cases} \]
</p>
<p> where the angle \(z\) is given by </p><p class="formulaDsp">
\[ \begin{aligned} \sin z &amp;= \frac{2t}{1 + t^2},\quad\cos z = \frac{(1-t)(1+t)}{1 + t^2},\\ t &amp;= \frac{(x-y)\Delta[\sin](x,y)} {\sin x\sqrt{1 - k^2\sin^2y} + \sin y\sqrt{1 - k^2\sin^2x}} \frac{\sin x + \sin y}{\cos x + \cos y}. \end{aligned} \]
</p>
<p> We also need to apply the divided difference formulas to the conversions from \(\phi\) to \(\beta\) and \(\phi\) to \(\psi\); but these all involve elementary functions and the techniques given in Kahan and Fateman can be used.</p>
<p>The end result is that the <a class="el" href="classGeographicLib_1_1Rhumb.html" title="Solve of the direct and inverse rhumb problems. ">Rhumb</a> class allows the computation of all rhumb lines for any flattening with full double precision accuracy (the maximum error is about 10 nanometers). I've kept the implementation simple, which results in rather a lot of repeated evaluations of quantities. However, in this case, the need for clarity trumps the desire for speed..</p>
<h1><a class="anchor" id="dividedclenshaw"></a>
Clenshaw evaluation of differenced sums</h1>
<p>The use of <a href="https://en.wikipedia.org/wiki/Clenshaw_algorithm#Geodetic_applications">Clenshaw summation</a> for summing series of the form, </p><p class="formulaDsp">
\[ g(x) = \sum_{k=1}^N c_k \sin(2kx), \]
</p>
<p> is well established. However when computing divided differences, we are interested in evaluating </p><p class="formulaDsp">
\[ g(x)-g(y) = \sum_{k=1}^N 2 c_k \sin\bigl(k(x-y)\bigr)\cos\bigl(k(x+y)\bigr) \]
</p>
<p> and the applicability of Clenshaw summation is not so clear. Botnev and Ustinov assert that the method can be used in this case (but they give no details). It turns out that Clenshaw summation can be used if we simultaneously compute the sum \(g(x)+g(y)\) and perform a matrix summation, </p><p class="formulaDsp">
\[ \mathsf G(x,y) = \begin{bmatrix} (g(x) + g(y)) / 2\\ (g(x) - g(y)) / (x - y) \end{bmatrix} = \sum_{k=1}^N c_k \mathsf F_k(x,y), \]
</p>
<p> where </p><p class="formulaDsp">
\[ \mathsf F_k(x,y)= \begin{bmatrix} \sin kp \cos kd\\ (2/d)\sin kd \cos kp \end{bmatrix}, \]
</p>
<p> and \(p=x+y\) and \(d=x-y\). The first element of \(\mathsf G(x,y)\) is the average value of \(g\) and the second element, the divided difference, is the average slope. \(\mathsf F_k(x,y)\) satisfies the recurrence relation </p><p class="formulaDsp">
\[ \mathsf F_{k+1}(x,y) = \mathsf A(x,y) \mathsf F_k(x,y) - \mathsf F_{k-1}(x,y), \]
</p>
<p> where </p><p class="formulaDsp">
\[ \mathsf A(x,y) = \begin{bmatrix} 2 \cos p \cos d &amp; -d\sin p \sin d \\ -(4/d) \sin p \sin d &amp; 2 \cos p \cos d \end{bmatrix}. \]
</p>
<p> The standard Clenshaw algorithm can now be applied to yield </p><p class="formulaDsp">
\[ \begin{aligned} \mathsf B_{N+1} &amp;= \mathsf B_{N+2} = \mathsf 0, \\ \mathsf B_k &amp;= \mathsf A \mathsf B_{k+1} - \mathsf B_{k+2} + \mathsf c_k \mathsf I, \qquad\text{for $N\ge k \ge 1$},\\ \mathsf G(x,y) &amp;= \mathsf B_1 \mathsf F_1(x,y), \end{aligned} \]
</p>
<p> where \(B_k\) are \(2\times2\) matrices. The divided difference \(\Delta[g](x,y)\) is given by the second element of \(\mathsf G(x,y)\).</p>
<center> Back to <a class="el" href="triaxial.html">Geodesics on a triaxial ellipsoid</a>. Forward to <a class="el" href="transversemercator.html">Transverse Mercator projection</a>. Up to <a class="el" href="index.html#contents">Contents</a>. </center> </div></div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.8
</small></address>
</body>
</html>