\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{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \cos \lambda_1 \cdot \sin \left(-\lambda_2\right)\right)}{\frac{{\left(\mathsf{fma}\left(\sin \lambda_1, \sin \lambda_2, \cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2\right)}^{3} + {\left(\cos \phi_1\right)}^{3}}{\mathsf{fma}\left(\cos \phi_1, \cos \phi_1, -\left(\mathsf{fma}\left(\sin \lambda_1, \sin \lambda_2, \cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2\right) \cdot \left(\cos \phi_1 - \mathsf{fma}\left(\sin \lambda_1, \sin \lambda_2, \cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2\right)\right)}}double f(double lambda1, double lambda2, double phi1, double phi2) {
double r51880 = lambda1;
double r51881 = phi2;
double r51882 = cos(r51881);
double r51883 = lambda2;
double r51884 = r51880 - r51883;
double r51885 = sin(r51884);
double r51886 = r51882 * r51885;
double r51887 = phi1;
double r51888 = cos(r51887);
double r51889 = cos(r51884);
double r51890 = r51882 * r51889;
double r51891 = r51888 + r51890;
double r51892 = atan2(r51886, r51891);
double r51893 = r51880 + r51892;
return r51893;
}
double f(double lambda1, double lambda2, double phi1, double phi2) {
double r51894 = lambda1;
double r51895 = phi2;
double r51896 = cos(r51895);
double r51897 = sin(r51894);
double r51898 = lambda2;
double r51899 = cos(r51898);
double r51900 = r51897 * r51899;
double r51901 = cos(r51894);
double r51902 = -r51898;
double r51903 = sin(r51902);
double r51904 = r51901 * r51903;
double r51905 = r51900 + r51904;
double r51906 = r51896 * r51905;
double r51907 = sin(r51898);
double r51908 = r51901 * r51899;
double r51909 = fma(r51897, r51907, r51908);
double r51910 = r51909 * r51896;
double r51911 = 3.0;
double r51912 = pow(r51910, r51911);
double r51913 = phi1;
double r51914 = cos(r51913);
double r51915 = pow(r51914, r51911);
double r51916 = r51912 + r51915;
double r51917 = r51914 - r51910;
double r51918 = r51910 * r51917;
double r51919 = -r51918;
double r51920 = fma(r51914, r51914, r51919);
double r51921 = r51916 / r51920;
double r51922 = atan2(r51906, r51921);
double r51923 = r51894 + r51922;
return r51923;
}



Bits error versus lambda1



Bits error versus lambda2



Bits error versus phi1



Bits error versus phi2
Initial program 0.7
Simplified0.7
rmApplied sub-neg0.7
Applied sin-sum0.7
Simplified0.7
rmApplied cos-diff0.2
rmApplied fma-udef0.2
Simplified0.2
rmApplied flip3-+0.3
Simplified0.3
Final simplification0.3
herbie shell --seed 2020045 +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)))))))