Average Error: 12.9 → 0.2
Time: 1.1min
Precision: binary64
Cost: 116544
\[\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{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\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, \mathsf{expm1}\left(\mathsf{log1p}\left(\sin \lambda_1 \cdot \sin \lambda_2\right)\right)\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
  (*
   (fma (sin lambda1) (cos lambda2) (* (sin lambda2) (- (cos lambda1))))
   (cos phi2))
  (-
   (* (cos phi1) (sin phi2))
   (*
    (* (cos phi2) (sin phi1))
    (fma
     (cos lambda1)
     (cos lambda2)
     (expm1 (log1p (* (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((fma(sin(lambda1), cos(lambda2), (sin(lambda2) * -cos(lambda1))) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * fma(cos(lambda1), cos(lambda2), expm1(log1p((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(Float64(fma(sin(lambda1), cos(lambda2), Float64(sin(lambda2) * Float64(-cos(lambda1)))) * cos(phi2)), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * fma(cos(lambda1), cos(lambda2), expm1(log1p(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[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Sin[lambda2], $MachinePrecision] * (-N[Cos[lambda1], $MachinePrecision])), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $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[(Exp[N[Log[1 + N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]] - 1), $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{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\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, \mathsf{expm1}\left(\mathsf{log1p}\left(\sin \lambda_1 \cdot \sin \lambda_2\right)\right)\right)}

Error

Derivation

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

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

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

    \[\leadsto \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\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, \mathsf{expm1}\left(\mathsf{log1p}\left(\sin \lambda_1 \cdot \sin \lambda_2\right)\right)\right)} \]

Alternatives

Alternative 1
Error0.2
Cost103744
\[\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\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.5
Cost97480
\[\begin{array}{l} t_0 := \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2\\ t_1 := \cos \phi_1 \cdot \sin \phi_2\\ t_2 := t_1 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\phi_2 \leq -2838413535.2810926:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}{t_2}\\ \mathbf{elif}\;\phi_2 \leq 3.3152388756327223 \cdot 10^{-9}:\\ \;\;\;\;\tan^{-1}_* \frac{t_0}{t_1 - \sin \phi_1 \cdot \mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \sin \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t_0}{t_2}\\ \end{array} \]
Alternative 3
Error0.2
Cost97472
\[\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \lambda_1 + \sin \lambda_1 \cdot \sin \lambda_2\right)\right)} \]
Alternative 4
Error0.2
Cost97472
\[\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \left(\cos \phi_2 \cdot \left(\cos \lambda_2 \cdot \cos \lambda_1 + \sin \lambda_1 \cdot \sin \lambda_2\right)\right)} \]
Alternative 5
Error3.5
Cost91208
\[\begin{array}{l} t_0 := \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2\\ t_1 := \cos \phi_1 \cdot \sin \phi_2\\ t_2 := t_1 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\phi_2 \leq -2838413535.2810926:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}{t_2}\\ \mathbf{elif}\;\phi_2 \leq 3.3152388756327223 \cdot 10^{-9}:\\ \;\;\;\;\tan^{-1}_* \frac{t_0}{t_1 - \sin \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \lambda_1 + \sin \lambda_1 \cdot \sin \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t_0}{t_2}\\ \end{array} \]
Alternative 6
Error6.6
Cost78016
\[\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\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 7
Error7.7
Cost71752
\[\begin{array}{l} t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\ t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, -\sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t_0}\\ \mathbf{if}\;\phi_1 \leq -221.532771749485:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\phi_1 \leq 9.452911611736827 \cdot 10^{-34}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2}{\sin \phi_2 - \sin \phi_1 \cdot t_0}\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 8
Error6.6
Cost71680
\[\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \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)} \]
Alternative 9
Error8.0
Cost65416
\[\begin{array}{l} t_0 := \mathsf{expm1}\left(\cos \phi_1 \cdot \sin \phi_2\right)\\ t_1 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\ t_2 := \cos \left(\lambda_1 - \lambda_2\right)\\ t_3 := \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t_2\\ \mathbf{if}\;\phi_1 \leq -221.532771749485:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{\mathsf{log1p}\left(t_0\right) - t_3}\\ \mathbf{elif}\;\phi_1 \leq 2.783393955628898 \cdot 10^{-32}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2}{\sin \phi_2 - \sin \phi_1 \cdot t_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{\log \left(t_0 + 1\right) - t_3}\\ \end{array} \]
Alternative 10
Error8.0
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 -221.532771749485:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{\mathsf{log1p}\left(\mathsf{expm1}\left(t_0\right)\right) - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t_2}\\ \mathbf{elif}\;\phi_1 \leq 9.452911611736827 \cdot 10^{-34}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2}{\sin \phi_2 - \sin \phi_1 \cdot t_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{t_0 - \mathsf{expm1}\left(\mathsf{log1p}\left(\sin \phi_1 \cdot \left(\cos \phi_2 \cdot t_2\right)\right)\right)}\\ \end{array} \]
Alternative 11
Error8.0
Cost65224
\[\begin{array}{l} t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\ t_1 := \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 t_0}\\ \mathbf{if}\;\phi_1 \leq -221.532771749485:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\phi_1 \leq 9.452911611736827 \cdot 10^{-34}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2}{\sin \phi_2 - \sin \phi_1 \cdot t_0}\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 12
Error8.0
Cost65224
\[\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)\\ t_3 := \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t_2\\ \mathbf{if}\;\phi_1 \leq -221.532771749485:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{\mathsf{log1p}\left(\mathsf{expm1}\left(t_0\right)\right) - t_3}\\ \mathbf{elif}\;\phi_1 \leq 9.452911611736827 \cdot 10^{-34}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2}{\sin \phi_2 - \sin \phi_1 \cdot t_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{t_0 - t_3}\\ \end{array} \]
Alternative 13
Error8.0
Cost58888
\[\begin{array}{l} t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\ t_1 := \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 t_0}\\ \mathbf{if}\;\phi_1 \leq -221.532771749485:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\phi_1 \leq 9.452911611736827 \cdot 10^{-34}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}{\sin \phi_2 - \sin \phi_1 \cdot t_0}\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 14
Error13.3
Cost52492
\[\begin{array}{l} t_0 := \cos \phi_2 \cdot \sin \phi_1\\ t_1 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\ t_2 := \cos \phi_1 \cdot \sin \phi_2\\ \mathbf{if}\;\lambda_1 \leq -4868404498169.834:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2}{\sin \phi_2}\\ \mathbf{elif}\;\lambda_1 \leq 2.549130745843823 \cdot 10^{-14}:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{t_2 - \cos \lambda_2 \cdot t_0}\\ \mathbf{elif}\;\lambda_1 \leq 6.00888231176834 \cdot 10^{+107}:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{t_2 - \cos \lambda_1 \cdot t_0}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}{\sin \phi_2}\\ \end{array} \]
Alternative 15
Error8.9
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 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)}\\ \mathbf{if}\;\phi_1 \leq -221.532771749485:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\phi_1 \leq 9.452911611736827 \cdot 10^{-34}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 16
Error8.9
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 -221.532771749485:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\phi_1 \leq 9.452911611736827 \cdot 10^{-34}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 17
Error13.4
Cost52360
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2}{\sin \phi_2}\\ \mathbf{if}\;\lambda_1 \leq -4868404498169.834:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\lambda_1 \leq 4160140226.8139997:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \phi_1\right)}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 18
Error17.4
Cost52040
\[\begin{array}{l} t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\ t_1 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\phi_1 \leq -1352137.2163366585:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot t_0}\\ \mathbf{elif}\;\phi_1 \leq 9.452911611736827 \cdot 10^{-34}:\\ \;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \lambda_2 \cdot \left(-\cos \lambda_1\right)\right) \cdot \cos \phi_2}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{\sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t_0}\\ \end{array} \]
Alternative 19
Error17.5
Cost45960
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\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 -221.532771749485:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\phi_1 \leq 9.452911611736827 \cdot 10^{-34}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 20
Error17.4
Cost45960
\[\begin{array}{l} t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\ t_1 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\phi_1 \leq -1352137.2163366585:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot t_0}\\ \mathbf{elif}\;\phi_1 \leq 9.452911611736827 \cdot 10^{-34}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t_1}{\sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t_0}\\ \end{array} \]
Alternative 21
Error18.0
Cost45704
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{if}\;\phi_1 \leq -1352137.2163366585:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\phi_1 \leq 9.452911611736827 \cdot 10^{-34}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 22
Error22.5
Cost39368
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(-\lambda_2\right)}{\sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{if}\;\lambda_2 \leq -5.972940394618287 \cdot 10^{+27}:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\lambda_2 \leq 3.2781418026123373 \cdot 10^{+33}:\\ \;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 - \cos \lambda_1 \cdot \sin \phi_1}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 23
Error21.8
Cost39304
\[\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 - \cos \phi_2 \cdot \sin \phi_1}\\ \mathbf{if}\;\phi_2 \leq -3.669094150931664 \cdot 10^{-9}:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\phi_2 \leq 0.0013637663750267505:\\ \;\;\;\;\tan^{-1}_* \frac{t_0}{\phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 24
Error22.2
Cost39172
\[\begin{array}{l} t_0 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\ \mathbf{if}\;\phi_2 \leq -873.4080055536418:\\ \;\;\;\;\tan^{-1}_* \frac{t_0}{\sin \phi_2 - \cos \lambda_2 \cdot \sin \phi_1}\\ \mathbf{elif}\;\phi_2 \leq 0.0013637663750267505:\\ \;\;\;\;\tan^{-1}_* \frac{t_0}{\phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;\tan^{-1}_* \frac{t_0}{\sin \phi_2}\\ \end{array} \]
Alternative 25
Error22.1
Cost39168
\[\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)} \]
Alternative 26
Error22.2
Cost33032
\[\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 -5.765269933443718 \cdot 10^{-13}:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\phi_2 \leq 0.0013637663750267505:\\ \;\;\;\;\tan^{-1}_* \frac{t_0}{\phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 27
Error22.5
Cost32968
\[\begin{array}{l} t_0 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\ t_1 := \tan^{-1}_* \frac{t_0}{\cos \left(\lambda_1 - \lambda_2\right) \cdot \left(-\sin \phi_1\right)}\\ \mathbf{if}\;\phi_1 \leq -1352137.2163366585:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\phi_1 \leq 63284432278.72814:\\ \;\;\;\;\tan^{-1}_* \frac{t_0}{\sin \phi_2 - \cos \phi_2 \cdot \phi_1}\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 28
Error31.7
Cost32904
\[\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_1 \leq -1352137.2163366585:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\phi_1 \leq 5.302073810009531 \cdot 10^{+30}:\\ \;\;\;\;\tan^{-1}_* \frac{t_0}{\sin \phi_2 - \cos \phi_2 \cdot \phi_1}\\ \mathbf{else}:\\ \;\;\;\;t_1\\ \end{array} \]
Alternative 29
Error35.9
Cost26184
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(-\lambda_2\right)}{\sin \phi_2}\\ \mathbf{if}\;\lambda_2 \leq -3.230952221212637 \cdot 10^{-33}:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\lambda_2 \leq 5.293477623871993 \cdot 10^{-76}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 30
Error39.6
Cost26120
\[\begin{array}{l} t_0 := \tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2}\\ \mathbf{if}\;\lambda_2 \leq -3.230952221212637 \cdot 10^{-33}:\\ \;\;\;\;t_0\\ \mathbf{elif}\;\lambda_2 \leq 5.293477623871993 \cdot 10^{-76}:\\ \;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_2}\\ \mathbf{else}:\\ \;\;\;\;t_0\\ \end{array} \]
Alternative 31
Error32.7
Cost25984
\[\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2} \]
Alternative 32
Error43.4
Cost19456
\[\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2} \]

Error

Reproduce

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