\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 \lambda_2\right)}{\frac{\mathsf{fma}\left(\cos \phi_1, \cos \phi_1 \cdot \cos \phi_1, \log \left(e^{\left(\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \sin \lambda_2, \cos \lambda_1 \cdot \cos \lambda_2\right)\right) \cdot \left(\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \sin \lambda_2, \cos \lambda_1 \cdot \cos \lambda_2\right)\right)}\right) \cdot \left(\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \sin \lambda_2, \cos \lambda_1 \cdot \cos \lambda_2\right)\right)\right)}{\mathsf{fma}\left(\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \sin \lambda_2, \cos \lambda_1 \cdot \cos \lambda_2\right), \cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \sin \lambda_2, \cos \lambda_1 \cdot \cos \lambda_2\right) - \cos \phi_1, \cos \phi_1 \cdot \cos \phi_1\right)}}double f(double lambda1, double lambda2, double phi1, double phi2) {
double r2002503 = lambda1;
double r2002504 = phi2;
double r2002505 = cos(r2002504);
double r2002506 = lambda2;
double r2002507 = r2002503 - r2002506;
double r2002508 = sin(r2002507);
double r2002509 = r2002505 * r2002508;
double r2002510 = phi1;
double r2002511 = cos(r2002510);
double r2002512 = cos(r2002507);
double r2002513 = r2002505 * r2002512;
double r2002514 = r2002511 + r2002513;
double r2002515 = atan2(r2002509, r2002514);
double r2002516 = r2002503 + r2002515;
return r2002516;
}
double f(double lambda1, double lambda2, double phi1, double phi2) {
double r2002517 = lambda1;
double r2002518 = phi2;
double r2002519 = cos(r2002518);
double r2002520 = sin(r2002517);
double r2002521 = lambda2;
double r2002522 = cos(r2002521);
double r2002523 = r2002520 * r2002522;
double r2002524 = cos(r2002517);
double r2002525 = sin(r2002521);
double r2002526 = r2002524 * r2002525;
double r2002527 = r2002523 - r2002526;
double r2002528 = r2002519 * r2002527;
double r2002529 = phi1;
double r2002530 = cos(r2002529);
double r2002531 = r2002530 * r2002530;
double r2002532 = r2002524 * r2002522;
double r2002533 = fma(r2002520, r2002525, r2002532);
double r2002534 = r2002519 * r2002533;
double r2002535 = r2002534 * r2002534;
double r2002536 = exp(r2002535);
double r2002537 = log(r2002536);
double r2002538 = r2002537 * r2002534;
double r2002539 = fma(r2002530, r2002531, r2002538);
double r2002540 = r2002534 - r2002530;
double r2002541 = fma(r2002534, r2002540, r2002531);
double r2002542 = r2002539 / r2002541;
double r2002543 = atan2(r2002528, r2002542);
double r2002544 = r2002517 + r2002543;
return r2002544;
}



Bits error versus lambda1



Bits error versus lambda2



Bits error versus phi1



Bits error versus phi2
Initial program 0.9
rmApplied sin-diff0.8
rmApplied cos-diff0.2
rmApplied flip3-+0.3
Simplified0.3
Simplified0.3
rmApplied add-log-exp0.3
Final simplification0.3
herbie shell --seed 2019158 +o rules:numerics
(FPCore (lambda1 lambda2 phi1 phi2)
:name "Midpoint on a great circle"
(+ lambda1 (atan2 (* (cos phi2) (sin (- lambda1 lambda2))) (+ (cos phi1) (* (cos phi2) (cos (- lambda1 lambda2)))))))