R \cdot \sqrt{\left(\left(\lambda_1 - \lambda_2\right) \cdot \cos \left(\frac{\phi_1 + \phi_2}{2}\right)\right) \cdot \left(\left(\lambda_1 - \lambda_2\right) \cdot \cos \left(\frac{\phi_1 + \phi_2}{2}\right)\right) + \left(\phi_1 - \phi_2\right) \cdot \left(\phi_1 - \phi_2\right)}\begin{array}{l}
\mathbf{if}\;\phi_2 \leq 8.698164444328864 \cdot 10^{+36}:\\
\;\;\;\;\sqrt{\sqrt{\left(\left(\lambda_1 - \lambda_2\right) \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(0.5 + 0.5 \cdot \cos \left(\frac{\phi_2 + \phi_1}{2} \cdot 2\right)\right) + \left(\phi_1 - \phi_2\right) \cdot \left(\phi_1 - \phi_2\right)}} \cdot \left(\sqrt{\sqrt{\left(\left(\lambda_1 - \lambda_2\right) \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(0.5 + 0.5 \cdot \cos \left(\frac{\phi_2 + \phi_1}{2} \cdot 2\right)\right) + \left(\phi_1 - \phi_2\right) \cdot \left(\phi_1 - \phi_2\right)}} \cdot R\right)\\
\mathbf{else}:\\
\;\;\;\;R \cdot \left(\phi_2 - \phi_1\right)\\
\end{array}(FPCore (R lambda1 lambda2 phi1 phi2)
:precision binary64
(*
R
(sqrt
(+
(*
(* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0)))
(* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0))))
(* (- phi1 phi2) (- phi1 phi2))))))(FPCore (R lambda1 lambda2 phi1 phi2)
:precision binary64
(if (<= phi2 8.698164444328864e+36)
(*
(sqrt
(sqrt
(+
(*
(* (- lambda1 lambda2) (- lambda1 lambda2))
(+ 0.5 (* 0.5 (cos (* (/ (+ phi2 phi1) 2.0) 2.0)))))
(* (- phi1 phi2) (- phi1 phi2)))))
(*
(sqrt
(sqrt
(+
(*
(* (- lambda1 lambda2) (- lambda1 lambda2))
(+ 0.5 (* 0.5 (cos (* (/ (+ phi2 phi1) 2.0) 2.0)))))
(* (- phi1 phi2) (- phi1 phi2)))))
R))
(* R (- phi2 phi1))))double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
return ((double) (R * ((double) sqrt(((double) (((double) (((double) (((double) (lambda1 - lambda2)) * ((double) cos((((double) (phi1 + phi2)) / 2.0))))) * ((double) (((double) (lambda1 - lambda2)) * ((double) cos((((double) (phi1 + phi2)) / 2.0))))))) + ((double) (((double) (phi1 - phi2)) * ((double) (phi1 - phi2))))))))));
}
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((phi2 <= 8.698164444328864e+36)) {
tmp = ((double) (((double) sqrt(((double) sqrt(((double) (((double) (((double) (((double) (lambda1 - lambda2)) * ((double) (lambda1 - lambda2)))) * ((double) (0.5 + ((double) (0.5 * ((double) cos(((double) ((((double) (phi2 + phi1)) / 2.0) * 2.0)))))))))) + ((double) (((double) (phi1 - phi2)) * ((double) (phi1 - phi2)))))))))) * ((double) (((double) sqrt(((double) sqrt(((double) (((double) (((double) (((double) (lambda1 - lambda2)) * ((double) (lambda1 - lambda2)))) * ((double) (0.5 + ((double) (0.5 * ((double) cos(((double) ((((double) (phi2 + phi1)) / 2.0) * 2.0)))))))))) + ((double) (((double) (phi1 - phi2)) * ((double) (phi1 - phi2)))))))))) * R))));
} else {
tmp = ((double) (R * ((double) (phi2 - phi1))));
}
return tmp;
}



Bits error versus R



Bits error versus lambda1



Bits error versus lambda2



Bits error versus phi1



Bits error versus phi2
Results
if phi2 < 8.69816444432886367e36Initial program 36.5
rmApplied swap-sqr_binary6436.5
rmApplied sqr-cos-a_binary6436.6
Simplified36.6
rmApplied add-sqr-sqrt_binary6436.6
Applied sqrt-prod_binary6436.7
Applied associate-*r*_binary6436.8
Simplified36.8
if 8.69816444432886367e36 < phi2 Initial program 49.0
Taylor expanded around 0 24.8
Final simplification34.2
herbie shell --seed 2020210
(FPCore (R lambda1 lambda2 phi1 phi2)
:name "Equirectangular approximation to distance on a great circle"
:precision binary64
(* R (sqrt (+ (* (* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0))) (* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0)))) (* (- phi1 phi2) (- phi1 phi2))))))