Bearing on a great circle

Percentage Accurate: 79.3% → 99.7%
Time: 28.0s
Alternatives: 30
Speedup: 0.9×

Specification

?
\[\begin{array}{l} \\ \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \end{array} \]
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (atan2
  (* (sin (- lambda1 lambda2)) (cos phi2))
  (-
   (* (cos phi1) (sin phi2))
   (* (* (sin phi1) (cos phi2)) (cos (- lambda1 lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
	return atan2((sin((lambda1 - lambda2)) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2)))));
}
real(8) function code(lambda1, lambda2, phi1, phi2)
    real(8), intent (in) :: lambda1
    real(8), intent (in) :: lambda2
    real(8), intent (in) :: phi1
    real(8), intent (in) :: phi2
    code = atan2((sin((lambda1 - lambda2)) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2)))))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
	return Math.atan2((Math.sin((lambda1 - lambda2)) * Math.cos(phi2)), ((Math.cos(phi1) * Math.sin(phi2)) - ((Math.sin(phi1) * Math.cos(phi2)) * Math.cos((lambda1 - lambda2)))));
}
def code(lambda1, lambda2, phi1, phi2):
	return math.atan2((math.sin((lambda1 - lambda2)) * math.cos(phi2)), ((math.cos(phi1) * math.sin(phi2)) - ((math.sin(phi1) * math.cos(phi2)) * math.cos((lambda1 - lambda2)))))
function code(lambda1, lambda2, phi1, phi2)
	return atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(sin(phi1) * cos(phi2)) * cos(Float64(lambda1 - lambda2)))))
end
function tmp = code(lambda1, lambda2, phi1, phi2)
	tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2)))));
end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}

\\
\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}

Sampling outcomes in binary64 precision:

Local Percentage Accuracy vs ?

The average percentage accuracy by input value. Horizontal axis shows value of an input variable; the variable is choosen in the title. Vertical axis is accuracy; higher is better. Red represent the original program, while blue represents Herbie's suggestion. These can be toggled with buttons below the plot. The line is an average while dots represent individual samples.

Accuracy vs Speed?

Herbie found 30 alternatives:

AlternativeAccuracySpeedup
The accuracy (vertical axis) and speed (horizontal axis) of each alternatives. Up and to the right is better. The red square shows the initial program, and each blue circle shows an alternative.The line shows the best available speed-accuracy tradeoffs.

Initial Program: 79.3% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \end{array} \]
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (atan2
  (* (sin (- lambda1 lambda2)) (cos phi2))
  (-
   (* (cos phi1) (sin phi2))
   (* (* (sin phi1) (cos phi2)) (cos (- lambda1 lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
	return atan2((sin((lambda1 - lambda2)) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2)))));
}
real(8) function code(lambda1, lambda2, phi1, phi2)
    real(8), intent (in) :: lambda1
    real(8), intent (in) :: lambda2
    real(8), intent (in) :: phi1
    real(8), intent (in) :: phi2
    code = atan2((sin((lambda1 - lambda2)) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2)))))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
	return Math.atan2((Math.sin((lambda1 - lambda2)) * Math.cos(phi2)), ((Math.cos(phi1) * Math.sin(phi2)) - ((Math.sin(phi1) * Math.cos(phi2)) * Math.cos((lambda1 - lambda2)))));
}
def code(lambda1, lambda2, phi1, phi2):
	return math.atan2((math.sin((lambda1 - lambda2)) * math.cos(phi2)), ((math.cos(phi1) * math.sin(phi2)) - ((math.sin(phi1) * math.cos(phi2)) * math.cos((lambda1 - lambda2)))))
function code(lambda1, lambda2, phi1, phi2)
	return atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(sin(phi1) * cos(phi2)) * cos(Float64(lambda1 - lambda2)))))
end
function tmp = code(lambda1, lambda2, phi1, phi2)
	tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2)))));
end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}

\\
\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}

Alternative 1: 99.7% accurate, 0.5× speedup?

\[\begin{array}{l} \\ \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \mathsf{fma}\left(\sin \phi_1 \cdot \left(\cos \lambda_1 \cdot \cos \lambda_2\right), \cos \phi_2, \left(\sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)\right)} \end{array} \]
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (atan2
  (*
   (cos phi2)
   (fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2)))))
  (-
   (* (sin phi2) (cos phi1))
   (fma
    (* (sin phi1) (* (cos lambda1) (cos lambda2)))
    (cos phi2)
    (* (* (sin lambda2) (sin lambda1)) (* (sin phi1) (cos phi2)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
	return atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), ((sin(phi2) * cos(phi1)) - fma((sin(phi1) * (cos(lambda1) * cos(lambda2))), cos(phi2), ((sin(lambda2) * sin(lambda1)) * (sin(phi1) * cos(phi2))))));
}
function code(lambda1, lambda2, phi1, phi2)
	return atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(Float64(sin(phi2) * cos(phi1)) - fma(Float64(sin(phi1) * Float64(cos(lambda1) * cos(lambda2))), cos(phi2), Float64(Float64(sin(lambda2) * sin(lambda1)) * Float64(sin(phi1) * cos(phi2))))))
end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Sin[phi1], $MachinePrecision] * N[(N[Cos[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision] + N[(N[(N[Sin[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}

\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \mathsf{fma}\left(\sin \phi_1 \cdot \left(\cos \lambda_1 \cdot \cos \lambda_2\right), \cos \phi_2, \left(\sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)\right)}
\end{array}
Derivation
  1. Initial program 77.1%

    \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
  2. Add Preprocessing
  3. Step-by-step derivation
    1. lift-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    2. lift--.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    3. sin-diffN/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    4. sub-negN/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    5. lower-fma.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    6. lower-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\color{blue}{\sin \lambda_1}, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    7. lower-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \color{blue}{\cos \lambda_2}, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    8. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\color{blue}{\sin \lambda_2 \cdot \cos \lambda_1}\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    9. distribute-lft-neg-inN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    10. sin-negN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    11. lower-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    12. sin-negN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    13. lower-neg.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    14. lower-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\color{blue}{\sin \lambda_2}\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    15. lower-cos.f6489.3

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \color{blue}{\cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
  4. Applied rewrites89.3%

    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
  5. Step-by-step derivation
    1. lift-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
    2. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \left(\lambda_1 - \lambda_2\right)}} \]
    3. lift--.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \color{blue}{\left(\lambda_1 - \lambda_2\right)}} \]
    4. cos-diffN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\left(\cos \lambda_1 \cdot \cos \lambda_2 + \sin \lambda_1 \cdot \sin \lambda_2\right)}} \]
    5. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\color{blue}{\cos \lambda_1} \cdot \cos \lambda_2 + \sin \lambda_1 \cdot \sin \lambda_2\right)} \]
    6. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\cos \lambda_1 \cdot \color{blue}{\cos \lambda_2} + \sin \lambda_1 \cdot \sin \lambda_2\right)} \]
    7. lift-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\color{blue}{\cos \lambda_1 \cdot \cos \lambda_2} + \sin \lambda_1 \cdot \sin \lambda_2\right)} \]
    8. distribute-lft-inN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\cos \lambda_1 \cdot \cos \lambda_2\right) + \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2\right)\right)}} \]
    9. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\left(\cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)} + \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2\right)\right)} \]
    10. lift-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\left(\cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right)} + \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2\right)\right)} \]
    11. associate-*r*N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\left(\left(\cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \sin \phi_1\right) \cdot \cos \phi_2} + \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2\right)\right)} \]
    12. lower-fma.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\mathsf{fma}\left(\left(\cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \sin \phi_1, \cos \phi_2, \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2\right)\right)}} \]
    13. lower-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \mathsf{fma}\left(\color{blue}{\left(\cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \sin \phi_1}, \cos \phi_2, \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2\right)\right)} \]
    14. lower-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \mathsf{fma}\left(\left(\cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \sin \phi_1, \cos \phi_2, \color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2\right)}\right)} \]
  6. Applied rewrites99.7%

    \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\mathsf{fma}\left(\left(\cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \sin \phi_1, \cos \phi_2, \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\sin \lambda_2 \cdot \sin \lambda_1\right)\right)}} \]
  7. Final simplification99.7%

    \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \mathsf{fma}\left(\sin \phi_1 \cdot \left(\cos \lambda_1 \cdot \cos \lambda_2\right), \cos \phi_2, \left(\sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)\right)} \]
  8. Add Preprocessing

Alternative 2: 99.7% accurate, 0.5× speedup?

\[\begin{array}{l} \\ \tan^{-1}_* \frac{\mathsf{fma}\left(-\cos \lambda_1, \cos \phi_2 \cdot \sin \lambda_2, \left(\cos \phi_2 \cdot \sin \lambda_1\right) \cdot \cos \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \end{array} \]
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (atan2
  (fma
   (- (cos lambda1))
   (* (cos phi2) (sin lambda2))
   (* (* (cos phi2) (sin lambda1)) (cos lambda2)))
  (-
   (* (sin phi2) (cos phi1))
   (*
    (*
     (fma (cos lambda2) (cos lambda1) (* (sin lambda2) (sin lambda1)))
     (cos phi2))
    (sin phi1)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
	return atan2(fma(-cos(lambda1), (cos(phi2) * sin(lambda2)), ((cos(phi2) * sin(lambda1)) * cos(lambda2))), ((sin(phi2) * cos(phi1)) - ((fma(cos(lambda2), cos(lambda1), (sin(lambda2) * sin(lambda1))) * cos(phi2)) * sin(phi1))));
}
function code(lambda1, lambda2, phi1, phi2)
	return atan(fma(Float64(-cos(lambda1)), Float64(cos(phi2) * sin(lambda2)), Float64(Float64(cos(phi2) * sin(lambda1)) * cos(lambda2))), Float64(Float64(sin(phi2) * cos(phi1)) - Float64(Float64(fma(cos(lambda2), cos(lambda1), Float64(sin(lambda2) * sin(lambda1))) * cos(phi2)) * sin(phi1))))
end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[((-N[Cos[lambda1], $MachinePrecision]) * N[(N[Cos[phi2], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision] + N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}

\\
\tan^{-1}_* \frac{\mathsf{fma}\left(-\cos \lambda_1, \cos \phi_2 \cdot \sin \lambda_2, \left(\cos \phi_2 \cdot \sin \lambda_1\right) \cdot \cos \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1}
\end{array}
Derivation
  1. Initial program 77.1%

    \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
  2. Add Preprocessing
  3. Step-by-step derivation
    1. lift-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
    2. lift-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right)} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    3. associate-*l*N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)}} \]
    4. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot \sin \phi_1}} \]
    5. lower-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot \sin \phi_1}} \]
    6. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right)} \cdot \sin \phi_1} \]
    7. lower-*.f6477.1

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right)} \cdot \sin \phi_1} \]
  4. Applied rewrites77.1%

    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1}} \]
  5. Step-by-step derivation
    1. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\cos \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    2. lift--.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \color{blue}{\left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    3. cos-diffN/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\left(\cos \lambda_1 \cdot \cos \lambda_2 + \sin \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    4. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\left(\color{blue}{\cos \lambda_1} \cdot \cos \lambda_2 + \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    5. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\left(\cos \lambda_1 \cdot \color{blue}{\cos \lambda_2} + \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    6. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\left(\color{blue}{\cos \lambda_2 \cdot \cos \lambda_1} + \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    7. lower-fma.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    8. lift-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \color{blue}{\sin \lambda_1} \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    9. lift-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \color{blue}{\sin \lambda_2}\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    10. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \color{blue}{\sin \lambda_2 \cdot \sin \lambda_1}\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    11. lower-*.f6477.3

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \color{blue}{\sin \lambda_2 \cdot \sin \lambda_1}\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  6. Applied rewrites77.3%

    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  7. Step-by-step derivation
    1. lift-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    2. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    3. lift-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    4. lift--.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    5. sin-diffN/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    6. lift-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\color{blue}{\sin \lambda_1} \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    7. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \color{blue}{\cos \lambda_2} - \cos \lambda_1 \cdot \sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    8. sub-negN/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    9. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\color{blue}{\cos \lambda_1} \cdot \sin \lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    10. lift-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\cos \lambda_1 \cdot \color{blue}{\sin \lambda_2}\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    11. distribute-rgt-neg-outN/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \color{blue}{\cos \lambda_1 \cdot \left(\mathsf{neg}\left(\sin \lambda_2\right)\right)}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    12. lift-neg.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \cos \lambda_1 \cdot \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    13. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    14. lift-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    15. flip-+N/A

      \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\frac{\left(\sin \lambda_1 \cdot \cos \lambda_2\right) \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2\right) - \left(\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \left(\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right)}{\sin \lambda_1 \cdot \cos \lambda_2 - \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  8. Applied rewrites99.7%

    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\left(-\sin \lambda_2\right) \cdot \cos \lambda_1, \cos \phi_2, \left(\sin \lambda_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  9. Taylor expanded in lambda1 around inf

    \[\leadsto \tan^{-1}_* \frac{\color{blue}{-1 \cdot \left(\cos \lambda_1 \cdot \left(\cos \phi_2 \cdot \sin \lambda_2\right)\right) + \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \lambda_1\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  10. Step-by-step derivation
    1. associate-*r*N/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(-1 \cdot \cos \lambda_1\right) \cdot \left(\cos \phi_2 \cdot \sin \lambda_2\right)} + \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \lambda_1\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    2. lower-fma.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(-1 \cdot \cos \lambda_1, \cos \phi_2 \cdot \sin \lambda_2, \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \lambda_1\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    3. mul-1-negN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\color{blue}{\mathsf{neg}\left(\cos \lambda_1\right)}, \cos \phi_2 \cdot \sin \lambda_2, \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \lambda_1\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    4. lower-neg.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\color{blue}{\mathsf{neg}\left(\cos \lambda_1\right)}, \cos \phi_2 \cdot \sin \lambda_2, \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \lambda_1\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    5. lower-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\color{blue}{\cos \lambda_1}\right), \cos \phi_2 \cdot \sin \lambda_2, \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \lambda_1\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    6. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \color{blue}{\sin \lambda_2 \cdot \cos \phi_2}, \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \lambda_1\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    7. lower-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \color{blue}{\sin \lambda_2 \cdot \cos \phi_2}, \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \lambda_1\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    8. lower-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \color{blue}{\sin \lambda_2} \cdot \cos \phi_2, \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \lambda_1\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    9. lower-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \sin \lambda_2 \cdot \color{blue}{\cos \phi_2}, \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \lambda_1\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    10. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \sin \lambda_2 \cdot \cos \phi_2, \color{blue}{\left(\cos \phi_2 \cdot \sin \lambda_1\right) \cdot \cos \lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    11. lower-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \sin \lambda_2 \cdot \cos \phi_2, \color{blue}{\left(\cos \phi_2 \cdot \sin \lambda_1\right) \cdot \cos \lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    12. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \sin \lambda_2 \cdot \cos \phi_2, \color{blue}{\left(\sin \lambda_1 \cdot \cos \phi_2\right)} \cdot \cos \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    13. lower-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \sin \lambda_2 \cdot \cos \phi_2, \color{blue}{\left(\sin \lambda_1 \cdot \cos \phi_2\right)} \cdot \cos \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    14. lower-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \sin \lambda_2 \cdot \cos \phi_2, \left(\color{blue}{\sin \lambda_1} \cdot \cos \phi_2\right) \cdot \cos \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    15. lower-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \sin \lambda_2 \cdot \cos \phi_2, \left(\sin \lambda_1 \cdot \color{blue}{\cos \phi_2}\right) \cdot \cos \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    16. lower-cos.f6499.7

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(-\cos \lambda_1, \sin \lambda_2 \cdot \cos \phi_2, \left(\sin \lambda_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  11. Applied rewrites99.7%

    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(-\cos \lambda_1, \sin \lambda_2 \cdot \cos \phi_2, \left(\sin \lambda_1 \cdot \cos \phi_2\right) \cdot \cos \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  12. Final simplification99.7%

    \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(-\cos \lambda_1, \cos \phi_2 \cdot \sin \lambda_2, \left(\cos \phi_2 \cdot \sin \lambda_1\right) \cdot \cos \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  13. Add Preprocessing

Alternative 3: 99.7% accurate, 0.6× speedup?

\[\begin{array}{l} \\ \tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \end{array} \]
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (atan2
  (*
   (- (* (cos lambda2) (sin lambda1)) (* (cos lambda1) (sin lambda2)))
   (cos phi2))
  (-
   (* (sin phi2) (cos phi1))
   (*
    (*
     (fma (cos lambda2) (cos lambda1) (* (sin lambda2) (sin lambda1)))
     (cos phi2))
    (sin phi1)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
	return atan2((((cos(lambda2) * sin(lambda1)) - (cos(lambda1) * sin(lambda2))) * cos(phi2)), ((sin(phi2) * cos(phi1)) - ((fma(cos(lambda2), cos(lambda1), (sin(lambda2) * sin(lambda1))) * cos(phi2)) * sin(phi1))));
}
function code(lambda1, lambda2, phi1, phi2)
	return atan(Float64(Float64(Float64(cos(lambda2) * sin(lambda1)) - Float64(cos(lambda1) * sin(lambda2))) * cos(phi2)), Float64(Float64(sin(phi2) * cos(phi1)) - Float64(Float64(fma(cos(lambda2), cos(lambda1), Float64(sin(lambda2) * sin(lambda1))) * cos(phi2)) * sin(phi1))))
end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}

\\
\tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1}
\end{array}
Derivation
  1. Initial program 77.1%

    \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
  2. Add Preprocessing
  3. Step-by-step derivation
    1. lift-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
    2. lift-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right)} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    3. associate-*l*N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)}} \]
    4. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot \sin \phi_1}} \]
    5. lower-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot \sin \phi_1}} \]
    6. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right)} \cdot \sin \phi_1} \]
    7. lower-*.f6477.1

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right)} \cdot \sin \phi_1} \]
  4. Applied rewrites77.1%

    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1}} \]
  5. Step-by-step derivation
    1. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\cos \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    2. lift--.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \color{blue}{\left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    3. cos-diffN/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\left(\cos \lambda_1 \cdot \cos \lambda_2 + \sin \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    4. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\left(\color{blue}{\cos \lambda_1} \cdot \cos \lambda_2 + \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    5. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\left(\cos \lambda_1 \cdot \color{blue}{\cos \lambda_2} + \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    6. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\left(\color{blue}{\cos \lambda_2 \cdot \cos \lambda_1} + \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    7. lower-fma.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    8. lift-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \color{blue}{\sin \lambda_1} \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    9. lift-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \color{blue}{\sin \lambda_2}\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    10. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \color{blue}{\sin \lambda_2 \cdot \sin \lambda_1}\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    11. lower-*.f6477.3

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \color{blue}{\sin \lambda_2 \cdot \sin \lambda_1}\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  6. Applied rewrites77.3%

    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  7. Step-by-step derivation
    1. lift-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    2. lift--.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    3. sin-diffN/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    4. lift-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\left(\color{blue}{\sin \lambda_1} \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    5. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\left(\sin \lambda_1 \cdot \color{blue}{\cos \lambda_2} - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    6. lift-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \color{blue}{\cos \lambda_1} \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    7. lift-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \color{blue}{\sin \lambda_2}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    8. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \color{blue}{\sin \lambda_2 \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    9. lower--.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \sin \lambda_2 \cdot \cos \lambda_1\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    10. lower-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\left(\color{blue}{\sin \lambda_1 \cdot \cos \lambda_2} - \sin \lambda_2 \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    11. lower-*.f6499.7

      \[\leadsto \tan^{-1}_* \frac{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \color{blue}{\sin \lambda_2 \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  8. Applied rewrites99.7%

    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \sin \lambda_2 \cdot \cos \lambda_1\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  9. Final simplification99.7%

    \[\leadsto \tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  10. Add Preprocessing

Alternative 4: 94.7% accurate, 0.6× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{t\_0 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{if}\;\phi_2 \leq -2.4 \cdot 10^{-5}:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;\phi_2 \leq 3.5 \cdot 10^{-6}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(-\cos \lambda_1, \sin \lambda_2, \cos \lambda_2 \cdot \sin \lambda_1\right)}{t\_0 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (let* ((t_0 (* (sin phi2) (cos phi1)))
        (t_1
         (atan2
          (*
           (cos phi2)
           (fma
            (sin lambda1)
            (cos lambda2)
            (* (cos lambda1) (- (sin lambda2)))))
          (- t_0 (* (cos (- lambda1 lambda2)) (* (sin phi1) (cos phi2)))))))
   (if (<= phi2 -2.4e-5)
     t_1
     (if (<= phi2 3.5e-6)
       (atan2
        (fma (- (cos lambda1)) (sin lambda2) (* (cos lambda2) (sin lambda1)))
        (-
         t_0
         (*
          (*
           (fma (cos lambda2) (cos lambda1) (* (sin lambda2) (sin lambda1)))
           (cos phi2))
          (sin phi1))))
       t_1))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
	double t_0 = sin(phi2) * cos(phi1);
	double t_1 = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), (t_0 - (cos((lambda1 - lambda2)) * (sin(phi1) * cos(phi2)))));
	double tmp;
	if (phi2 <= -2.4e-5) {
		tmp = t_1;
	} else if (phi2 <= 3.5e-6) {
		tmp = atan2(fma(-cos(lambda1), sin(lambda2), (cos(lambda2) * sin(lambda1))), (t_0 - ((fma(cos(lambda2), cos(lambda1), (sin(lambda2) * sin(lambda1))) * cos(phi2)) * sin(phi1))));
	} else {
		tmp = t_1;
	}
	return tmp;
}
function code(lambda1, lambda2, phi1, phi2)
	t_0 = Float64(sin(phi2) * cos(phi1))
	t_1 = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(t_0 - Float64(cos(Float64(lambda1 - lambda2)) * Float64(sin(phi1) * cos(phi2)))))
	tmp = 0.0
	if (phi2 <= -2.4e-5)
		tmp = t_1;
	elseif (phi2 <= 3.5e-6)
		tmp = atan(fma(Float64(-cos(lambda1)), sin(lambda2), Float64(cos(lambda2) * sin(lambda1))), Float64(t_0 - Float64(Float64(fma(cos(lambda2), cos(lambda1), Float64(sin(lambda2) * sin(lambda1))) * cos(phi2)) * sin(phi1))));
	else
		tmp = t_1;
	end
	return tmp
end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi2, -2.4e-5], t$95$1, If[LessEqual[phi2, 3.5e-6], N[ArcTan[N[((-N[Cos[lambda1], $MachinePrecision]) * N[Sin[lambda2], $MachinePrecision] + N[(N[Cos[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$1]]]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \sin \phi_2 \cdot \cos \phi_1\\
t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{t\_0 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\
\mathbf{if}\;\phi_2 \leq -2.4 \cdot 10^{-5}:\\
\;\;\;\;t\_1\\

\mathbf{elif}\;\phi_2 \leq 3.5 \cdot 10^{-6}:\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(-\cos \lambda_1, \sin \lambda_2, \cos \lambda_2 \cdot \sin \lambda_1\right)}{t\_0 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1}\\

\mathbf{else}:\\
\;\;\;\;t\_1\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if phi2 < -2.4000000000000001e-5 or 3.49999999999999995e-6 < phi2

    1. Initial program 76.2%

      \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      2. lift--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      3. sin-diffN/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      4. sub-negN/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      5. lower-fma.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      6. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\color{blue}{\sin \lambda_1}, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      7. lower-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \color{blue}{\cos \lambda_2}, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      8. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\color{blue}{\sin \lambda_2 \cdot \cos \lambda_1}\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      9. distribute-lft-neg-inN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      10. sin-negN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      11. lower-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      12. sin-negN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      13. lower-neg.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      14. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\color{blue}{\sin \lambda_2}\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      15. lower-cos.f6490.0

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \color{blue}{\cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    4. Applied rewrites90.0%

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

    if -2.4000000000000001e-5 < phi2 < 3.49999999999999995e-6

    1. Initial program 77.9%

      \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
      2. lift-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right)} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      3. associate-*l*N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)}} \]
      4. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot \sin \phi_1}} \]
      5. lower-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot \sin \phi_1}} \]
      6. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right)} \cdot \sin \phi_1} \]
      7. lower-*.f6477.9

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right)} \cdot \sin \phi_1} \]
    4. Applied rewrites77.9%

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1}} \]
    5. Step-by-step derivation
      1. lift-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\cos \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      2. lift--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \color{blue}{\left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      3. cos-diffN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\left(\cos \lambda_1 \cdot \cos \lambda_2 + \sin \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      4. lift-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\left(\color{blue}{\cos \lambda_1} \cdot \cos \lambda_2 + \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      5. lift-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\left(\cos \lambda_1 \cdot \color{blue}{\cos \lambda_2} + \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      6. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\left(\color{blue}{\cos \lambda_2 \cdot \cos \lambda_1} + \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      7. lower-fma.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      8. lift-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \color{blue}{\sin \lambda_1} \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      9. lift-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \color{blue}{\sin \lambda_2}\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      10. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \color{blue}{\sin \lambda_2 \cdot \sin \lambda_1}\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      11. lower-*.f6478.2

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \color{blue}{\sin \lambda_2 \cdot \sin \lambda_1}\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    6. Applied rewrites78.2%

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    7. Step-by-step derivation
      1. lift-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      2. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      3. lift-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      4. lift--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      5. sin-diffN/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      6. lift-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\color{blue}{\sin \lambda_1} \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      7. lift-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \color{blue}{\cos \lambda_2} - \cos \lambda_1 \cdot \sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      8. sub-negN/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      9. lift-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\color{blue}{\cos \lambda_1} \cdot \sin \lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      10. lift-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\cos \lambda_1 \cdot \color{blue}{\sin \lambda_2}\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      11. distribute-rgt-neg-outN/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \color{blue}{\cos \lambda_1 \cdot \left(\mathsf{neg}\left(\sin \lambda_2\right)\right)}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      12. lift-neg.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \cos \lambda_1 \cdot \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      13. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      14. lift-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 + \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      15. flip-+N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\frac{\left(\sin \lambda_1 \cdot \cos \lambda_2\right) \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2\right) - \left(\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \left(\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right)}{\sin \lambda_1 \cdot \cos \lambda_2 - \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    8. Applied rewrites99.9%

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\left(-\sin \lambda_2\right) \cdot \cos \lambda_1, \cos \phi_2, \left(\sin \lambda_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    9. Taylor expanded in phi2 around 0

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{-1 \cdot \left(\cos \lambda_1 \cdot \sin \lambda_2\right) + \cos \lambda_2 \cdot \sin \lambda_1}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    10. Step-by-step derivation
      1. associate-*r*N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(-1 \cdot \cos \lambda_1\right) \cdot \sin \lambda_2} + \cos \lambda_2 \cdot \sin \lambda_1}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      2. lower-fma.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(-1 \cdot \cos \lambda_1, \sin \lambda_2, \cos \lambda_2 \cdot \sin \lambda_1\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      3. mul-1-negN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\color{blue}{\mathsf{neg}\left(\cos \lambda_1\right)}, \sin \lambda_2, \cos \lambda_2 \cdot \sin \lambda_1\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      4. lower-neg.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\color{blue}{\mathsf{neg}\left(\cos \lambda_1\right)}, \sin \lambda_2, \cos \lambda_2 \cdot \sin \lambda_1\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      5. lower-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\color{blue}{\cos \lambda_1}\right), \sin \lambda_2, \cos \lambda_2 \cdot \sin \lambda_1\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      6. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \color{blue}{\sin \lambda_2}, \cos \lambda_2 \cdot \sin \lambda_1\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      7. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \sin \lambda_2, \color{blue}{\sin \lambda_1 \cdot \cos \lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      8. lower-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \sin \lambda_2, \color{blue}{\sin \lambda_1 \cdot \cos \lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      9. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{neg}\left(\cos \lambda_1\right), \sin \lambda_2, \color{blue}{\sin \lambda_1} \cdot \cos \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      10. lower-cos.f6499.9

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(-\cos \lambda_1, \sin \lambda_2, \sin \lambda_1 \cdot \color{blue}{\cos \lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
    11. Applied rewrites99.9%

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(-\cos \lambda_1, \sin \lambda_2, \sin \lambda_1 \cdot \cos \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification94.8%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\phi_2 \leq -2.4 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{elif}\;\phi_2 \leq 3.5 \cdot 10^{-6}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(-\cos \lambda_1, \sin \lambda_2, \cos \lambda_2 \cdot \sin \lambda_1\right)}{\sin \phi_2 \cdot \cos \phi_1 - \left(\mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 5: 89.0% accurate, 0.7× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ t_1 := \cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)\\ t_2 := \sin \phi_1 \cdot \cos \phi_2\\ t_3 := \tan^{-1}_* \frac{t\_1}{t\_0 - \cos \lambda_2 \cdot t\_2}\\ \mathbf{if}\;\lambda_2 \leq -1.28 \cdot 10^{+35}:\\ \;\;\;\;t\_3\\ \mathbf{elif}\;\lambda_2 \leq 0.0038:\\ \;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \cos \lambda_1 \cdot t\_2}\\ \mathbf{else}:\\ \;\;\;\;t\_3\\ \end{array} \end{array} \]
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (let* ((t_0 (* (sin phi2) (cos phi1)))
        (t_1
         (*
          (cos phi2)
          (fma
           (sin lambda1)
           (cos lambda2)
           (* (cos lambda1) (- (sin lambda2))))))
        (t_2 (* (sin phi1) (cos phi2)))
        (t_3 (atan2 t_1 (- t_0 (* (cos lambda2) t_2)))))
   (if (<= lambda2 -1.28e+35)
     t_3
     (if (<= lambda2 0.0038) (atan2 t_1 (- t_0 (* (cos lambda1) t_2))) t_3))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
	double t_0 = sin(phi2) * cos(phi1);
	double t_1 = cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)));
	double t_2 = sin(phi1) * cos(phi2);
	double t_3 = atan2(t_1, (t_0 - (cos(lambda2) * t_2)));
	double tmp;
	if (lambda2 <= -1.28e+35) {
		tmp = t_3;
	} else if (lambda2 <= 0.0038) {
		tmp = atan2(t_1, (t_0 - (cos(lambda1) * t_2)));
	} else {
		tmp = t_3;
	}
	return tmp;
}
function code(lambda1, lambda2, phi1, phi2)
	t_0 = Float64(sin(phi2) * cos(phi1))
	t_1 = Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2)))))
	t_2 = Float64(sin(phi1) * cos(phi2))
	t_3 = atan(t_1, Float64(t_0 - Float64(cos(lambda2) * t_2)))
	tmp = 0.0
	if (lambda2 <= -1.28e+35)
		tmp = t_3;
	elseif (lambda2 <= 0.0038)
		tmp = atan(t_1, Float64(t_0 - Float64(cos(lambda1) * t_2)));
	else
		tmp = t_3;
	end
	return tmp
end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[ArcTan[t$95$1 / N[(t$95$0 - N[(N[Cos[lambda2], $MachinePrecision] * t$95$2), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda2, -1.28e+35], t$95$3, If[LessEqual[lambda2, 0.0038], N[ArcTan[t$95$1 / N[(t$95$0 - N[(N[Cos[lambda1], $MachinePrecision] * t$95$2), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$3]]]]]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \sin \phi_2 \cdot \cos \phi_1\\
t_1 := \cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)\\
t_2 := \sin \phi_1 \cdot \cos \phi_2\\
t_3 := \tan^{-1}_* \frac{t\_1}{t\_0 - \cos \lambda_2 \cdot t\_2}\\
\mathbf{if}\;\lambda_2 \leq -1.28 \cdot 10^{+35}:\\
\;\;\;\;t\_3\\

\mathbf{elif}\;\lambda_2 \leq 0.0038:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \cos \lambda_1 \cdot t\_2}\\

\mathbf{else}:\\
\;\;\;\;t\_3\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if lambda2 < -1.2799999999999999e35 or 0.00379999999999999999 < lambda2

    1. Initial program 62.6%

      \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      2. lift--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      3. sin-diffN/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      4. sub-negN/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      5. lower-fma.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      6. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\color{blue}{\sin \lambda_1}, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      7. lower-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \color{blue}{\cos \lambda_2}, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      8. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\color{blue}{\sin \lambda_2 \cdot \cos \lambda_1}\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      9. distribute-lft-neg-inN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      10. sin-negN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      11. lower-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      12. sin-negN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      13. lower-neg.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      14. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\color{blue}{\sin \lambda_2}\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      15. lower-cos.f6481.8

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \color{blue}{\cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    4. Applied rewrites81.8%

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    5. Taylor expanded in lambda1 around 0

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \left(\mathsf{neg}\left(\lambda_2\right)\right)}} \]
    6. Step-by-step derivation
      1. cos-negN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_2}} \]
      2. lower-cos.f6482.0

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_2}} \]
    7. Applied rewrites82.0%

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_2}} \]

    if -1.2799999999999999e35 < lambda2 < 0.00379999999999999999

    1. Initial program 94.8%

      \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      2. lift--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      3. sin-diffN/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      4. sub-negN/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      5. lower-fma.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      6. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\color{blue}{\sin \lambda_1}, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      7. lower-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \color{blue}{\cos \lambda_2}, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      8. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\color{blue}{\sin \lambda_2 \cdot \cos \lambda_1}\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      9. distribute-lft-neg-inN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      10. sin-negN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      11. lower-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      12. sin-negN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      13. lower-neg.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      14. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\color{blue}{\sin \lambda_2}\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      15. lower-cos.f6498.5

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \color{blue}{\cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    4. Applied rewrites98.5%

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    5. Taylor expanded in lambda2 around 0

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_1}} \]
    6. Step-by-step derivation
      1. lower-cos.f6498.5

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_1}} \]
    7. Applied rewrites98.5%

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_1}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification89.4%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_2 \leq -1.28 \cdot 10^{+35}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \cos \lambda_2 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{elif}\;\lambda_2 \leq 0.0038:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \cos \lambda_1 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \cos \lambda_2 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 6: 89.5% accurate, 0.7× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{t\_0 - \cos \lambda_1 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{if}\;\lambda_1 \leq -0.0115:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;\lambda_1 \leq 10^{-6}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, t\_0\right)}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (let* ((t_0 (* (sin phi2) (cos phi1)))
        (t_1
         (atan2
          (*
           (cos phi2)
           (fma
            (sin lambda1)
            (cos lambda2)
            (* (cos lambda1) (- (sin lambda2)))))
          (- t_0 (* (cos lambda1) (* (sin phi1) (cos phi2)))))))
   (if (<= lambda1 -0.0115)
     t_1
     (if (<= lambda1 1e-6)
       (atan2
        (* (sin (- lambda1 lambda2)) (cos phi2))
        (fma (* (- (sin phi1)) (cos (- lambda1 lambda2))) (cos phi2) t_0))
       t_1))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
	double t_0 = sin(phi2) * cos(phi1);
	double t_1 = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), (t_0 - (cos(lambda1) * (sin(phi1) * cos(phi2)))));
	double tmp;
	if (lambda1 <= -0.0115) {
		tmp = t_1;
	} else if (lambda1 <= 1e-6) {
		tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), fma((-sin(phi1) * cos((lambda1 - lambda2))), cos(phi2), t_0));
	} else {
		tmp = t_1;
	}
	return tmp;
}
function code(lambda1, lambda2, phi1, phi2)
	t_0 = Float64(sin(phi2) * cos(phi1))
	t_1 = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(t_0 - Float64(cos(lambda1) * Float64(sin(phi1) * cos(phi2)))))
	tmp = 0.0
	if (lambda1 <= -0.0115)
		tmp = t_1;
	elseif (lambda1 <= 1e-6)
		tmp = atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), fma(Float64(Float64(-sin(phi1)) * cos(Float64(lambda1 - lambda2))), cos(phi2), t_0));
	else
		tmp = t_1;
	end
	return tmp
end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Cos[lambda1], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda1, -0.0115], t$95$1, If[LessEqual[lambda1, 1e-6], N[ArcTan[N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[((-N[Sin[phi1], $MachinePrecision]) * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision] + t$95$0), $MachinePrecision]], $MachinePrecision], t$95$1]]]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \sin \phi_2 \cdot \cos \phi_1\\
t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{t\_0 - \cos \lambda_1 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\
\mathbf{if}\;\lambda_1 \leq -0.0115:\\
\;\;\;\;t\_1\\

\mathbf{elif}\;\lambda_1 \leq 10^{-6}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, t\_0\right)}\\

\mathbf{else}:\\
\;\;\;\;t\_1\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if lambda1 < -0.0115 or 9.99999999999999955e-7 < lambda1

    1. Initial program 54.3%

      \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      2. lift--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      3. sin-diffN/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      4. sub-negN/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      5. lower-fma.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      6. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\color{blue}{\sin \lambda_1}, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      7. lower-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \color{blue}{\cos \lambda_2}, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      8. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\color{blue}{\sin \lambda_2 \cdot \cos \lambda_1}\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      9. distribute-lft-neg-inN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      10. sin-negN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      11. lower-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      12. sin-negN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      13. lower-neg.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      14. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\color{blue}{\sin \lambda_2}\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      15. lower-cos.f6479.2

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \color{blue}{\cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    4. Applied rewrites79.2%

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    5. Taylor expanded in lambda2 around 0

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_1}} \]
    6. Step-by-step derivation
      1. lower-cos.f6479.1

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_1}} \]
    7. Applied rewrites79.1%

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_1}} \]

    if -0.0115 < lambda1 < 9.99999999999999955e-7

    1. Initial program 99.2%

      \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      2. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      3. lower-*.f6499.2

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      4. lift--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
      5. sub-negN/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\cos \phi_1 \cdot \sin \phi_2 + \left(\mathsf{neg}\left(\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)\right)}} \]
      6. +-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\left(\mathsf{neg}\left(\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)\right) + \cos \phi_1 \cdot \sin \phi_2}} \]
      7. lift-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}\right)\right) + \cos \phi_1 \cdot \sin \phi_2} \]
      8. lift-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right)} \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)\right) + \cos \phi_1 \cdot \sin \phi_2} \]
      9. associate-*l*N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\color{blue}{\sin \phi_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)}\right)\right) + \cos \phi_1 \cdot \sin \phi_2} \]
      10. distribute-lft-neg-inN/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)} + \cos \phi_1 \cdot \sin \phi_2} \]
      11. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right)} + \cos \phi_1 \cdot \sin \phi_2} \]
      12. associate-*r*N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\left(\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot \cos \phi_2} + \cos \phi_1 \cdot \sin \phi_2} \]
      13. lower-fma.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, \cos \phi_1 \cdot \sin \phi_2\right)}} \]
    4. Applied rewrites99.2%

      \[\leadsto \color{blue}{\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, \sin \phi_2 \cdot \cos \phi_1\right)}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification89.3%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 \leq -0.0115:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \cos \lambda_1 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{elif}\;\lambda_1 \leq 10^{-6}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, \sin \phi_2 \cdot \cos \phi_1\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \cos \lambda_1 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 7: 89.7% accurate, 0.7× speedup?

\[\begin{array}{l} \\ \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)} \end{array} \]
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (atan2
  (*
   (cos phi2)
   (fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2)))))
  (-
   (* (sin phi2) (cos phi1))
   (* (cos (- lambda1 lambda2)) (* (sin phi1) (cos phi2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
	return atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), ((sin(phi2) * cos(phi1)) - (cos((lambda1 - lambda2)) * (sin(phi1) * cos(phi2)))));
}
function code(lambda1, lambda2, phi1, phi2)
	return atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(Float64(sin(phi2) * cos(phi1)) - Float64(cos(Float64(lambda1 - lambda2)) * Float64(sin(phi1) * cos(phi2)))))
end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}

\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}
\end{array}
Derivation
  1. Initial program 77.1%

    \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
  2. Add Preprocessing
  3. Step-by-step derivation
    1. lift-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    2. lift--.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    3. sin-diffN/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    4. sub-negN/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    5. lower-fma.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    6. lower-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\color{blue}{\sin \lambda_1}, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    7. lower-cos.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \color{blue}{\cos \lambda_2}, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    8. *-commutativeN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\color{blue}{\sin \lambda_2 \cdot \cos \lambda_1}\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    9. distribute-lft-neg-inN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    10. sin-negN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    11. lower-*.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    12. sin-negN/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    13. lower-neg.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    14. lower-sin.f64N/A

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\color{blue}{\sin \lambda_2}\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    15. lower-cos.f6489.3

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \color{blue}{\cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
  4. Applied rewrites89.3%

    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
  5. Final simplification89.3%

    \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)} \]
  6. Add Preprocessing

Alternative 8: 88.1% accurate, 0.8× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ t_1 := \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0 - \mathsf{fma}\left(0, 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{if}\;\phi_1 \leq -4.2 \cdot 10^{-7}:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;\phi_1 \leq 7.3 \cdot 10^{-6}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{t\_0 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (let* ((t_0 (* (sin phi2) (cos phi1)))
        (t_1
         (atan2
          (* (sin (- lambda1 lambda2)) (cos phi2))
          (-
           t_0
           (*
            (fma 0.0 0.5 (* (cos lambda1) (cos lambda2)))
            (* (sin phi1) (cos phi2)))))))
   (if (<= phi1 -4.2e-7)
     t_1
     (if (<= phi1 7.3e-6)
       (atan2
        (*
         (cos phi2)
         (fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2)))))
        (- t_0 (* (sin phi1) (cos (- lambda1 lambda2)))))
       t_1))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
	double t_0 = sin(phi2) * cos(phi1);
	double t_1 = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - (fma(0.0, 0.5, (cos(lambda1) * cos(lambda2))) * (sin(phi1) * cos(phi2)))));
	double tmp;
	if (phi1 <= -4.2e-7) {
		tmp = t_1;
	} else if (phi1 <= 7.3e-6) {
		tmp = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), (t_0 - (sin(phi1) * cos((lambda1 - lambda2)))));
	} else {
		tmp = t_1;
	}
	return tmp;
}
function code(lambda1, lambda2, phi1, phi2)
	t_0 = Float64(sin(phi2) * cos(phi1))
	t_1 = atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), Float64(t_0 - Float64(fma(0.0, 0.5, Float64(cos(lambda1) * cos(lambda2))) * Float64(sin(phi1) * cos(phi2)))))
	tmp = 0.0
	if (phi1 <= -4.2e-7)
		tmp = t_1;
	elseif (phi1 <= 7.3e-6)
		tmp = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(t_0 - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2)))));
	else
		tmp = t_1;
	end
	return tmp
end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[(0.0 * 0.5 + N[(N[Cos[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi1, -4.2e-7], t$95$1, If[LessEqual[phi1, 7.3e-6], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$1]]]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \sin \phi_2 \cdot \cos \phi_1\\
t_1 := \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0 - \mathsf{fma}\left(0, 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\
\mathbf{if}\;\phi_1 \leq -4.2 \cdot 10^{-7}:\\
\;\;\;\;t\_1\\

\mathbf{elif}\;\phi_1 \leq 7.3 \cdot 10^{-6}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{t\_0 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\

\mathbf{else}:\\
\;\;\;\;t\_1\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if phi1 < -4.2e-7 or 7.30000000000000041e-6 < phi1

    1. Initial program 75.9%

      \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \left(\lambda_1 - \lambda_2\right)}} \]
      2. lift--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \color{blue}{\left(\lambda_1 - \lambda_2\right)}} \]
      3. cos-diffN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\left(\cos \lambda_1 \cdot \cos \lambda_2 + \sin \lambda_1 \cdot \sin \lambda_2\right)}} \]
      4. +-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_1 \cdot \cos \lambda_2\right)}} \]
      5. sin-multN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\color{blue}{\frac{\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_1 + \lambda_2\right)}{2}} + \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      6. div-invN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_1 + \lambda_2\right)\right) \cdot \frac{1}{2}} + \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      7. lower-fma.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_1 + \lambda_2\right), \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)}} \]
      8. lift--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \color{blue}{\left(\lambda_1 - \lambda_2\right)} - \cos \left(\lambda_1 + \lambda_2\right), \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      9. lift-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\color{blue}{\cos \left(\lambda_1 - \lambda_2\right)} - \cos \left(\lambda_1 + \lambda_2\right), \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      10. lower--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\color{blue}{\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_1 + \lambda_2\right)}, \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      11. lower-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \color{blue}{\cos \left(\lambda_1 + \lambda_2\right)}, \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      12. +-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \color{blue}{\left(\lambda_2 + \lambda_1\right)}, \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      13. lower-+.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \color{blue}{\left(\lambda_2 + \lambda_1\right)}, \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      14. metadata-evalN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_2 + \lambda_1\right), \color{blue}{\frac{1}{2}}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      15. lower-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_2 + \lambda_1\right), \frac{1}{2}, \color{blue}{\cos \lambda_1 \cdot \cos \lambda_2}\right)} \]
      16. lower-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_2 + \lambda_1\right), \frac{1}{2}, \color{blue}{\cos \lambda_1} \cdot \cos \lambda_2\right)} \]
      17. lower-cos.f6476.1

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_2 + \lambda_1\right), 0.5, \cos \lambda_1 \cdot \color{blue}{\cos \lambda_2}\right)} \]
    4. Applied rewrites76.1%

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_2 + \lambda_1\right), 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right)}} \]
    5. Taylor expanded in lambda1 around 0

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\color{blue}{\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) - \cos \lambda_2}, \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
    6. Step-by-step derivation
      1. cos-negN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\color{blue}{\cos \lambda_2} - \cos \lambda_2, \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      2. +-inverses76.1

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\color{blue}{0}, 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
    7. Applied rewrites76.1%

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\color{blue}{0}, 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]

    if -4.2e-7 < phi1 < 7.30000000000000041e-6

    1. Initial program 78.1%

      \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      2. lift--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      3. sin-diffN/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      4. sub-negN/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\sin \lambda_1 \cdot \cos \lambda_2 + \left(\mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      5. lower-fma.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      6. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\color{blue}{\sin \lambda_1}, \cos \lambda_2, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      7. lower-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \color{blue}{\cos \lambda_2}, \mathsf{neg}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      8. *-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \mathsf{neg}\left(\color{blue}{\sin \lambda_2 \cdot \cos \lambda_1}\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      9. distribute-lft-neg-inN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      10. sin-negN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      11. lower-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      12. sin-negN/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      13. lower-neg.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      14. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\color{blue}{\sin \lambda_2}\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      15. lower-cos.f6499.1

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \color{blue}{\cos \lambda_1}\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    4. Applied rewrites99.1%

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    5. Taylor expanded in phi2 around 0

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(\mathsf{neg}\left(\sin \lambda_2\right)\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    6. Step-by-step derivation
      1. lower-sin.f6498.7

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    7. Applied rewrites98.7%

      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification87.9%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\phi_1 \leq -4.2 \cdot 10^{-7}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \mathsf{fma}\left(0, 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{elif}\;\phi_1 \leq 7.3 \cdot 10^{-6}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \mathsf{fma}\left(0, 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 9: 83.3% accurate, 0.9× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ t_1 := \cos \left(\lambda_1 - \lambda_2\right)\\ t_2 := \sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\\ \mathbf{if}\;\phi_2 \leq -7 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - \mathsf{fma}\left(0, 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{elif}\;\phi_2 \leq 1.4 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{t\_0 - \sin \phi_1 \cdot t\_1}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t\_2}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot t\_1, \cos \phi_2, t\_0\right)}\\ \end{array} \end{array} \]
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (let* ((t_0 (* (sin phi2) (cos phi1)))
        (t_1 (cos (- lambda1 lambda2)))
        (t_2 (* (sin (- lambda1 lambda2)) (cos phi2))))
   (if (<= phi2 -7e-5)
     (atan2
      t_2
      (-
       t_0
       (*
        (fma 0.0 0.5 (* (cos lambda1) (cos lambda2)))
        (* (sin phi1) (cos phi2)))))
     (if (<= phi2 1.4e-5)
       (atan2
        (fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2))))
        (- t_0 (* (sin phi1) t_1)))
       (atan2 t_2 (fma (* (- (sin phi1)) t_1) (cos phi2) t_0))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
	double t_0 = sin(phi2) * cos(phi1);
	double t_1 = cos((lambda1 - lambda2));
	double t_2 = sin((lambda1 - lambda2)) * cos(phi2);
	double tmp;
	if (phi2 <= -7e-5) {
		tmp = atan2(t_2, (t_0 - (fma(0.0, 0.5, (cos(lambda1) * cos(lambda2))) * (sin(phi1) * cos(phi2)))));
	} else if (phi2 <= 1.4e-5) {
		tmp = atan2(fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2))), (t_0 - (sin(phi1) * t_1)));
	} else {
		tmp = atan2(t_2, fma((-sin(phi1) * t_1), cos(phi2), t_0));
	}
	return tmp;
}
function code(lambda1, lambda2, phi1, phi2)
	t_0 = Float64(sin(phi2) * cos(phi1))
	t_1 = cos(Float64(lambda1 - lambda2))
	t_2 = Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2))
	tmp = 0.0
	if (phi2 <= -7e-5)
		tmp = atan(t_2, Float64(t_0 - Float64(fma(0.0, 0.5, Float64(cos(lambda1) * cos(lambda2))) * Float64(sin(phi1) * cos(phi2)))));
	elseif (phi2 <= 1.4e-5)
		tmp = atan(fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2)))), Float64(t_0 - Float64(sin(phi1) * t_1)));
	else
		tmp = atan(t_2, fma(Float64(Float64(-sin(phi1)) * t_1), cos(phi2), t_0));
	end
	return tmp
end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[phi2, -7e-5], N[ArcTan[t$95$2 / N[(t$95$0 - N[(N[(0.0 * 0.5 + N[(N[Cos[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi2, 1.4e-5], N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Sin[phi1], $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$2 / N[(N[((-N[Sin[phi1], $MachinePrecision]) * t$95$1), $MachinePrecision] * N[Cos[phi2], $MachinePrecision] + t$95$0), $MachinePrecision]], $MachinePrecision]]]]]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \sin \phi_2 \cdot \cos \phi_1\\
t_1 := \cos \left(\lambda_1 - \lambda_2\right)\\
t_2 := \sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\\
\mathbf{if}\;\phi_2 \leq -7 \cdot 10^{-5}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - \mathsf{fma}\left(0, 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\

\mathbf{elif}\;\phi_2 \leq 1.4 \cdot 10^{-5}:\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{t\_0 - \sin \phi_1 \cdot t\_1}\\

\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot t\_1, \cos \phi_2, t\_0\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if phi2 < -6.9999999999999994e-5

    1. Initial program 73.3%

      \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    2. Add Preprocessing
    3. Step-by-step derivation
      1. lift-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \left(\lambda_1 - \lambda_2\right)}} \]
      2. lift--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \color{blue}{\left(\lambda_1 - \lambda_2\right)}} \]
      3. cos-diffN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\left(\cos \lambda_1 \cdot \cos \lambda_2 + \sin \lambda_1 \cdot \sin \lambda_2\right)}} \]
      4. +-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_1 \cdot \cos \lambda_2\right)}} \]
      5. sin-multN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\color{blue}{\frac{\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_1 + \lambda_2\right)}{2}} + \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      6. div-invN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \left(\color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_1 + \lambda_2\right)\right) \cdot \frac{1}{2}} + \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      7. lower-fma.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_1 + \lambda_2\right), \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)}} \]
      8. lift--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \color{blue}{\left(\lambda_1 - \lambda_2\right)} - \cos \left(\lambda_1 + \lambda_2\right), \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      9. lift-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\color{blue}{\cos \left(\lambda_1 - \lambda_2\right)} - \cos \left(\lambda_1 + \lambda_2\right), \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      10. lower--.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\color{blue}{\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_1 + \lambda_2\right)}, \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      11. lower-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \color{blue}{\cos \left(\lambda_1 + \lambda_2\right)}, \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      12. +-commutativeN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \color{blue}{\left(\lambda_2 + \lambda_1\right)}, \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      13. lower-+.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \color{blue}{\left(\lambda_2 + \lambda_1\right)}, \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      14. metadata-evalN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_2 + \lambda_1\right), \color{blue}{\frac{1}{2}}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      15. lower-*.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_2 + \lambda_1\right), \frac{1}{2}, \color{blue}{\cos \lambda_1 \cdot \cos \lambda_2}\right)} \]
      16. lower-cos.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_2 + \lambda_1\right), \frac{1}{2}, \color{blue}{\cos \lambda_1} \cdot \cos \lambda_2\right)} \]
      17. lower-cos.f6473.4

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_2 + \lambda_1\right), 0.5, \cos \lambda_1 \cdot \color{blue}{\cos \lambda_2}\right)} \]
    4. Applied rewrites73.4%

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right) - \cos \left(\lambda_2 + \lambda_1\right), 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right)}} \]
    5. Taylor expanded in lambda1 around 0

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\color{blue}{\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) - \cos \lambda_2}, \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
    6. Step-by-step derivation
      1. cos-negN/A

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\color{blue}{\cos \lambda_2} - \cos \lambda_2, \frac{1}{2}, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
      2. +-inverses73.4

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\color{blue}{0}, 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]
    7. Applied rewrites73.4%

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \mathsf{fma}\left(\color{blue}{0}, 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right)} \]

    if -6.9999999999999994e-5 < phi2 < 1.39999999999999998e-5

    1. Initial program 77.9%

      \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    2. Add Preprocessing
    3. Taylor expanded in phi2 around 0

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    4. Step-by-step derivation
      1. lower-sin.f64N/A

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      2. lower--.f6477.9

        \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    5. Applied rewrites77.9%

      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    6. Taylor expanded in phi2 around 0

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    7. Step-by-step derivation
      1. lower-sin.f6477.9

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    8. Applied rewrites77.9%

      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
    9. Step-by-step derivation
      1. Applied rewrites88.6%

        \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \color{blue}{\cos \lambda_2}, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

      if 1.39999999999999998e-5 < phi2

      1. Initial program 80.3%

        \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift-*.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. *-commutativeN/A

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        3. lower-*.f6480.3

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. lift--.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
        5. sub-negN/A

          \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\cos \phi_1 \cdot \sin \phi_2 + \left(\mathsf{neg}\left(\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)\right)}} \]
        6. +-commutativeN/A

          \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\left(\mathsf{neg}\left(\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)\right) + \cos \phi_1 \cdot \sin \phi_2}} \]
        7. lift-*.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}\right)\right) + \cos \phi_1 \cdot \sin \phi_2} \]
        8. lift-*.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right)} \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)\right) + \cos \phi_1 \cdot \sin \phi_2} \]
        9. associate-*l*N/A

          \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\color{blue}{\sin \phi_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)}\right)\right) + \cos \phi_1 \cdot \sin \phi_2} \]
        10. distribute-lft-neg-inN/A

          \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)} + \cos \phi_1 \cdot \sin \phi_2} \]
        11. *-commutativeN/A

          \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right)} + \cos \phi_1 \cdot \sin \phi_2} \]
        12. associate-*r*N/A

          \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\left(\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot \cos \phi_2} + \cos \phi_1 \cdot \sin \phi_2} \]
        13. lower-fma.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, \cos \phi_1 \cdot \sin \phi_2\right)}} \]
      4. Applied rewrites80.4%

        \[\leadsto \color{blue}{\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, \sin \phi_2 \cdot \cos \phi_1\right)}} \]
    10. Recombined 3 regimes into one program.
    11. Final simplification82.3%

      \[\leadsto \begin{array}{l} \mathbf{if}\;\phi_2 \leq -7 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \mathsf{fma}\left(0, 0.5, \cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{elif}\;\phi_2 \leq 1.4 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, \sin \phi_2 \cdot \cos \phi_1\right)}\\ \end{array} \]
    12. Add Preprocessing

    Alternative 10: 83.3% accurate, 0.9× speedup?

    \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ t_1 := \cos \left(\lambda_1 - \lambda_2\right)\\ t_2 := \sin \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\phi_2 \leq -9.4 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{\frac{1}{\frac{\frac{1}{\cos \phi_2}}{t\_2}}}{t\_0 - t\_1 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{elif}\;\phi_2 \leq 1.4 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{t\_0 - \sin \phi_1 \cdot t\_1}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t\_2 \cdot \cos \phi_2}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot t\_1, \cos \phi_2, t\_0\right)}\\ \end{array} \end{array} \]
    (FPCore (lambda1 lambda2 phi1 phi2)
     :precision binary64
     (let* ((t_0 (* (sin phi2) (cos phi1)))
            (t_1 (cos (- lambda1 lambda2)))
            (t_2 (sin (- lambda1 lambda2))))
       (if (<= phi2 -9.4e-5)
         (atan2
          (/ 1.0 (/ (/ 1.0 (cos phi2)) t_2))
          (- t_0 (* t_1 (* (sin phi1) (cos phi2)))))
         (if (<= phi2 1.4e-5)
           (atan2
            (fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2))))
            (- t_0 (* (sin phi1) t_1)))
           (atan2
            (* t_2 (cos phi2))
            (fma (* (- (sin phi1)) t_1) (cos phi2) t_0))))))
    double code(double lambda1, double lambda2, double phi1, double phi2) {
    	double t_0 = sin(phi2) * cos(phi1);
    	double t_1 = cos((lambda1 - lambda2));
    	double t_2 = sin((lambda1 - lambda2));
    	double tmp;
    	if (phi2 <= -9.4e-5) {
    		tmp = atan2((1.0 / ((1.0 / cos(phi2)) / t_2)), (t_0 - (t_1 * (sin(phi1) * cos(phi2)))));
    	} else if (phi2 <= 1.4e-5) {
    		tmp = atan2(fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2))), (t_0 - (sin(phi1) * t_1)));
    	} else {
    		tmp = atan2((t_2 * cos(phi2)), fma((-sin(phi1) * t_1), cos(phi2), t_0));
    	}
    	return tmp;
    }
    
    function code(lambda1, lambda2, phi1, phi2)
    	t_0 = Float64(sin(phi2) * cos(phi1))
    	t_1 = cos(Float64(lambda1 - lambda2))
    	t_2 = sin(Float64(lambda1 - lambda2))
    	tmp = 0.0
    	if (phi2 <= -9.4e-5)
    		tmp = atan(Float64(1.0 / Float64(Float64(1.0 / cos(phi2)) / t_2)), Float64(t_0 - Float64(t_1 * Float64(sin(phi1) * cos(phi2)))));
    	elseif (phi2 <= 1.4e-5)
    		tmp = atan(fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2)))), Float64(t_0 - Float64(sin(phi1) * t_1)));
    	else
    		tmp = atan(Float64(t_2 * cos(phi2)), fma(Float64(Float64(-sin(phi1)) * t_1), cos(phi2), t_0));
    	end
    	return tmp
    end
    
    code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi2, -9.4e-5], N[ArcTan[N[(1.0 / N[(N[(1.0 / N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / t$95$2), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(t$95$1 * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi2, 1.4e-5], N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Sin[phi1], $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(t$95$2 * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[((-N[Sin[phi1], $MachinePrecision]) * t$95$1), $MachinePrecision] * N[Cos[phi2], $MachinePrecision] + t$95$0), $MachinePrecision]], $MachinePrecision]]]]]]
    
    \begin{array}{l}
    
    \\
    \begin{array}{l}
    t_0 := \sin \phi_2 \cdot \cos \phi_1\\
    t_1 := \cos \left(\lambda_1 - \lambda_2\right)\\
    t_2 := \sin \left(\lambda_1 - \lambda_2\right)\\
    \mathbf{if}\;\phi_2 \leq -9.4 \cdot 10^{-5}:\\
    \;\;\;\;\tan^{-1}_* \frac{\frac{1}{\frac{\frac{1}{\cos \phi_2}}{t\_2}}}{t\_0 - t\_1 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\
    
    \mathbf{elif}\;\phi_2 \leq 1.4 \cdot 10^{-5}:\\
    \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{t\_0 - \sin \phi_1 \cdot t\_1}\\
    
    \mathbf{else}:\\
    \;\;\;\;\tan^{-1}_* \frac{t\_2 \cdot \cos \phi_2}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot t\_1, \cos \phi_2, t\_0\right)}\\
    
    
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 3 regimes
    2. if phi2 < -9.39999999999999945e-5

      1. Initial program 73.3%

        \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift-*.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. lift-sin.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        3. lift-cos.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \color{blue}{\cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. sin-cos-multN/A

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\frac{\sin \left(\left(\lambda_1 - \lambda_2\right) - \phi_2\right) + \sin \left(\left(\lambda_1 - \lambda_2\right) + \phi_2\right)}{2}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. clear-numN/A

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\frac{1}{\frac{2}{\sin \left(\left(\lambda_1 - \lambda_2\right) - \phi_2\right) + \sin \left(\left(\lambda_1 - \lambda_2\right) + \phi_2\right)}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        6. lower-/.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\frac{1}{\frac{2}{\sin \left(\left(\lambda_1 - \lambda_2\right) - \phi_2\right) + \sin \left(\left(\lambda_1 - \lambda_2\right) + \phi_2\right)}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        7. clear-numN/A

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\color{blue}{\frac{1}{\frac{\sin \left(\left(\lambda_1 - \lambda_2\right) - \phi_2\right) + \sin \left(\left(\lambda_1 - \lambda_2\right) + \phi_2\right)}{2}}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        8. sin-cos-multN/A

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\frac{1}{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        9. lift-sin.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\frac{1}{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)} \cdot \cos \phi_2}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        10. lift-cos.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\frac{1}{\sin \left(\lambda_1 - \lambda_2\right) \cdot \color{blue}{\cos \phi_2}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        11. lift-*.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\frac{1}{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        12. lower-/.f6473.3

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\color{blue}{\frac{1}{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        13. lift-*.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\frac{1}{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        14. *-commutativeN/A

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\frac{1}{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        15. lower-*.f6473.3

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\frac{1}{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      4. Applied rewrites73.3%

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\frac{1}{\frac{1}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      5. Step-by-step derivation
        1. lift-/.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\color{blue}{\frac{1}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. lift-*.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\frac{1}{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        3. associate-/r*N/A

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\color{blue}{\frac{\frac{1}{\cos \phi_2}}{\sin \left(\lambda_1 - \lambda_2\right)}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. lower-/.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\color{blue}{\frac{\frac{1}{\cos \phi_2}}{\sin \left(\lambda_1 - \lambda_2\right)}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. lower-/.f6473.4

          \[\leadsto \tan^{-1}_* \frac{\frac{1}{\frac{\color{blue}{\frac{1}{\cos \phi_2}}}{\sin \left(\lambda_1 - \lambda_2\right)}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      6. Applied rewrites73.4%

        \[\leadsto \tan^{-1}_* \frac{\frac{1}{\color{blue}{\frac{\frac{1}{\cos \phi_2}}{\sin \left(\lambda_1 - \lambda_2\right)}}}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

      if -9.39999999999999945e-5 < phi2 < 1.39999999999999998e-5

      1. Initial program 77.9%

        \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      2. Add Preprocessing
      3. Taylor expanded in phi2 around 0

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      4. Step-by-step derivation
        1. lower-sin.f64N/A

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. lower--.f6477.9

          \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      5. Applied rewrites77.9%

        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      6. Taylor expanded in phi2 around 0

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      7. Step-by-step derivation
        1. lower-sin.f6477.9

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      8. Applied rewrites77.9%

        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      9. Step-by-step derivation
        1. Applied rewrites88.6%

          \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \color{blue}{\cos \lambda_2}, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

        if 1.39999999999999998e-5 < phi2

        1. Initial program 80.3%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Step-by-step derivation
          1. lift-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          3. lower-*.f6480.3

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          4. lift--.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
          5. sub-negN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\cos \phi_1 \cdot \sin \phi_2 + \left(\mathsf{neg}\left(\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)\right)}} \]
          6. +-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\left(\mathsf{neg}\left(\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)\right) + \cos \phi_1 \cdot \sin \phi_2}} \]
          7. lift-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}\right)\right) + \cos \phi_1 \cdot \sin \phi_2} \]
          8. lift-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right)} \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)\right) + \cos \phi_1 \cdot \sin \phi_2} \]
          9. associate-*l*N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\color{blue}{\sin \phi_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)}\right)\right) + \cos \phi_1 \cdot \sin \phi_2} \]
          10. distribute-lft-neg-inN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)} + \cos \phi_1 \cdot \sin \phi_2} \]
          11. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right)} + \cos \phi_1 \cdot \sin \phi_2} \]
          12. associate-*r*N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\left(\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot \cos \phi_2} + \cos \phi_1 \cdot \sin \phi_2} \]
          13. lower-fma.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, \cos \phi_1 \cdot \sin \phi_2\right)}} \]
        4. Applied rewrites80.4%

          \[\leadsto \color{blue}{\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, \sin \phi_2 \cdot \cos \phi_1\right)}} \]
      10. Recombined 3 regimes into one program.
      11. Final simplification82.2%

        \[\leadsto \begin{array}{l} \mathbf{if}\;\phi_2 \leq -9.4 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{\frac{1}{\frac{\frac{1}{\cos \phi_2}}{\sin \left(\lambda_1 - \lambda_2\right)}}}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{elif}\;\phi_2 \leq 1.4 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, \sin \phi_2 \cdot \cos \phi_1\right)}\\ \end{array} \]
      12. Add Preprocessing

      Alternative 11: 78.6% accurate, 1.0× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_1 \cdot \cos \phi_2\\ t_1 := \sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\\ t_2 := \sin \phi_2 \cdot \cos \phi_1\\ \mathbf{if}\;\lambda_2 \leq -1.28 \cdot 10^{+35}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \cos \phi_2}{t\_2 - \cos \left(\lambda_1 - \lambda_2\right) \cdot t\_0}\\ \mathbf{elif}\;\lambda_2 \leq 0.0038:\\ \;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_2 - \cos \lambda_1 \cdot t\_0}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_2 - \left(\sin \phi_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2}\\ \end{array} \end{array} \]
      (FPCore (lambda1 lambda2 phi1 phi2)
       :precision binary64
       (let* ((t_0 (* (sin phi1) (cos phi2)))
              (t_1 (* (sin (- lambda1 lambda2)) (cos phi2)))
              (t_2 (* (sin phi2) (cos phi1))))
         (if (<= lambda2 -1.28e+35)
           (atan2
            (* (sin (- lambda2)) (cos phi2))
            (- t_2 (* (cos (- lambda1 lambda2)) t_0)))
           (if (<= lambda2 0.0038)
             (atan2 t_1 (- t_2 (* (cos lambda1) t_0)))
             (atan2 t_1 (- t_2 (* (* (sin phi1) (cos lambda2)) (cos phi2))))))))
      double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = sin(phi1) * cos(phi2);
      	double t_1 = sin((lambda1 - lambda2)) * cos(phi2);
      	double t_2 = sin(phi2) * cos(phi1);
      	double tmp;
      	if (lambda2 <= -1.28e+35) {
      		tmp = atan2((sin(-lambda2) * cos(phi2)), (t_2 - (cos((lambda1 - lambda2)) * t_0)));
      	} else if (lambda2 <= 0.0038) {
      		tmp = atan2(t_1, (t_2 - (cos(lambda1) * t_0)));
      	} else {
      		tmp = atan2(t_1, (t_2 - ((sin(phi1) * cos(lambda2)) * cos(phi2))));
      	}
      	return tmp;
      }
      
      real(8) function code(lambda1, lambda2, phi1, phi2)
          real(8), intent (in) :: lambda1
          real(8), intent (in) :: lambda2
          real(8), intent (in) :: phi1
          real(8), intent (in) :: phi2
          real(8) :: t_0
          real(8) :: t_1
          real(8) :: t_2
          real(8) :: tmp
          t_0 = sin(phi1) * cos(phi2)
          t_1 = sin((lambda1 - lambda2)) * cos(phi2)
          t_2 = sin(phi2) * cos(phi1)
          if (lambda2 <= (-1.28d+35)) then
              tmp = atan2((sin(-lambda2) * cos(phi2)), (t_2 - (cos((lambda1 - lambda2)) * t_0)))
          else if (lambda2 <= 0.0038d0) then
              tmp = atan2(t_1, (t_2 - (cos(lambda1) * t_0)))
          else
              tmp = atan2(t_1, (t_2 - ((sin(phi1) * cos(lambda2)) * cos(phi2))))
          end if
          code = tmp
      end function
      
      public static double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = Math.sin(phi1) * Math.cos(phi2);
      	double t_1 = Math.sin((lambda1 - lambda2)) * Math.cos(phi2);
      	double t_2 = Math.sin(phi2) * Math.cos(phi1);
      	double tmp;
      	if (lambda2 <= -1.28e+35) {
      		tmp = Math.atan2((Math.sin(-lambda2) * Math.cos(phi2)), (t_2 - (Math.cos((lambda1 - lambda2)) * t_0)));
      	} else if (lambda2 <= 0.0038) {
      		tmp = Math.atan2(t_1, (t_2 - (Math.cos(lambda1) * t_0)));
      	} else {
      		tmp = Math.atan2(t_1, (t_2 - ((Math.sin(phi1) * Math.cos(lambda2)) * Math.cos(phi2))));
      	}
      	return tmp;
      }
      
      def code(lambda1, lambda2, phi1, phi2):
      	t_0 = math.sin(phi1) * math.cos(phi2)
      	t_1 = math.sin((lambda1 - lambda2)) * math.cos(phi2)
      	t_2 = math.sin(phi2) * math.cos(phi1)
      	tmp = 0
      	if lambda2 <= -1.28e+35:
      		tmp = math.atan2((math.sin(-lambda2) * math.cos(phi2)), (t_2 - (math.cos((lambda1 - lambda2)) * t_0)))
      	elif lambda2 <= 0.0038:
      		tmp = math.atan2(t_1, (t_2 - (math.cos(lambda1) * t_0)))
      	else:
      		tmp = math.atan2(t_1, (t_2 - ((math.sin(phi1) * math.cos(lambda2)) * math.cos(phi2))))
      	return tmp
      
      function code(lambda1, lambda2, phi1, phi2)
      	t_0 = Float64(sin(phi1) * cos(phi2))
      	t_1 = Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2))
      	t_2 = Float64(sin(phi2) * cos(phi1))
      	tmp = 0.0
      	if (lambda2 <= -1.28e+35)
      		tmp = atan(Float64(sin(Float64(-lambda2)) * cos(phi2)), Float64(t_2 - Float64(cos(Float64(lambda1 - lambda2)) * t_0)));
      	elseif (lambda2 <= 0.0038)
      		tmp = atan(t_1, Float64(t_2 - Float64(cos(lambda1) * t_0)));
      	else
      		tmp = atan(t_1, Float64(t_2 - Float64(Float64(sin(phi1) * cos(lambda2)) * cos(phi2))));
      	end
      	return tmp
      end
      
      function tmp_2 = code(lambda1, lambda2, phi1, phi2)
      	t_0 = sin(phi1) * cos(phi2);
      	t_1 = sin((lambda1 - lambda2)) * cos(phi2);
      	t_2 = sin(phi2) * cos(phi1);
      	tmp = 0.0;
      	if (lambda2 <= -1.28e+35)
      		tmp = atan2((sin(-lambda2) * cos(phi2)), (t_2 - (cos((lambda1 - lambda2)) * t_0)));
      	elseif (lambda2 <= 0.0038)
      		tmp = atan2(t_1, (t_2 - (cos(lambda1) * t_0)));
      	else
      		tmp = atan2(t_1, (t_2 - ((sin(phi1) * cos(lambda2)) * cos(phi2))));
      	end
      	tmp_2 = tmp;
      end
      
      code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda2, -1.28e+35], N[ArcTan[N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$2 - N[(N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda2, 0.0038], N[ArcTan[t$95$1 / N[(t$95$2 - N[(N[Cos[lambda1], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / N[(t$95$2 - N[(N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \sin \phi_1 \cdot \cos \phi_2\\
      t_1 := \sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\\
      t_2 := \sin \phi_2 \cdot \cos \phi_1\\
      \mathbf{if}\;\lambda_2 \leq -1.28 \cdot 10^{+35}:\\
      \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \cos \phi_2}{t\_2 - \cos \left(\lambda_1 - \lambda_2\right) \cdot t\_0}\\
      
      \mathbf{elif}\;\lambda_2 \leq 0.0038:\\
      \;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_2 - \cos \lambda_1 \cdot t\_0}\\
      
      \mathbf{else}:\\
      \;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_2 - \left(\sin \phi_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2}\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 3 regimes
      2. if lambda2 < -1.2799999999999999e35

        1. Initial program 57.4%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in lambda1 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(-1 \cdot \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. Step-by-step derivation
          1. neg-mul-1N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\mathsf{neg}\left(\lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower-neg.f6463.4

            \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(-\lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. Applied rewrites63.4%

          \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(-\lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

        if -1.2799999999999999e35 < lambda2 < 0.00379999999999999999

        1. Initial program 94.8%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in lambda2 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_1}} \]
        4. Step-by-step derivation
          1. lower-cos.f6494.8

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_1}} \]
        5. Applied rewrites94.8%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_1}} \]

        if 0.00379999999999999999 < lambda2

        1. Initial program 66.9%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in lambda1 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\cos \phi_2 \cdot \left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \sin \phi_1\right)}} \]
        4. Step-by-step derivation
          1. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \sin \phi_1\right) \cdot \cos \phi_2}} \]
          2. lower-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \sin \phi_1\right) \cdot \cos \phi_2}} \]
          3. lower-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \sin \phi_1\right)} \cdot \cos \phi_2} \]
          4. cos-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\cos \lambda_2} \cdot \sin \phi_1\right) \cdot \cos \phi_2} \]
          5. lower-cos.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\cos \lambda_2} \cdot \sin \phi_1\right) \cdot \cos \phi_2} \]
          6. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \lambda_2 \cdot \color{blue}{\sin \phi_1}\right) \cdot \cos \phi_2} \]
          7. lower-cos.f6466.9

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \lambda_2 \cdot \sin \phi_1\right) \cdot \color{blue}{\cos \phi_2}} \]
        5. Applied rewrites66.9%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \lambda_2 \cdot \sin \phi_1\right) \cdot \cos \phi_2}} \]
      3. Recombined 3 regimes into one program.
      4. Final simplification78.6%

        \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_2 \leq -1.28 \cdot 10^{+35}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{elif}\;\lambda_2 \leq 0.0038:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \cos \lambda_1 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \left(\sin \phi_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2}\\ \end{array} \]
      5. Add Preprocessing

      Alternative 12: 79.2% accurate, 1.0× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ t_1 := \tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_0 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{if}\;\lambda_1 \leq -0.58:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;\lambda_1 \leq 0.0052:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0 - \left(\cos \lambda_2 \cdot \cos \phi_2\right) \cdot \sin \phi_1}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
      (FPCore (lambda1 lambda2 phi1 phi2)
       :precision binary64
       (let* ((t_0 (* (sin phi2) (cos phi1)))
              (t_1
               (atan2
                (* (sin lambda1) (cos phi2))
                (- t_0 (* (cos (- lambda1 lambda2)) (* (sin phi1) (cos phi2)))))))
         (if (<= lambda1 -0.58)
           t_1
           (if (<= lambda1 0.0052)
             (atan2
              (* (sin (- lambda1 lambda2)) (cos phi2))
              (- t_0 (* (* (cos lambda2) (cos phi2)) (sin phi1))))
             t_1))))
      double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = sin(phi2) * cos(phi1);
      	double t_1 = atan2((sin(lambda1) * cos(phi2)), (t_0 - (cos((lambda1 - lambda2)) * (sin(phi1) * cos(phi2)))));
      	double tmp;
      	if (lambda1 <= -0.58) {
      		tmp = t_1;
      	} else if (lambda1 <= 0.0052) {
      		tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - ((cos(lambda2) * cos(phi2)) * sin(phi1))));
      	} else {
      		tmp = t_1;
      	}
      	return tmp;
      }
      
      real(8) function code(lambda1, lambda2, phi1, phi2)
          real(8), intent (in) :: lambda1
          real(8), intent (in) :: lambda2
          real(8), intent (in) :: phi1
          real(8), intent (in) :: phi2
          real(8) :: t_0
          real(8) :: t_1
          real(8) :: tmp
          t_0 = sin(phi2) * cos(phi1)
          t_1 = atan2((sin(lambda1) * cos(phi2)), (t_0 - (cos((lambda1 - lambda2)) * (sin(phi1) * cos(phi2)))))
          if (lambda1 <= (-0.58d0)) then
              tmp = t_1
          else if (lambda1 <= 0.0052d0) then
              tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - ((cos(lambda2) * cos(phi2)) * sin(phi1))))
          else
              tmp = t_1
          end if
          code = tmp
      end function
      
      public static double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = Math.sin(phi2) * Math.cos(phi1);
      	double t_1 = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (t_0 - (Math.cos((lambda1 - lambda2)) * (Math.sin(phi1) * Math.cos(phi2)))));
      	double tmp;
      	if (lambda1 <= -0.58) {
      		tmp = t_1;
      	} else if (lambda1 <= 0.0052) {
      		tmp = Math.atan2((Math.sin((lambda1 - lambda2)) * Math.cos(phi2)), (t_0 - ((Math.cos(lambda2) * Math.cos(phi2)) * Math.sin(phi1))));
      	} else {
      		tmp = t_1;
      	}
      	return tmp;
      }
      
      def code(lambda1, lambda2, phi1, phi2):
      	t_0 = math.sin(phi2) * math.cos(phi1)
      	t_1 = math.atan2((math.sin(lambda1) * math.cos(phi2)), (t_0 - (math.cos((lambda1 - lambda2)) * (math.sin(phi1) * math.cos(phi2)))))
      	tmp = 0
      	if lambda1 <= -0.58:
      		tmp = t_1
      	elif lambda1 <= 0.0052:
      		tmp = math.atan2((math.sin((lambda1 - lambda2)) * math.cos(phi2)), (t_0 - ((math.cos(lambda2) * math.cos(phi2)) * math.sin(phi1))))
      	else:
      		tmp = t_1
      	return tmp
      
      function code(lambda1, lambda2, phi1, phi2)
      	t_0 = Float64(sin(phi2) * cos(phi1))
      	t_1 = atan(Float64(sin(lambda1) * cos(phi2)), Float64(t_0 - Float64(cos(Float64(lambda1 - lambda2)) * Float64(sin(phi1) * cos(phi2)))))
      	tmp = 0.0
      	if (lambda1 <= -0.58)
      		tmp = t_1;
      	elseif (lambda1 <= 0.0052)
      		tmp = atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), Float64(t_0 - Float64(Float64(cos(lambda2) * cos(phi2)) * sin(phi1))));
      	else
      		tmp = t_1;
      	end
      	return tmp
      end
      
      function tmp_2 = code(lambda1, lambda2, phi1, phi2)
      	t_0 = sin(phi2) * cos(phi1);
      	t_1 = atan2((sin(lambda1) * cos(phi2)), (t_0 - (cos((lambda1 - lambda2)) * (sin(phi1) * cos(phi2)))));
      	tmp = 0.0;
      	if (lambda1 <= -0.58)
      		tmp = t_1;
      	elseif (lambda1 <= 0.0052)
      		tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - ((cos(lambda2) * cos(phi2)) * sin(phi1))));
      	else
      		tmp = t_1;
      	end
      	tmp_2 = tmp;
      end
      
      code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda1, -0.58], t$95$1, If[LessEqual[lambda1, 0.0052], N[ArcTan[N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$1]]]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \sin \phi_2 \cdot \cos \phi_1\\
      t_1 := \tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_0 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\
      \mathbf{if}\;\lambda_1 \leq -0.58:\\
      \;\;\;\;t\_1\\
      
      \mathbf{elif}\;\lambda_1 \leq 0.0052:\\
      \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0 - \left(\cos \lambda_2 \cdot \cos \phi_2\right) \cdot \sin \phi_1}\\
      
      \mathbf{else}:\\
      \;\;\;\;t\_1\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 2 regimes
      2. if lambda1 < -0.57999999999999996 or 0.0051999999999999998 < lambda1

        1. Initial program 54.5%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in lambda2 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. Step-by-step derivation
          1. lower-sin.f6455.5

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. Applied rewrites55.5%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

        if -0.57999999999999996 < lambda1 < 0.0051999999999999998

        1. Initial program 98.6%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Step-by-step derivation
          1. lift-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
          2. lift-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right)} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          3. associate-*l*N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)}} \]
          4. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot \sin \phi_1}} \]
          5. lower-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot \sin \phi_1}} \]
          6. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right)} \cdot \sin \phi_1} \]
          7. lower-*.f6498.6

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right)} \cdot \sin \phi_1} \]
        4. Applied rewrites98.6%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right) \cdot \sin \phi_1}} \]
        5. Taylor expanded in lambda1 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\cos \left(\mathsf{neg}\left(\lambda_2\right)\right)} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
        6. Step-by-step derivation
          1. cos-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\cos \lambda_2} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
          2. lower-cos.f6498.6

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\cos \lambda_2} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
        7. Applied rewrites98.6%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\cos \lambda_2} \cdot \cos \phi_2\right) \cdot \sin \phi_1} \]
      3. Recombined 2 regimes into one program.
      4. Final simplification77.6%

        \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 \leq -0.58:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{elif}\;\lambda_1 \leq 0.0052:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \left(\cos \lambda_2 \cdot \cos \phi_2\right) \cdot \sin \phi_1}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \end{array} \]
      5. Add Preprocessing

      Alternative 13: 79.2% accurate, 1.0× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ t_1 := \tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_0 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{if}\;\lambda_1 \leq -0.58:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;\lambda_1 \leq 0.0052:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0 - \left(\sin \phi_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
      (FPCore (lambda1 lambda2 phi1 phi2)
       :precision binary64
       (let* ((t_0 (* (sin phi2) (cos phi1)))
              (t_1
               (atan2
                (* (sin lambda1) (cos phi2))
                (- t_0 (* (cos (- lambda1 lambda2)) (* (sin phi1) (cos phi2)))))))
         (if (<= lambda1 -0.58)
           t_1
           (if (<= lambda1 0.0052)
             (atan2
              (* (sin (- lambda1 lambda2)) (cos phi2))
              (- t_0 (* (* (sin phi1) (cos lambda2)) (cos phi2))))
             t_1))))
      double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = sin(phi2) * cos(phi1);
      	double t_1 = atan2((sin(lambda1) * cos(phi2)), (t_0 - (cos((lambda1 - lambda2)) * (sin(phi1) * cos(phi2)))));
      	double tmp;
      	if (lambda1 <= -0.58) {
      		tmp = t_1;
      	} else if (lambda1 <= 0.0052) {
      		tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - ((sin(phi1) * cos(lambda2)) * cos(phi2))));
      	} else {
      		tmp = t_1;
      	}
      	return tmp;
      }
      
      real(8) function code(lambda1, lambda2, phi1, phi2)
          real(8), intent (in) :: lambda1
          real(8), intent (in) :: lambda2
          real(8), intent (in) :: phi1
          real(8), intent (in) :: phi2
          real(8) :: t_0
          real(8) :: t_1
          real(8) :: tmp
          t_0 = sin(phi2) * cos(phi1)
          t_1 = atan2((sin(lambda1) * cos(phi2)), (t_0 - (cos((lambda1 - lambda2)) * (sin(phi1) * cos(phi2)))))
          if (lambda1 <= (-0.58d0)) then
              tmp = t_1
          else if (lambda1 <= 0.0052d0) then
              tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - ((sin(phi1) * cos(lambda2)) * cos(phi2))))
          else
              tmp = t_1
          end if
          code = tmp
      end function
      
      public static double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = Math.sin(phi2) * Math.cos(phi1);
      	double t_1 = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (t_0 - (Math.cos((lambda1 - lambda2)) * (Math.sin(phi1) * Math.cos(phi2)))));
      	double tmp;
      	if (lambda1 <= -0.58) {
      		tmp = t_1;
      	} else if (lambda1 <= 0.0052) {
      		tmp = Math.atan2((Math.sin((lambda1 - lambda2)) * Math.cos(phi2)), (t_0 - ((Math.sin(phi1) * Math.cos(lambda2)) * Math.cos(phi2))));
      	} else {
      		tmp = t_1;
      	}
      	return tmp;
      }
      
      def code(lambda1, lambda2, phi1, phi2):
      	t_0 = math.sin(phi2) * math.cos(phi1)
      	t_1 = math.atan2((math.sin(lambda1) * math.cos(phi2)), (t_0 - (math.cos((lambda1 - lambda2)) * (math.sin(phi1) * math.cos(phi2)))))
      	tmp = 0
      	if lambda1 <= -0.58:
      		tmp = t_1
      	elif lambda1 <= 0.0052:
      		tmp = math.atan2((math.sin((lambda1 - lambda2)) * math.cos(phi2)), (t_0 - ((math.sin(phi1) * math.cos(lambda2)) * math.cos(phi2))))
      	else:
      		tmp = t_1
      	return tmp
      
      function code(lambda1, lambda2, phi1, phi2)
      	t_0 = Float64(sin(phi2) * cos(phi1))
      	t_1 = atan(Float64(sin(lambda1) * cos(phi2)), Float64(t_0 - Float64(cos(Float64(lambda1 - lambda2)) * Float64(sin(phi1) * cos(phi2)))))
      	tmp = 0.0
      	if (lambda1 <= -0.58)
      		tmp = t_1;
      	elseif (lambda1 <= 0.0052)
      		tmp = atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), Float64(t_0 - Float64(Float64(sin(phi1) * cos(lambda2)) * cos(phi2))));
      	else
      		tmp = t_1;
      	end
      	return tmp
      end
      
      function tmp_2 = code(lambda1, lambda2, phi1, phi2)
      	t_0 = sin(phi2) * cos(phi1);
      	t_1 = atan2((sin(lambda1) * cos(phi2)), (t_0 - (cos((lambda1 - lambda2)) * (sin(phi1) * cos(phi2)))));
      	tmp = 0.0;
      	if (lambda1 <= -0.58)
      		tmp = t_1;
      	elseif (lambda1 <= 0.0052)
      		tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - ((sin(phi1) * cos(lambda2)) * cos(phi2))));
      	else
      		tmp = t_1;
      	end
      	tmp_2 = tmp;
      end
      
      code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda1, -0.58], t$95$1, If[LessEqual[lambda1, 0.0052], N[ArcTan[N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$1]]]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \sin \phi_2 \cdot \cos \phi_1\\
      t_1 := \tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_0 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\
      \mathbf{if}\;\lambda_1 \leq -0.58:\\
      \;\;\;\;t\_1\\
      
      \mathbf{elif}\;\lambda_1 \leq 0.0052:\\
      \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0 - \left(\sin \phi_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2}\\
      
      \mathbf{else}:\\
      \;\;\;\;t\_1\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 2 regimes
      2. if lambda1 < -0.57999999999999996 or 0.0051999999999999998 < lambda1

        1. Initial program 54.5%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in lambda2 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. Step-by-step derivation
          1. lower-sin.f6455.5

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. Applied rewrites55.5%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

        if -0.57999999999999996 < lambda1 < 0.0051999999999999998

        1. Initial program 98.6%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in lambda1 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\cos \phi_2 \cdot \left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \sin \phi_1\right)}} \]
        4. Step-by-step derivation
          1. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \sin \phi_1\right) \cdot \cos \phi_2}} \]
          2. lower-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \sin \phi_1\right) \cdot \cos \phi_2}} \]
          3. lower-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \sin \phi_1\right)} \cdot \cos \phi_2} \]
          4. cos-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\cos \lambda_2} \cdot \sin \phi_1\right) \cdot \cos \phi_2} \]
          5. lower-cos.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\color{blue}{\cos \lambda_2} \cdot \sin \phi_1\right) \cdot \cos \phi_2} \]
          6. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \lambda_2 \cdot \color{blue}{\sin \phi_1}\right) \cdot \cos \phi_2} \]
          7. lower-cos.f6498.6

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \lambda_2 \cdot \sin \phi_1\right) \cdot \color{blue}{\cos \phi_2}} \]
        5. Applied rewrites98.6%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\left(\cos \lambda_2 \cdot \sin \phi_1\right) \cdot \cos \phi_2}} \]
      3. Recombined 2 regimes into one program.
      4. Final simplification77.6%

        \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 \leq -0.58:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{elif}\;\lambda_1 \leq 0.0052:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \left(\sin \phi_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \end{array} \]
      5. Add Preprocessing

      Alternative 14: 70.5% accurate, 1.0× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ t_1 := \tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_0 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{if}\;\lambda_1 \leq -0.62:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;\lambda_1 \leq 5800:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0 - \cos \left(\lambda_2 - \lambda_1\right) \cdot \sin \phi_1}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
      (FPCore (lambda1 lambda2 phi1 phi2)
       :precision binary64
       (let* ((t_0 (* (sin phi2) (cos phi1)))
              (t_1
               (atan2
                (* (sin lambda1) (cos phi2))
                (- t_0 (* (cos (- lambda1 lambda2)) (* (sin phi1) (cos phi2)))))))
         (if (<= lambda1 -0.62)
           t_1
           (if (<= lambda1 5800.0)
             (atan2
              (* (sin (- lambda1 lambda2)) (cos phi2))
              (- t_0 (* (cos (- lambda2 lambda1)) (sin phi1))))
             t_1))))
      double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = sin(phi2) * cos(phi1);
      	double t_1 = atan2((sin(lambda1) * cos(phi2)), (t_0 - (cos((lambda1 - lambda2)) * (sin(phi1) * cos(phi2)))));
      	double tmp;
      	if (lambda1 <= -0.62) {
      		tmp = t_1;
      	} else if (lambda1 <= 5800.0) {
      		tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - (cos((lambda2 - lambda1)) * sin(phi1))));
      	} else {
      		tmp = t_1;
      	}
      	return tmp;
      }
      
      real(8) function code(lambda1, lambda2, phi1, phi2)
          real(8), intent (in) :: lambda1
          real(8), intent (in) :: lambda2
          real(8), intent (in) :: phi1
          real(8), intent (in) :: phi2
          real(8) :: t_0
          real(8) :: t_1
          real(8) :: tmp
          t_0 = sin(phi2) * cos(phi1)
          t_1 = atan2((sin(lambda1) * cos(phi2)), (t_0 - (cos((lambda1 - lambda2)) * (sin(phi1) * cos(phi2)))))
          if (lambda1 <= (-0.62d0)) then
              tmp = t_1
          else if (lambda1 <= 5800.0d0) then
              tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - (cos((lambda2 - lambda1)) * sin(phi1))))
          else
              tmp = t_1
          end if
          code = tmp
      end function
      
      public static double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = Math.sin(phi2) * Math.cos(phi1);
      	double t_1 = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (t_0 - (Math.cos((lambda1 - lambda2)) * (Math.sin(phi1) * Math.cos(phi2)))));
      	double tmp;
      	if (lambda1 <= -0.62) {
      		tmp = t_1;
      	} else if (lambda1 <= 5800.0) {
      		tmp = Math.atan2((Math.sin((lambda1 - lambda2)) * Math.cos(phi2)), (t_0 - (Math.cos((lambda2 - lambda1)) * Math.sin(phi1))));
      	} else {
      		tmp = t_1;
      	}
      	return tmp;
      }
      
      def code(lambda1, lambda2, phi1, phi2):
      	t_0 = math.sin(phi2) * math.cos(phi1)
      	t_1 = math.atan2((math.sin(lambda1) * math.cos(phi2)), (t_0 - (math.cos((lambda1 - lambda2)) * (math.sin(phi1) * math.cos(phi2)))))
      	tmp = 0
      	if lambda1 <= -0.62:
      		tmp = t_1
      	elif lambda1 <= 5800.0:
      		tmp = math.atan2((math.sin((lambda1 - lambda2)) * math.cos(phi2)), (t_0 - (math.cos((lambda2 - lambda1)) * math.sin(phi1))))
      	else:
      		tmp = t_1
      	return tmp
      
      function code(lambda1, lambda2, phi1, phi2)
      	t_0 = Float64(sin(phi2) * cos(phi1))
      	t_1 = atan(Float64(sin(lambda1) * cos(phi2)), Float64(t_0 - Float64(cos(Float64(lambda1 - lambda2)) * Float64(sin(phi1) * cos(phi2)))))
      	tmp = 0.0
      	if (lambda1 <= -0.62)
      		tmp = t_1;
      	elseif (lambda1 <= 5800.0)
      		tmp = atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), Float64(t_0 - Float64(cos(Float64(lambda2 - lambda1)) * sin(phi1))));
      	else
      		tmp = t_1;
      	end
      	return tmp
      end
      
      function tmp_2 = code(lambda1, lambda2, phi1, phi2)
      	t_0 = sin(phi2) * cos(phi1);
      	t_1 = atan2((sin(lambda1) * cos(phi2)), (t_0 - (cos((lambda1 - lambda2)) * (sin(phi1) * cos(phi2)))));
      	tmp = 0.0;
      	if (lambda1 <= -0.62)
      		tmp = t_1;
      	elseif (lambda1 <= 5800.0)
      		tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - (cos((lambda2 - lambda1)) * sin(phi1))));
      	else
      		tmp = t_1;
      	end
      	tmp_2 = tmp;
      end
      
      code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda1, -0.62], t$95$1, If[LessEqual[lambda1, 5800.0], N[ArcTan[N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$1]]]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \sin \phi_2 \cdot \cos \phi_1\\
      t_1 := \tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_0 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\
      \mathbf{if}\;\lambda_1 \leq -0.62:\\
      \;\;\;\;t\_1\\
      
      \mathbf{elif}\;\lambda_1 \leq 5800:\\
      \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0 - \cos \left(\lambda_2 - \lambda_1\right) \cdot \sin \phi_1}\\
      
      \mathbf{else}:\\
      \;\;\;\;t\_1\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 2 regimes
      2. if lambda1 < -0.619999999999999996 or 5800 < lambda1

        1. Initial program 54.4%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in lambda2 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. Step-by-step derivation
          1. lower-sin.f6455.6

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. Applied rewrites55.6%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

        if -0.619999999999999996 < lambda1 < 5800

        1. Initial program 98.0%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\cos \left(\lambda_1 - \lambda_2\right) \cdot \sin \phi_1}} \]
        4. Step-by-step derivation
          1. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
          2. lower-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
          3. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          4. sub-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\lambda_1 + \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}} \]
          5. remove-double-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\color{blue}{\left(\mathsf{neg}\left(\left(\mathsf{neg}\left(\lambda_1\right)\right)\right)\right)} + \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)} \]
          6. mul-1-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\left(\mathsf{neg}\left(\color{blue}{-1 \cdot \lambda_1}\right)\right) + \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)} \]
          7. distribute-neg-inN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\mathsf{neg}\left(\left(-1 \cdot \lambda_1 + \lambda_2\right)\right)\right)}} \]
          8. +-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\mathsf{neg}\left(\color{blue}{\left(\lambda_2 + -1 \cdot \lambda_1\right)}\right)\right)} \]
          9. cos-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \left(\lambda_2 + -1 \cdot \lambda_1\right)}} \]
          10. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_2 + \color{blue}{\lambda_1 \cdot -1}\right)} \]
          11. *-lft-identityN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\color{blue}{1 \cdot \lambda_2} + \lambda_1 \cdot -1\right)} \]
          12. *-inversesN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\color{blue}{\frac{\lambda_1}{\lambda_1}} \cdot \lambda_2 + \lambda_1 \cdot -1\right)} \]
          13. /-rgt-identityN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{\lambda_1}{\lambda_1} \cdot \color{blue}{\frac{\lambda_2}{1}} + \lambda_1 \cdot -1\right)} \]
          14. times-fracN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\color{blue}{\frac{\lambda_1 \cdot \lambda_2}{\lambda_1 \cdot 1}} + \lambda_1 \cdot -1\right)} \]
          15. *-rgt-identityN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{\lambda_1 \cdot \lambda_2}{\color{blue}{\lambda_1}} + \lambda_1 \cdot -1\right)} \]
          16. associate-*r/N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\color{blue}{\lambda_1 \cdot \frac{\lambda_2}{\lambda_1}} + \lambda_1 \cdot -1\right)} \]
          17. distribute-lft-inN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\lambda_1 \cdot \left(\frac{\lambda_2}{\lambda_1} + -1\right)\right)}} \]
          18. metadata-evalN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 \cdot \left(\frac{\lambda_2}{\lambda_1} + \color{blue}{\left(\mathsf{neg}\left(1\right)\right)}\right)\right)} \]
          19. sub-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 \cdot \color{blue}{\left(\frac{\lambda_2}{\lambda_1} - 1\right)}\right)} \]
          20. lower-cos.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \left(\lambda_1 \cdot \left(\frac{\lambda_2}{\lambda_1} - 1\right)\right)}} \]
          21. sub-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 \cdot \color{blue}{\left(\frac{\lambda_2}{\lambda_1} + \left(\mathsf{neg}\left(1\right)\right)\right)}\right)} \]
          22. metadata-evalN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 \cdot \left(\frac{\lambda_2}{\lambda_1} + \color{blue}{-1}\right)\right)} \]
          23. distribute-lft-inN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\lambda_1 \cdot \frac{\lambda_2}{\lambda_1} + \lambda_1 \cdot -1\right)}} \]
          24. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 \cdot \frac{\lambda_2}{\lambda_1} + \color{blue}{-1 \cdot \lambda_1}\right)} \]
        5. Applied rewrites81.2%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1 \cdot \cos \left(\lambda_2 - \lambda_1\right)}} \]
      3. Recombined 2 regimes into one program.
      4. Final simplification68.9%

        \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 \leq -0.62:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{elif}\;\lambda_1 \leq 5800:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_2 - \lambda_1\right) \cdot \sin \phi_1}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \end{array} \]
      5. Add Preprocessing

      Alternative 15: 79.3% accurate, 1.0× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\ t_1 := \sin \phi_2 \cdot \cos \phi_1\\ \mathbf{if}\;\lambda_2 \leq -3.3 \cdot 10^{+72}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \cos \phi_2}{t\_1 - t\_0 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot t\_0, \cos \phi_2, t\_1\right)}\\ \end{array} \end{array} \]
      (FPCore (lambda1 lambda2 phi1 phi2)
       :precision binary64
       (let* ((t_0 (cos (- lambda1 lambda2))) (t_1 (* (sin phi2) (cos phi1))))
         (if (<= lambda2 -3.3e+72)
           (atan2
            (* (sin (- lambda2)) (cos phi2))
            (- t_1 (* t_0 (* (sin phi1) (cos phi2)))))
           (atan2
            (* (sin (- lambda1 lambda2)) (cos phi2))
            (fma (* (- (sin phi1)) t_0) (cos phi2) t_1)))))
      double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = cos((lambda1 - lambda2));
      	double t_1 = sin(phi2) * cos(phi1);
      	double tmp;
      	if (lambda2 <= -3.3e+72) {
      		tmp = atan2((sin(-lambda2) * cos(phi2)), (t_1 - (t_0 * (sin(phi1) * cos(phi2)))));
      	} else {
      		tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), fma((-sin(phi1) * t_0), cos(phi2), t_1));
      	}
      	return tmp;
      }
      
      function code(lambda1, lambda2, phi1, phi2)
      	t_0 = cos(Float64(lambda1 - lambda2))
      	t_1 = Float64(sin(phi2) * cos(phi1))
      	tmp = 0.0
      	if (lambda2 <= -3.3e+72)
      		tmp = atan(Float64(sin(Float64(-lambda2)) * cos(phi2)), Float64(t_1 - Float64(t_0 * Float64(sin(phi1) * cos(phi2)))));
      	else
      		tmp = atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), fma(Float64(Float64(-sin(phi1)) * t_0), cos(phi2), t_1));
      	end
      	return tmp
      end
      
      code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda2, -3.3e+72], N[ArcTan[N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$1 - N[(t$95$0 * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[((-N[Sin[phi1], $MachinePrecision]) * t$95$0), $MachinePrecision] * N[Cos[phi2], $MachinePrecision] + t$95$1), $MachinePrecision]], $MachinePrecision]]]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
      t_1 := \sin \phi_2 \cdot \cos \phi_1\\
      \mathbf{if}\;\lambda_2 \leq -3.3 \cdot 10^{+72}:\\
      \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \cos \phi_2}{t\_1 - t\_0 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\
      
      \mathbf{else}:\\
      \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot t\_0, \cos \phi_2, t\_1\right)}\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 2 regimes
      2. if lambda2 < -3.3e72

        1. Initial program 54.2%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in lambda1 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(-1 \cdot \lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. Step-by-step derivation
          1. neg-mul-1N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\mathsf{neg}\left(\lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower-neg.f6463.5

            \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(-\lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. Applied rewrites63.5%

          \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(-\lambda_2\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

        if -3.3e72 < lambda2

        1. Initial program 82.9%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Step-by-step derivation
          1. lift-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          3. lower-*.f6482.9

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          4. lift--.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
          5. sub-negN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\cos \phi_1 \cdot \sin \phi_2 + \left(\mathsf{neg}\left(\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)\right)}} \]
          6. +-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\left(\mathsf{neg}\left(\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)\right) + \cos \phi_1 \cdot \sin \phi_2}} \]
          7. lift-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}\right)\right) + \cos \phi_1 \cdot \sin \phi_2} \]
          8. lift-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\color{blue}{\left(\sin \phi_1 \cdot \cos \phi_2\right)} \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)\right) + \cos \phi_1 \cdot \sin \phi_2} \]
          9. associate-*l*N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\color{blue}{\sin \phi_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)}\right)\right) + \cos \phi_1 \cdot \sin \phi_2} \]
          10. distribute-lft-neg-inN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)} + \cos \phi_1 \cdot \sin \phi_2} \]
          11. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \color{blue}{\left(\cos \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\right)} + \cos \phi_1 \cdot \sin \phi_2} \]
          12. associate-*r*N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\left(\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot \cos \phi_2} + \cos \phi_1 \cdot \sin \phi_2} \]
          13. lower-fma.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\mathsf{fma}\left(\left(\mathsf{neg}\left(\sin \phi_1\right)\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, \cos \phi_1 \cdot \sin \phi_2\right)}} \]
        4. Applied rewrites82.9%

          \[\leadsto \color{blue}{\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, \sin \phi_2 \cdot \cos \phi_1\right)}} \]
      3. Recombined 2 regimes into one program.
      4. Final simplification79.0%

        \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_2 \leq -3.3 \cdot 10^{+72}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\mathsf{fma}\left(\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, \sin \phi_2 \cdot \cos \phi_1\right)}\\ \end{array} \]
      5. Add Preprocessing

      Alternative 16: 58.2% accurate, 1.1× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\ t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \lambda_1}{t\_0}\\ \mathbf{if}\;\lambda_1 \leq -1.15 \cdot 10^{-12}:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;\lambda_1 \leq 3.7 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(-\sin \lambda_2\right)}{t\_0}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
      (FPCore (lambda1 lambda2 phi1 phi2)
       :precision binary64
       (let* ((t_0
               (-
                (* (sin phi2) (cos phi1))
                (* (sin phi1) (cos (- lambda1 lambda2)))))
              (t_1 (atan2 (* (cos phi2) (sin lambda1)) t_0)))
         (if (<= lambda1 -1.15e-12)
           t_1
           (if (<= lambda1 3.7e-5)
             (atan2 (* (cos phi2) (- (sin lambda2))) t_0)
             t_1))))
      double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)));
      	double t_1 = atan2((cos(phi2) * sin(lambda1)), t_0);
      	double tmp;
      	if (lambda1 <= -1.15e-12) {
      		tmp = t_1;
      	} else if (lambda1 <= 3.7e-5) {
      		tmp = atan2((cos(phi2) * -sin(lambda2)), t_0);
      	} else {
      		tmp = t_1;
      	}
      	return tmp;
      }
      
      real(8) function code(lambda1, lambda2, phi1, phi2)
          real(8), intent (in) :: lambda1
          real(8), intent (in) :: lambda2
          real(8), intent (in) :: phi1
          real(8), intent (in) :: phi2
          real(8) :: t_0
          real(8) :: t_1
          real(8) :: tmp
          t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)))
          t_1 = atan2((cos(phi2) * sin(lambda1)), t_0)
          if (lambda1 <= (-1.15d-12)) then
              tmp = t_1
          else if (lambda1 <= 3.7d-5) then
              tmp = atan2((cos(phi2) * -sin(lambda2)), t_0)
          else
              tmp = t_1
          end if
          code = tmp
      end function
      
      public static double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = (Math.sin(phi2) * Math.cos(phi1)) - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)));
      	double t_1 = Math.atan2((Math.cos(phi2) * Math.sin(lambda1)), t_0);
      	double tmp;
      	if (lambda1 <= -1.15e-12) {
      		tmp = t_1;
      	} else if (lambda1 <= 3.7e-5) {
      		tmp = Math.atan2((Math.cos(phi2) * -Math.sin(lambda2)), t_0);
      	} else {
      		tmp = t_1;
      	}
      	return tmp;
      }
      
      def code(lambda1, lambda2, phi1, phi2):
      	t_0 = (math.sin(phi2) * math.cos(phi1)) - (math.sin(phi1) * math.cos((lambda1 - lambda2)))
      	t_1 = math.atan2((math.cos(phi2) * math.sin(lambda1)), t_0)
      	tmp = 0
      	if lambda1 <= -1.15e-12:
      		tmp = t_1
      	elif lambda1 <= 3.7e-5:
      		tmp = math.atan2((math.cos(phi2) * -math.sin(lambda2)), t_0)
      	else:
      		tmp = t_1
      	return tmp
      
      function code(lambda1, lambda2, phi1, phi2)
      	t_0 = Float64(Float64(sin(phi2) * cos(phi1)) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))
      	t_1 = atan(Float64(cos(phi2) * sin(lambda1)), t_0)
      	tmp = 0.0
      	if (lambda1 <= -1.15e-12)
      		tmp = t_1;
      	elseif (lambda1 <= 3.7e-5)
      		tmp = atan(Float64(cos(phi2) * Float64(-sin(lambda2))), t_0);
      	else
      		tmp = t_1;
      	end
      	return tmp
      end
      
      function tmp_2 = code(lambda1, lambda2, phi1, phi2)
      	t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)));
      	t_1 = atan2((cos(phi2) * sin(lambda1)), t_0);
      	tmp = 0.0;
      	if (lambda1 <= -1.15e-12)
      		tmp = t_1;
      	elseif (lambda1 <= 3.7e-5)
      		tmp = atan2((cos(phi2) * -sin(lambda2)), t_0);
      	else
      		tmp = t_1;
      	end
      	tmp_2 = tmp;
      end
      
      code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision] / t$95$0], $MachinePrecision]}, If[LessEqual[lambda1, -1.15e-12], t$95$1, If[LessEqual[lambda1, 3.7e-5], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision] / t$95$0], $MachinePrecision], t$95$1]]]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
      t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \lambda_1}{t\_0}\\
      \mathbf{if}\;\lambda_1 \leq -1.15 \cdot 10^{-12}:\\
      \;\;\;\;t\_1\\
      
      \mathbf{elif}\;\lambda_1 \leq 3.7 \cdot 10^{-5}:\\
      \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(-\sin \lambda_2\right)}{t\_0}\\
      
      \mathbf{else}:\\
      \;\;\;\;t\_1\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 2 regimes
      2. if lambda1 < -1.14999999999999995e-12 or 3.69999999999999981e-5 < lambda1

        1. Initial program 55.2%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. Step-by-step derivation
          1. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower--.f6436.0

            \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. Applied rewrites36.0%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        6. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        7. Step-by-step derivation
          1. lower-sin.f6435.9

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        8. Applied rewrites35.9%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        9. Taylor expanded in lambda2 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \lambda_1}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        10. Step-by-step derivation
          1. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1 \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1 \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          3. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          4. lower-cos.f6446.4

            \[\leadsto \tan^{-1}_* \frac{\sin \lambda_1 \cdot \color{blue}{\cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        11. Applied rewrites46.4%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1 \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

        if -1.14999999999999995e-12 < lambda1 < 3.69999999999999981e-5

        1. Initial program 99.6%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. Step-by-step derivation
          1. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower--.f6459.8

            \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. Applied rewrites59.8%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        6. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        7. Step-by-step derivation
          1. lower-sin.f6459.4

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        8. Applied rewrites59.4%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        9. Taylor expanded in lambda1 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        10. Step-by-step derivation
          1. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          3. sin-negN/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          4. lower-neg.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          5. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\left(\mathsf{neg}\left(\color{blue}{\sin \lambda_2}\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          6. lower-cos.f6474.9

            \[\leadsto \tan^{-1}_* \frac{\left(-\sin \lambda_2\right) \cdot \color{blue}{\cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        11. Applied rewrites74.9%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(-\sin \lambda_2\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
      3. Recombined 2 regimes into one program.
      4. Final simplification60.4%

        \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 \leq -1.15 \cdot 10^{-12}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \lambda_1}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{elif}\;\lambda_1 \leq 3.7 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(-\sin \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \lambda_1}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \end{array} \]
      5. Add Preprocessing

      Alternative 17: 54.8% accurate, 1.1× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \lambda_1}{t\_0 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{if}\;\lambda_1 \leq -2.1 \cdot 10^{-12}:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;\lambda_1 \leq 8.8 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{t\_0 - \cos \lambda_2 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
      (FPCore (lambda1 lambda2 phi1 phi2)
       :precision binary64
       (let* ((t_0 (* (sin phi2) (cos phi1)))
              (t_1
               (atan2
                (* (cos phi2) (sin lambda1))
                (- t_0 (* (sin phi1) (cos (- lambda1 lambda2)))))))
         (if (<= lambda1 -2.1e-12)
           t_1
           (if (<= lambda1 8.8e-5)
             (atan2
              (sin (- lambda1 lambda2))
              (- t_0 (* (cos lambda2) (* (sin phi1) (cos phi2)))))
             t_1))))
      double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = sin(phi2) * cos(phi1);
      	double t_1 = atan2((cos(phi2) * sin(lambda1)), (t_0 - (sin(phi1) * cos((lambda1 - lambda2)))));
      	double tmp;
      	if (lambda1 <= -2.1e-12) {
      		tmp = t_1;
      	} else if (lambda1 <= 8.8e-5) {
      		tmp = atan2(sin((lambda1 - lambda2)), (t_0 - (cos(lambda2) * (sin(phi1) * cos(phi2)))));
      	} else {
      		tmp = t_1;
      	}
      	return tmp;
      }
      
      real(8) function code(lambda1, lambda2, phi1, phi2)
          real(8), intent (in) :: lambda1
          real(8), intent (in) :: lambda2
          real(8), intent (in) :: phi1
          real(8), intent (in) :: phi2
          real(8) :: t_0
          real(8) :: t_1
          real(8) :: tmp
          t_0 = sin(phi2) * cos(phi1)
          t_1 = atan2((cos(phi2) * sin(lambda1)), (t_0 - (sin(phi1) * cos((lambda1 - lambda2)))))
          if (lambda1 <= (-2.1d-12)) then
              tmp = t_1
          else if (lambda1 <= 8.8d-5) then
              tmp = atan2(sin((lambda1 - lambda2)), (t_0 - (cos(lambda2) * (sin(phi1) * cos(phi2)))))
          else
              tmp = t_1
          end if
          code = tmp
      end function
      
      public static double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = Math.sin(phi2) * Math.cos(phi1);
      	double t_1 = Math.atan2((Math.cos(phi2) * Math.sin(lambda1)), (t_0 - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)))));
      	double tmp;
      	if (lambda1 <= -2.1e-12) {
      		tmp = t_1;
      	} else if (lambda1 <= 8.8e-5) {
      		tmp = Math.atan2(Math.sin((lambda1 - lambda2)), (t_0 - (Math.cos(lambda2) * (Math.sin(phi1) * Math.cos(phi2)))));
      	} else {
      		tmp = t_1;
      	}
      	return tmp;
      }
      
      def code(lambda1, lambda2, phi1, phi2):
      	t_0 = math.sin(phi2) * math.cos(phi1)
      	t_1 = math.atan2((math.cos(phi2) * math.sin(lambda1)), (t_0 - (math.sin(phi1) * math.cos((lambda1 - lambda2)))))
      	tmp = 0
      	if lambda1 <= -2.1e-12:
      		tmp = t_1
      	elif lambda1 <= 8.8e-5:
      		tmp = math.atan2(math.sin((lambda1 - lambda2)), (t_0 - (math.cos(lambda2) * (math.sin(phi1) * math.cos(phi2)))))
      	else:
      		tmp = t_1
      	return tmp
      
      function code(lambda1, lambda2, phi1, phi2)
      	t_0 = Float64(sin(phi2) * cos(phi1))
      	t_1 = atan(Float64(cos(phi2) * sin(lambda1)), Float64(t_0 - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2)))))
      	tmp = 0.0
      	if (lambda1 <= -2.1e-12)
      		tmp = t_1;
      	elseif (lambda1 <= 8.8e-5)
      		tmp = atan(sin(Float64(lambda1 - lambda2)), Float64(t_0 - Float64(cos(lambda2) * Float64(sin(phi1) * cos(phi2)))));
      	else
      		tmp = t_1;
      	end
      	return tmp
      end
      
      function tmp_2 = code(lambda1, lambda2, phi1, phi2)
      	t_0 = sin(phi2) * cos(phi1);
      	t_1 = atan2((cos(phi2) * sin(lambda1)), (t_0 - (sin(phi1) * cos((lambda1 - lambda2)))));
      	tmp = 0.0;
      	if (lambda1 <= -2.1e-12)
      		tmp = t_1;
      	elseif (lambda1 <= 8.8e-5)
      		tmp = atan2(sin((lambda1 - lambda2)), (t_0 - (cos(lambda2) * (sin(phi1) * cos(phi2)))));
      	else
      		tmp = t_1;
      	end
      	tmp_2 = tmp;
      end
      
      code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda1, -2.1e-12], t$95$1, If[LessEqual[lambda1, 8.8e-5], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(t$95$0 - N[(N[Cos[lambda2], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$1]]]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \sin \phi_2 \cdot \cos \phi_1\\
      t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \lambda_1}{t\_0 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
      \mathbf{if}\;\lambda_1 \leq -2.1 \cdot 10^{-12}:\\
      \;\;\;\;t\_1\\
      
      \mathbf{elif}\;\lambda_1 \leq 8.8 \cdot 10^{-5}:\\
      \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{t\_0 - \cos \lambda_2 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\
      
      \mathbf{else}:\\
      \;\;\;\;t\_1\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 2 regimes
      2. if lambda1 < -2.09999999999999994e-12 or 8.7999999999999998e-5 < lambda1

        1. Initial program 55.2%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. Step-by-step derivation
          1. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower--.f6436.0

            \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. Applied rewrites36.0%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        6. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        7. Step-by-step derivation
          1. lower-sin.f6435.9

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        8. Applied rewrites35.9%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        9. Taylor expanded in lambda2 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \lambda_1}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        10. Step-by-step derivation
          1. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1 \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1 \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          3. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          4. lower-cos.f6446.4

            \[\leadsto \tan^{-1}_* \frac{\sin \lambda_1 \cdot \color{blue}{\cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        11. Applied rewrites46.4%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \lambda_1 \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

        if -2.09999999999999994e-12 < lambda1 < 8.7999999999999998e-5

        1. Initial program 99.6%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. Step-by-step derivation
          1. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower--.f6459.8

            \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. Applied rewrites59.8%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        6. Taylor expanded in lambda1 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \left(\mathsf{neg}\left(\lambda_2\right)\right)}} \]
        7. Step-by-step derivation
          1. cos-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_2}} \]
          2. lower-cos.f6459.8

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_2}} \]
        8. Applied rewrites59.8%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\cos \lambda_2}} \]
      3. Recombined 2 regimes into one program.
      4. Final simplification53.0%

        \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 \leq -2.1 \cdot 10^{-12}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \lambda_1}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{elif}\;\lambda_1 \leq 8.8 \cdot 10^{-5}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \cos \lambda_2 \cdot \left(\sin \phi_1 \cdot \cos \phi_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \lambda_1}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \end{array} \]
      5. Add Preprocessing

      Alternative 18: 65.6% accurate, 1.1× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ \mathbf{if}\;\lambda_2 \leq -2 \cdot 10^{+72}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(-\sin \lambda_2\right)}{t\_0 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0 - \cos \left(\lambda_2 - \lambda_1\right) \cdot \sin \phi_1}\\ \end{array} \end{array} \]
      (FPCore (lambda1 lambda2 phi1 phi2)
       :precision binary64
       (let* ((t_0 (* (sin phi2) (cos phi1))))
         (if (<= lambda2 -2e+72)
           (atan2
            (* (cos phi2) (- (sin lambda2)))
            (- t_0 (* (sin phi1) (cos (- lambda1 lambda2)))))
           (atan2
            (* (sin (- lambda1 lambda2)) (cos phi2))
            (- t_0 (* (cos (- lambda2 lambda1)) (sin phi1)))))))
      double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = sin(phi2) * cos(phi1);
      	double tmp;
      	if (lambda2 <= -2e+72) {
      		tmp = atan2((cos(phi2) * -sin(lambda2)), (t_0 - (sin(phi1) * cos((lambda1 - lambda2)))));
      	} else {
      		tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - (cos((lambda2 - lambda1)) * sin(phi1))));
      	}
      	return tmp;
      }
      
      real(8) function code(lambda1, lambda2, phi1, phi2)
          real(8), intent (in) :: lambda1
          real(8), intent (in) :: lambda2
          real(8), intent (in) :: phi1
          real(8), intent (in) :: phi2
          real(8) :: t_0
          real(8) :: tmp
          t_0 = sin(phi2) * cos(phi1)
          if (lambda2 <= (-2d+72)) then
              tmp = atan2((cos(phi2) * -sin(lambda2)), (t_0 - (sin(phi1) * cos((lambda1 - lambda2)))))
          else
              tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - (cos((lambda2 - lambda1)) * sin(phi1))))
          end if
          code = tmp
      end function
      
      public static double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = Math.sin(phi2) * Math.cos(phi1);
      	double tmp;
      	if (lambda2 <= -2e+72) {
      		tmp = Math.atan2((Math.cos(phi2) * -Math.sin(lambda2)), (t_0 - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)))));
      	} else {
      		tmp = Math.atan2((Math.sin((lambda1 - lambda2)) * Math.cos(phi2)), (t_0 - (Math.cos((lambda2 - lambda1)) * Math.sin(phi1))));
      	}
      	return tmp;
      }
      
      def code(lambda1, lambda2, phi1, phi2):
      	t_0 = math.sin(phi2) * math.cos(phi1)
      	tmp = 0
      	if lambda2 <= -2e+72:
      		tmp = math.atan2((math.cos(phi2) * -math.sin(lambda2)), (t_0 - (math.sin(phi1) * math.cos((lambda1 - lambda2)))))
      	else:
      		tmp = math.atan2((math.sin((lambda1 - lambda2)) * math.cos(phi2)), (t_0 - (math.cos((lambda2 - lambda1)) * math.sin(phi1))))
      	return tmp
      
      function code(lambda1, lambda2, phi1, phi2)
      	t_0 = Float64(sin(phi2) * cos(phi1))
      	tmp = 0.0
      	if (lambda2 <= -2e+72)
      		tmp = atan(Float64(cos(phi2) * Float64(-sin(lambda2))), Float64(t_0 - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2)))));
      	else
      		tmp = atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), Float64(t_0 - Float64(cos(Float64(lambda2 - lambda1)) * sin(phi1))));
      	end
      	return tmp
      end
      
      function tmp_2 = code(lambda1, lambda2, phi1, phi2)
      	t_0 = sin(phi2) * cos(phi1);
      	tmp = 0.0;
      	if (lambda2 <= -2e+72)
      		tmp = atan2((cos(phi2) * -sin(lambda2)), (t_0 - (sin(phi1) * cos((lambda1 - lambda2)))));
      	else
      		tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - (cos((lambda2 - lambda1)) * sin(phi1))));
      	end
      	tmp_2 = tmp;
      end
      
      code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda2, -2e+72], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision] / N[(t$95$0 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \sin \phi_2 \cdot \cos \phi_1\\
      \mathbf{if}\;\lambda_2 \leq -2 \cdot 10^{+72}:\\
      \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(-\sin \lambda_2\right)}{t\_0 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
      
      \mathbf{else}:\\
      \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0 - \cos \left(\lambda_2 - \lambda_1\right) \cdot \sin \phi_1}\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 2 regimes
      2. if lambda2 < -1.99999999999999989e72

        1. Initial program 54.2%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. Step-by-step derivation
          1. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower--.f6432.0

            \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. Applied rewrites32.0%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        6. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        7. Step-by-step derivation
          1. lower-sin.f6432.5

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        8. Applied rewrites32.5%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        9. Taylor expanded in lambda1 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        10. Step-by-step derivation
          1. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          3. sin-negN/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          4. lower-neg.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\mathsf{neg}\left(\sin \lambda_2\right)\right)} \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          5. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\left(\mathsf{neg}\left(\color{blue}{\sin \lambda_2}\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          6. lower-cos.f6453.6

            \[\leadsto \tan^{-1}_* \frac{\left(-\sin \lambda_2\right) \cdot \color{blue}{\cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        11. Applied rewrites53.6%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(-\sin \lambda_2\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

        if -1.99999999999999989e72 < lambda2

        1. Initial program 82.9%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\cos \left(\lambda_1 - \lambda_2\right) \cdot \sin \phi_1}} \]
        4. Step-by-step derivation
          1. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
          2. lower-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}} \]
          3. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          4. sub-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\lambda_1 + \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}} \]
          5. remove-double-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\color{blue}{\left(\mathsf{neg}\left(\left(\mathsf{neg}\left(\lambda_1\right)\right)\right)\right)} + \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)} \]
          6. mul-1-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\left(\mathsf{neg}\left(\color{blue}{-1 \cdot \lambda_1}\right)\right) + \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)} \]
          7. distribute-neg-inN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\mathsf{neg}\left(\left(-1 \cdot \lambda_1 + \lambda_2\right)\right)\right)}} \]
          8. +-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\mathsf{neg}\left(\color{blue}{\left(\lambda_2 + -1 \cdot \lambda_1\right)}\right)\right)} \]
          9. cos-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \left(\lambda_2 + -1 \cdot \lambda_1\right)}} \]
          10. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_2 + \color{blue}{\lambda_1 \cdot -1}\right)} \]
          11. *-lft-identityN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\color{blue}{1 \cdot \lambda_2} + \lambda_1 \cdot -1\right)} \]
          12. *-inversesN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\color{blue}{\frac{\lambda_1}{\lambda_1}} \cdot \lambda_2 + \lambda_1 \cdot -1\right)} \]
          13. /-rgt-identityN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{\lambda_1}{\lambda_1} \cdot \color{blue}{\frac{\lambda_2}{1}} + \lambda_1 \cdot -1\right)} \]
          14. times-fracN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\color{blue}{\frac{\lambda_1 \cdot \lambda_2}{\lambda_1 \cdot 1}} + \lambda_1 \cdot -1\right)} \]
          15. *-rgt-identityN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{\lambda_1 \cdot \lambda_2}{\color{blue}{\lambda_1}} + \lambda_1 \cdot -1\right)} \]
          16. associate-*r/N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\color{blue}{\lambda_1 \cdot \frac{\lambda_2}{\lambda_1}} + \lambda_1 \cdot -1\right)} \]
          17. distribute-lft-inN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\lambda_1 \cdot \left(\frac{\lambda_2}{\lambda_1} + -1\right)\right)}} \]
          18. metadata-evalN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 \cdot \left(\frac{\lambda_2}{\lambda_1} + \color{blue}{\left(\mathsf{neg}\left(1\right)\right)}\right)\right)} \]
          19. sub-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 \cdot \color{blue}{\left(\frac{\lambda_2}{\lambda_1} - 1\right)}\right)} \]
          20. lower-cos.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \left(\lambda_1 \cdot \left(\frac{\lambda_2}{\lambda_1} - 1\right)\right)}} \]
          21. sub-negN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 \cdot \color{blue}{\left(\frac{\lambda_2}{\lambda_1} + \left(\mathsf{neg}\left(1\right)\right)\right)}\right)} \]
          22. metadata-evalN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 \cdot \left(\frac{\lambda_2}{\lambda_1} + \color{blue}{-1}\right)\right)} \]
          23. distribute-lft-inN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\lambda_1 \cdot \frac{\lambda_2}{\lambda_1} + \lambda_1 \cdot -1\right)}} \]
          24. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 \cdot \frac{\lambda_2}{\lambda_1} + \color{blue}{-1 \cdot \lambda_1}\right)} \]
        5. Applied rewrites68.9%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1 \cdot \cos \left(\lambda_2 - \lambda_1\right)}} \]
      3. Recombined 2 regimes into one program.
      4. Final simplification65.8%

        \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_2 \leq -2 \cdot 10^{+72}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(-\sin \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\lambda_2 - \lambda_1\right) \cdot \sin \phi_1}\\ \end{array} \]
      5. Add Preprocessing

      Alternative 19: 52.2% accurate, 1.2× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \left(\lambda_1 - \lambda_2\right)\\ t_1 := \sin \phi_2 \cdot \cos \phi_1\\ t_2 := t\_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\lambda_1 - \lambda_2 \leq -2000000:\\ \;\;\;\;\tan^{-1}_* \frac{t\_0}{t\_2}\\ \mathbf{elif}\;\lambda_1 - \lambda_2 \leq 2 \cdot 10^{-40}:\\ \;\;\;\;\tan^{-1}_* \frac{\left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t\_0}{t\_1 - \cos \left(\left(\frac{1}{\lambda_2 + \lambda_1} \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(\lambda_2 + \lambda_1\right)\right) \cdot \sin \phi_1}\\ \end{array} \end{array} \]
      (FPCore (lambda1 lambda2 phi1 phi2)
       :precision binary64
       (let* ((t_0 (sin (- lambda1 lambda2)))
              (t_1 (* (sin phi2) (cos phi1)))
              (t_2 (- t_1 (* (sin phi1) (cos (- lambda1 lambda2))))))
         (if (<= (- lambda1 lambda2) -2000000.0)
           (atan2 t_0 t_2)
           (if (<= (- lambda1 lambda2) 2e-40)
             (atan2 (* (- lambda1 lambda2) (cos phi2)) t_2)
             (atan2
              t_0
              (-
               t_1
               (*
                (cos
                 (*
                  (* (/ 1.0 (+ lambda2 lambda1)) (- lambda1 lambda2))
                  (+ lambda2 lambda1)))
                (sin phi1))))))))
      double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = sin((lambda1 - lambda2));
      	double t_1 = sin(phi2) * cos(phi1);
      	double t_2 = t_1 - (sin(phi1) * cos((lambda1 - lambda2)));
      	double tmp;
      	if ((lambda1 - lambda2) <= -2000000.0) {
      		tmp = atan2(t_0, t_2);
      	} else if ((lambda1 - lambda2) <= 2e-40) {
      		tmp = atan2(((lambda1 - lambda2) * cos(phi2)), t_2);
      	} else {
      		tmp = atan2(t_0, (t_1 - (cos((((1.0 / (lambda2 + lambda1)) * (lambda1 - lambda2)) * (lambda2 + lambda1))) * sin(phi1))));
      	}
      	return tmp;
      }
      
      real(8) function code(lambda1, lambda2, phi1, phi2)
          real(8), intent (in) :: lambda1
          real(8), intent (in) :: lambda2
          real(8), intent (in) :: phi1
          real(8), intent (in) :: phi2
          real(8) :: t_0
          real(8) :: t_1
          real(8) :: t_2
          real(8) :: tmp
          t_0 = sin((lambda1 - lambda2))
          t_1 = sin(phi2) * cos(phi1)
          t_2 = t_1 - (sin(phi1) * cos((lambda1 - lambda2)))
          if ((lambda1 - lambda2) <= (-2000000.0d0)) then
              tmp = atan2(t_0, t_2)
          else if ((lambda1 - lambda2) <= 2d-40) then
              tmp = atan2(((lambda1 - lambda2) * cos(phi2)), t_2)
          else
              tmp = atan2(t_0, (t_1 - (cos((((1.0d0 / (lambda2 + lambda1)) * (lambda1 - lambda2)) * (lambda2 + lambda1))) * sin(phi1))))
          end if
          code = tmp
      end function
      
      public static double code(double lambda1, double lambda2, double phi1, double phi2) {
      	double t_0 = Math.sin((lambda1 - lambda2));
      	double t_1 = Math.sin(phi2) * Math.cos(phi1);
      	double t_2 = t_1 - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)));
      	double tmp;
      	if ((lambda1 - lambda2) <= -2000000.0) {
      		tmp = Math.atan2(t_0, t_2);
      	} else if ((lambda1 - lambda2) <= 2e-40) {
      		tmp = Math.atan2(((lambda1 - lambda2) * Math.cos(phi2)), t_2);
      	} else {
      		tmp = Math.atan2(t_0, (t_1 - (Math.cos((((1.0 / (lambda2 + lambda1)) * (lambda1 - lambda2)) * (lambda2 + lambda1))) * Math.sin(phi1))));
      	}
      	return tmp;
      }
      
      def code(lambda1, lambda2, phi1, phi2):
      	t_0 = math.sin((lambda1 - lambda2))
      	t_1 = math.sin(phi2) * math.cos(phi1)
      	t_2 = t_1 - (math.sin(phi1) * math.cos((lambda1 - lambda2)))
      	tmp = 0
      	if (lambda1 - lambda2) <= -2000000.0:
      		tmp = math.atan2(t_0, t_2)
      	elif (lambda1 - lambda2) <= 2e-40:
      		tmp = math.atan2(((lambda1 - lambda2) * math.cos(phi2)), t_2)
      	else:
      		tmp = math.atan2(t_0, (t_1 - (math.cos((((1.0 / (lambda2 + lambda1)) * (lambda1 - lambda2)) * (lambda2 + lambda1))) * math.sin(phi1))))
      	return tmp
      
      function code(lambda1, lambda2, phi1, phi2)
      	t_0 = sin(Float64(lambda1 - lambda2))
      	t_1 = Float64(sin(phi2) * cos(phi1))
      	t_2 = Float64(t_1 - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))
      	tmp = 0.0
      	if (Float64(lambda1 - lambda2) <= -2000000.0)
      		tmp = atan(t_0, t_2);
      	elseif (Float64(lambda1 - lambda2) <= 2e-40)
      		tmp = atan(Float64(Float64(lambda1 - lambda2) * cos(phi2)), t_2);
      	else
      		tmp = atan(t_0, Float64(t_1 - Float64(cos(Float64(Float64(Float64(1.0 / Float64(lambda2 + lambda1)) * Float64(lambda1 - lambda2)) * Float64(lambda2 + lambda1))) * sin(phi1))));
      	end
      	return tmp
      end
      
      function tmp_2 = code(lambda1, lambda2, phi1, phi2)
      	t_0 = sin((lambda1 - lambda2));
      	t_1 = sin(phi2) * cos(phi1);
      	t_2 = t_1 - (sin(phi1) * cos((lambda1 - lambda2)));
      	tmp = 0.0;
      	if ((lambda1 - lambda2) <= -2000000.0)
      		tmp = atan2(t_0, t_2);
      	elseif ((lambda1 - lambda2) <= 2e-40)
      		tmp = atan2(((lambda1 - lambda2) * cos(phi2)), t_2);
      	else
      		tmp = atan2(t_0, (t_1 - (cos((((1.0 / (lambda2 + lambda1)) * (lambda1 - lambda2)) * (lambda2 + lambda1))) * sin(phi1))));
      	end
      	tmp_2 = tmp;
      end
      
      code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(t$95$1 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[N[(lambda1 - lambda2), $MachinePrecision], -2000000.0], N[ArcTan[t$95$0 / t$95$2], $MachinePrecision], If[LessEqual[N[(lambda1 - lambda2), $MachinePrecision], 2e-40], N[ArcTan[N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / t$95$2], $MachinePrecision], N[ArcTan[t$95$0 / N[(t$95$1 - N[(N[Cos[N[(N[(N[(1.0 / N[(lambda2 + lambda1), $MachinePrecision]), $MachinePrecision] * N[(lambda1 - lambda2), $MachinePrecision]), $MachinePrecision] * N[(lambda2 + lambda1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]]]
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \sin \left(\lambda_1 - \lambda_2\right)\\
      t_1 := \sin \phi_2 \cdot \cos \phi_1\\
      t_2 := t\_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
      \mathbf{if}\;\lambda_1 - \lambda_2 \leq -2000000:\\
      \;\;\;\;\tan^{-1}_* \frac{t\_0}{t\_2}\\
      
      \mathbf{elif}\;\lambda_1 - \lambda_2 \leq 2 \cdot 10^{-40}:\\
      \;\;\;\;\tan^{-1}_* \frac{\left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_2}\\
      
      \mathbf{else}:\\
      \;\;\;\;\tan^{-1}_* \frac{t\_0}{t\_1 - \cos \left(\left(\frac{1}{\lambda_2 + \lambda_1} \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(\lambda_2 + \lambda_1\right)\right) \cdot \sin \phi_1}\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 3 regimes
      2. if (-.f64 lambda1 lambda2) < -2e6

        1. Initial program 74.9%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. Step-by-step derivation
          1. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower--.f6444.9

            \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. Applied rewrites44.9%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        6. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        7. Step-by-step derivation
          1. lower-sin.f6445.0

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        8. Applied rewrites45.0%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

        if -2e6 < (-.f64 lambda1 lambda2) < 1.9999999999999999e-40

        1. Initial program 99.6%

          \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        2. Add Preprocessing
        3. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        4. Step-by-step derivation
          1. lower-sin.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. lower--.f6463.1

            \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        5. Applied rewrites63.1%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        6. Taylor expanded in phi2 around 0

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        7. Step-by-step derivation
          1. lower-sin.f6461.2

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        8. Applied rewrites61.2%

          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        9. Taylor expanded in lambda1 around 0

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\lambda_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right) + \cos \phi_2 \cdot \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        10. Step-by-step derivation
          1. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\lambda_1 \cdot \color{blue}{\left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \phi_2\right)} + \cos \phi_2 \cdot \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. associate-*r*N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right) \cdot \cos \phi_2} + \cos \phi_2 \cdot \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          3. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\left(\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right) \cdot \cos \phi_2 + \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          4. distribute-rgt-outN/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \left(\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right) + \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          5. +-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\left(\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          6. lower-*.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \left(\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          7. lower-cos.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2} \cdot \left(\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          8. +-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\left(\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right) + \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          9. *-commutativeN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\color{blue}{\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \lambda_1} + \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          10. lower-fma.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\mathsf{fma}\left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right), \lambda_1, \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          11. cos-negN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\color{blue}{\cos \lambda_2}, \lambda_1, \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          12. lower-cos.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\color{blue}{\cos \lambda_2}, \lambda_1, \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          13. sin-negN/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \lambda_1, \color{blue}{\mathsf{neg}\left(\sin \lambda_2\right)}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          14. lower-neg.f64N/A

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \lambda_1, \color{blue}{\mathsf{neg}\left(\sin \lambda_2\right)}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          15. lower-sin.f6480.9

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \lambda_1, -\color{blue}{\sin \lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        11. Applied rewrites80.9%

          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \lambda_1, -\sin \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        12. Taylor expanded in lambda2 around 0

          \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\lambda_1 + \color{blue}{-1 \cdot \lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
        13. Step-by-step derivation
          1. Applied rewrites80.9%

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\lambda_1 - \color{blue}{\lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

          if 1.9999999999999999e-40 < (-.f64 lambda1 lambda2)

          1. Initial program 68.5%

            \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. Add Preprocessing
          3. Taylor expanded in phi2 around 0

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          4. Step-by-step derivation
            1. lower-sin.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            2. lower--.f6443.2

              \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          5. Applied rewrites43.2%

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          6. Taylor expanded in phi2 around 0

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          7. Step-by-step derivation
            1. lower-sin.f6443.4

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          8. Applied rewrites43.4%

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          9. Step-by-step derivation
            1. lift--.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\lambda_1 - \lambda_2\right)}} \]
            2. flip--N/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\frac{\lambda_1 \cdot \lambda_1 - \lambda_2 \cdot \lambda_2}{\lambda_1 + \lambda_2}\right)}} \]
            3. difference-of-squaresN/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{\color{blue}{\left(\lambda_1 + \lambda_2\right) \cdot \left(\lambda_1 - \lambda_2\right)}}{\lambda_1 + \lambda_2}\right)} \]
            4. +-commutativeN/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{\color{blue}{\left(\lambda_2 + \lambda_1\right)} \cdot \left(\lambda_1 - \lambda_2\right)}{\lambda_1 + \lambda_2}\right)} \]
            5. lift-+.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{\color{blue}{\left(\lambda_2 + \lambda_1\right)} \cdot \left(\lambda_1 - \lambda_2\right)}{\lambda_1 + \lambda_2}\right)} \]
            6. lift--.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{\left(\lambda_2 + \lambda_1\right) \cdot \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\lambda_1 + \lambda_2}\right)} \]
            7. +-commutativeN/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{\left(\lambda_2 + \lambda_1\right) \cdot \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\lambda_2 + \lambda_1}}\right)} \]
            8. lift-+.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{\left(\lambda_2 + \lambda_1\right) \cdot \left(\lambda_1 - \lambda_2\right)}{\color{blue}{\lambda_2 + \lambda_1}}\right)} \]
            9. lift-*.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{\color{blue}{\left(\lambda_2 + \lambda_1\right) \cdot \left(\lambda_1 - \lambda_2\right)}}{\lambda_2 + \lambda_1}\right)} \]
            10. div-invN/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\left(\left(\lambda_2 + \lambda_1\right) \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \frac{1}{\lambda_2 + \lambda_1}\right)}} \]
            11. *-commutativeN/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\frac{1}{\lambda_2 + \lambda_1} \cdot \left(\left(\lambda_2 + \lambda_1\right) \cdot \left(\lambda_1 - \lambda_2\right)\right)\right)}} \]
            12. lift-*.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{1}{\lambda_2 + \lambda_1} \cdot \color{blue}{\left(\left(\lambda_2 + \lambda_1\right) \cdot \left(\lambda_1 - \lambda_2\right)\right)}\right)} \]
            13. *-commutativeN/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\frac{1}{\lambda_2 + \lambda_1} \cdot \color{blue}{\left(\left(\lambda_1 - \lambda_2\right) \cdot \left(\lambda_2 + \lambda_1\right)\right)}\right)} \]
            14. associate-*r*N/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\left(\frac{1}{\lambda_2 + \lambda_1} \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(\lambda_2 + \lambda_1\right)\right)}} \]
            15. lower-*.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\left(\frac{1}{\lambda_2 + \lambda_1} \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(\lambda_2 + \lambda_1\right)\right)}} \]
            16. lower-*.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\color{blue}{\left(\frac{1}{\lambda_2 + \lambda_1} \cdot \left(\lambda_1 - \lambda_2\right)\right)} \cdot \left(\lambda_2 + \lambda_1\right)\right)} \]
            17. lower-/.f6443.5

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\left(\color{blue}{\frac{1}{\lambda_2 + \lambda_1}} \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(\lambda_2 + \lambda_1\right)\right)} \]
          10. Applied rewrites43.5%

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \color{blue}{\left(\left(\frac{1}{\lambda_2 + \lambda_1} \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(\lambda_2 + \lambda_1\right)\right)}} \]
        14. Recombined 3 regimes into one program.
        15. Final simplification51.3%

          \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 - \lambda_2 \leq -2000000:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{elif}\;\lambda_1 - \lambda_2 \leq 2 \cdot 10^{-40}:\\ \;\;\;\;\tan^{-1}_* \frac{\left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \cos \left(\left(\frac{1}{\lambda_2 + \lambda_1} \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(\lambda_2 + \lambda_1\right)\right) \cdot \sin \phi_1}\\ \end{array} \]
        16. Add Preprocessing

        Alternative 20: 51.8% accurate, 1.2× speedup?

        \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\lambda_1 - \lambda_2 \leq -2000000:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{t\_0}\\ \mathbf{elif}\;\lambda_1 - \lambda_2 \leq 2 \cdot 10^{-40}:\\ \;\;\;\;\tan^{-1}_* \frac{\left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\left(\frac{1}{\lambda_2 + \lambda_1} \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(\lambda_2 + \lambda_1\right)\right)}{t\_0}\\ \end{array} \end{array} \]
        (FPCore (lambda1 lambda2 phi1 phi2)
         :precision binary64
         (let* ((t_0
                 (-
                  (* (sin phi2) (cos phi1))
                  (* (sin phi1) (cos (- lambda1 lambda2))))))
           (if (<= (- lambda1 lambda2) -2000000.0)
             (atan2 (sin (- lambda1 lambda2)) t_0)
             (if (<= (- lambda1 lambda2) 2e-40)
               (atan2 (* (- lambda1 lambda2) (cos phi2)) t_0)
               (atan2
                (sin
                 (*
                  (* (/ 1.0 (+ lambda2 lambda1)) (- lambda1 lambda2))
                  (+ lambda2 lambda1)))
                t_0)))))
        double code(double lambda1, double lambda2, double phi1, double phi2) {
        	double t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)));
        	double tmp;
        	if ((lambda1 - lambda2) <= -2000000.0) {
        		tmp = atan2(sin((lambda1 - lambda2)), t_0);
        	} else if ((lambda1 - lambda2) <= 2e-40) {
        		tmp = atan2(((lambda1 - lambda2) * cos(phi2)), t_0);
        	} else {
        		tmp = atan2(sin((((1.0 / (lambda2 + lambda1)) * (lambda1 - lambda2)) * (lambda2 + lambda1))), t_0);
        	}
        	return tmp;
        }
        
        real(8) function code(lambda1, lambda2, phi1, phi2)
            real(8), intent (in) :: lambda1
            real(8), intent (in) :: lambda2
            real(8), intent (in) :: phi1
            real(8), intent (in) :: phi2
            real(8) :: t_0
            real(8) :: tmp
            t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)))
            if ((lambda1 - lambda2) <= (-2000000.0d0)) then
                tmp = atan2(sin((lambda1 - lambda2)), t_0)
            else if ((lambda1 - lambda2) <= 2d-40) then
                tmp = atan2(((lambda1 - lambda2) * cos(phi2)), t_0)
            else
                tmp = atan2(sin((((1.0d0 / (lambda2 + lambda1)) * (lambda1 - lambda2)) * (lambda2 + lambda1))), t_0)
            end if
            code = tmp
        end function
        
        public static double code(double lambda1, double lambda2, double phi1, double phi2) {
        	double t_0 = (Math.sin(phi2) * Math.cos(phi1)) - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)));
        	double tmp;
        	if ((lambda1 - lambda2) <= -2000000.0) {
        		tmp = Math.atan2(Math.sin((lambda1 - lambda2)), t_0);
        	} else if ((lambda1 - lambda2) <= 2e-40) {
        		tmp = Math.atan2(((lambda1 - lambda2) * Math.cos(phi2)), t_0);
        	} else {
        		tmp = Math.atan2(Math.sin((((1.0 / (lambda2 + lambda1)) * (lambda1 - lambda2)) * (lambda2 + lambda1))), t_0);
        	}
        	return tmp;
        }
        
        def code(lambda1, lambda2, phi1, phi2):
        	t_0 = (math.sin(phi2) * math.cos(phi1)) - (math.sin(phi1) * math.cos((lambda1 - lambda2)))
        	tmp = 0
        	if (lambda1 - lambda2) <= -2000000.0:
        		tmp = math.atan2(math.sin((lambda1 - lambda2)), t_0)
        	elif (lambda1 - lambda2) <= 2e-40:
        		tmp = math.atan2(((lambda1 - lambda2) * math.cos(phi2)), t_0)
        	else:
        		tmp = math.atan2(math.sin((((1.0 / (lambda2 + lambda1)) * (lambda1 - lambda2)) * (lambda2 + lambda1))), t_0)
        	return tmp
        
        function code(lambda1, lambda2, phi1, phi2)
        	t_0 = Float64(Float64(sin(phi2) * cos(phi1)) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))
        	tmp = 0.0
        	if (Float64(lambda1 - lambda2) <= -2000000.0)
        		tmp = atan(sin(Float64(lambda1 - lambda2)), t_0);
        	elseif (Float64(lambda1 - lambda2) <= 2e-40)
        		tmp = atan(Float64(Float64(lambda1 - lambda2) * cos(phi2)), t_0);
        	else
        		tmp = atan(sin(Float64(Float64(Float64(1.0 / Float64(lambda2 + lambda1)) * Float64(lambda1 - lambda2)) * Float64(lambda2 + lambda1))), t_0);
        	end
        	return tmp
        end
        
        function tmp_2 = code(lambda1, lambda2, phi1, phi2)
        	t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)));
        	tmp = 0.0;
        	if ((lambda1 - lambda2) <= -2000000.0)
        		tmp = atan2(sin((lambda1 - lambda2)), t_0);
        	elseif ((lambda1 - lambda2) <= 2e-40)
        		tmp = atan2(((lambda1 - lambda2) * cos(phi2)), t_0);
        	else
        		tmp = atan2(sin((((1.0 / (lambda2 + lambda1)) * (lambda1 - lambda2)) * (lambda2 + lambda1))), t_0);
        	end
        	tmp_2 = tmp;
        end
        
        code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[N[(lambda1 - lambda2), $MachinePrecision], -2000000.0], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / t$95$0], $MachinePrecision], If[LessEqual[N[(lambda1 - lambda2), $MachinePrecision], 2e-40], N[ArcTan[N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / t$95$0], $MachinePrecision], N[ArcTan[N[Sin[N[(N[(N[(1.0 / N[(lambda2 + lambda1), $MachinePrecision]), $MachinePrecision] * N[(lambda1 - lambda2), $MachinePrecision]), $MachinePrecision] * N[(lambda2 + lambda1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / t$95$0], $MachinePrecision]]]]
        
        \begin{array}{l}
        
        \\
        \begin{array}{l}
        t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
        \mathbf{if}\;\lambda_1 - \lambda_2 \leq -2000000:\\
        \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{t\_0}\\
        
        \mathbf{elif}\;\lambda_1 - \lambda_2 \leq 2 \cdot 10^{-40}:\\
        \;\;\;\;\tan^{-1}_* \frac{\left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0}\\
        
        \mathbf{else}:\\
        \;\;\;\;\tan^{-1}_* \frac{\sin \left(\left(\frac{1}{\lambda_2 + \lambda_1} \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(\lambda_2 + \lambda_1\right)\right)}{t\_0}\\
        
        
        \end{array}
        \end{array}
        
        Derivation
        1. Split input into 3 regimes
        2. if (-.f64 lambda1 lambda2) < -2e6

          1. Initial program 74.9%

            \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. Add Preprocessing
          3. Taylor expanded in phi2 around 0

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          4. Step-by-step derivation
            1. lower-sin.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            2. lower--.f6444.9

              \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          5. Applied rewrites44.9%

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          6. Taylor expanded in phi2 around 0

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          7. Step-by-step derivation
            1. lower-sin.f6445.0

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          8. Applied rewrites45.0%

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

          if -2e6 < (-.f64 lambda1 lambda2) < 1.9999999999999999e-40

          1. Initial program 99.6%

            \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          2. Add Preprocessing
          3. Taylor expanded in phi2 around 0

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          4. Step-by-step derivation
            1. lower-sin.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            2. lower--.f6463.1

              \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          5. Applied rewrites63.1%

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          6. Taylor expanded in phi2 around 0

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          7. Step-by-step derivation
            1. lower-sin.f6461.2

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          8. Applied rewrites61.2%

            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          9. Taylor expanded in lambda1 around 0

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\lambda_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right) + \cos \phi_2 \cdot \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          10. Step-by-step derivation
            1. *-commutativeN/A

              \[\leadsto \tan^{-1}_* \frac{\lambda_1 \cdot \color{blue}{\left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \phi_2\right)} + \cos \phi_2 \cdot \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            2. associate-*r*N/A

              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right) \cdot \cos \phi_2} + \cos \phi_2 \cdot \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            3. *-commutativeN/A

              \[\leadsto \tan^{-1}_* \frac{\left(\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right) \cdot \cos \phi_2 + \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            4. distribute-rgt-outN/A

              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \left(\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right) + \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            5. +-commutativeN/A

              \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\left(\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            6. lower-*.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \left(\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            7. lower-cos.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2} \cdot \left(\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            8. +-commutativeN/A

              \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\left(\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right) + \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            9. *-commutativeN/A

              \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\color{blue}{\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \lambda_1} + \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            10. lower-fma.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\mathsf{fma}\left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right), \lambda_1, \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            11. cos-negN/A

              \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\color{blue}{\cos \lambda_2}, \lambda_1, \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            12. lower-cos.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\color{blue}{\cos \lambda_2}, \lambda_1, \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            13. sin-negN/A

              \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \lambda_1, \color{blue}{\mathsf{neg}\left(\sin \lambda_2\right)}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            14. lower-neg.f64N/A

              \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \lambda_1, \color{blue}{\mathsf{neg}\left(\sin \lambda_2\right)}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            15. lower-sin.f6480.9

              \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \lambda_1, -\color{blue}{\sin \lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          11. Applied rewrites80.9%

            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \lambda_1, -\sin \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          12. Taylor expanded in lambda2 around 0

            \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\lambda_1 + \color{blue}{-1 \cdot \lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
          13. Step-by-step derivation
            1. Applied rewrites80.9%

              \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\lambda_1 - \color{blue}{\lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

            if 1.9999999999999999e-40 < (-.f64 lambda1 lambda2)

            1. Initial program 68.5%

              \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            2. Add Preprocessing
            3. Taylor expanded in phi2 around 0

              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            4. Step-by-step derivation
              1. lower-sin.f64N/A

                \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              2. lower--.f6443.2

                \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            5. Applied rewrites43.2%

              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            6. Taylor expanded in phi2 around 0

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            7. Step-by-step derivation
              1. lower-sin.f6443.4

                \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            8. Applied rewrites43.4%

              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            9. Step-by-step derivation
              1. Applied rewrites43.5%

                \[\leadsto \tan^{-1}_* \frac{\sin \left(\left(\frac{1}{\lambda_2 + \lambda_1} \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(\lambda_2 + \lambda_1\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
            10. Recombined 3 regimes into one program.
            11. Final simplification51.3%

              \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 - \lambda_2 \leq -2000000:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{elif}\;\lambda_1 - \lambda_2 \leq 2 \cdot 10^{-40}:\\ \;\;\;\;\tan^{-1}_* \frac{\left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\left(\frac{1}{\lambda_2 + \lambda_1} \cdot \left(\lambda_1 - \lambda_2\right)\right) \cdot \left(\lambda_2 + \lambda_1\right)\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \end{array} \]
            12. Add Preprocessing

            Alternative 21: 53.0% accurate, 1.3× speedup?

            \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\ t_1 := \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{t\_0}\\ \mathbf{if}\;\lambda_1 - \lambda_2 \leq -2000000:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;\lambda_1 - \lambda_2 \leq 2 \cdot 10^{-40}:\\ \;\;\;\;\tan^{-1}_* \frac{\left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
            (FPCore (lambda1 lambda2 phi1 phi2)
             :precision binary64
             (let* ((t_0
                     (-
                      (* (sin phi2) (cos phi1))
                      (* (sin phi1) (cos (- lambda1 lambda2)))))
                    (t_1 (atan2 (sin (- lambda1 lambda2)) t_0)))
               (if (<= (- lambda1 lambda2) -2000000.0)
                 t_1
                 (if (<= (- lambda1 lambda2) 2e-40)
                   (atan2 (* (- lambda1 lambda2) (cos phi2)) t_0)
                   t_1))))
            double code(double lambda1, double lambda2, double phi1, double phi2) {
            	double t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)));
            	double t_1 = atan2(sin((lambda1 - lambda2)), t_0);
            	double tmp;
            	if ((lambda1 - lambda2) <= -2000000.0) {
            		tmp = t_1;
            	} else if ((lambda1 - lambda2) <= 2e-40) {
            		tmp = atan2(((lambda1 - lambda2) * cos(phi2)), t_0);
            	} else {
            		tmp = t_1;
            	}
            	return tmp;
            }
            
            real(8) function code(lambda1, lambda2, phi1, phi2)
                real(8), intent (in) :: lambda1
                real(8), intent (in) :: lambda2
                real(8), intent (in) :: phi1
                real(8), intent (in) :: phi2
                real(8) :: t_0
                real(8) :: t_1
                real(8) :: tmp
                t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)))
                t_1 = atan2(sin((lambda1 - lambda2)), t_0)
                if ((lambda1 - lambda2) <= (-2000000.0d0)) then
                    tmp = t_1
                else if ((lambda1 - lambda2) <= 2d-40) then
                    tmp = atan2(((lambda1 - lambda2) * cos(phi2)), t_0)
                else
                    tmp = t_1
                end if
                code = tmp
            end function
            
            public static double code(double lambda1, double lambda2, double phi1, double phi2) {
            	double t_0 = (Math.sin(phi2) * Math.cos(phi1)) - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)));
            	double t_1 = Math.atan2(Math.sin((lambda1 - lambda2)), t_0);
            	double tmp;
            	if ((lambda1 - lambda2) <= -2000000.0) {
            		tmp = t_1;
            	} else if ((lambda1 - lambda2) <= 2e-40) {
            		tmp = Math.atan2(((lambda1 - lambda2) * Math.cos(phi2)), t_0);
            	} else {
            		tmp = t_1;
            	}
            	return tmp;
            }
            
            def code(lambda1, lambda2, phi1, phi2):
            	t_0 = (math.sin(phi2) * math.cos(phi1)) - (math.sin(phi1) * math.cos((lambda1 - lambda2)))
            	t_1 = math.atan2(math.sin((lambda1 - lambda2)), t_0)
            	tmp = 0
            	if (lambda1 - lambda2) <= -2000000.0:
            		tmp = t_1
            	elif (lambda1 - lambda2) <= 2e-40:
            		tmp = math.atan2(((lambda1 - lambda2) * math.cos(phi2)), t_0)
            	else:
            		tmp = t_1
            	return tmp
            
            function code(lambda1, lambda2, phi1, phi2)
            	t_0 = Float64(Float64(sin(phi2) * cos(phi1)) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))
            	t_1 = atan(sin(Float64(lambda1 - lambda2)), t_0)
            	tmp = 0.0
            	if (Float64(lambda1 - lambda2) <= -2000000.0)
            		tmp = t_1;
            	elseif (Float64(lambda1 - lambda2) <= 2e-40)
            		tmp = atan(Float64(Float64(lambda1 - lambda2) * cos(phi2)), t_0);
            	else
            		tmp = t_1;
            	end
            	return tmp
            end
            
            function tmp_2 = code(lambda1, lambda2, phi1, phi2)
            	t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)));
            	t_1 = atan2(sin((lambda1 - lambda2)), t_0);
            	tmp = 0.0;
            	if ((lambda1 - lambda2) <= -2000000.0)
            		tmp = t_1;
            	elseif ((lambda1 - lambda2) <= 2e-40)
            		tmp = atan2(((lambda1 - lambda2) * cos(phi2)), t_0);
            	else
            		tmp = t_1;
            	end
            	tmp_2 = tmp;
            end
            
            code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / t$95$0], $MachinePrecision]}, If[LessEqual[N[(lambda1 - lambda2), $MachinePrecision], -2000000.0], t$95$1, If[LessEqual[N[(lambda1 - lambda2), $MachinePrecision], 2e-40], N[ArcTan[N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / t$95$0], $MachinePrecision], t$95$1]]]]
            
            \begin{array}{l}
            
            \\
            \begin{array}{l}
            t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
            t_1 := \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{t\_0}\\
            \mathbf{if}\;\lambda_1 - \lambda_2 \leq -2000000:\\
            \;\;\;\;t\_1\\
            
            \mathbf{elif}\;\lambda_1 - \lambda_2 \leq 2 \cdot 10^{-40}:\\
            \;\;\;\;\tan^{-1}_* \frac{\left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0}\\
            
            \mathbf{else}:\\
            \;\;\;\;t\_1\\
            
            
            \end{array}
            \end{array}
            
            Derivation
            1. Split input into 2 regimes
            2. if (-.f64 lambda1 lambda2) < -2e6 or 1.9999999999999999e-40 < (-.f64 lambda1 lambda2)

              1. Initial program 71.7%

                \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              2. Add Preprocessing
              3. Taylor expanded in phi2 around 0

                \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              4. Step-by-step derivation
                1. lower-sin.f64N/A

                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                2. lower--.f6444.0

                  \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              5. Applied rewrites44.0%

                \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              6. Taylor expanded in phi2 around 0

                \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              7. Step-by-step derivation
                1. lower-sin.f6444.2

                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              8. Applied rewrites44.2%

                \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

              if -2e6 < (-.f64 lambda1 lambda2) < 1.9999999999999999e-40

              1. Initial program 99.6%

                \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              2. Add Preprocessing
              3. Taylor expanded in phi2 around 0

                \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              4. Step-by-step derivation
                1. lower-sin.f64N/A

                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                2. lower--.f6463.1

                  \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              5. Applied rewrites63.1%

                \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              6. Taylor expanded in phi2 around 0

                \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              7. Step-by-step derivation
                1. lower-sin.f6461.2

                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              8. Applied rewrites61.2%

                \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              9. Taylor expanded in lambda1 around 0

                \[\leadsto \tan^{-1}_* \frac{\color{blue}{\lambda_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right) + \cos \phi_2 \cdot \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              10. Step-by-step derivation
                1. *-commutativeN/A

                  \[\leadsto \tan^{-1}_* \frac{\lambda_1 \cdot \color{blue}{\left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \phi_2\right)} + \cos \phi_2 \cdot \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                2. associate-*r*N/A

                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right) \cdot \cos \phi_2} + \cos \phi_2 \cdot \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                3. *-commutativeN/A

                  \[\leadsto \tan^{-1}_* \frac{\left(\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right) \cdot \cos \phi_2 + \color{blue}{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \cos \phi_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                4. distribute-rgt-outN/A

                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \left(\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right) + \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                5. +-commutativeN/A

                  \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\left(\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                6. lower-*.f64N/A

                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \left(\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                7. lower-cos.f64N/A

                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2} \cdot \left(\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                8. +-commutativeN/A

                  \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\left(\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right) + \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                9. *-commutativeN/A

                  \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\color{blue}{\cos \left(\mathsf{neg}\left(\lambda_2\right)\right) \cdot \lambda_1} + \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                10. lower-fma.f64N/A

                  \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \color{blue}{\mathsf{fma}\left(\cos \left(\mathsf{neg}\left(\lambda_2\right)\right), \lambda_1, \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                11. cos-negN/A

                  \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\color{blue}{\cos \lambda_2}, \lambda_1, \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                12. lower-cos.f64N/A

                  \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\color{blue}{\cos \lambda_2}, \lambda_1, \sin \left(\mathsf{neg}\left(\lambda_2\right)\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                13. sin-negN/A

                  \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \lambda_1, \color{blue}{\mathsf{neg}\left(\sin \lambda_2\right)}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                14. lower-neg.f64N/A

                  \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \lambda_1, \color{blue}{\mathsf{neg}\left(\sin \lambda_2\right)}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                15. lower-sin.f6480.9

                  \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \lambda_1, -\color{blue}{\sin \lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              11. Applied rewrites80.9%

                \[\leadsto \tan^{-1}_* \frac{\color{blue}{\cos \phi_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \lambda_1, -\sin \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              12. Taylor expanded in lambda2 around 0

                \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\lambda_1 + \color{blue}{-1 \cdot \lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              13. Step-by-step derivation
                1. Applied rewrites80.9%

                  \[\leadsto \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\lambda_1 - \color{blue}{\lambda_2}\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
              14. Recombined 2 regimes into one program.
              15. Final simplification51.3%

                \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 - \lambda_2 \leq -2000000:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{elif}\;\lambda_1 - \lambda_2 \leq 2 \cdot 10^{-40}:\\ \;\;\;\;\tan^{-1}_* \frac{\left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \end{array} \]
              16. Add Preprocessing

              Alternative 22: 48.8% accurate, 1.3× speedup?

              \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \left(\lambda_1 - \lambda_2\right)\\ t_1 := \sin \phi_2 \cdot \cos \phi_1\\ \mathbf{if}\;\lambda_2 \leq -1.25 \cdot 10^{+22}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{t\_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{elif}\;\lambda_2 \leq 0.0046:\\ \;\;\;\;\tan^{-1}_* \frac{t\_0}{t\_1 - \sin \phi_1 \cdot \cos \lambda_1}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t\_0}{t\_1 - \sin \phi_1 \cdot \cos \lambda_2}\\ \end{array} \end{array} \]
              (FPCore (lambda1 lambda2 phi1 phi2)
               :precision binary64
               (let* ((t_0 (sin (- lambda1 lambda2))) (t_1 (* (sin phi2) (cos phi1))))
                 (if (<= lambda2 -1.25e+22)
                   (atan2 (sin (- lambda2)) (- t_1 (* (sin phi1) (cos (- lambda1 lambda2)))))
                   (if (<= lambda2 0.0046)
                     (atan2 t_0 (- t_1 (* (sin phi1) (cos lambda1))))
                     (atan2 t_0 (- t_1 (* (sin phi1) (cos lambda2))))))))
              double code(double lambda1, double lambda2, double phi1, double phi2) {
              	double t_0 = sin((lambda1 - lambda2));
              	double t_1 = sin(phi2) * cos(phi1);
              	double tmp;
              	if (lambda2 <= -1.25e+22) {
              		tmp = atan2(sin(-lambda2), (t_1 - (sin(phi1) * cos((lambda1 - lambda2)))));
              	} else if (lambda2 <= 0.0046) {
              		tmp = atan2(t_0, (t_1 - (sin(phi1) * cos(lambda1))));
              	} else {
              		tmp = atan2(t_0, (t_1 - (sin(phi1) * cos(lambda2))));
              	}
              	return tmp;
              }
              
              real(8) function code(lambda1, lambda2, phi1, phi2)
                  real(8), intent (in) :: lambda1
                  real(8), intent (in) :: lambda2
                  real(8), intent (in) :: phi1
                  real(8), intent (in) :: phi2
                  real(8) :: t_0
                  real(8) :: t_1
                  real(8) :: tmp
                  t_0 = sin((lambda1 - lambda2))
                  t_1 = sin(phi2) * cos(phi1)
                  if (lambda2 <= (-1.25d+22)) then
                      tmp = atan2(sin(-lambda2), (t_1 - (sin(phi1) * cos((lambda1 - lambda2)))))
                  else if (lambda2 <= 0.0046d0) then
                      tmp = atan2(t_0, (t_1 - (sin(phi1) * cos(lambda1))))
                  else
                      tmp = atan2(t_0, (t_1 - (sin(phi1) * cos(lambda2))))
                  end if
                  code = tmp
              end function
              
              public static double code(double lambda1, double lambda2, double phi1, double phi2) {
              	double t_0 = Math.sin((lambda1 - lambda2));
              	double t_1 = Math.sin(phi2) * Math.cos(phi1);
              	double tmp;
              	if (lambda2 <= -1.25e+22) {
              		tmp = Math.atan2(Math.sin(-lambda2), (t_1 - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)))));
              	} else if (lambda2 <= 0.0046) {
              		tmp = Math.atan2(t_0, (t_1 - (Math.sin(phi1) * Math.cos(lambda1))));
              	} else {
              		tmp = Math.atan2(t_0, (t_1 - (Math.sin(phi1) * Math.cos(lambda2))));
              	}
              	return tmp;
              }
              
              def code(lambda1, lambda2, phi1, phi2):
              	t_0 = math.sin((lambda1 - lambda2))
              	t_1 = math.sin(phi2) * math.cos(phi1)
              	tmp = 0
              	if lambda2 <= -1.25e+22:
              		tmp = math.atan2(math.sin(-lambda2), (t_1 - (math.sin(phi1) * math.cos((lambda1 - lambda2)))))
              	elif lambda2 <= 0.0046:
              		tmp = math.atan2(t_0, (t_1 - (math.sin(phi1) * math.cos(lambda1))))
              	else:
              		tmp = math.atan2(t_0, (t_1 - (math.sin(phi1) * math.cos(lambda2))))
              	return tmp
              
              function code(lambda1, lambda2, phi1, phi2)
              	t_0 = sin(Float64(lambda1 - lambda2))
              	t_1 = Float64(sin(phi2) * cos(phi1))
              	tmp = 0.0
              	if (lambda2 <= -1.25e+22)
              		tmp = atan(sin(Float64(-lambda2)), Float64(t_1 - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2)))));
              	elseif (lambda2 <= 0.0046)
              		tmp = atan(t_0, Float64(t_1 - Float64(sin(phi1) * cos(lambda1))));
              	else
              		tmp = atan(t_0, Float64(t_1 - Float64(sin(phi1) * cos(lambda2))));
              	end
              	return tmp
              end
              
              function tmp_2 = code(lambda1, lambda2, phi1, phi2)
              	t_0 = sin((lambda1 - lambda2));
              	t_1 = sin(phi2) * cos(phi1);
              	tmp = 0.0;
              	if (lambda2 <= -1.25e+22)
              		tmp = atan2(sin(-lambda2), (t_1 - (sin(phi1) * cos((lambda1 - lambda2)))));
              	elseif (lambda2 <= 0.0046)
              		tmp = atan2(t_0, (t_1 - (sin(phi1) * cos(lambda1))));
              	else
              		tmp = atan2(t_0, (t_1 - (sin(phi1) * cos(lambda2))));
              	end
              	tmp_2 = tmp;
              end
              
              code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda2, -1.25e+22], N[ArcTan[N[Sin[(-lambda2)], $MachinePrecision] / N[(t$95$1 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda2, 0.0046], N[ArcTan[t$95$0 / N[(t$95$1 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$0 / N[(t$95$1 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]]
              
              \begin{array}{l}
              
              \\
              \begin{array}{l}
              t_0 := \sin \left(\lambda_1 - \lambda_2\right)\\
              t_1 := \sin \phi_2 \cdot \cos \phi_1\\
              \mathbf{if}\;\lambda_2 \leq -1.25 \cdot 10^{+22}:\\
              \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{t\_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
              
              \mathbf{elif}\;\lambda_2 \leq 0.0046:\\
              \;\;\;\;\tan^{-1}_* \frac{t\_0}{t\_1 - \sin \phi_1 \cdot \cos \lambda_1}\\
              
              \mathbf{else}:\\
              \;\;\;\;\tan^{-1}_* \frac{t\_0}{t\_1 - \sin \phi_1 \cdot \cos \lambda_2}\\
              
              
              \end{array}
              \end{array}
              
              Derivation
              1. Split input into 3 regimes
              2. if lambda2 < -1.2499999999999999e22

                1. Initial program 56.8%

                  \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                2. Add Preprocessing
                3. Taylor expanded in phi2 around 0

                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                4. Step-by-step derivation
                  1. lower-sin.f64N/A

                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  2. lower--.f6435.0

                    \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                5. Applied rewrites35.0%

                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                6. Taylor expanded in phi2 around 0

                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                7. Step-by-step derivation
                  1. lower-sin.f6435.4

                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                8. Applied rewrites35.4%

                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                9. Taylor expanded in lambda1 around 0

                  \[\leadsto \tan^{-1}_* \frac{\sin \left(-1 \cdot \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                10. Step-by-step derivation
                  1. Applied rewrites42.6%

                    \[\leadsto \tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

                  if -1.2499999999999999e22 < lambda2 < 0.0045999999999999999

                  1. Initial program 96.2%

                    \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  2. Add Preprocessing
                  3. Taylor expanded in phi2 around 0

                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  4. Step-by-step derivation
                    1. lower-sin.f64N/A

                      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    2. lower--.f6458.6

                      \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  5. Applied rewrites58.6%

                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  6. Taylor expanded in phi2 around 0

                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  7. Step-by-step derivation
                    1. lower-sin.f6457.9

                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  8. Applied rewrites57.9%

                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  9. Taylor expanded in lambda2 around 0

                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_1}} \]
                  10. Step-by-step derivation
                    1. lower-cos.f6457.9

                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_1}} \]
                  11. Applied rewrites57.9%

                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_1}} \]

                  if 0.0045999999999999999 < lambda2

                  1. Initial program 66.9%

                    \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  2. Add Preprocessing
                  3. Taylor expanded in phi2 around 0

                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  4. Step-by-step derivation
                    1. lower-sin.f64N/A

                      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    2. lower--.f6442.9

                      \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  5. Applied rewrites42.9%

                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  6. Taylor expanded in phi2 around 0

                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  7. Step-by-step derivation
                    1. lower-sin.f6442.9

                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  8. Applied rewrites42.9%

                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  9. Taylor expanded in lambda1 around 0

                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \left(\mathsf{neg}\left(\lambda_2\right)\right)}} \]
                  10. Step-by-step derivation
                    1. cos-negN/A

                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_2}} \]
                    2. lower-cos.f6442.8

                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_2}} \]
                  11. Applied rewrites42.8%

                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_2}} \]
                11. Recombined 3 regimes into one program.
                12. Final simplification49.3%

                  \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_2 \leq -1.25 \cdot 10^{+22}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{elif}\;\lambda_2 \leq 0.0046:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \lambda_1}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \lambda_2}\\ \end{array} \]
                13. Add Preprocessing

                Alternative 23: 49.1% accurate, 1.3× speedup?

                \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ t_1 := \tan^{-1}_* \frac{\sin \lambda_1}{t\_0 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{if}\;\lambda_1 \leq -0.72:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;\lambda_1 \leq 0.012:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{t\_0 - \sin \phi_1 \cdot \cos \lambda_2}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
                (FPCore (lambda1 lambda2 phi1 phi2)
                 :precision binary64
                 (let* ((t_0 (* (sin phi2) (cos phi1)))
                        (t_1
                         (atan2
                          (sin lambda1)
                          (- t_0 (* (sin phi1) (cos (- lambda1 lambda2)))))))
                   (if (<= lambda1 -0.72)
                     t_1
                     (if (<= lambda1 0.012)
                       (atan2 (sin (- lambda1 lambda2)) (- t_0 (* (sin phi1) (cos lambda2))))
                       t_1))))
                double code(double lambda1, double lambda2, double phi1, double phi2) {
                	double t_0 = sin(phi2) * cos(phi1);
                	double t_1 = atan2(sin(lambda1), (t_0 - (sin(phi1) * cos((lambda1 - lambda2)))));
                	double tmp;
                	if (lambda1 <= -0.72) {
                		tmp = t_1;
                	} else if (lambda1 <= 0.012) {
                		tmp = atan2(sin((lambda1 - lambda2)), (t_0 - (sin(phi1) * cos(lambda2))));
                	} else {
                		tmp = t_1;
                	}
                	return tmp;
                }
                
                real(8) function code(lambda1, lambda2, phi1, phi2)
                    real(8), intent (in) :: lambda1
                    real(8), intent (in) :: lambda2
                    real(8), intent (in) :: phi1
                    real(8), intent (in) :: phi2
                    real(8) :: t_0
                    real(8) :: t_1
                    real(8) :: tmp
                    t_0 = sin(phi2) * cos(phi1)
                    t_1 = atan2(sin(lambda1), (t_0 - (sin(phi1) * cos((lambda1 - lambda2)))))
                    if (lambda1 <= (-0.72d0)) then
                        tmp = t_1
                    else if (lambda1 <= 0.012d0) then
                        tmp = atan2(sin((lambda1 - lambda2)), (t_0 - (sin(phi1) * cos(lambda2))))
                    else
                        tmp = t_1
                    end if
                    code = tmp
                end function
                
                public static double code(double lambda1, double lambda2, double phi1, double phi2) {
                	double t_0 = Math.sin(phi2) * Math.cos(phi1);
                	double t_1 = Math.atan2(Math.sin(lambda1), (t_0 - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)))));
                	double tmp;
                	if (lambda1 <= -0.72) {
                		tmp = t_1;
                	} else if (lambda1 <= 0.012) {
                		tmp = Math.atan2(Math.sin((lambda1 - lambda2)), (t_0 - (Math.sin(phi1) * Math.cos(lambda2))));
                	} else {
                		tmp = t_1;
                	}
                	return tmp;
                }
                
                def code(lambda1, lambda2, phi1, phi2):
                	t_0 = math.sin(phi2) * math.cos(phi1)
                	t_1 = math.atan2(math.sin(lambda1), (t_0 - (math.sin(phi1) * math.cos((lambda1 - lambda2)))))
                	tmp = 0
                	if lambda1 <= -0.72:
                		tmp = t_1
                	elif lambda1 <= 0.012:
                		tmp = math.atan2(math.sin((lambda1 - lambda2)), (t_0 - (math.sin(phi1) * math.cos(lambda2))))
                	else:
                		tmp = t_1
                	return tmp
                
                function code(lambda1, lambda2, phi1, phi2)
                	t_0 = Float64(sin(phi2) * cos(phi1))
                	t_1 = atan(sin(lambda1), Float64(t_0 - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2)))))
                	tmp = 0.0
                	if (lambda1 <= -0.72)
                		tmp = t_1;
                	elseif (lambda1 <= 0.012)
                		tmp = atan(sin(Float64(lambda1 - lambda2)), Float64(t_0 - Float64(sin(phi1) * cos(lambda2))));
                	else
                		tmp = t_1;
                	end
                	return tmp
                end
                
                function tmp_2 = code(lambda1, lambda2, phi1, phi2)
                	t_0 = sin(phi2) * cos(phi1);
                	t_1 = atan2(sin(lambda1), (t_0 - (sin(phi1) * cos((lambda1 - lambda2)))));
                	tmp = 0.0;
                	if (lambda1 <= -0.72)
                		tmp = t_1;
                	elseif (lambda1 <= 0.012)
                		tmp = atan2(sin((lambda1 - lambda2)), (t_0 - (sin(phi1) * cos(lambda2))));
                	else
                		tmp = t_1;
                	end
                	tmp_2 = tmp;
                end
                
                code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[Sin[lambda1], $MachinePrecision] / N[(t$95$0 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda1, -0.72], t$95$1, If[LessEqual[lambda1, 0.012], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(t$95$0 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$1]]]]
                
                \begin{array}{l}
                
                \\
                \begin{array}{l}
                t_0 := \sin \phi_2 \cdot \cos \phi_1\\
                t_1 := \tan^{-1}_* \frac{\sin \lambda_1}{t\_0 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
                \mathbf{if}\;\lambda_1 \leq -0.72:\\
                \;\;\;\;t\_1\\
                
                \mathbf{elif}\;\lambda_1 \leq 0.012:\\
                \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{t\_0 - \sin \phi_1 \cdot \cos \lambda_2}\\
                
                \mathbf{else}:\\
                \;\;\;\;t\_1\\
                
                
                \end{array}
                \end{array}
                
                Derivation
                1. Split input into 2 regimes
                2. if lambda1 < -0.71999999999999997 or 0.012 < lambda1

                  1. Initial program 54.5%

                    \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  2. Add Preprocessing
                  3. Taylor expanded in phi2 around 0

                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  4. Step-by-step derivation
                    1. lower-sin.f64N/A

                      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    2. lower--.f6436.2

                      \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  5. Applied rewrites36.2%

                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  6. Taylor expanded in phi2 around 0

                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  7. Step-by-step derivation
                    1. lower-sin.f6436.2

                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  8. Applied rewrites36.2%

                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  9. Taylor expanded in lambda2 around 0

                    \[\leadsto \tan^{-1}_* \frac{\sin \lambda_1}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                  10. Step-by-step derivation
                    1. Applied rewrites37.1%

                      \[\leadsto \tan^{-1}_* \frac{\sin \lambda_1}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

                    if -0.71999999999999997 < lambda1 < 0.012

                    1. Initial program 98.6%

                      \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    2. Add Preprocessing
                    3. Taylor expanded in phi2 around 0

                      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    4. Step-by-step derivation
                      1. lower-sin.f64N/A

                        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                      2. lower--.f6458.6

                        \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    5. Applied rewrites58.6%

                      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    6. Taylor expanded in phi2 around 0

                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    7. Step-by-step derivation
                      1. lower-sin.f6458.2

                        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    8. Applied rewrites58.2%

                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    9. Taylor expanded in lambda1 around 0

                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \left(\mathsf{neg}\left(\lambda_2\right)\right)}} \]
                    10. Step-by-step derivation
                      1. cos-negN/A

                        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_2}} \]
                      2. lower-cos.f6458.2

                        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_2}} \]
                    11. Applied rewrites58.2%

                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_2}} \]
                  11. Recombined 2 regimes into one program.
                  12. Final simplification47.9%

                    \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 \leq -0.72:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{elif}\;\lambda_1 \leq 0.012:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \lambda_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \end{array} \]
                  13. Add Preprocessing

                  Alternative 24: 39.7% accurate, 1.3× speedup?

                  \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\ t_1 := \tan^{-1}_* \frac{\sin \lambda_1}{t\_0}\\ \mathbf{if}\;\lambda_1 \leq -7.8 \cdot 10^{-7}:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;\lambda_1 \leq 5.4 \cdot 10^{-33}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.16666666666666666, \lambda_2, -0.5 \cdot \lambda_1\right), \lambda_2, -1\right), \lambda_2, \lambda_1\right)}{t\_0}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
                  (FPCore (lambda1 lambda2 phi1 phi2)
                   :precision binary64
                   (let* ((t_0
                           (-
                            (* (sin phi2) (cos phi1))
                            (* (sin phi1) (cos (- lambda1 lambda2)))))
                          (t_1 (atan2 (sin lambda1) t_0)))
                     (if (<= lambda1 -7.8e-7)
                       t_1
                       (if (<= lambda1 5.4e-33)
                         (atan2
                          (fma
                           (fma (fma 0.16666666666666666 lambda2 (* -0.5 lambda1)) lambda2 -1.0)
                           lambda2
                           lambda1)
                          t_0)
                         t_1))))
                  double code(double lambda1, double lambda2, double phi1, double phi2) {
                  	double t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)));
                  	double t_1 = atan2(sin(lambda1), t_0);
                  	double tmp;
                  	if (lambda1 <= -7.8e-7) {
                  		tmp = t_1;
                  	} else if (lambda1 <= 5.4e-33) {
                  		tmp = atan2(fma(fma(fma(0.16666666666666666, lambda2, (-0.5 * lambda1)), lambda2, -1.0), lambda2, lambda1), t_0);
                  	} else {
                  		tmp = t_1;
                  	}
                  	return tmp;
                  }
                  
                  function code(lambda1, lambda2, phi1, phi2)
                  	t_0 = Float64(Float64(sin(phi2) * cos(phi1)) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))
                  	t_1 = atan(sin(lambda1), t_0)
                  	tmp = 0.0
                  	if (lambda1 <= -7.8e-7)
                  		tmp = t_1;
                  	elseif (lambda1 <= 5.4e-33)
                  		tmp = atan(fma(fma(fma(0.16666666666666666, lambda2, Float64(-0.5 * lambda1)), lambda2, -1.0), lambda2, lambda1), t_0);
                  	else
                  		tmp = t_1;
                  	end
                  	return tmp
                  end
                  
                  code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[Sin[lambda1], $MachinePrecision] / t$95$0], $MachinePrecision]}, If[LessEqual[lambda1, -7.8e-7], t$95$1, If[LessEqual[lambda1, 5.4e-33], N[ArcTan[N[(N[(N[(0.16666666666666666 * lambda2 + N[(-0.5 * lambda1), $MachinePrecision]), $MachinePrecision] * lambda2 + -1.0), $MachinePrecision] * lambda2 + lambda1), $MachinePrecision] / t$95$0], $MachinePrecision], t$95$1]]]]
                  
                  \begin{array}{l}
                  
                  \\
                  \begin{array}{l}
                  t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
                  t_1 := \tan^{-1}_* \frac{\sin \lambda_1}{t\_0}\\
                  \mathbf{if}\;\lambda_1 \leq -7.8 \cdot 10^{-7}:\\
                  \;\;\;\;t\_1\\
                  
                  \mathbf{elif}\;\lambda_1 \leq 5.4 \cdot 10^{-33}:\\
                  \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.16666666666666666, \lambda_2, -0.5 \cdot \lambda_1\right), \lambda_2, -1\right), \lambda_2, \lambda_1\right)}{t\_0}\\
                  
                  \mathbf{else}:\\
                  \;\;\;\;t\_1\\
                  
                  
                  \end{array}
                  \end{array}
                  
                  Derivation
                  1. Split input into 2 regimes
                  2. if lambda1 < -7.80000000000000049e-7 or 5.4000000000000002e-33 < lambda1

                    1. Initial program 55.7%

                      \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    2. Add Preprocessing
                    3. Taylor expanded in phi2 around 0

                      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    4. Step-by-step derivation
                      1. lower-sin.f64N/A

                        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                      2. lower--.f6436.6

                        \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    5. Applied rewrites36.6%

                      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    6. Taylor expanded in phi2 around 0

                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    7. Step-by-step derivation
                      1. lower-sin.f6436.6

                        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    8. Applied rewrites36.6%

                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    9. Taylor expanded in lambda2 around 0

                      \[\leadsto \tan^{-1}_* \frac{\sin \lambda_1}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                    10. Step-by-step derivation
                      1. Applied rewrites36.1%

                        \[\leadsto \tan^{-1}_* \frac{\sin \lambda_1}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

                      if -7.80000000000000049e-7 < lambda1 < 5.4000000000000002e-33

                      1. Initial program 99.5%

                        \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                      2. Add Preprocessing
                      3. Taylor expanded in phi2 around 0

                        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                      4. Step-by-step derivation
                        1. lower-sin.f64N/A

                          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                        2. lower--.f6459.3

                          \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                      5. Applied rewrites59.3%

                        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                      6. Taylor expanded in phi2 around 0

                        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                      7. Step-by-step derivation
                        1. lower-sin.f6458.9

                          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                      8. Applied rewrites58.9%

                        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                      9. Taylor expanded in lambda1 around 0

                        \[\leadsto \tan^{-1}_* \frac{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \color{blue}{\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                      10. Step-by-step derivation
                        1. Applied rewrites58.9%

                          \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\cos \lambda_2, \color{blue}{\lambda_1}, -\sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                        2. Taylor expanded in lambda2 around 0

                          \[\leadsto \tan^{-1}_* \frac{\lambda_1 + \lambda_2 \cdot \color{blue}{\left(\lambda_2 \cdot \left(\frac{-1}{2} \cdot \lambda_1 + \frac{1}{6} \cdot \lambda_2\right) - 1\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                        3. Step-by-step derivation
                          1. Applied rewrites39.7%

                            \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.16666666666666666, \lambda_2, -0.5 \cdot \lambda_1\right), \lambda_2, -1\right), \lambda_2, \lambda_1\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                        4. Recombined 2 regimes into one program.
                        5. Final simplification37.8%

                          \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 \leq -7.8 \cdot 10^{-7}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{elif}\;\lambda_1 \leq 5.4 \cdot 10^{-33}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.16666666666666666, \lambda_2, -0.5 \cdot \lambda_1\right), \lambda_2, -1\right), \lambda_2, \lambda_1\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \end{array} \]
                        6. Add Preprocessing

                        Alternative 25: 39.7% accurate, 1.3× speedup?

                        \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1\\ t_1 := \tan^{-1}_* \frac{\sin \lambda_1}{t\_0 - \sin \phi_1 \cdot \cos \lambda_1}\\ \mathbf{if}\;\lambda_1 \leq -7.8 \cdot 10^{-7}:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;\lambda_1 \leq 5.4 \cdot 10^{-33}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.16666666666666666, \lambda_2, -0.5 \cdot \lambda_1\right), \lambda_2, -1\right), \lambda_2, \lambda_1\right)}{t\_0 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
                        (FPCore (lambda1 lambda2 phi1 phi2)
                         :precision binary64
                         (let* ((t_0 (* (sin phi2) (cos phi1)))
                                (t_1 (atan2 (sin lambda1) (- t_0 (* (sin phi1) (cos lambda1))))))
                           (if (<= lambda1 -7.8e-7)
                             t_1
                             (if (<= lambda1 5.4e-33)
                               (atan2
                                (fma
                                 (fma (fma 0.16666666666666666 lambda2 (* -0.5 lambda1)) lambda2 -1.0)
                                 lambda2
                                 lambda1)
                                (- t_0 (* (sin phi1) (cos (- lambda1 lambda2)))))
                               t_1))))
                        double code(double lambda1, double lambda2, double phi1, double phi2) {
                        	double t_0 = sin(phi2) * cos(phi1);
                        	double t_1 = atan2(sin(lambda1), (t_0 - (sin(phi1) * cos(lambda1))));
                        	double tmp;
                        	if (lambda1 <= -7.8e-7) {
                        		tmp = t_1;
                        	} else if (lambda1 <= 5.4e-33) {
                        		tmp = atan2(fma(fma(fma(0.16666666666666666, lambda2, (-0.5 * lambda1)), lambda2, -1.0), lambda2, lambda1), (t_0 - (sin(phi1) * cos((lambda1 - lambda2)))));
                        	} else {
                        		tmp = t_1;
                        	}
                        	return tmp;
                        }
                        
                        function code(lambda1, lambda2, phi1, phi2)
                        	t_0 = Float64(sin(phi2) * cos(phi1))
                        	t_1 = atan(sin(lambda1), Float64(t_0 - Float64(sin(phi1) * cos(lambda1))))
                        	tmp = 0.0
                        	if (lambda1 <= -7.8e-7)
                        		tmp = t_1;
                        	elseif (lambda1 <= 5.4e-33)
                        		tmp = atan(fma(fma(fma(0.16666666666666666, lambda2, Float64(-0.5 * lambda1)), lambda2, -1.0), lambda2, lambda1), Float64(t_0 - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2)))));
                        	else
                        		tmp = t_1;
                        	end
                        	return tmp
                        end
                        
                        code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[Sin[lambda1], $MachinePrecision] / N[(t$95$0 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda1, -7.8e-7], t$95$1, If[LessEqual[lambda1, 5.4e-33], N[ArcTan[N[(N[(N[(0.16666666666666666 * lambda2 + N[(-0.5 * lambda1), $MachinePrecision]), $MachinePrecision] * lambda2 + -1.0), $MachinePrecision] * lambda2 + lambda1), $MachinePrecision] / N[(t$95$0 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$1]]]]
                        
                        \begin{array}{l}
                        
                        \\
                        \begin{array}{l}
                        t_0 := \sin \phi_2 \cdot \cos \phi_1\\
                        t_1 := \tan^{-1}_* \frac{\sin \lambda_1}{t\_0 - \sin \phi_1 \cdot \cos \lambda_1}\\
                        \mathbf{if}\;\lambda_1 \leq -7.8 \cdot 10^{-7}:\\
                        \;\;\;\;t\_1\\
                        
                        \mathbf{elif}\;\lambda_1 \leq 5.4 \cdot 10^{-33}:\\
                        \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.16666666666666666, \lambda_2, -0.5 \cdot \lambda_1\right), \lambda_2, -1\right), \lambda_2, \lambda_1\right)}{t\_0 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
                        
                        \mathbf{else}:\\
                        \;\;\;\;t\_1\\
                        
                        
                        \end{array}
                        \end{array}
                        
                        Derivation
                        1. Split input into 2 regimes
                        2. if lambda1 < -7.80000000000000049e-7 or 5.4000000000000002e-33 < lambda1

                          1. Initial program 55.7%

                            \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                          2. Add Preprocessing
                          3. Taylor expanded in phi2 around 0

                            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                          4. Step-by-step derivation
                            1. lower-sin.f64N/A

                              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                            2. lower--.f6436.6

                              \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                          5. Applied rewrites36.6%

                            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                          6. Taylor expanded in phi2 around 0

                            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                          7. Step-by-step derivation
                            1. lower-sin.f6436.6

                              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                          8. Applied rewrites36.6%

                            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                          9. Taylor expanded in lambda2 around 0

                            \[\leadsto \tan^{-1}_* \frac{\sin \lambda_1}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                          10. Step-by-step derivation
                            1. Applied rewrites36.1%

                              \[\leadsto \tan^{-1}_* \frac{\sin \lambda_1}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                            2. Taylor expanded in lambda2 around 0

                              \[\leadsto \tan^{-1}_* \frac{\sin \lambda_1}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_1}} \]
                            3. Step-by-step derivation
                              1. lower-cos.f6436.0

                                \[\leadsto \tan^{-1}_* \frac{\sin \lambda_1}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_1}} \]
                            4. Applied rewrites36.0%

                              \[\leadsto \tan^{-1}_* \frac{\sin \lambda_1}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_1}} \]

                            if -7.80000000000000049e-7 < lambda1 < 5.4000000000000002e-33

                            1. Initial program 99.5%

                              \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                            2. Add Preprocessing
                            3. Taylor expanded in phi2 around 0

                              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                            4. Step-by-step derivation
                              1. lower-sin.f64N/A

                                \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                              2. lower--.f6459.3

                                \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                            5. Applied rewrites59.3%

                              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                            6. Taylor expanded in phi2 around 0

                              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                            7. Step-by-step derivation
                              1. lower-sin.f6458.9

                                \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                            8. Applied rewrites58.9%

                              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                            9. Taylor expanded in lambda1 around 0

                              \[\leadsto \tan^{-1}_* \frac{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \color{blue}{\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                            10. Step-by-step derivation
                              1. Applied rewrites58.9%

                                \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\cos \lambda_2, \color{blue}{\lambda_1}, -\sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                              2. Taylor expanded in lambda2 around 0

                                \[\leadsto \tan^{-1}_* \frac{\lambda_1 + \lambda_2 \cdot \color{blue}{\left(\lambda_2 \cdot \left(\frac{-1}{2} \cdot \lambda_1 + \frac{1}{6} \cdot \lambda_2\right) - 1\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                              3. Step-by-step derivation
                                1. Applied rewrites39.7%

                                  \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.16666666666666666, \lambda_2, -0.5 \cdot \lambda_1\right), \lambda_2, -1\right), \lambda_2, \lambda_1\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                              4. Recombined 2 regimes into one program.
                              5. Final simplification37.8%

                                \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 \leq -7.8 \cdot 10^{-7}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \lambda_1}\\ \mathbf{elif}\;\lambda_1 \leq 5.4 \cdot 10^{-33}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.16666666666666666, \lambda_2, -0.5 \cdot \lambda_1\right), \lambda_2, -1\right), \lambda_2, \lambda_1\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \lambda_1}\\ \end{array} \]
                              6. Add Preprocessing

                              Alternative 26: 49.0% accurate, 1.3× speedup?

                              \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\lambda_2 \leq -3.8 \cdot 10^{+72}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{t\_0}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{t\_0}\\ \end{array} \end{array} \]
                              (FPCore (lambda1 lambda2 phi1 phi2)
                               :precision binary64
                               (let* ((t_0
                                       (-
                                        (* (sin phi2) (cos phi1))
                                        (* (sin phi1) (cos (- lambda1 lambda2))))))
                                 (if (<= lambda2 -3.8e+72)
                                   (atan2 (sin (- lambda2)) t_0)
                                   (atan2 (sin (- lambda1 lambda2)) t_0))))
                              double code(double lambda1, double lambda2, double phi1, double phi2) {
                              	double t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)));
                              	double tmp;
                              	if (lambda2 <= -3.8e+72) {
                              		tmp = atan2(sin(-lambda2), t_0);
                              	} else {
                              		tmp = atan2(sin((lambda1 - lambda2)), t_0);
                              	}
                              	return tmp;
                              }
                              
                              real(8) function code(lambda1, lambda2, phi1, phi2)
                                  real(8), intent (in) :: lambda1
                                  real(8), intent (in) :: lambda2
                                  real(8), intent (in) :: phi1
                                  real(8), intent (in) :: phi2
                                  real(8) :: t_0
                                  real(8) :: tmp
                                  t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)))
                                  if (lambda2 <= (-3.8d+72)) then
                                      tmp = atan2(sin(-lambda2), t_0)
                                  else
                                      tmp = atan2(sin((lambda1 - lambda2)), t_0)
                                  end if
                                  code = tmp
                              end function
                              
                              public static double code(double lambda1, double lambda2, double phi1, double phi2) {
                              	double t_0 = (Math.sin(phi2) * Math.cos(phi1)) - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)));
                              	double tmp;
                              	if (lambda2 <= -3.8e+72) {
                              		tmp = Math.atan2(Math.sin(-lambda2), t_0);
                              	} else {
                              		tmp = Math.atan2(Math.sin((lambda1 - lambda2)), t_0);
                              	}
                              	return tmp;
                              }
                              
                              def code(lambda1, lambda2, phi1, phi2):
                              	t_0 = (math.sin(phi2) * math.cos(phi1)) - (math.sin(phi1) * math.cos((lambda1 - lambda2)))
                              	tmp = 0
                              	if lambda2 <= -3.8e+72:
                              		tmp = math.atan2(math.sin(-lambda2), t_0)
                              	else:
                              		tmp = math.atan2(math.sin((lambda1 - lambda2)), t_0)
                              	return tmp
                              
                              function code(lambda1, lambda2, phi1, phi2)
                              	t_0 = Float64(Float64(sin(phi2) * cos(phi1)) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))
                              	tmp = 0.0
                              	if (lambda2 <= -3.8e+72)
                              		tmp = atan(sin(Float64(-lambda2)), t_0);
                              	else
                              		tmp = atan(sin(Float64(lambda1 - lambda2)), t_0);
                              	end
                              	return tmp
                              end
                              
                              function tmp_2 = code(lambda1, lambda2, phi1, phi2)
                              	t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)));
                              	tmp = 0.0;
                              	if (lambda2 <= -3.8e+72)
                              		tmp = atan2(sin(-lambda2), t_0);
                              	else
                              		tmp = atan2(sin((lambda1 - lambda2)), t_0);
                              	end
                              	tmp_2 = tmp;
                              end
                              
                              code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda2, -3.8e+72], N[ArcTan[N[Sin[(-lambda2)], $MachinePrecision] / t$95$0], $MachinePrecision], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / t$95$0], $MachinePrecision]]]
                              
                              \begin{array}{l}
                              
                              \\
                              \begin{array}{l}
                              t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
                              \mathbf{if}\;\lambda_2 \leq -3.8 \cdot 10^{+72}:\\
                              \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{t\_0}\\
                              
                              \mathbf{else}:\\
                              \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{t\_0}\\
                              
                              
                              \end{array}
                              \end{array}
                              
                              Derivation
                              1. Split input into 2 regimes
                              2. if lambda2 < -3.80000000000000006e72

                                1. Initial program 54.2%

                                  \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                2. Add Preprocessing
                                3. Taylor expanded in phi2 around 0

                                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                4. Step-by-step derivation
                                  1. lower-sin.f64N/A

                                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  2. lower--.f6432.0

                                    \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                5. Applied rewrites32.0%

                                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                6. Taylor expanded in phi2 around 0

                                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                7. Step-by-step derivation
                                  1. lower-sin.f6432.5

                                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                8. Applied rewrites32.5%

                                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                9. Taylor expanded in lambda1 around 0

                                  \[\leadsto \tan^{-1}_* \frac{\sin \left(-1 \cdot \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                10. Step-by-step derivation
                                  1. Applied rewrites42.7%

                                    \[\leadsto \tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

                                  if -3.80000000000000006e72 < lambda2

                                  1. Initial program 82.9%

                                    \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  2. Add Preprocessing
                                  3. Taylor expanded in phi2 around 0

                                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  4. Step-by-step derivation
                                    1. lower-sin.f64N/A

                                      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                    2. lower--.f6451.7

                                      \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  5. Applied rewrites51.7%

                                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  6. Taylor expanded in phi2 around 0

                                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  7. Step-by-step derivation
                                    1. lower-sin.f6451.3

                                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  8. Applied rewrites51.3%

                                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                11. Recombined 2 regimes into one program.
                                12. Final simplification49.5%

                                  \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_2 \leq -3.8 \cdot 10^{+72}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \end{array} \]
                                13. Add Preprocessing

                                Alternative 27: 43.7% accurate, 1.3× speedup?

                                \[\begin{array}{l} \\ \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \lambda_1} \end{array} \]
                                (FPCore (lambda1 lambda2 phi1 phi2)
                                 :precision binary64
                                 (atan2
                                  (sin (- lambda1 lambda2))
                                  (- (* (sin phi2) (cos phi1)) (* (sin phi1) (cos lambda1)))))
                                double code(double lambda1, double lambda2, double phi1, double phi2) {
                                	return atan2(sin((lambda1 - lambda2)), ((sin(phi2) * cos(phi1)) - (sin(phi1) * cos(lambda1))));
                                }
                                
                                real(8) function code(lambda1, lambda2, phi1, phi2)
                                    real(8), intent (in) :: lambda1
                                    real(8), intent (in) :: lambda2
                                    real(8), intent (in) :: phi1
                                    real(8), intent (in) :: phi2
                                    code = atan2(sin((lambda1 - lambda2)), ((sin(phi2) * cos(phi1)) - (sin(phi1) * cos(lambda1))))
                                end function
                                
                                public static double code(double lambda1, double lambda2, double phi1, double phi2) {
                                	return Math.atan2(Math.sin((lambda1 - lambda2)), ((Math.sin(phi2) * Math.cos(phi1)) - (Math.sin(phi1) * Math.cos(lambda1))));
                                }
                                
                                def code(lambda1, lambda2, phi1, phi2):
                                	return math.atan2(math.sin((lambda1 - lambda2)), ((math.sin(phi2) * math.cos(phi1)) - (math.sin(phi1) * math.cos(lambda1))))
                                
                                function code(lambda1, lambda2, phi1, phi2)
                                	return atan(sin(Float64(lambda1 - lambda2)), Float64(Float64(sin(phi2) * cos(phi1)) - Float64(sin(phi1) * cos(lambda1))))
                                end
                                
                                function tmp = code(lambda1, lambda2, phi1, phi2)
                                	tmp = atan2(sin((lambda1 - lambda2)), ((sin(phi2) * cos(phi1)) - (sin(phi1) * cos(lambda1))));
                                end
                                
                                code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
                                
                                \begin{array}{l}
                                
                                \\
                                \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \lambda_1}
                                \end{array}
                                
                                Derivation
                                1. Initial program 77.1%

                                  \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                2. Add Preprocessing
                                3. Taylor expanded in phi2 around 0

                                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                4. Step-by-step derivation
                                  1. lower-sin.f64N/A

                                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  2. lower--.f6447.7

                                    \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                5. Applied rewrites47.7%

                                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                6. Taylor expanded in phi2 around 0

                                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                7. Step-by-step derivation
                                  1. lower-sin.f6447.5

                                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                8. Applied rewrites47.5%

                                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                9. Taylor expanded in lambda2 around 0

                                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_1}} \]
                                10. Step-by-step derivation
                                  1. lower-cos.f6440.8

                                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_1}} \]
                                11. Applied rewrites40.8%

                                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \color{blue}{\cos \lambda_1}} \]
                                12. Final simplification40.8%

                                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \lambda_1} \]
                                13. Add Preprocessing

                                Alternative 28: 31.0% accurate, 1.5× speedup?

                                \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\lambda_1 \leq -3.7 \cdot 10^{-126}:\\ \;\;\;\;\tan^{-1}_* \frac{\lambda_1 - \lambda_2}{t\_0}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.16666666666666666, \lambda_2, -0.5 \cdot \lambda_1\right), \lambda_2, -1\right), \lambda_2, \lambda_1\right)}{t\_0}\\ \end{array} \end{array} \]
                                (FPCore (lambda1 lambda2 phi1 phi2)
                                 :precision binary64
                                 (let* ((t_0
                                         (-
                                          (* (sin phi2) (cos phi1))
                                          (* (sin phi1) (cos (- lambda1 lambda2))))))
                                   (if (<= lambda1 -3.7e-126)
                                     (atan2 (- lambda1 lambda2) t_0)
                                     (atan2
                                      (fma
                                       (fma (fma 0.16666666666666666 lambda2 (* -0.5 lambda1)) lambda2 -1.0)
                                       lambda2
                                       lambda1)
                                      t_0))))
                                double code(double lambda1, double lambda2, double phi1, double phi2) {
                                	double t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)));
                                	double tmp;
                                	if (lambda1 <= -3.7e-126) {
                                		tmp = atan2((lambda1 - lambda2), t_0);
                                	} else {
                                		tmp = atan2(fma(fma(fma(0.16666666666666666, lambda2, (-0.5 * lambda1)), lambda2, -1.0), lambda2, lambda1), t_0);
                                	}
                                	return tmp;
                                }
                                
                                function code(lambda1, lambda2, phi1, phi2)
                                	t_0 = Float64(Float64(sin(phi2) * cos(phi1)) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))
                                	tmp = 0.0
                                	if (lambda1 <= -3.7e-126)
                                		tmp = atan(Float64(lambda1 - lambda2), t_0);
                                	else
                                		tmp = atan(fma(fma(fma(0.16666666666666666, lambda2, Float64(-0.5 * lambda1)), lambda2, -1.0), lambda2, lambda1), t_0);
                                	end
                                	return tmp
                                end
                                
                                code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda1, -3.7e-126], N[ArcTan[N[(lambda1 - lambda2), $MachinePrecision] / t$95$0], $MachinePrecision], N[ArcTan[N[(N[(N[(0.16666666666666666 * lambda2 + N[(-0.5 * lambda1), $MachinePrecision]), $MachinePrecision] * lambda2 + -1.0), $MachinePrecision] * lambda2 + lambda1), $MachinePrecision] / t$95$0], $MachinePrecision]]]
                                
                                \begin{array}{l}
                                
                                \\
                                \begin{array}{l}
                                t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
                                \mathbf{if}\;\lambda_1 \leq -3.7 \cdot 10^{-126}:\\
                                \;\;\;\;\tan^{-1}_* \frac{\lambda_1 - \lambda_2}{t\_0}\\
                                
                                \mathbf{else}:\\
                                \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.16666666666666666, \lambda_2, -0.5 \cdot \lambda_1\right), \lambda_2, -1\right), \lambda_2, \lambda_1\right)}{t\_0}\\
                                
                                
                                \end{array}
                                \end{array}
                                
                                Derivation
                                1. Split input into 2 regimes
                                2. if lambda1 < -3.6999999999999999e-126

                                  1. Initial program 72.7%

                                    \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  2. Add Preprocessing
                                  3. Taylor expanded in phi2 around 0

                                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  4. Step-by-step derivation
                                    1. lower-sin.f64N/A

                                      \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                    2. lower--.f6446.3

                                      \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  5. Applied rewrites46.3%

                                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  6. Taylor expanded in phi2 around 0

                                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  7. Step-by-step derivation
                                    1. lower-sin.f6446.3

                                      \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  8. Applied rewrites46.3%

                                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  9. Taylor expanded in lambda1 around 0

                                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \color{blue}{\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                  10. Step-by-step derivation
                                    1. Applied rewrites37.5%

                                      \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\cos \lambda_2, \color{blue}{\lambda_1}, -\sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                    2. Taylor expanded in lambda2 around 0

                                      \[\leadsto \tan^{-1}_* \frac{\lambda_1 + -1 \cdot \color{blue}{\lambda_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                    3. Step-by-step derivation
                                      1. Applied rewrites34.3%

                                        \[\leadsto \tan^{-1}_* \frac{\lambda_1 - \lambda_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

                                      if -3.6999999999999999e-126 < lambda1

                                      1. Initial program 79.8%

                                        \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                      2. Add Preprocessing
                                      3. Taylor expanded in phi2 around 0

                                        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                      4. Step-by-step derivation
                                        1. lower-sin.f64N/A

                                          \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                        2. lower--.f6448.6

                                          \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                      5. Applied rewrites48.6%

                                        \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                      6. Taylor expanded in phi2 around 0

                                        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                      7. Step-by-step derivation
                                        1. lower-sin.f6448.2

                                          \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                      8. Applied rewrites48.2%

                                        \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                      9. Taylor expanded in lambda1 around 0

                                        \[\leadsto \tan^{-1}_* \frac{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \color{blue}{\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                      10. Step-by-step derivation
                                        1. Applied rewrites44.6%

                                          \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\cos \lambda_2, \color{blue}{\lambda_1}, -\sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                        2. Taylor expanded in lambda2 around 0

                                          \[\leadsto \tan^{-1}_* \frac{\lambda_1 + \lambda_2 \cdot \color{blue}{\left(\lambda_2 \cdot \left(\frac{-1}{2} \cdot \lambda_1 + \frac{1}{6} \cdot \lambda_2\right) - 1\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                        3. Step-by-step derivation
                                          1. Applied rewrites33.0%

                                            \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.16666666666666666, \lambda_2, -0.5 \cdot \lambda_1\right), \lambda_2, -1\right), \lambda_2, \lambda_1\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                        4. Recombined 2 regimes into one program.
                                        5. Final simplification33.5%

                                          \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_1 \leq -3.7 \cdot 10^{-126}:\\ \;\;\;\;\tan^{-1}_* \frac{\lambda_1 - \lambda_2}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(0.16666666666666666, \lambda_2, -0.5 \cdot \lambda_1\right), \lambda_2, -1\right), \lambda_2, \lambda_1\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \end{array} \]
                                        6. Add Preprocessing

                                        Alternative 29: 31.1% accurate, 1.5× speedup?

                                        \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\lambda_2 \leq 1.8 \cdot 10^{+61}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\lambda_2 \cdot \lambda_1, -0.5, -1\right), \lambda_2, \lambda_1\right)}{t\_0}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\lambda_1 - \lambda_2}{t\_0}\\ \end{array} \end{array} \]
                                        (FPCore (lambda1 lambda2 phi1 phi2)
                                         :precision binary64
                                         (let* ((t_0
                                                 (-
                                                  (* (sin phi2) (cos phi1))
                                                  (* (sin phi1) (cos (- lambda1 lambda2))))))
                                           (if (<= lambda2 1.8e+61)
                                             (atan2 (fma (fma (* lambda2 lambda1) -0.5 -1.0) lambda2 lambda1) t_0)
                                             (atan2 (- lambda1 lambda2) t_0))))
                                        double code(double lambda1, double lambda2, double phi1, double phi2) {
                                        	double t_0 = (sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)));
                                        	double tmp;
                                        	if (lambda2 <= 1.8e+61) {
                                        		tmp = atan2(fma(fma((lambda2 * lambda1), -0.5, -1.0), lambda2, lambda1), t_0);
                                        	} else {
                                        		tmp = atan2((lambda1 - lambda2), t_0);
                                        	}
                                        	return tmp;
                                        }
                                        
                                        function code(lambda1, lambda2, phi1, phi2)
                                        	t_0 = Float64(Float64(sin(phi2) * cos(phi1)) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))
                                        	tmp = 0.0
                                        	if (lambda2 <= 1.8e+61)
                                        		tmp = atan(fma(fma(Float64(lambda2 * lambda1), -0.5, -1.0), lambda2, lambda1), t_0);
                                        	else
                                        		tmp = atan(Float64(lambda1 - lambda2), t_0);
                                        	end
                                        	return tmp
                                        end
                                        
                                        code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda2, 1.8e+61], N[ArcTan[N[(N[(N[(lambda2 * lambda1), $MachinePrecision] * -0.5 + -1.0), $MachinePrecision] * lambda2 + lambda1), $MachinePrecision] / t$95$0], $MachinePrecision], N[ArcTan[N[(lambda1 - lambda2), $MachinePrecision] / t$95$0], $MachinePrecision]]]
                                        
                                        \begin{array}{l}
                                        
                                        \\
                                        \begin{array}{l}
                                        t_0 := \sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
                                        \mathbf{if}\;\lambda_2 \leq 1.8 \cdot 10^{+61}:\\
                                        \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\lambda_2 \cdot \lambda_1, -0.5, -1\right), \lambda_2, \lambda_1\right)}{t\_0}\\
                                        
                                        \mathbf{else}:\\
                                        \;\;\;\;\tan^{-1}_* \frac{\lambda_1 - \lambda_2}{t\_0}\\
                                        
                                        
                                        \end{array}
                                        \end{array}
                                        
                                        Derivation
                                        1. Split input into 2 regimes
                                        2. if lambda2 < 1.80000000000000005e61

                                          1. Initial program 81.0%

                                            \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                          2. Add Preprocessing
                                          3. Taylor expanded in phi2 around 0

                                            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                          4. Step-by-step derivation
                                            1. lower-sin.f64N/A

                                              \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                            2. lower--.f6450.4

                                              \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                          5. Applied rewrites50.4%

                                            \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                          6. Taylor expanded in phi2 around 0

                                            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                          7. Step-by-step derivation
                                            1. lower-sin.f6450.1

                                              \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                          8. Applied rewrites50.1%

                                            \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                          9. Taylor expanded in lambda1 around 0

                                            \[\leadsto \tan^{-1}_* \frac{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \color{blue}{\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                          10. Step-by-step derivation
                                            1. Applied rewrites44.1%

                                              \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\cos \lambda_2, \color{blue}{\lambda_1}, -\sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                            2. Taylor expanded in lambda2 around 0

                                              \[\leadsto \tan^{-1}_* \frac{\lambda_1 + \lambda_2 \cdot \color{blue}{\left(\frac{-1}{2} \cdot \left(\lambda_1 \cdot \lambda_2\right) - 1\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                            3. Step-by-step derivation
                                              1. Applied rewrites36.1%

                                                \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\lambda_1 \cdot \lambda_2, -0.5, -1\right), \lambda_2, \lambda_1\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]

                                              if 1.80000000000000005e61 < lambda2

                                              1. Initial program 64.9%

                                                \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                              2. Add Preprocessing
                                              3. Taylor expanded in phi2 around 0

                                                \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                              4. Step-by-step derivation
                                                1. lower-sin.f64N/A

                                                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                2. lower--.f6439.3

                                                  \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                              5. Applied rewrites39.3%

                                                \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                              6. Taylor expanded in phi2 around 0

                                                \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                              7. Step-by-step derivation
                                                1. lower-sin.f6439.3

                                                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                              8. Applied rewrites39.3%

                                                \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                              9. Taylor expanded in lambda1 around 0

                                                \[\leadsto \tan^{-1}_* \frac{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \color{blue}{\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                              10. Step-by-step derivation
                                                1. Applied rewrites34.9%

                                                  \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\cos \lambda_2, \color{blue}{\lambda_1}, -\sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                2. Taylor expanded in lambda2 around 0

                                                  \[\leadsto \tan^{-1}_* \frac{\lambda_1 + -1 \cdot \color{blue}{\lambda_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                3. Step-by-step derivation
                                                  1. Applied rewrites21.7%

                                                    \[\leadsto \tan^{-1}_* \frac{\lambda_1 - \lambda_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                4. Recombined 2 regimes into one program.
                                                5. Final simplification32.6%

                                                  \[\leadsto \begin{array}{l} \mathbf{if}\;\lambda_2 \leq 1.8 \cdot 10^{+61}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\mathsf{fma}\left(\lambda_2 \cdot \lambda_1, -0.5, -1\right), \lambda_2, \lambda_1\right)}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\lambda_1 - \lambda_2}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \end{array} \]
                                                6. Add Preprocessing

                                                Alternative 30: 30.8% accurate, 1.6× speedup?

                                                \[\begin{array}{l} \\ \tan^{-1}_* \frac{\lambda_1 - \lambda_2}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \end{array} \]
                                                (FPCore (lambda1 lambda2 phi1 phi2)
                                                 :precision binary64
                                                 (atan2
                                                  (- lambda1 lambda2)
                                                  (- (* (sin phi2) (cos phi1)) (* (sin phi1) (cos (- lambda1 lambda2))))))
                                                double code(double lambda1, double lambda2, double phi1, double phi2) {
                                                	return atan2((lambda1 - lambda2), ((sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)))));
                                                }
                                                
                                                real(8) function code(lambda1, lambda2, phi1, phi2)
                                                    real(8), intent (in) :: lambda1
                                                    real(8), intent (in) :: lambda2
                                                    real(8), intent (in) :: phi1
                                                    real(8), intent (in) :: phi2
                                                    code = atan2((lambda1 - lambda2), ((sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)))))
                                                end function
                                                
                                                public static double code(double lambda1, double lambda2, double phi1, double phi2) {
                                                	return Math.atan2((lambda1 - lambda2), ((Math.sin(phi2) * Math.cos(phi1)) - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)))));
                                                }
                                                
                                                def code(lambda1, lambda2, phi1, phi2):
                                                	return math.atan2((lambda1 - lambda2), ((math.sin(phi2) * math.cos(phi1)) - (math.sin(phi1) * math.cos((lambda1 - lambda2)))))
                                                
                                                function code(lambda1, lambda2, phi1, phi2)
                                                	return atan(Float64(lambda1 - lambda2), Float64(Float64(sin(phi2) * cos(phi1)) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2)))))
                                                end
                                                
                                                function tmp = code(lambda1, lambda2, phi1, phi2)
                                                	tmp = atan2((lambda1 - lambda2), ((sin(phi2) * cos(phi1)) - (sin(phi1) * cos((lambda1 - lambda2)))));
                                                end
                                                
                                                code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(lambda1 - lambda2), $MachinePrecision] / N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
                                                
                                                \begin{array}{l}
                                                
                                                \\
                                                \tan^{-1}_* \frac{\lambda_1 - \lambda_2}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}
                                                \end{array}
                                                
                                                Derivation
                                                1. Initial program 77.1%

                                                  \[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                2. Add Preprocessing
                                                3. Taylor expanded in phi2 around 0

                                                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                4. Step-by-step derivation
                                                  1. lower-sin.f64N/A

                                                    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                  2. lower--.f6447.7

                                                    \[\leadsto \tan^{-1}_* \frac{\sin \color{blue}{\left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                5. Applied rewrites47.7%

                                                  \[\leadsto \tan^{-1}_* \frac{\color{blue}{\sin \left(\lambda_1 - \lambda_2\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                6. Taylor expanded in phi2 around 0

                                                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                7. Step-by-step derivation
                                                  1. lower-sin.f6447.5

                                                    \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                8. Applied rewrites47.5%

                                                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \color{blue}{\sin \phi_1} \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                9. Taylor expanded in lambda1 around 0

                                                  \[\leadsto \tan^{-1}_* \frac{\sin \left(\mathsf{neg}\left(\lambda_2\right)\right) + \color{blue}{\lambda_1 \cdot \cos \left(\mathsf{neg}\left(\lambda_2\right)\right)}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                10. Step-by-step derivation
                                                  1. Applied rewrites41.9%

                                                    \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\cos \lambda_2, \color{blue}{\lambda_1}, -\sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                  2. Taylor expanded in lambda2 around 0

                                                    \[\leadsto \tan^{-1}_* \frac{\lambda_1 + -1 \cdot \color{blue}{\lambda_2}}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                  3. Step-by-step derivation
                                                    1. Applied rewrites30.7%

                                                      \[\leadsto \tan^{-1}_* \frac{\lambda_1 - \lambda_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                    2. Final simplification30.7%

                                                      \[\leadsto \tan^{-1}_* \frac{\lambda_1 - \lambda_2}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
                                                    3. Add Preprocessing

                                                    Reproduce

                                                    ?
                                                    herbie shell --seed 2024235 
                                                    (FPCore (lambda1 lambda2 phi1 phi2)
                                                      :name "Bearing on a great circle"
                                                      :precision binary64
                                                      (atan2 (* (sin (- lambda1 lambda2)) (cos phi2)) (- (* (cos phi1) (sin phi2)) (* (* (sin phi1) (cos phi2)) (cos (- lambda1 lambda2))))))