Simplified24.5
\[\leadsto \color{blue}{\tan^{-1}_* \frac{\sqrt{\mathsf{fma}\left(\cos \phi_1, \cos \phi_2 \cdot \left(\sin \left(\frac{\lambda_2 - \lambda_1}{2}\right) \cdot \sin \left(\frac{\lambda_2 - \lambda_1}{2}\right)\right), {\sin \left(\frac{\phi_1 - \phi_2}{2}\right)}^{2}\right)}}{\sqrt{\mathsf{fma}\left(\cos \phi_1, \cos \phi_2 \cdot \left(\sin \left(-0.5 \cdot \left(\lambda_2 - \lambda_1\right)\right) \cdot \sin \left(\frac{\lambda_2 - \lambda_1}{2}\right)\right), 1\right) - {\sin \left(\frac{\phi_1 - \phi_2}{2}\right)}^{2}}} \cdot \left(R \cdot 2\right)}
\]
Proof
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (Rewrite<= sqr-neg_binary64 (*.f64 (neg.f64 (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2))) (neg.f64 (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (Rewrite<= sin-neg_binary64 (sin.f64 (neg.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) (neg.f64 (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (Rewrite<= distribute-frac-neg_binary64 (/.f64 (neg.f64 (-.f64 lambda2 lambda1)) 2))) (neg.f64 (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (Rewrite<= sub0-neg_binary64 (-.f64 0 (-.f64 lambda2 lambda1))) 2)) (neg.f64 (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (Rewrite<= associate-+l-_binary64 (+.f64 (-.f64 0 lambda2) lambda1)) 2)) (neg.f64 (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (+.f64 (Rewrite<= neg-sub0_binary64 (neg.f64 lambda2)) lambda1) 2)) (neg.f64 (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (Rewrite<= +-commutative_binary64 (+.f64 lambda1 (neg.f64 lambda2))) 2)) (neg.f64 (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (Rewrite<= sub-neg_binary64 (-.f64 lambda1 lambda2)) 2)) (neg.f64 (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (Rewrite<= sin-neg_binary64 (sin.f64 (neg.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (Rewrite<= distribute-frac-neg_binary64 (/.f64 (neg.f64 (-.f64 lambda2 lambda1)) 2))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (/.f64 (Rewrite<= sub0-neg_binary64 (-.f64 0 (-.f64 lambda2 lambda1))) 2)))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (/.f64 (Rewrite<= associate-+l-_binary64 (+.f64 (-.f64 0 lambda2) lambda1)) 2)))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (/.f64 (+.f64 (Rewrite<= neg-sub0_binary64 (neg.f64 lambda2)) lambda1) 2)))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (/.f64 (Rewrite<= +-commutative_binary64 (+.f64 lambda1 (neg.f64 lambda2))) 2)))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (/.f64 (Rewrite<= sub-neg_binary64 (-.f64 lambda1 lambda2)) 2)))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (Rewrite<= fma-def_binary64 (+.f64 (*.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 6 points increase in error, 2 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (Rewrite<= associate-*l*_binary64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 1 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (Rewrite<= associate-*l*_binary64 (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 5 points increase in error, 6 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (Rewrite<= +-commutative_binary64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 -1/2 (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (*.f64 (Rewrite<= metadata-eval (/.f64 -1 2)) (-.f64 lambda2 lambda1))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (Rewrite<= associate-/r/_binary64 (/.f64 -1 (/.f64 2 (-.f64 lambda2 lambda1))))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 25 points increase in error, 6 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (Rewrite<= associate-/l*_binary64 (/.f64 (*.f64 -1 (-.f64 lambda2 lambda1)) 2))) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 6 points increase in error, 25 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (Rewrite<= neg-mul-1_binary64 (neg.f64 (-.f64 lambda2 lambda1))) 2)) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (Rewrite<= sub0-neg_binary64 (-.f64 0 (-.f64 lambda2 lambda1))) 2)) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (Rewrite<= associate-+l-_binary64 (+.f64 (-.f64 0 lambda2) lambda1)) 2)) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (+.f64 (Rewrite<= neg-sub0_binary64 (neg.f64 lambda2)) lambda1) 2)) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (Rewrite<= +-commutative_binary64 (+.f64 lambda1 (neg.f64 lambda2))) 2)) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (Rewrite<= sub-neg_binary64 (-.f64 lambda1 lambda2)) 2)) (sin.f64 (/.f64 (-.f64 lambda2 lambda1) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (/.f64 (Rewrite=> sub-neg_binary64 (+.f64 lambda2 (neg.f64 lambda1))) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (/.f64 (Rewrite=> +-commutative_binary64 (+.f64 (neg.f64 lambda1) lambda2)) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (/.f64 (+.f64 (Rewrite=> neg-sub0_binary64 (-.f64 0 lambda1)) lambda2) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (/.f64 (Rewrite=> associate-+l-_binary64 (-.f64 0 (-.f64 lambda1 lambda2))) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (/.f64 (Rewrite=> sub0-neg_binary64 (neg.f64 (-.f64 lambda1 lambda2))) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (sin.f64 (Rewrite=> distribute-frac-neg_binary64 (neg.f64 (/.f64 (-.f64 lambda1 lambda2) 2)))))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (*.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)) (Rewrite=> sin-neg_binary64 (neg.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)))))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (Rewrite<= associate-*l*_binary64 (*.f64 (*.f64 (cos.f64 phi2) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (neg.f64 (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 3 points increase in error, 1 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (fma.f64 (cos.f64 phi1) (Rewrite<= distribute-rgt-neg-in_binary64 (neg.f64 (*.f64 (*.f64 (cos.f64 phi2) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (Rewrite<= fma-def_binary64 (+.f64 (*.f64 (cos.f64 phi1) (neg.f64 (*.f64 (*.f64 (cos.f64 phi2) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) 1)) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 4 points increase in error, 1 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (+.f64 (Rewrite<= distribute-rgt-neg-in_binary64 (neg.f64 (*.f64 (cos.f64 phi1) (*.f64 (*.f64 (cos.f64 phi2) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)))))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (+.f64 (neg.f64 (Rewrite<= associate-*l*_binary64 (*.f64 (*.f64 (cos.f64 phi1) (*.f64 (cos.f64 phi2) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 2 points increase in error, 2 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (+.f64 (neg.f64 (*.f64 (Rewrite<= associate-*l*_binary64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)))) 1) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 1 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (Rewrite=> +-commutative_binary64 (+.f64 1 (neg.f64 (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 (Rewrite<= sub-neg_binary64 (-.f64 1 (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (Rewrite<= associate--r+_binary64 (-.f64 1 (+.f64 (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2)))))) (*.f64 R 2)): 12 points increase in error, 11 points decrease in error
(*.f64 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 1 (Rewrite<= +-commutative_binary64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)))))))) (*.f64 R 2)): 0 points increase in error, 0 points decrease in error
(Rewrite<= *-commutative_binary64 (*.f64 (*.f64 R 2) (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 1 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))))))): 0 points increase in error, 0 points decrease in error
(Rewrite<= associate-*r*_binary64 (*.f64 R (*.f64 2 (atan2.f64 (sqrt.f64 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))))) (sqrt.f64 (-.f64 1 (+.f64 (pow.f64 (sin.f64 (/.f64 (-.f64 phi1 phi2) 2)) 2) (*.f64 (*.f64 (*.f64 (cos.f64 phi1) (cos.f64 phi2)) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2))) (sin.f64 (/.f64 (-.f64 lambda1 lambda2) 2)))))))))): 0 points increase in error, 0 points decrease in error