\lambda_1 + \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 + \cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\lambda_1 + \tan^{-1}_* \frac{\mathsf{log1p}\left(\mathsf{expm1}\left(\cos \phi_2 \cdot \left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right)\right)\right)}{\log \left(e^{\mathsf{fma}\left(\mathsf{fma}\left(\cos \lambda_1, \cos \lambda_2, \sin \lambda_1 \cdot \sin \lambda_2\right), \cos \phi_2, \cos \phi_1\right)}\right)}double f(double lambda1, double lambda2, double phi1, double phi2) {
double r49841 = lambda1;
double r49842 = phi2;
double r49843 = cos(r49842);
double r49844 = lambda2;
double r49845 = r49841 - r49844;
double r49846 = sin(r49845);
double r49847 = r49843 * r49846;
double r49848 = phi1;
double r49849 = cos(r49848);
double r49850 = cos(r49845);
double r49851 = r49843 * r49850;
double r49852 = r49849 + r49851;
double r49853 = atan2(r49847, r49852);
double r49854 = r49841 + r49853;
return r49854;
}
double f(double lambda1, double lambda2, double phi1, double phi2) {
double r49855 = lambda1;
double r49856 = phi2;
double r49857 = cos(r49856);
double r49858 = lambda2;
double r49859 = cos(r49858);
double r49860 = sin(r49855);
double r49861 = r49859 * r49860;
double r49862 = cos(r49855);
double r49863 = sin(r49858);
double r49864 = r49862 * r49863;
double r49865 = r49861 - r49864;
double r49866 = r49857 * r49865;
double r49867 = expm1(r49866);
double r49868 = log1p(r49867);
double r49869 = r49860 * r49863;
double r49870 = fma(r49862, r49859, r49869);
double r49871 = phi1;
double r49872 = cos(r49871);
double r49873 = fma(r49870, r49857, r49872);
double r49874 = exp(r49873);
double r49875 = log(r49874);
double r49876 = atan2(r49868, r49875);
double r49877 = r49855 + r49876;
return r49877;
}



Bits error versus lambda1



Bits error versus lambda2



Bits error versus phi1



Bits error versus phi2
Initial program 0.8
Simplified0.8
rmApplied sub-neg0.8
Applied cos-sum0.8
Simplified0.8
rmApplied sin-diff0.2
Simplified0.2
rmApplied log1p-expm1-u0.2
rmApplied add-log-exp0.3
Simplified0.3
Final simplification0.3
herbie shell --seed 2019208 +o rules:numerics
(FPCore (lambda1 lambda2 phi1 phi2)
:name "Midpoint on a great circle"
:precision binary64
(+ lambda1 (atan2 (* (cos phi2) (sin (- lambda1 lambda2))) (+ (cos phi1) (* (cos phi2) (cos (- lambda1 lambda2)))))))