Average Error: 13.0 → 0.2
Time: 1.2min
Precision: binary64
Cost: 110208
\[\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)} \]
\[\tan^{-1}_* \frac{\mathsf{log1p}\left(\mathsf{expm1}\left(\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \mathsf{fma}\left(\cos \lambda_1, \cos \lambda_2, \sin \lambda_1 \cdot \sin \lambda_2\right)} \]
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (atan2
  (* (sin (- lambda1 lambda2)) (cos phi2))
  (-
   (* (cos phi1) (sin phi2))
   (* (* (sin phi1) (cos phi2)) (cos (- lambda1 lambda2))))))
(FPCore (lambda1 lambda2 phi1 phi2)
 :precision binary64
 (atan2
  (log1p
   (expm1
    (*
     (- (* (cos lambda2) (sin lambda1)) (* (cos lambda1) (sin lambda2)))
     (cos phi2))))
  (-
   (* (cos phi1) (sin phi2))
   (*
    (* (cos phi2) (sin phi1))
    (fma (cos lambda1) (cos lambda2) (* (sin lambda1) (sin 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)))));
}
double code(double lambda1, double lambda2, double phi1, double phi2) {
	return atan2(log1p(expm1((((cos(lambda2) * sin(lambda1)) - (cos(lambda1) * sin(lambda2))) * cos(phi2)))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * fma(cos(lambda1), cos(lambda2), (sin(lambda1) * sin(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 code(lambda1, lambda2, phi1, phi2)
	return atan(log1p(expm1(Float64(Float64(Float64(cos(lambda2) * sin(lambda1)) - Float64(cos(lambda1) * sin(lambda2))) * cos(phi2)))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * fma(cos(lambda1), cos(lambda2), Float64(sin(lambda1) * sin(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]
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[Log[1 + N[(Exp[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]] - 1), $MachinePrecision]], $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[(N[Cos[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\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)}
\tan^{-1}_* \frac{\mathsf{log1p}\left(\mathsf{expm1}\left(\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \mathsf{fma}\left(\cos \lambda_1, \cos \lambda_2, \sin \lambda_1 \cdot \sin \lambda_2\right)}

Error

Derivation

  1. Initial program 13.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. Applied egg-rr6.6

    \[\leadsto \tan^{-1}_* \frac{\color{blue}{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \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)} \]
  3. Applied egg-rr0.2

    \[\leadsto \tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \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 \color{blue}{\mathsf{fma}\left(\cos \lambda_1, \cos \lambda_2, \sin \lambda_1 \cdot \sin \lambda_2\right)}} \]
  4. Applied egg-rr0.2

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

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

Alternatives

Alternative 1
Error0.2
Cost97408
\[\tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \mathsf{fma}\left(\cos \lambda_1, \cos \lambda_2, \sin \lambda_1 \cdot \sin \lambda_2\right)} \]
Alternative 2
Error3.6
Cost91144
\[\begin{array}{l} t_0 := \cos \phi_1 \cdot \sin \phi_2\\ t_1 := \cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\\ t_2 := t_1 \cdot \cos \phi_2\\ t_3 := \cos \phi_2 \cdot \sin \phi_1\\ t_4 := t_0 - t_3 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\phi_2 \leq -23.94448187344216:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{log1p}\left(\mathsf{expm1}\left(t_2\right)\right)}{t_4}\\ \mathbf{elif}\;\phi_2 \leq 2.0811713522807498 \cdot 10^{-30}:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{t_0 - t_3 \cdot \mathsf{fma}\left(\cos \lambda_1, \cos \lambda_2, \sin \lambda_1 \cdot \sin \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t_2}{t_4}\\ \end{array} \]
Alternative 3
Error0.2
Cost91136
\[\tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_2 \cdot \cos \lambda_1\right)\right)} \]
Alternative 4
Error0.2
Cost91136
\[\tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_2 \cdot \cos \lambda_1\right)} \]
Alternative 5
Error3.6
Cost84872
\[\begin{array}{l} t_0 := \cos \phi_1 \cdot \sin \phi_2\\ t_1 := t_0 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\\ t_2 := \left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\\ \mathbf{if}\;\phi_2 \leq -4800476.271127779:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{log1p}\left(\mathsf{expm1}\left(t_2\right)\right)}{t_1}\\ \mathbf{elif}\;\phi_2 \leq 2.0811713522807498 \cdot 10^{-30}:\\ \;\;\;\;\tan^{-1}_* \frac{t_2}{t_0 - \sin \phi_1 \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_2 \cdot \cos \lambda_1\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t_2}{t_1}\\ \end{array} \]
Alternative 6
Error6.6
Cost84480
\[\tan^{-1}_* \frac{\mathsf{log1p}\left(\mathsf{expm1}\left(\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
Alternative 7
Error6.7
Cost71816
\[\begin{array}{l} t_0 := \cos \phi_1 \cdot \sin \phi_2\\ t_1 := \tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{t_0 - \cos \phi_2 \cdot \left(\cos \lambda_2 \cdot \sin \phi_1\right)}\\ \mathbf{if}\;\lambda_2 \leq -1.786819203045079 \cdot 10^{-6}:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\lambda_2 \leq 1.7247104484775318 \cdot 10^{-18}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2 \cdot \left(-\sin \phi_1\right), t_0\right)}\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 8
Error6.9
Cost71816
\[\begin{array}{l} t_0 := \cos \phi_1 \cdot \sin \phi_2\\ t_1 := \cos \phi_2 \cdot \sin \phi_1\\ t_2 := \tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{t_0 - \cos \lambda_1 \cdot t_1}\\ \mathbf{if}\;\lambda_1 \leq -4.0612115102434096 \cdot 10^{-12}:\\ \;\;\;\;t_2\\ \mathbf{elif}\;\lambda_1 \leq 1.0404002948190269 \cdot 10^{-29}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t_0 - t_1 \cdot \log \left(e^{\cos \left(\lambda_1 - \lambda_2\right)}\right)}\\ \mathbf{else}:\\ \;\;\;\;t_2\\ \end{array} \]
Alternative 9
Error6.6
Cost71680
\[\tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
Alternative 10
Error7.4
Cost65416
\[\begin{array}{l} t_0 := \cos \phi_1 \cdot \sin \phi_2\\ t_1 := \cos \lambda_1 \cdot \sin \lambda_2\\ t_2 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 - t_1\right)}{t_0 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{if}\;\phi_1 \leq -6.169454533123174 \cdot 10^{-10}:\\ \;\;\;\;t_2\\ \mathbf{elif}\;\phi_1 \leq 3.86226751310576 \cdot 10^{-15}:\\ \;\;\;\;\tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - t_1\right) \cdot \cos \phi_2}{t_0 - \cos \lambda_1 \cdot \sin \phi_1}\\ \mathbf{else}:\\ \;\;\;\;t_2\\ \end{array} \]
Alternative 11
Error7.7
Cost65288
\[\begin{array}{l} t_0 := \cos \phi_1 \cdot \sin \phi_2\\ t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2 \cdot \left(-\sin \phi_1\right), t_0\right)}\\ \mathbf{if}\;\phi_1 \leq -6.169454533123174 \cdot 10^{-10}:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\phi_1 \leq 3.86226751310576 \cdot 10^{-15}:\\ \;\;\;\;\tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{t_0 - \cos \phi_2 \cdot \sin \phi_1}\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 12
Error7.7
Cost65288
\[\begin{array}{l} t_0 := \cos \phi_1 \cdot \sin \phi_2\\ t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2 \cdot \left(-\sin \phi_1\right), t_0\right)}\\ \mathbf{if}\;\phi_1 \leq -6.169454533123174 \cdot 10^{-10}:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\phi_1 \leq 3.86226751310576 \cdot 10^{-15}:\\ \;\;\;\;\tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{t_0 - \cos \lambda_1 \cdot \sin \phi_1}\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 13
Error7.7
Cost65288
\[\begin{array}{l} t_0 := \cos \phi_1 \cdot \sin \phi_2\\ t_1 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\ t_2 := \cos \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\phi_1 \leq -6.169454533123174 \cdot 10^{-10}:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{t_0 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \log \left(e^{t_2}\right)}\\ \mathbf{elif}\;\phi_1 \leq 3.86226751310576 \cdot 10^{-15}:\\ \;\;\;\;\tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{t_0 - \cos \lambda_1 \cdot \sin \phi_1}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{\mathsf{fma}\left(t_2, \cos \phi_2 \cdot \left(-\sin \phi_1\right), t_0\right)}\\ \end{array} \]
Alternative 14
Error7.7
Cost65288
\[\begin{array}{l} t_0 := \cos \phi_1 \cdot \sin \phi_2\\ t_1 := \cos \left(\lambda_1 - \lambda_2\right)\\ t_2 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\phi_1 \leq -1.2440947566623845 \cdot 10^{-20}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{log1p}\left(\mathsf{expm1}\left(t_2\right)\right)}{t_0 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t_1}\\ \mathbf{elif}\;\phi_1 \leq 3.86226751310576 \cdot 10^{-15}:\\ \;\;\;\;\tan^{-1}_* \frac{\left(\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2\right) \cdot \cos \phi_2}{t_0 - \cos \lambda_1 \cdot \sin \phi_1}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t_2}{\mathsf{fma}\left(t_1, \cos \phi_2 \cdot \left(-\sin \phi_1\right), t_0\right)}\\ \end{array} \]
Alternative 15
Error8.5
Cost58824
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2 \cdot \left(-\sin \phi_1\right), \cos \phi_1 \cdot \sin \phi_2\right)}\\ \mathbf{if}\;\phi_1 \leq -6.573972928886095 \cdot 10^{-37}:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\phi_1 \leq 3.86226751310576 \cdot 10^{-15}:\\ \;\;\;\;\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}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 16
Error17.9
Cost52560
\[\begin{array}{l} t_0 := \cos \phi_2 \cdot \sin \phi_1\\ t_1 := \cos \phi_1 \cdot \sin \phi_2\\ t_2 := \tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t_1 - \cos \lambda_1 \cdot t_0}\\ t_3 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(-\lambda_2\right)}{t_1 - \cos \lambda_2 \cdot t_0}\\ \mathbf{if}\;\phi_1 \leq -6.489329372935244 \cdot 10^{+257}:\\ \;\;\;\;t_2\\ \mathbf{elif}\;\phi_1 \leq -8.00024442257792 \cdot 10^{+153}:\\ \;\;\;\;t_3\\ \mathbf{elif}\;\phi_1 \leq -1.016370402733148 \cdot 10^{+91}:\\ \;\;\;\;t_2\\ \mathbf{elif}\;\phi_1 \leq -6.169454533123174 \cdot 10^{-10}:\\ \;\;\;\;t_3\\ \mathbf{elif}\;\phi_1 \leq 1.2033645018628762 \cdot 10^{-12}:\\ \;\;\;\;\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}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t_1 - \sin \phi_1 \cdot \cos \left(\lambda_2 - \lambda_1\right)}\\ \end{array} \]
Alternative 17
Error18.6
Cost52496
\[\begin{array}{l} t_0 := \cos \phi_1 \cdot \sin \phi_2\\ t_1 := \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}\\ t_2 := \tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t_0 - \cos \lambda_1 \cdot \left(\cos \phi_2 \cdot \sin \phi_1\right)}\\ \mathbf{if}\;\lambda_2 \leq -1.786819203045079 \cdot 10^{-6}:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\lambda_2 \leq 2.8937149176004596 \cdot 10^{-169}:\\ \;\;\;\;t_2\\ \mathbf{elif}\;\lambda_2 \leq 2.0305480447907982 \cdot 10^{-57}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t_0 - \sin \phi_1 \cdot \cos \left(\lambda_2 - \lambda_1\right)}\\ \mathbf{elif}\;\lambda_2 \leq 1.7247104484775318 \cdot 10^{-18}:\\ \;\;\;\;t_2\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 18
Error13.9
Cost52492
\[\begin{array}{l} t_0 := \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}\\ t_1 := \cos \phi_1 \cdot \sin \phi_2\\ \mathbf{if}\;\lambda_2 \leq -1.6134669449475096 \cdot 10^{+197}:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\lambda_2 \leq -1.1840412785902056 \cdot 10^{+61}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(-\lambda_2\right)}{t_1 - \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \phi_1\right)}\\ \mathbf{elif}\;\lambda_2 \leq 1.7247104484775318 \cdot 10^{-18}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t_1 - \cos \phi_2 \cdot \left(\cos \lambda_1 \cdot \sin \phi_1\right)}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 19
Error8.5
Cost52488
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{if}\;\phi_1 \leq -6.573972928886095 \cdot 10^{-37}:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\phi_1 \leq 3.86226751310576 \cdot 10^{-15}:\\ \;\;\;\;\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}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 20
Error13.0
Cost52360
\[\begin{array}{l} t_0 := \cos \phi_2 \cdot \sin \phi_1\\ t_1 := \cos \phi_1 \cdot \sin \phi_2\\ \mathbf{if}\;\lambda_1 \leq -36.697335031329395:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t_1 - t_0 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{elif}\;\lambda_1 \leq 8.521344220556394 \cdot 10^{-16}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t_1 - \cos \lambda_2 \cdot t_0}\\ \mathbf{else}:\\ \;\;\;\;\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}\\ \end{array} \]
Alternative 21
Error17.1
Cost45960
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_2 - \lambda_1\right)}\\ \mathbf{if}\;\phi_1 \leq -6.573972928886095 \cdot 10^{-37}:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\phi_1 \leq 1.2033645018628762 \cdot 10^{-12}:\\ \;\;\;\;\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}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 22
Error17.9
Cost45704
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \left(\lambda_1 - \lambda_2\right) \cdot \left(-\sin \phi_1\right)}\\ \mathbf{if}\;\phi_1 \leq -6.169454533123174 \cdot 10^{-10}:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\phi_1 \leq 1.2033645018628762 \cdot 10^{-12}:\\ \;\;\;\;\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}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 23
Error23.8
Cost39428
\[\begin{array}{l} t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\ t_1 := \sin \left(\lambda_1 - \lambda_2\right)\\ t_2 := \tan^{-1}_* \frac{t_1 \cdot \left(-0.5 \cdot \left(\phi_2 \cdot \phi_2\right) + 1\right)}{\phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot t_0}\\ t_3 := \cos \phi_2 \cdot t_1\\ \mathbf{if}\;\phi_2 \leq -0.0034790442115492596:\\ \;\;\;\;\tan^{-1}_* \frac{t_3}{\sin \phi_2 - \cos \phi_2 \cdot \left(\phi_1 \cdot t_0\right)}\\ \mathbf{elif}\;\phi_2 \leq -2.516168697790264 \cdot 10^{-245}:\\ \;\;\;\;t_2\\ \mathbf{elif}\;\phi_2 \leq 3.177155320395769 \cdot 10^{-291}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2}{\sin \phi_2}\\ \mathbf{elif}\;\phi_2 \leq 1.5585160415176891 \cdot 10^{-13}:\\ \;\;\;\;t_2\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{log1p}\left(\mathsf{expm1}\left(t_3\right)\right)}{\sin \phi_2}\\ \end{array} \]
Alternative 24
Error23.4
Cost39312
\[\begin{array}{l} t_0 := \sin \left(\lambda_1 - \lambda_2\right)\\ t_1 := \tan^{-1}_* \frac{t_0 \cdot \left(-0.5 \cdot \left(\phi_2 \cdot \phi_2\right) + 1\right)}{\phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ t_2 := \cos \phi_2 \cdot t_0\\ \mathbf{if}\;\phi_2 \leq -23.94448187344216:\\ \;\;\;\;\tan^{-1}_* \frac{t_2}{\sin \phi_2}\\ \mathbf{elif}\;\phi_2 \leq -2.516168697790264 \cdot 10^{-245}:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\phi_2 \leq 3.177155320395769 \cdot 10^{-291}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \lambda_2 \cdot \sin \lambda_1 - \cos \lambda_1 \cdot \sin \lambda_2}{\sin \phi_2}\\ \mathbf{elif}\;\phi_2 \leq 1.5585160415176891 \cdot 10^{-13}:\\ \;\;\;\;t_1\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{log1p}\left(\mathsf{expm1}\left(t_2\right)\right)}{\sin \phi_2}\\ \end{array} \]
Alternative 25
Error22.5
Cost39048
\[\begin{array}{l} t_0 := \sin \left(\lambda_1 - \lambda_2\right)\\ t_1 := \cos \phi_2 \cdot t_0\\ \mathbf{if}\;\phi_2 \leq -23.94448187344216:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{\sin \phi_2}\\ \mathbf{elif}\;\phi_2 \leq 1.5585160415176891 \cdot 10^{-13}:\\ \;\;\;\;\tan^{-1}_* \frac{t_0 \cdot \left(-0.5 \cdot \left(\phi_2 \cdot \phi_2\right) + 1\right)}{\phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{log1p}\left(\mathsf{expm1}\left(t_1\right)\right)}{\sin \phi_2}\\ \end{array} \]
Alternative 26
Error22.5
Cost33544
\[\begin{array}{l} t_0 := \sin \left(\lambda_1 - \lambda_2\right)\\ t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot t_0}{\sin \phi_2}\\ \mathbf{if}\;\phi_2 \leq -23.94448187344216:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\phi_2 \leq 1.5585160415176891 \cdot 10^{-13}:\\ \;\;\;\;\tan^{-1}_* \frac{t_0 \cdot \left(-0.5 \cdot \left(\phi_2 \cdot \phi_2\right) + 1\right)}{\phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 27
Error23.6
Cost32968
\[\begin{array}{l} t_0 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\ t_1 := \tan^{-1}_* \frac{t_0}{\sin \phi_2}\\ \mathbf{if}\;\phi_2 \leq -2.192199344932273 \cdot 10^{-21}:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\phi_2 \leq 1.5585160415176891 \cdot 10^{-13}:\\ \;\;\;\;\tan^{-1}_* \frac{t_0}{\cos \left(\lambda_1 - \lambda_2\right) \cdot \left(-\sin \phi_1\right)}\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 28
Error32.5
Cost32776
\[\begin{array}{l} t_0 := \sin \left(-\lambda_2\right)\\ \mathbf{if}\;\lambda_2 \leq -0.0007315083631945296:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(t_0 + \lambda_1 \cdot \cos \left(-\lambda_2\right)\right)}{\sin \phi_2}\\ \mathbf{elif}\;\lambda_2 \leq 11714.975537780228:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 - \lambda_2 \cdot \cos \lambda_1\right)}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot t_0}{\sin \phi_2}\\ \end{array} \]
Alternative 29
Error32.6
Cost26888
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2}\\ \mathbf{if}\;\phi_2 \leq -2.516168697790264 \cdot 10^{-245}:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\phi_2 \leq 3.177155320395769 \cdot 10^{-291}:\\ \;\;\;\;\tan^{-1}_* \frac{\left(-0.5 \cdot \left(\phi_2 \cdot \phi_2\right) + 1\right) \cdot \left(\sin \left(-\lambda_2\right) + \lambda_1 \cdot \cos \left(-\lambda_2\right)\right)}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 30
Error32.6
Cost26376
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2}\\ \mathbf{if}\;\phi_2 \leq -2.516168697790264 \cdot 10^{-245}:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\phi_2 \leq 3.177155320395769 \cdot 10^{-291}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) + \lambda_1 \cdot \cos \left(-\lambda_2\right)}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 31
Error35.4
Cost26184
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_2}\\ \mathbf{if}\;\lambda_1 \leq -2.1294296100961147 \cdot 10^{-44}:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\lambda_1 \leq 1.0404002948190269 \cdot 10^{-29}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(-\lambda_2\right)}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 32
Error39.7
Cost26120
\[\begin{array}{l} \mathbf{if}\;\lambda_2 \leq -1.119731867246954 \cdot 10^{+29}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2}\\ \mathbf{elif}\;\lambda_2 \leq 1.9217956622741274 \cdot 10^{-18}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \left(-0.5 \cdot \left(\phi_2 \cdot \phi_2\right) + 1\right)}{\sin \phi_2}\\ \end{array} \]
Alternative 33
Error32.3
Cost26116
\[\begin{array}{l} \mathbf{if}\;\lambda_1 \leq -18904979442.69125:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2}\\ \end{array} \]
Alternative 34
Error46.5
Cost19972
\[\begin{array}{l} \mathbf{if}\;\lambda_1 \leq -2.8627904630718573 \cdot 10^{-55}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \left(-0.5 \cdot \left(\phi_2 \cdot \phi_2\right) + 1\right)}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{\sin \phi_2}\\ \end{array} \]
Alternative 35
Error46.3
Cost19524
\[\begin{array}{l} \mathbf{if}\;\lambda_1 \leq -2.8627904630718573 \cdot 10^{-55}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{\sin \phi_2}\\ \end{array} \]
Alternative 36
Error48.2
Cost19328
\[\tan^{-1}_* \frac{\sin \lambda_1}{\sin \phi_2} \]

Error

Reproduce

herbie shell --seed 2022214 
(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))))))