
(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:
Herbie found 27 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(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}
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(atan2
(*
(fma (- (cos lambda1)) (sin lambda2) (* (sin lambda1) (cos lambda2)))
(cos phi2))
(-
(* (sin phi2) (cos phi1))
(fma
(* (sin lambda1) (* (sin lambda2) (sin phi1)))
(cos phi2)
(* (cos lambda1) (* (* (cos phi2) (sin phi1)) (cos lambda2)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((fma(-cos(lambda1), sin(lambda2), (sin(lambda1) * cos(lambda2))) * cos(phi2)), ((sin(phi2) * cos(phi1)) - fma((sin(lambda1) * (sin(lambda2) * sin(phi1))), cos(phi2), (cos(lambda1) * ((cos(phi2) * sin(phi1)) * cos(lambda2))))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(fma(Float64(-cos(lambda1)), sin(lambda2), Float64(sin(lambda1) * cos(lambda2))) * cos(phi2)), Float64(Float64(sin(phi2) * cos(phi1)) - fma(Float64(sin(lambda1) * Float64(sin(lambda2) * sin(phi1))), cos(phi2), Float64(cos(lambda1) * Float64(Float64(cos(phi2) * sin(phi1)) * cos(lambda2)))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[((-N[Cos[lambda1], $MachinePrecision]) * N[Sin[lambda2], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Sin[lambda1], $MachinePrecision] * N[(N[Sin[lambda2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\mathsf{fma}\left(-\cos \lambda_1, \sin \lambda_2, \sin \lambda_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \mathsf{fma}\left(\sin \lambda_1 \cdot \left(\sin \lambda_2 \cdot \sin \phi_1\right), \cos \phi_2, \cos \lambda_1 \cdot \left(\left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \lambda_2\right)\right)}
\end{array}
Initial program 79.4%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6488.7
Applied rewrites88.7%
lift-*.f64N/A
lift-cos.f64N/A
lift--.f64N/A
cos-diffN/A
distribute-lft-inN/A
lower-+.f64N/A
lower-*.f64N/A
lift-cos.f64N/A
lift-cos.f64N/A
lower-*.f64N/A
lower-*.f64N/A
lift-sin.f64N/A
lift-sin.f64N/A
*-commutativeN/A
lower-*.f6499.7
Applied rewrites99.7%
Taylor expanded in lambda1 around 0
lower-atan2.f64N/A
Applied rewrites99.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(atan2
(*
(fma (- (cos lambda1)) (sin lambda2) (* (sin lambda1) (cos lambda2)))
(cos phi2))
(-
(* (sin phi2) (cos phi1))
(*
(sin phi1)
(fma
(* (sin lambda2) (sin lambda1))
(cos phi2)
(* (* (cos lambda2) (cos lambda1)) (cos phi2)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((fma(-cos(lambda1), sin(lambda2), (sin(lambda1) * cos(lambda2))) * cos(phi2)), ((sin(phi2) * cos(phi1)) - (sin(phi1) * fma((sin(lambda2) * sin(lambda1)), cos(phi2), ((cos(lambda2) * cos(lambda1)) * cos(phi2))))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(fma(Float64(-cos(lambda1)), sin(lambda2), Float64(sin(lambda1) * cos(lambda2))) * cos(phi2)), Float64(Float64(sin(phi2) * cos(phi1)) - Float64(sin(phi1) * fma(Float64(sin(lambda2) * sin(lambda1)), cos(phi2), Float64(Float64(cos(lambda2) * cos(lambda1)) * cos(phi2)))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[((-N[Cos[lambda1], $MachinePrecision]) * N[Sin[lambda2], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[(N[(N[Sin[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision] + N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\mathsf{fma}\left(-\cos \lambda_1, \sin \lambda_2, \sin \lambda_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \mathsf{fma}\left(\sin \lambda_2 \cdot \sin \lambda_1, \cos \phi_2, \left(\cos \lambda_2 \cdot \cos \lambda_1\right) \cdot \cos \phi_2\right)}
\end{array}
Initial program 79.4%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6488.7
Applied rewrites88.7%
lift-*.f64N/A
lift-cos.f64N/A
lift--.f64N/A
cos-diffN/A
distribute-lft-inN/A
lower-+.f64N/A
lower-*.f64N/A
lift-cos.f64N/A
lift-cos.f64N/A
lower-*.f64N/A
lower-*.f64N/A
lift-sin.f64N/A
lift-sin.f64N/A
*-commutativeN/A
lower-*.f6499.7
Applied rewrites99.7%
Taylor expanded in lambda1 around 0
lower-atan2.f64N/A
Applied rewrites99.7%
Applied rewrites99.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(atan2
(*
(fma (sin lambda1) (cos lambda2) (* (- (sin lambda2)) (cos lambda1)))
(cos phi2))
(-
(* (cos phi1) (sin phi2))
(*
(* (sin phi1) (cos phi2))
(fma (sin lambda2) (sin lambda1) (* (cos lambda1) (cos 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)) - ((sin(phi1) * cos(phi2)) * fma(sin(lambda2), sin(lambda1), (cos(lambda1) * cos(lambda2))))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(fma(sin(lambda1), cos(lambda2), Float64(Float64(-sin(lambda2)) * cos(lambda1))) * cos(phi2)), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(sin(phi1) * cos(phi2)) * fma(sin(lambda2), sin(lambda1), Float64(cos(lambda1) * cos(lambda2)))))) end
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[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[(N[Sin[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\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 \mathsf{fma}\left(\sin \lambda_2, \sin \lambda_1, \cos \lambda_1 \cdot \cos \lambda_2\right)}
\end{array}
Initial program 79.4%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6488.7
Applied rewrites88.7%
lift-cos.f64N/A
lift--.f64N/A
cos-diffN/A
+-commutativeN/A
lift-sin.f64N/A
lift-sin.f64N/A
*-commutativeN/A
lower-fma.f64N/A
lift-cos.f64N/A
lift-cos.f64N/A
lower-*.f6499.7
Applied rewrites99.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0
(-
(* (cos phi1) (sin phi2))
(* (* (sin phi1) (cos phi2)) (cos (- lambda1 lambda2)))))
(t_1 (- (cos lambda1))))
(if (<= phi2 -5e-6)
(atan2
(fma
(* t_1 (sin lambda2))
(cos phi2)
(* (* (cos lambda2) (sin lambda1)) (cos phi2)))
t_0)
(if (<= phi2 2.15e-8)
(atan2
(* (fma t_1 (sin lambda2) (* (sin lambda1) (cos lambda2))) (cos phi2))
(-
(* (sin phi2) (cos phi1))
(*
(sin phi1)
(fma (sin lambda2) (sin lambda1) (* (cos lambda1) (cos lambda2))))))
(atan2
(*
(fma (sin lambda1) (cos lambda2) (* (- (sin lambda2)) (cos lambda1)))
(cos phi2))
t_0)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = (cos(phi1) * sin(phi2)) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2)));
double t_1 = -cos(lambda1);
double tmp;
if (phi2 <= -5e-6) {
tmp = atan2(fma((t_1 * sin(lambda2)), cos(phi2), ((cos(lambda2) * sin(lambda1)) * cos(phi2))), t_0);
} else if (phi2 <= 2.15e-8) {
tmp = atan2((fma(t_1, sin(lambda2), (sin(lambda1) * cos(lambda2))) * cos(phi2)), ((sin(phi2) * cos(phi1)) - (sin(phi1) * fma(sin(lambda2), sin(lambda1), (cos(lambda1) * cos(lambda2))))));
} else {
tmp = atan2((fma(sin(lambda1), cos(lambda2), (-sin(lambda2) * cos(lambda1))) * cos(phi2)), t_0);
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(sin(phi1) * cos(phi2)) * cos(Float64(lambda1 - lambda2)))) t_1 = Float64(-cos(lambda1)) tmp = 0.0 if (phi2 <= -5e-6) tmp = atan(fma(Float64(t_1 * sin(lambda2)), cos(phi2), Float64(Float64(cos(lambda2) * sin(lambda1)) * cos(phi2))), t_0); elseif (phi2 <= 2.15e-8) tmp = atan(Float64(fma(t_1, sin(lambda2), Float64(sin(lambda1) * cos(lambda2))) * cos(phi2)), Float64(Float64(sin(phi2) * cos(phi1)) - Float64(sin(phi1) * fma(sin(lambda2), sin(lambda1), Float64(cos(lambda1) * cos(lambda2)))))); else tmp = atan(Float64(fma(sin(lambda1), cos(lambda2), Float64(Float64(-sin(lambda2)) * cos(lambda1))) * cos(phi2)), t_0); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = 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]}, Block[{t$95$1 = (-N[Cos[lambda1], $MachinePrecision])}, If[LessEqual[phi2, -5e-6], N[ArcTan[N[(N[(t$95$1 * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision] + N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / t$95$0], $MachinePrecision], If[LessEqual[phi2, 2.15e-8], N[ArcTan[N[(N[(t$95$1 * N[Sin[lambda2], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[(N[Sin[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], 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] / t$95$0], $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
t_1 := -\cos \lambda_1\\
\mathbf{if}\;\phi_2 \leq -5 \cdot 10^{-6}:\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(t\_1 \cdot \sin \lambda_2, \cos \phi_2, \left(\cos \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2\right)}{t\_0}\\
\mathbf{elif}\;\phi_2 \leq 2.15 \cdot 10^{-8}:\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(t\_1, \sin \lambda_2, \sin \lambda_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \mathsf{fma}\left(\sin \lambda_2, \sin \lambda_1, \cos \lambda_1 \cdot \cos \lambda_2\right)}\\
\mathbf{else}:\\
\;\;\;\;\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}{t\_0}\\
\end{array}
\end{array}
if phi2 < -5.00000000000000041e-6Initial program 78.7%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6491.0
Applied rewrites91.0%
lift-*.f64N/A
*-commutativeN/A
lift-fma.f64N/A
+-commutativeN/A
distribute-rgt-inN/A
lower-fma.f64N/A
lift-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f6491.0
Applied rewrites91.0%
if -5.00000000000000041e-6 < phi2 < 2.1500000000000001e-8Initial program 81.5%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6487.3
Applied rewrites87.3%
lift-*.f64N/A
lift-cos.f64N/A
lift--.f64N/A
cos-diffN/A
distribute-lft-inN/A
lower-+.f64N/A
lower-*.f64N/A
lift-cos.f64N/A
lift-cos.f64N/A
lower-*.f64N/A
lower-*.f64N/A
lift-sin.f64N/A
lift-sin.f64N/A
*-commutativeN/A
lower-*.f6499.9
Applied rewrites99.9%
Taylor expanded in lambda1 around 0
lower-atan2.f64N/A
Applied rewrites99.9%
Taylor expanded in phi2 around 0
Applied rewrites99.9%
if 2.1500000000000001e-8 < phi2 Initial program 75.5%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6489.4
Applied rewrites89.4%
Final simplification95.3%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (fma (* (- (cos lambda1)) (sin lambda2)) (cos phi2) (* (* (cos lambda2) (sin lambda1)) (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((-cos(lambda1) * sin(lambda2)), cos(phi2), ((cos(lambda2) * sin(lambda1)) * cos(phi2))), ((cos(phi1) * sin(phi2)) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2)))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(fma(Float64(Float64(-cos(lambda1)) * sin(lambda2)), cos(phi2), Float64(Float64(cos(lambda2) * sin(lambda1)) * cos(phi2))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(sin(phi1) * cos(phi2)) * cos(Float64(lambda1 - lambda2))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[((-N[Cos[lambda1], $MachinePrecision]) * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision] + N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $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{\mathsf{fma}\left(\left(-\cos \lambda_1\right) \cdot \sin \lambda_2, \cos \phi_2, \left(\cos \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \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)}
\end{array}
Initial program 79.4%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6488.7
Applied rewrites88.7%
lift-*.f64N/A
*-commutativeN/A
lift-fma.f64N/A
+-commutativeN/A
distribute-rgt-inN/A
lower-fma.f64N/A
lift-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f6488.7
Applied rewrites88.7%
Final simplification88.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2)))
(t_1
(*
(fma (sin lambda1) (cos lambda2) (* (- (sin lambda2)) (cos lambda1)))
(cos phi2))))
(if (or (<= lambda2 -2.35e-7) (not (<= lambda2 2400000.0)))
(atan2 t_1 (- t_0 (* (* (cos lambda2) (sin phi1)) (cos phi2))))
(atan2 t_1 (- t_0 (* (* (sin phi1) (cos phi2)) (cos lambda1)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double t_1 = fma(sin(lambda1), cos(lambda2), (-sin(lambda2) * cos(lambda1))) * cos(phi2);
double tmp;
if ((lambda2 <= -2.35e-7) || !(lambda2 <= 2400000.0)) {
tmp = atan2(t_1, (t_0 - ((cos(lambda2) * sin(phi1)) * cos(phi2))));
} else {
tmp = atan2(t_1, (t_0 - ((sin(phi1) * cos(phi2)) * cos(lambda1))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = Float64(fma(sin(lambda1), cos(lambda2), Float64(Float64(-sin(lambda2)) * cos(lambda1))) * cos(phi2)) tmp = 0.0 if ((lambda2 <= -2.35e-7) || !(lambda2 <= 2400000.0)) tmp = atan(t_1, Float64(t_0 - Float64(Float64(cos(lambda2) * sin(phi1)) * cos(phi2)))); else tmp = atan(t_1, Float64(t_0 - Float64(Float64(sin(phi1) * cos(phi2)) * cos(lambda1)))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = 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]}, If[Or[LessEqual[lambda2, -2.35e-7], N[Not[LessEqual[lambda2, 2400000.0]], $MachinePrecision]], N[ArcTan[t$95$1 / N[(t$95$0 - N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / N[(t$95$0 - N[(N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
t_1 := \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2\\
\mathbf{if}\;\lambda_2 \leq -2.35 \cdot 10^{-7} \lor \neg \left(\lambda_2 \leq 2400000\right):\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \left(\cos \lambda_2 \cdot \sin \phi_1\right) \cdot \cos \phi_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \lambda_1}\\
\end{array}
\end{array}
if lambda2 < -2.35e-7 or 2.4e6 < lambda2 Initial program 61.1%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6479.2
Applied rewrites79.2%
Taylor expanded in lambda1 around 0
*-commutativeN/A
lower-*.f64N/A
lower-*.f64N/A
cos-negN/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-cos.f6479.4
Applied rewrites79.4%
if -2.35e-7 < lambda2 < 2.4e6Initial program 98.3%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6498.4
Applied rewrites98.4%
Taylor expanded in lambda2 around 0
*-commutativeN/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
lower-cos.f6498.4
Applied rewrites98.4%
Final simplification88.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(if (or (<= lambda2 -2.35e-7) (not (<= lambda2 2400000.0)))
(atan2
(*
(fma (sin lambda1) (cos lambda2) (* (- (sin lambda2)) (cos lambda1)))
(cos phi2))
(- (* (cos phi1) (sin phi2)) (* (* (cos lambda2) (sin phi1)) (cos phi2))))
(atan2
(*
(fma (- (cos lambda1)) (sin lambda2) (* (sin lambda1) (cos lambda2)))
(cos phi2))
(-
(* (sin phi2) (cos phi1))
(* (* (sin phi1) (cos phi2)) (cos lambda1))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((lambda2 <= -2.35e-7) || !(lambda2 <= 2400000.0)) {
tmp = atan2((fma(sin(lambda1), cos(lambda2), (-sin(lambda2) * cos(lambda1))) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((cos(lambda2) * sin(phi1)) * cos(phi2))));
} else {
tmp = atan2((fma(-cos(lambda1), sin(lambda2), (sin(lambda1) * cos(lambda2))) * cos(phi2)), ((sin(phi2) * cos(phi1)) - ((sin(phi1) * cos(phi2)) * cos(lambda1))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if ((lambda2 <= -2.35e-7) || !(lambda2 <= 2400000.0)) tmp = atan(Float64(fma(sin(lambda1), cos(lambda2), Float64(Float64(-sin(lambda2)) * cos(lambda1))) * cos(phi2)), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(lambda2) * sin(phi1)) * cos(phi2)))); else tmp = atan(Float64(fma(Float64(-cos(lambda1)), sin(lambda2), Float64(sin(lambda1) * cos(lambda2))) * cos(phi2)), Float64(Float64(sin(phi2) * cos(phi1)) - Float64(Float64(sin(phi1) * cos(phi2)) * cos(lambda1)))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := If[Or[LessEqual[lambda2, -2.35e-7], N[Not[LessEqual[lambda2, 2400000.0]], $MachinePrecision]], 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[lambda2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[((-N[Cos[lambda1], $MachinePrecision]) * N[Sin[lambda2], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\lambda_2 \leq -2.35 \cdot 10^{-7} \lor \neg \left(\lambda_2 \leq 2400000\right):\\
\;\;\;\;\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(\cos \lambda_2 \cdot \sin \phi_1\right) \cdot \cos \phi_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(-\cos \lambda_1, \sin \lambda_2, \sin \lambda_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \lambda_1}\\
\end{array}
\end{array}
if lambda2 < -2.35e-7 or 2.4e6 < lambda2 Initial program 61.1%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6479.2
Applied rewrites79.2%
Taylor expanded in lambda1 around 0
*-commutativeN/A
lower-*.f64N/A
lower-*.f64N/A
cos-negN/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-cos.f6479.4
Applied rewrites79.4%
if -2.35e-7 < lambda2 < 2.4e6Initial program 98.3%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6498.4
Applied rewrites98.4%
lift-*.f64N/A
lift-cos.f64N/A
lift--.f64N/A
cos-diffN/A
distribute-lft-inN/A
lower-+.f64N/A
lower-*.f64N/A
lift-cos.f64N/A
lift-cos.f64N/A
lower-*.f64N/A
lower-*.f64N/A
lift-sin.f64N/A
lift-sin.f64N/A
*-commutativeN/A
lower-*.f6499.7
Applied rewrites99.7%
Taylor expanded in lambda1 around 0
lower-atan2.f64N/A
Applied rewrites99.7%
Taylor expanded in lambda2 around 0
Applied rewrites98.4%
Final simplification88.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (sin phi1) (cos phi2))))
(if (or (<= lambda1 -6e-7) (not (<= lambda1 5.2e-7)))
(atan2
(*
(fma (- (cos lambda1)) (sin lambda2) (* (sin lambda1) (cos lambda2)))
(cos phi2))
(- (* (sin phi2) (cos phi1)) (* t_0 (cos lambda1))))
(atan2
(* (sin (- lambda1 lambda2)) (cos phi2))
(-
(* (cos phi1) (sin phi2))
(* t_0 (fma (sin lambda2) lambda1 (cos lambda2))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = sin(phi1) * cos(phi2);
double tmp;
if ((lambda1 <= -6e-7) || !(lambda1 <= 5.2e-7)) {
tmp = atan2((fma(-cos(lambda1), sin(lambda2), (sin(lambda1) * cos(lambda2))) * cos(phi2)), ((sin(phi2) * cos(phi1)) - (t_0 * cos(lambda1))));
} else {
tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), ((cos(phi1) * sin(phi2)) - (t_0 * fma(sin(lambda2), lambda1, cos(lambda2)))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(sin(phi1) * cos(phi2)) tmp = 0.0 if ((lambda1 <= -6e-7) || !(lambda1 <= 5.2e-7)) tmp = atan(Float64(fma(Float64(-cos(lambda1)), sin(lambda2), Float64(sin(lambda1) * cos(lambda2))) * cos(phi2)), Float64(Float64(sin(phi2) * cos(phi1)) - Float64(t_0 * cos(lambda1)))); else tmp = atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(t_0 * fma(sin(lambda2), lambda1, cos(lambda2))))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]}, If[Or[LessEqual[lambda1, -6e-7], N[Not[LessEqual[lambda1, 5.2e-7]], $MachinePrecision]], N[ArcTan[N[(N[((-N[Cos[lambda1], $MachinePrecision]) * N[Sin[lambda2], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(t$95$0 * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], 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[(t$95$0 * N[(N[Sin[lambda2], $MachinePrecision] * lambda1 + N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \sin \phi_1 \cdot \cos \phi_2\\
\mathbf{if}\;\lambda_1 \leq -6 \cdot 10^{-7} \lor \neg \left(\lambda_1 \leq 5.2 \cdot 10^{-7}\right):\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(-\cos \lambda_1, \sin \lambda_2, \sin \lambda_1 \cdot \cos \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 \cdot \cos \phi_1 - t\_0 \cdot \cos \lambda_1}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - t\_0 \cdot \mathsf{fma}\left(\sin \lambda_2, \lambda_1, \cos \lambda_2\right)}\\
\end{array}
\end{array}
if lambda1 < -5.9999999999999997e-7 or 5.19999999999999998e-7 < lambda1 Initial program 60.4%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6478.5
Applied rewrites78.5%
lift-*.f64N/A
lift-cos.f64N/A
lift--.f64N/A
cos-diffN/A
distribute-lft-inN/A
lower-+.f64N/A
lower-*.f64N/A
lift-cos.f64N/A
lift-cos.f64N/A
lower-*.f64N/A
lower-*.f64N/A
lift-sin.f64N/A
lift-sin.f64N/A
*-commutativeN/A
lower-*.f6499.8
Applied rewrites99.8%
Taylor expanded in lambda1 around 0
lower-atan2.f64N/A
Applied rewrites99.8%
Taylor expanded in lambda2 around 0
Applied rewrites78.4%
if -5.9999999999999997e-7 < lambda1 < 5.19999999999999998e-7Initial program 99.3%
Taylor expanded in lambda1 around 0
+-commutativeN/A
mul-1-negN/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
remove-double-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
cos-negN/A
lower-cos.f6499.4
Applied rewrites99.4%
Final simplification88.6%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2)))
(t_1
(*
(fma (sin lambda1) (cos lambda2) (* (- (sin lambda2)) (cos lambda1)))
(cos phi2))))
(if (<= lambda2 -2.35e-7)
(atan2 t_1 (- t_0 (* (* (cos lambda2) (sin phi1)) (cos phi2))))
(if (<= lambda2 2400000.0)
(atan2 t_1 (- t_0 (* (* (sin phi1) (cos phi2)) (cos lambda1))))
(atan2 t_1 (- t_0 (* (* (cos phi2) (sin phi1)) (cos lambda2))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double t_1 = fma(sin(lambda1), cos(lambda2), (-sin(lambda2) * cos(lambda1))) * cos(phi2);
double tmp;
if (lambda2 <= -2.35e-7) {
tmp = atan2(t_1, (t_0 - ((cos(lambda2) * sin(phi1)) * cos(phi2))));
} else if (lambda2 <= 2400000.0) {
tmp = atan2(t_1, (t_0 - ((sin(phi1) * cos(phi2)) * cos(lambda1))));
} else {
tmp = atan2(t_1, (t_0 - ((cos(phi2) * sin(phi1)) * cos(lambda2))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = Float64(fma(sin(lambda1), cos(lambda2), Float64(Float64(-sin(lambda2)) * cos(lambda1))) * cos(phi2)) tmp = 0.0 if (lambda2 <= -2.35e-7) tmp = atan(t_1, Float64(t_0 - Float64(Float64(cos(lambda2) * sin(phi1)) * cos(phi2)))); elseif (lambda2 <= 2400000.0) tmp = atan(t_1, Float64(t_0 - Float64(Float64(sin(phi1) * cos(phi2)) * cos(lambda1)))); else tmp = atan(t_1, Float64(t_0 - Float64(Float64(cos(phi2) * sin(phi1)) * cos(lambda2)))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = 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]}, If[LessEqual[lambda2, -2.35e-7], N[ArcTan[t$95$1 / N[(t$95$0 - N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda2, 2400000.0], N[ArcTan[t$95$1 / N[(t$95$0 - N[(N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / N[(t$95$0 - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
t_1 := \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \left(-\sin \lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2\\
\mathbf{if}\;\lambda_2 \leq -2.35 \cdot 10^{-7}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \left(\cos \lambda_2 \cdot \sin \phi_1\right) \cdot \cos \phi_2}\\
\mathbf{elif}\;\lambda_2 \leq 2400000:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \lambda_1}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \lambda_2}\\
\end{array}
\end{array}
if lambda2 < -2.35e-7Initial program 61.3%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6480.1
Applied rewrites80.1%
Taylor expanded in lambda1 around 0
*-commutativeN/A
lower-*.f64N/A
lower-*.f64N/A
cos-negN/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-cos.f6480.1
Applied rewrites80.1%
if -2.35e-7 < lambda2 < 2.4e6Initial program 98.3%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6498.4
Applied rewrites98.4%
Taylor expanded in lambda2 around 0
*-commutativeN/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
lower-cos.f6498.4
Applied rewrites98.4%
if 2.4e6 < lambda2 Initial program 60.9%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6478.1
Applied rewrites78.1%
lift-*.f64N/A
lift-cos.f64N/A
lift--.f64N/A
cos-diffN/A
distribute-lft-inN/A
lower-+.f64N/A
lower-*.f64N/A
lift-cos.f64N/A
lift-cos.f64N/A
lower-*.f64N/A
lower-*.f64N/A
lift-sin.f64N/A
lift-sin.f64N/A
*-commutativeN/A
lower-*.f6499.7
Applied rewrites99.7%
Taylor expanded in lambda1 around 0
*-commutativeN/A
lower-*.f64N/A
lower-*.f64N/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-cos.f6478.4
Applied rewrites78.4%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (fma (sin lambda1) (cos lambda2) (* (- (sin lambda2)) (cos lambda1))) (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)) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2)))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(fma(sin(lambda1), cos(lambda2), Float64(Float64(-sin(lambda2)) * cos(lambda1))) * cos(phi2)), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(sin(phi1) * cos(phi2)) * cos(Float64(lambda1 - lambda2))))) end
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[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\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 \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
Initial program 79.4%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6488.7
Applied rewrites88.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (- (sin phi1)))
(t_1 (* (sin phi2) (cos phi1)))
(t_2 (sin (- lambda1 lambda2))))
(if (<= phi1 -0.011)
(atan2
(* (cos phi2) t_2)
(fma (* t_0 (cos (- lambda1 lambda2))) (cos phi2) t_1))
(if (<= phi1 7.2e-9)
(atan2
(*
(fma (sin lambda1) (cos lambda2) (* (- (sin lambda2)) (cos lambda1)))
(cos phi2))
(- (sin phi2) (* (* (sin phi1) (cos phi2)) (cos lambda1))))
(atan2
(* t_2 (cos phi2))
(fma t_0 (* (cos (- lambda2 lambda1)) (cos phi2)) t_1))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = -sin(phi1);
double t_1 = sin(phi2) * cos(phi1);
double t_2 = sin((lambda1 - lambda2));
double tmp;
if (phi1 <= -0.011) {
tmp = atan2((cos(phi2) * t_2), fma((t_0 * cos((lambda1 - lambda2))), cos(phi2), t_1));
} else if (phi1 <= 7.2e-9) {
tmp = atan2((fma(sin(lambda1), cos(lambda2), (-sin(lambda2) * cos(lambda1))) * cos(phi2)), (sin(phi2) - ((sin(phi1) * cos(phi2)) * cos(lambda1))));
} else {
tmp = atan2((t_2 * cos(phi2)), fma(t_0, (cos((lambda2 - lambda1)) * cos(phi2)), t_1));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(-sin(phi1)) t_1 = Float64(sin(phi2) * cos(phi1)) t_2 = sin(Float64(lambda1 - lambda2)) tmp = 0.0 if (phi1 <= -0.011) tmp = atan(Float64(cos(phi2) * t_2), fma(Float64(t_0 * cos(Float64(lambda1 - lambda2))), cos(phi2), t_1)); elseif (phi1 <= 7.2e-9) tmp = atan(Float64(fma(sin(lambda1), cos(lambda2), Float64(Float64(-sin(lambda2)) * cos(lambda1))) * cos(phi2)), Float64(sin(phi2) - Float64(Float64(sin(phi1) * cos(phi2)) * cos(lambda1)))); else tmp = atan(Float64(t_2 * cos(phi2)), fma(t_0, Float64(cos(Float64(lambda2 - lambda1)) * cos(phi2)), t_1)); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = (-N[Sin[phi1], $MachinePrecision])}, Block[{t$95$1 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi1, -0.011], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * t$95$2), $MachinePrecision] / N[(N[(t$95$0 * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision] + t$95$1), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi1, 7.2e-9], 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[Sin[phi2], $MachinePrecision] - N[(N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(t$95$2 * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 * N[(N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] + t$95$1), $MachinePrecision]], $MachinePrecision]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := -\sin \phi_1\\
t_1 := \sin \phi_2 \cdot \cos \phi_1\\
t_2 := \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_1 \leq -0.011:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot t\_2}{\mathsf{fma}\left(t\_0 \cdot \cos \left(\lambda_1 - \lambda_2\right), \cos \phi_2, t\_1\right)}\\
\mathbf{elif}\;\phi_1 \leq 7.2 \cdot 10^{-9}:\\
\;\;\;\;\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}{\sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \lambda_1}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2 \cdot \cos \phi_2}{\mathsf{fma}\left(t\_0, \cos \left(\lambda_2 - \lambda_1\right) \cdot \cos \phi_2, t\_1\right)}\\
\end{array}
\end{array}
if phi1 < -0.010999999999999999Initial program 83.4%
lift-*.f64N/A
*-commutativeN/A
lower-*.f6483.4
lift--.f64N/A
sub-negN/A
+-commutativeN/A
lift-*.f64N/A
lift-*.f64N/A
associate-*l*N/A
distribute-lft-neg-inN/A
*-commutativeN/A
associate-*r*N/A
lower-fma.f64N/A
Applied rewrites83.5%
if -0.010999999999999999 < phi1 < 7.2e-9Initial program 83.7%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6499.8
Applied rewrites99.8%
Taylor expanded in phi1 around 0
lower-sin.f6499.8
Applied rewrites99.8%
Taylor expanded in lambda2 around 0
lower-cos.f6499.8
Applied rewrites99.8%
if 7.2e-9 < phi1 Initial program 69.2%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6472.7
Applied rewrites72.7%
Applied rewrites69.2%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (- (sin phi1)))
(t_1 (cos (- lambda1 lambda2)))
(t_2 (* (sin phi2) (cos phi1)))
(t_3 (sin (- lambda1 lambda2))))
(if (<= phi1 -3.1e-12)
(atan2 (* (cos phi2) t_3) (fma (* t_0 t_1) (cos phi2) t_2))
(if (<= phi1 1.75e-9)
(atan2
(*
(fma (sin lambda2) (- (cos lambda1)) (* (cos lambda2) (sin lambda1)))
(cos phi2))
(- (sin phi2) (* (sin phi1) t_1)))
(atan2
(* t_3 (cos phi2))
(fma t_0 (* (cos (- lambda2 lambda1)) (cos phi2)) t_2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = -sin(phi1);
double t_1 = cos((lambda1 - lambda2));
double t_2 = sin(phi2) * cos(phi1);
double t_3 = sin((lambda1 - lambda2));
double tmp;
if (phi1 <= -3.1e-12) {
tmp = atan2((cos(phi2) * t_3), fma((t_0 * t_1), cos(phi2), t_2));
} else if (phi1 <= 1.75e-9) {
tmp = atan2((fma(sin(lambda2), -cos(lambda1), (cos(lambda2) * sin(lambda1))) * cos(phi2)), (sin(phi2) - (sin(phi1) * t_1)));
} else {
tmp = atan2((t_3 * cos(phi2)), fma(t_0, (cos((lambda2 - lambda1)) * cos(phi2)), t_2));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(-sin(phi1)) t_1 = cos(Float64(lambda1 - lambda2)) t_2 = Float64(sin(phi2) * cos(phi1)) t_3 = sin(Float64(lambda1 - lambda2)) tmp = 0.0 if (phi1 <= -3.1e-12) tmp = atan(Float64(cos(phi2) * t_3), fma(Float64(t_0 * t_1), cos(phi2), t_2)); elseif (phi1 <= 1.75e-9) tmp = atan(Float64(fma(sin(lambda2), Float64(-cos(lambda1)), Float64(cos(lambda2) * sin(lambda1))) * cos(phi2)), Float64(sin(phi2) - Float64(sin(phi1) * t_1))); else tmp = atan(Float64(t_3 * cos(phi2)), fma(t_0, Float64(cos(Float64(lambda2 - lambda1)) * cos(phi2)), t_2)); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = (-N[Sin[phi1], $MachinePrecision])}, Block[{t$95$1 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi1, -3.1e-12], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * t$95$3), $MachinePrecision] / N[(N[(t$95$0 * t$95$1), $MachinePrecision] * N[Cos[phi2], $MachinePrecision] + t$95$2), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi1, 1.75e-9], N[ArcTan[N[(N[(N[Sin[lambda2], $MachinePrecision] * (-N[Cos[lambda1], $MachinePrecision]) + N[(N[Cos[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(t$95$3 * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 * N[(N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] + t$95$2), $MachinePrecision]], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := -\sin \phi_1\\
t_1 := \cos \left(\lambda_1 - \lambda_2\right)\\
t_2 := \sin \phi_2 \cdot \cos \phi_1\\
t_3 := \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_1 \leq -3.1 \cdot 10^{-12}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot t\_3}{\mathsf{fma}\left(t\_0 \cdot t\_1, \cos \phi_2, t\_2\right)}\\
\mathbf{elif}\;\phi_1 \leq 1.75 \cdot 10^{-9}:\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_2, -\cos \lambda_1, \cos \lambda_2 \cdot \sin \lambda_1\right) \cdot \cos \phi_2}{\sin \phi_2 - \sin \phi_1 \cdot t\_1}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_3 \cdot \cos \phi_2}{\mathsf{fma}\left(t\_0, \cos \left(\lambda_2 - \lambda_1\right) \cdot \cos \phi_2, t\_2\right)}\\
\end{array}
\end{array}
if phi1 < -3.1000000000000001e-12Initial program 84.3%
lift-*.f64N/A
*-commutativeN/A
lower-*.f6484.3
lift--.f64N/A
sub-negN/A
+-commutativeN/A
lift-*.f64N/A
lift-*.f64N/A
associate-*l*N/A
distribute-lft-neg-inN/A
*-commutativeN/A
associate-*r*N/A
lower-fma.f64N/A
Applied rewrites84.3%
if -3.1000000000000001e-12 < phi1 < 1.75e-9Initial program 83.3%
Taylor expanded in phi1 around 0
lower-sin.f6483.3
Applied rewrites83.3%
Taylor expanded in phi2 around 0
lower-sin.f6483.3
Applied rewrites83.3%
lift--.f64N/A
flip--N/A
div-invN/A
lower-*.f64N/A
difference-of-squaresN/A
lift--.f64N/A
lower-*.f64N/A
+-commutativeN/A
lower-+.f64N/A
inv-powN/A
lower-pow.f64N/A
+-commutativeN/A
lower-+.f6445.7
Applied rewrites45.7%
lift-sin.f64N/A
lift-*.f64N/A
lift-pow.f64N/A
unpow-1N/A
un-div-invN/A
lift-*.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift--.f64N/A
difference-of-squaresN/A
lift-+.f64N/A
+-commutativeN/A
flip--N/A
sin-diffN/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
cancel-sign-sub-invN/A
Applied rewrites99.8%
if 1.75e-9 < phi1 Initial program 69.2%
lift-sin.f64N/A
lift--.f64N/A
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
sin-negN/A
lower-*.f64N/A
sin-negN/A
lower-neg.f64N/A
lower-sin.f64N/A
lower-cos.f6472.7
Applied rewrites72.7%
Applied rewrites69.2%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2)))
(t_1
(atan2
(* (sin (- lambda2)) (cos phi2))
(- t_0 (* (* (cos lambda2) (sin phi1)) (cos phi2)))))
(t_2 (cos (- lambda1 lambda2))))
(if (<= lambda2 -2.8e+41)
t_1
(if (<= lambda2 -1.25e-107)
(atan2
(* (sin (- lambda1 lambda2)) (cos phi2))
(-
(sin phi2)
(* (* (+ (sin (+ phi1 phi2)) (sin (- phi1 phi2))) 0.5) t_2)))
(if (<= lambda2 1.75e-98)
(atan2
(* (sin lambda1) (cos phi2))
(- t_0 (* (* (sin phi1) (cos phi2)) t_2)))
t_1)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double t_1 = atan2((sin(-lambda2) * cos(phi2)), (t_0 - ((cos(lambda2) * sin(phi1)) * cos(phi2))));
double t_2 = cos((lambda1 - lambda2));
double tmp;
if (lambda2 <= -2.8e+41) {
tmp = t_1;
} else if (lambda2 <= -1.25e-107) {
tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (sin(phi2) - (((sin((phi1 + phi2)) + sin((phi1 - phi2))) * 0.5) * t_2)));
} else if (lambda2 <= 1.75e-98) {
tmp = atan2((sin(lambda1) * cos(phi2)), (t_0 - ((sin(phi1) * cos(phi2)) * t_2)));
} 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) :: t_2
real(8) :: tmp
t_0 = cos(phi1) * sin(phi2)
t_1 = atan2((sin(-lambda2) * cos(phi2)), (t_0 - ((cos(lambda2) * sin(phi1)) * cos(phi2))))
t_2 = cos((lambda1 - lambda2))
if (lambda2 <= (-2.8d+41)) then
tmp = t_1
else if (lambda2 <= (-1.25d-107)) then
tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (sin(phi2) - (((sin((phi1 + phi2)) + sin((phi1 - phi2))) * 0.5d0) * t_2)))
else if (lambda2 <= 1.75d-98) then
tmp = atan2((sin(lambda1) * cos(phi2)), (t_0 - ((sin(phi1) * cos(phi2)) * t_2)))
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.cos(phi1) * Math.sin(phi2);
double t_1 = Math.atan2((Math.sin(-lambda2) * Math.cos(phi2)), (t_0 - ((Math.cos(lambda2) * Math.sin(phi1)) * Math.cos(phi2))));
double t_2 = Math.cos((lambda1 - lambda2));
double tmp;
if (lambda2 <= -2.8e+41) {
tmp = t_1;
} else if (lambda2 <= -1.25e-107) {
tmp = Math.atan2((Math.sin((lambda1 - lambda2)) * Math.cos(phi2)), (Math.sin(phi2) - (((Math.sin((phi1 + phi2)) + Math.sin((phi1 - phi2))) * 0.5) * t_2)));
} else if (lambda2 <= 1.75e-98) {
tmp = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (t_0 - ((Math.sin(phi1) * Math.cos(phi2)) * t_2)));
} else {
tmp = t_1;
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi1) * math.sin(phi2) t_1 = math.atan2((math.sin(-lambda2) * math.cos(phi2)), (t_0 - ((math.cos(lambda2) * math.sin(phi1)) * math.cos(phi2)))) t_2 = math.cos((lambda1 - lambda2)) tmp = 0 if lambda2 <= -2.8e+41: tmp = t_1 elif lambda2 <= -1.25e-107: tmp = math.atan2((math.sin((lambda1 - lambda2)) * math.cos(phi2)), (math.sin(phi2) - (((math.sin((phi1 + phi2)) + math.sin((phi1 - phi2))) * 0.5) * t_2))) elif lambda2 <= 1.75e-98: tmp = math.atan2((math.sin(lambda1) * math.cos(phi2)), (t_0 - ((math.sin(phi1) * math.cos(phi2)) * t_2))) else: tmp = t_1 return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = atan(Float64(sin(Float64(-lambda2)) * cos(phi2)), Float64(t_0 - Float64(Float64(cos(lambda2) * sin(phi1)) * cos(phi2)))) t_2 = cos(Float64(lambda1 - lambda2)) tmp = 0.0 if (lambda2 <= -2.8e+41) tmp = t_1; elseif (lambda2 <= -1.25e-107) tmp = atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), Float64(sin(phi2) - Float64(Float64(Float64(sin(Float64(phi1 + phi2)) + sin(Float64(phi1 - phi2))) * 0.5) * t_2))); elseif (lambda2 <= 1.75e-98) tmp = atan(Float64(sin(lambda1) * cos(phi2)), Float64(t_0 - Float64(Float64(sin(phi1) * cos(phi2)) * t_2))); else tmp = t_1; end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos(phi1) * sin(phi2); t_1 = atan2((sin(-lambda2) * cos(phi2)), (t_0 - ((cos(lambda2) * sin(phi1)) * cos(phi2)))); t_2 = cos((lambda1 - lambda2)); tmp = 0.0; if (lambda2 <= -2.8e+41) tmp = t_1; elseif (lambda2 <= -1.25e-107) tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (sin(phi2) - (((sin((phi1 + phi2)) + sin((phi1 - phi2))) * 0.5) * t_2))); elseif (lambda2 <= 1.75e-98) tmp = atan2((sin(lambda1) * cos(phi2)), (t_0 - ((sin(phi1) * cos(phi2)) * t_2))); else tmp = t_1; end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda2, -2.8e+41], t$95$1, If[LessEqual[lambda2, -1.25e-107], N[ArcTan[N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[(N[(N[Sin[N[(phi1 + phi2), $MachinePrecision]], $MachinePrecision] + N[Sin[N[(phi1 - phi2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 0.5), $MachinePrecision] * t$95$2), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda2, 1.75e-98], N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * t$95$2), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$1]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
t_1 := \tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \cos \phi_2}{t\_0 - \left(\cos \lambda_2 \cdot \sin \phi_1\right) \cdot \cos \phi_2}\\
t_2 := \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\lambda_2 \leq -2.8 \cdot 10^{+41}:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;\lambda_2 \leq -1.25 \cdot 10^{-107}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\sin \phi_2 - \left(\left(\sin \left(\phi_1 + \phi_2\right) + \sin \left(\phi_1 - \phi_2\right)\right) \cdot 0.5\right) \cdot t\_2}\\
\mathbf{elif}\;\lambda_2 \leq 1.75 \cdot 10^{-98}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_0 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot t\_2}\\
\mathbf{else}:\\
\;\;\;\;t\_1\\
\end{array}
\end{array}
if lambda2 < -2.7999999999999999e41 or 1.7500000000000001e-98 < lambda2 Initial program 63.7%
Taylor expanded in lambda1 around 0
neg-mul-1N/A
lower-neg.f6459.3
Applied rewrites59.3%
Taylor expanded in lambda1 around 0
*-commutativeN/A
lower-*.f64N/A
lower-*.f64N/A
cos-negN/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-cos.f6459.2
Applied rewrites59.2%
if -2.7999999999999999e41 < lambda2 < -1.24999999999999993e-107Initial program 90.2%
Taylor expanded in phi1 around 0
lower-sin.f6486.2
Applied rewrites86.2%
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
sin-cos-multN/A
div-invN/A
lower-*.f64N/A
+-commutativeN/A
lower-+.f64N/A
lower-sin.f64N/A
lower-+.f64N/A
lower-sin.f64N/A
lower--.f64N/A
metadata-eval86.3
Applied rewrites86.3%
if -1.24999999999999993e-107 < lambda2 < 1.7500000000000001e-98Initial program 99.7%
Taylor expanded in lambda2 around 0
lower-sin.f6492.4
Applied rewrites92.4%
Final simplification74.1%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2))))
(if (or (<= lambda2 -1.55e+16) (not (<= lambda2 7800000.0)))
(atan2
(* (sin (- lambda2)) (cos phi2))
(- t_0 (* (* (cos lambda2) (sin phi1)) (cos phi2))))
(atan2
(* (sin (- lambda1 lambda2)) (cos phi2))
(- t_0 (* (* (sin phi1) (cos phi2)) (cos lambda1)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double tmp;
if ((lambda2 <= -1.55e+16) || !(lambda2 <= 7800000.0)) {
tmp = atan2((sin(-lambda2) * cos(phi2)), (t_0 - ((cos(lambda2) * sin(phi1)) * cos(phi2))));
} else {
tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - ((sin(phi1) * cos(phi2)) * cos(lambda1))));
}
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 = cos(phi1) * sin(phi2)
if ((lambda2 <= (-1.55d+16)) .or. (.not. (lambda2 <= 7800000.0d0))) then
tmp = atan2((sin(-lambda2) * cos(phi2)), (t_0 - ((cos(lambda2) * sin(phi1)) * cos(phi2))))
else
tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - ((sin(phi1) * cos(phi2)) * cos(lambda1))))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos(phi1) * Math.sin(phi2);
double tmp;
if ((lambda2 <= -1.55e+16) || !(lambda2 <= 7800000.0)) {
tmp = Math.atan2((Math.sin(-lambda2) * Math.cos(phi2)), (t_0 - ((Math.cos(lambda2) * Math.sin(phi1)) * Math.cos(phi2))));
} else {
tmp = Math.atan2((Math.sin((lambda1 - lambda2)) * Math.cos(phi2)), (t_0 - ((Math.sin(phi1) * Math.cos(phi2)) * Math.cos(lambda1))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi1) * math.sin(phi2) tmp = 0 if (lambda2 <= -1.55e+16) or not (lambda2 <= 7800000.0): tmp = math.atan2((math.sin(-lambda2) * math.cos(phi2)), (t_0 - ((math.cos(lambda2) * math.sin(phi1)) * math.cos(phi2)))) else: tmp = math.atan2((math.sin((lambda1 - lambda2)) * math.cos(phi2)), (t_0 - ((math.sin(phi1) * math.cos(phi2)) * math.cos(lambda1)))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) tmp = 0.0 if ((lambda2 <= -1.55e+16) || !(lambda2 <= 7800000.0)) tmp = atan(Float64(sin(Float64(-lambda2)) * cos(phi2)), Float64(t_0 - Float64(Float64(cos(lambda2) * sin(phi1)) * cos(phi2)))); else tmp = atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), Float64(t_0 - Float64(Float64(sin(phi1) * cos(phi2)) * cos(lambda1)))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos(phi1) * sin(phi2); tmp = 0.0; if ((lambda2 <= -1.55e+16) || ~((lambda2 <= 7800000.0))) tmp = atan2((sin(-lambda2) * cos(phi2)), (t_0 - ((cos(lambda2) * sin(phi1)) * cos(phi2)))); else tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (t_0 - ((sin(phi1) * cos(phi2)) * cos(lambda1)))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, If[Or[LessEqual[lambda2, -1.55e+16], N[Not[LessEqual[lambda2, 7800000.0]], $MachinePrecision]], N[ArcTan[N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $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[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
\mathbf{if}\;\lambda_2 \leq -1.55 \cdot 10^{+16} \lor \neg \left(\lambda_2 \leq 7800000\right):\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \cos \phi_2}{t\_0 - \left(\cos \lambda_2 \cdot \sin \phi_1\right) \cdot \cos \phi_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{t\_0 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \lambda_1}\\
\end{array}
\end{array}
if lambda2 < -1.55e16 or 7.8e6 < lambda2 Initial program 60.8%
Taylor expanded in lambda1 around 0
neg-mul-1N/A
lower-neg.f6459.0
Applied rewrites59.0%
Taylor expanded in lambda1 around 0
*-commutativeN/A
lower-*.f64N/A
lower-*.f64N/A
cos-negN/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-cos.f6458.9
Applied rewrites58.9%
if -1.55e16 < lambda2 < 7.8e6Initial program 97.7%
Taylor expanded in lambda2 around 0
lower-cos.f6497.7
Applied rewrites97.7%
Final simplification78.4%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (sin phi1) (cos phi2)))
(t_1 (* (sin (- lambda1 lambda2)) (cos phi2)))
(t_2 (* (cos phi1) (sin phi2))))
(if (<= lambda1 -6e-7)
(atan2
(* (sin lambda1) (cos phi2))
(- t_2 (* t_0 (cos (- lambda1 lambda2)))))
(if (<= lambda1 0.00016)
(atan2 t_1 (- t_2 (* t_0 (cos lambda2))))
(atan2 t_1 (- t_2 (* t_0 (cos lambda1))))))))
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 = cos(phi1) * sin(phi2);
double tmp;
if (lambda1 <= -6e-7) {
tmp = atan2((sin(lambda1) * cos(phi2)), (t_2 - (t_0 * cos((lambda1 - lambda2)))));
} else if (lambda1 <= 0.00016) {
tmp = atan2(t_1, (t_2 - (t_0 * cos(lambda2))));
} else {
tmp = atan2(t_1, (t_2 - (t_0 * cos(lambda1))));
}
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 = cos(phi1) * sin(phi2)
if (lambda1 <= (-6d-7)) then
tmp = atan2((sin(lambda1) * cos(phi2)), (t_2 - (t_0 * cos((lambda1 - lambda2)))))
else if (lambda1 <= 0.00016d0) then
tmp = atan2(t_1, (t_2 - (t_0 * cos(lambda2))))
else
tmp = atan2(t_1, (t_2 - (t_0 * cos(lambda1))))
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.cos(phi1) * Math.sin(phi2);
double tmp;
if (lambda1 <= -6e-7) {
tmp = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (t_2 - (t_0 * Math.cos((lambda1 - lambda2)))));
} else if (lambda1 <= 0.00016) {
tmp = Math.atan2(t_1, (t_2 - (t_0 * Math.cos(lambda2))));
} else {
tmp = Math.atan2(t_1, (t_2 - (t_0 * Math.cos(lambda1))));
}
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.cos(phi1) * math.sin(phi2) tmp = 0 if lambda1 <= -6e-7: tmp = math.atan2((math.sin(lambda1) * math.cos(phi2)), (t_2 - (t_0 * math.cos((lambda1 - lambda2))))) elif lambda1 <= 0.00016: tmp = math.atan2(t_1, (t_2 - (t_0 * math.cos(lambda2)))) else: tmp = math.atan2(t_1, (t_2 - (t_0 * math.cos(lambda1)))) 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(cos(phi1) * sin(phi2)) tmp = 0.0 if (lambda1 <= -6e-7) tmp = atan(Float64(sin(lambda1) * cos(phi2)), Float64(t_2 - Float64(t_0 * cos(Float64(lambda1 - lambda2))))); elseif (lambda1 <= 0.00016) tmp = atan(t_1, Float64(t_2 - Float64(t_0 * cos(lambda2)))); else tmp = atan(t_1, Float64(t_2 - Float64(t_0 * cos(lambda1)))); 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 = cos(phi1) * sin(phi2); tmp = 0.0; if (lambda1 <= -6e-7) tmp = atan2((sin(lambda1) * cos(phi2)), (t_2 - (t_0 * cos((lambda1 - lambda2))))); elseif (lambda1 <= 0.00016) tmp = atan2(t_1, (t_2 - (t_0 * cos(lambda2)))); else tmp = atan2(t_1, (t_2 - (t_0 * cos(lambda1)))); 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[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda1, -6e-7], N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$2 - N[(t$95$0 * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda1, 0.00016], N[ArcTan[t$95$1 / N[(t$95$2 - N[(t$95$0 * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / N[(t$95$2 - N[(t$95$0 * N[Cos[lambda1], $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 := \cos \phi_1 \cdot \sin \phi_2\\
\mathbf{if}\;\lambda_1 \leq -6 \cdot 10^{-7}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_2 - t\_0 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\mathbf{elif}\;\lambda_1 \leq 0.00016:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_2 - t\_0 \cdot \cos \lambda_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_2 - t\_0 \cdot \cos \lambda_1}\\
\end{array}
\end{array}
if lambda1 < -5.9999999999999997e-7Initial program 64.9%
Taylor expanded in lambda2 around 0
lower-sin.f6465.5
Applied rewrites65.5%
if -5.9999999999999997e-7 < lambda1 < 1.60000000000000013e-4Initial program 99.3%
Taylor expanded in lambda1 around 0
cos-negN/A
lower-cos.f6499.3
Applied rewrites99.3%
if 1.60000000000000013e-4 < lambda1 Initial program 55.6%
Taylor expanded in lambda2 around 0
lower-cos.f6455.6
Applied rewrites55.6%
Final simplification79.6%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(if (or (<= lambda2 -2.5e+40) (not (<= lambda2 7.6e-25)))
(atan2
(* (sin (- lambda2)) (cos phi2))
(- (* (cos phi1) (sin phi2)) (* (* (cos lambda2) (sin phi1)) (cos phi2))))
(atan2
(* (sin (* (- 1.0 (/ lambda2 lambda1)) lambda1)) (cos phi2))
(- (sin phi2) (* (* (sin phi1) (cos phi2)) (cos (- lambda1 lambda2)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((lambda2 <= -2.5e+40) || !(lambda2 <= 7.6e-25)) {
tmp = atan2((sin(-lambda2) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((cos(lambda2) * sin(phi1)) * cos(phi2))));
} else {
tmp = atan2((sin(((1.0 - (lambda2 / lambda1)) * lambda1)) * cos(phi2)), (sin(phi2) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - 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) :: tmp
if ((lambda2 <= (-2.5d+40)) .or. (.not. (lambda2 <= 7.6d-25))) then
tmp = atan2((sin(-lambda2) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((cos(lambda2) * sin(phi1)) * cos(phi2))))
else
tmp = atan2((sin(((1.0d0 - (lambda2 / lambda1)) * lambda1)) * cos(phi2)), (sin(phi2) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2)))))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((lambda2 <= -2.5e+40) || !(lambda2 <= 7.6e-25)) {
tmp = Math.atan2((Math.sin(-lambda2) * Math.cos(phi2)), ((Math.cos(phi1) * Math.sin(phi2)) - ((Math.cos(lambda2) * Math.sin(phi1)) * Math.cos(phi2))));
} else {
tmp = Math.atan2((Math.sin(((1.0 - (lambda2 / lambda1)) * lambda1)) * Math.cos(phi2)), (Math.sin(phi2) - ((Math.sin(phi1) * Math.cos(phi2)) * Math.cos((lambda1 - lambda2)))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): tmp = 0 if (lambda2 <= -2.5e+40) or not (lambda2 <= 7.6e-25): tmp = math.atan2((math.sin(-lambda2) * math.cos(phi2)), ((math.cos(phi1) * math.sin(phi2)) - ((math.cos(lambda2) * math.sin(phi1)) * math.cos(phi2)))) else: tmp = math.atan2((math.sin(((1.0 - (lambda2 / lambda1)) * lambda1)) * math.cos(phi2)), (math.sin(phi2) - ((math.sin(phi1) * math.cos(phi2)) * math.cos((lambda1 - lambda2))))) return tmp
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if ((lambda2 <= -2.5e+40) || !(lambda2 <= 7.6e-25)) tmp = atan(Float64(sin(Float64(-lambda2)) * cos(phi2)), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(lambda2) * sin(phi1)) * cos(phi2)))); else tmp = atan(Float64(sin(Float64(Float64(1.0 - Float64(lambda2 / lambda1)) * lambda1)) * cos(phi2)), Float64(sin(phi2) - Float64(Float64(sin(phi1) * cos(phi2)) * cos(Float64(lambda1 - lambda2))))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) tmp = 0.0; if ((lambda2 <= -2.5e+40) || ~((lambda2 <= 7.6e-25))) tmp = atan2((sin(-lambda2) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((cos(lambda2) * sin(phi1)) * cos(phi2)))); else tmp = atan2((sin(((1.0 - (lambda2 / lambda1)) * lambda1)) * cos(phi2)), (sin(phi2) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2))))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := If[Or[LessEqual[lambda2, -2.5e+40], N[Not[LessEqual[lambda2, 7.6e-25]], $MachinePrecision]], N[ArcTan[N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Sin[N[(N[(1.0 - N[(lambda2 / lambda1), $MachinePrecision]), $MachinePrecision] * lambda1), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $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}
\\
\begin{array}{l}
\mathbf{if}\;\lambda_2 \leq -2.5 \cdot 10^{+40} \lor \neg \left(\lambda_2 \leq 7.6 \cdot 10^{-25}\right):\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \lambda_2 \cdot \sin \phi_1\right) \cdot \cos \phi_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\left(1 - \frac{\lambda_2}{\lambda_1}\right) \cdot \lambda_1\right) \cdot \cos \phi_2}{\sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\end{array}
\end{array}
if lambda2 < -2.50000000000000002e40 or 7.5999999999999996e-25 < lambda2 Initial program 60.5%
Taylor expanded in lambda1 around 0
neg-mul-1N/A
lower-neg.f6459.3
Applied rewrites59.3%
Taylor expanded in lambda1 around 0
*-commutativeN/A
lower-*.f64N/A
lower-*.f64N/A
cos-negN/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-cos.f6459.3
Applied rewrites59.3%
if -2.50000000000000002e40 < lambda2 < 7.5999999999999996e-25Initial program 97.0%
Taylor expanded in phi1 around 0
lower-sin.f6480.8
Applied rewrites80.8%
Taylor expanded in lambda1 around inf
*-commutativeN/A
lower-*.f64N/A
mul-1-negN/A
unsub-negN/A
lower--.f64N/A
lower-/.f6480.8
Applied rewrites80.8%
Final simplification70.5%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (cos phi2) (sin (- lambda1 lambda2))) (fma (* (- (sin phi1)) (cos (- lambda1 lambda2))) (cos phi2) (* (sin phi2) (cos phi1)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((cos(phi2) * sin((lambda1 - lambda2))), fma((-sin(phi1) * cos((lambda1 - lambda2))), cos(phi2), (sin(phi2) * cos(phi1))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), fma(Float64(Float64(-sin(phi1)) * cos(Float64(lambda1 - lambda2))), cos(phi2), Float64(sin(phi2) * cos(phi1)))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[((-N[Sin[phi1], $MachinePrecision]) * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision] + N[(N[Sin[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\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)}
\end{array}
Initial program 79.4%
lift-*.f64N/A
*-commutativeN/A
lower-*.f6479.4
lift--.f64N/A
sub-negN/A
+-commutativeN/A
lift-*.f64N/A
lift-*.f64N/A
associate-*l*N/A
distribute-lft-neg-inN/A
*-commutativeN/A
associate-*r*N/A
lower-fma.f64N/A
Applied rewrites79.4%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (sin (- lambda1 lambda2)) (cos phi2)) (- (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)), (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)), (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.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.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(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)), (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[Sin[phi2], $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}{\sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
Initial program 79.4%
Taylor expanded in phi1 around 0
lower-sin.f6465.3
Applied rewrites65.3%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (sin (- lambda1 lambda2))))
(if (or (<= phi2 -0.0025) (not (<= phi2 1.6e-15)))
(atan2 (* t_0 (cos phi2)) (- (sin phi2) (* (sin phi1) (cos lambda1))))
(atan2
(* (fma -0.5 (* phi2 phi2) 1.0) t_0)
(- (sin phi2) (* (sin phi1) (cos (- lambda1 lambda2))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = sin((lambda1 - lambda2));
double tmp;
if ((phi2 <= -0.0025) || !(phi2 <= 1.6e-15)) {
tmp = atan2((t_0 * cos(phi2)), (sin(phi2) - (sin(phi1) * cos(lambda1))));
} else {
tmp = atan2((fma(-0.5, (phi2 * phi2), 1.0) * t_0), (sin(phi2) - (sin(phi1) * cos((lambda1 - lambda2)))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = sin(Float64(lambda1 - lambda2)) tmp = 0.0 if ((phi2 <= -0.0025) || !(phi2 <= 1.6e-15)) tmp = atan(Float64(t_0 * cos(phi2)), Float64(sin(phi2) - Float64(sin(phi1) * cos(lambda1)))); else tmp = atan(Float64(fma(-0.5, Float64(phi2 * phi2), 1.0) * t_0), Float64(sin(phi2) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[Or[LessEqual[phi2, -0.0025], N[Not[LessEqual[phi2, 1.6e-15]], $MachinePrecision]], N[ArcTan[N[(t$95$0 * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[(-0.5 * N[(phi2 * phi2), $MachinePrecision] + 1.0), $MachinePrecision] * t$95$0), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq -0.0025 \lor \neg \left(\phi_2 \leq 1.6 \cdot 10^{-15}\right):\\
\;\;\;\;\tan^{-1}_* \frac{t\_0 \cdot \cos \phi_2}{\sin \phi_2 - \sin \phi_1 \cdot \cos \lambda_1}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(-0.5, \phi_2 \cdot \phi_2, 1\right) \cdot t\_0}{\sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\end{array}
\end{array}
if phi2 < -0.00250000000000000005 or 1.6e-15 < phi2 Initial program 76.5%
Taylor expanded in phi1 around 0
lower-sin.f6447.1
Applied rewrites47.1%
Taylor expanded in phi2 around 0
lower-sin.f6445.2
Applied rewrites45.2%
Taylor expanded in lambda2 around 0
lower-cos.f6445.1
Applied rewrites45.1%
if -0.00250000000000000005 < phi2 < 1.6e-15Initial program 82.0%
Taylor expanded in phi1 around 0
lower-sin.f6481.6
Applied rewrites81.6%
Taylor expanded in phi2 around 0
lower-sin.f6481.6
Applied rewrites81.6%
Taylor expanded in phi2 around 0
associate-*r*N/A
distribute-rgt1-inN/A
lower-*.f64N/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-sin.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f6481.6
Applied rewrites81.6%
Final simplification64.4%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (- (sin phi2) (* (sin phi1) (cos (- lambda1 lambda2))))))
(if (or (<= phi2 -1.75) (not (<= phi2 29.5)))
(atan2 (* (sin lambda1) (cos phi2)) t_0)
(atan2 (* (fma -0.5 (* phi2 phi2) 1.0) (sin (- lambda1 lambda2))) t_0))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = sin(phi2) - (sin(phi1) * cos((lambda1 - lambda2)));
double tmp;
if ((phi2 <= -1.75) || !(phi2 <= 29.5)) {
tmp = atan2((sin(lambda1) * cos(phi2)), t_0);
} else {
tmp = atan2((fma(-0.5, (phi2 * phi2), 1.0) * sin((lambda1 - lambda2))), t_0);
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(sin(phi2) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2)))) tmp = 0.0 if ((phi2 <= -1.75) || !(phi2 <= 29.5)) tmp = atan(Float64(sin(lambda1) * cos(phi2)), t_0); else tmp = atan(Float64(fma(-0.5, Float64(phi2 * phi2), 1.0) * sin(Float64(lambda1 - lambda2))), t_0); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[Or[LessEqual[phi2, -1.75], N[Not[LessEqual[phi2, 29.5]], $MachinePrecision]], N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / t$95$0], $MachinePrecision], N[ArcTan[N[(N[(-0.5 * N[(phi2 * phi2), $MachinePrecision] + 1.0), $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / t$95$0], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq -1.75 \lor \neg \left(\phi_2 \leq 29.5\right):\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_0}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(-0.5, \phi_2 \cdot \phi_2, 1\right) \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t\_0}\\
\end{array}
\end{array}
if phi2 < -1.75 or 29.5 < phi2 Initial program 76.9%
Taylor expanded in phi1 around 0
lower-sin.f6446.2
Applied rewrites46.2%
Taylor expanded in phi2 around 0
lower-sin.f6444.2
Applied rewrites44.2%
lift--.f64N/A
flip--N/A
div-invN/A
lower-*.f64N/A
difference-of-squaresN/A
lift--.f64N/A
lower-*.f64N/A
+-commutativeN/A
lower-+.f64N/A
inv-powN/A
lower-pow.f64N/A
+-commutativeN/A
lower-+.f6424.8
Applied rewrites24.8%
Taylor expanded in lambda2 around 0
lower-sin.f6429.2
Applied rewrites29.2%
if -1.75 < phi2 < 29.5Initial program 81.5%
Taylor expanded in phi1 around 0
lower-sin.f6481.1
Applied rewrites81.1%
Taylor expanded in phi2 around 0
lower-sin.f6481.1
Applied rewrites81.1%
Taylor expanded in phi2 around 0
associate-*r*N/A
distribute-rgt1-inN/A
lower-*.f64N/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-sin.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f6481.0
Applied rewrites81.0%
Final simplification57.5%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (sin (- lambda1 lambda2)) (cos phi2))))
(if (<= lambda1 -1.5e+82)
(atan2
(* (sin lambda1) (cos phi2))
(- (sin phi2) (* (sin phi1) (cos (- lambda1 lambda2)))))
(if (<= lambda1 0.094)
(atan2 t_0 (- (sin phi2) (* (sin phi1) (cos lambda2))))
(atan2 t_0 (- (sin phi2) (* (sin phi1) (cos lambda1))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = sin((lambda1 - lambda2)) * cos(phi2);
double tmp;
if (lambda1 <= -1.5e+82) {
tmp = atan2((sin(lambda1) * cos(phi2)), (sin(phi2) - (sin(phi1) * cos((lambda1 - lambda2)))));
} else if (lambda1 <= 0.094) {
tmp = atan2(t_0, (sin(phi2) - (sin(phi1) * cos(lambda2))));
} else {
tmp = atan2(t_0, (sin(phi2) - (sin(phi1) * cos(lambda1))));
}
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((lambda1 - lambda2)) * cos(phi2)
if (lambda1 <= (-1.5d+82)) then
tmp = atan2((sin(lambda1) * cos(phi2)), (sin(phi2) - (sin(phi1) * cos((lambda1 - lambda2)))))
else if (lambda1 <= 0.094d0) then
tmp = atan2(t_0, (sin(phi2) - (sin(phi1) * cos(lambda2))))
else
tmp = atan2(t_0, (sin(phi2) - (sin(phi1) * cos(lambda1))))
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)) * Math.cos(phi2);
double tmp;
if (lambda1 <= -1.5e+82) {
tmp = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (Math.sin(phi2) - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)))));
} else if (lambda1 <= 0.094) {
tmp = Math.atan2(t_0, (Math.sin(phi2) - (Math.sin(phi1) * Math.cos(lambda2))));
} else {
tmp = Math.atan2(t_0, (Math.sin(phi2) - (Math.sin(phi1) * Math.cos(lambda1))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.sin((lambda1 - lambda2)) * math.cos(phi2) tmp = 0 if lambda1 <= -1.5e+82: tmp = math.atan2((math.sin(lambda1) * math.cos(phi2)), (math.sin(phi2) - (math.sin(phi1) * math.cos((lambda1 - lambda2))))) elif lambda1 <= 0.094: tmp = math.atan2(t_0, (math.sin(phi2) - (math.sin(phi1) * math.cos(lambda2)))) else: tmp = math.atan2(t_0, (math.sin(phi2) - (math.sin(phi1) * math.cos(lambda1)))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)) tmp = 0.0 if (lambda1 <= -1.5e+82) tmp = atan(Float64(sin(lambda1) * cos(phi2)), Float64(sin(phi2) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))); elseif (lambda1 <= 0.094) tmp = atan(t_0, Float64(sin(phi2) - Float64(sin(phi1) * cos(lambda2)))); else tmp = atan(t_0, Float64(sin(phi2) - Float64(sin(phi1) * cos(lambda1)))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = sin((lambda1 - lambda2)) * cos(phi2); tmp = 0.0; if (lambda1 <= -1.5e+82) tmp = atan2((sin(lambda1) * cos(phi2)), (sin(phi2) - (sin(phi1) * cos((lambda1 - lambda2))))); elseif (lambda1 <= 0.094) tmp = atan2(t_0, (sin(phi2) - (sin(phi1) * cos(lambda2)))); else tmp = atan2(t_0, (sin(phi2) - (sin(phi1) * cos(lambda1)))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda1, -1.5e+82], N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda1, 0.094], N[ArcTan[t$95$0 / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$0 / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2\\
\mathbf{if}\;\lambda_1 \leq -1.5 \cdot 10^{+82}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\mathbf{elif}\;\lambda_1 \leq 0.094:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\sin \phi_2 - \sin \phi_1 \cdot \cos \lambda_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\sin \phi_2 - \sin \phi_1 \cdot \cos \lambda_1}\\
\end{array}
\end{array}
if lambda1 < -1.49999999999999995e82Initial program 61.2%
Taylor expanded in phi1 around 0
lower-sin.f6453.6
Applied rewrites53.6%
Taylor expanded in phi2 around 0
lower-sin.f6452.7
Applied rewrites52.7%
lift--.f64N/A
flip--N/A
div-invN/A
lower-*.f64N/A
difference-of-squaresN/A
lift--.f64N/A
lower-*.f64N/A
+-commutativeN/A
lower-+.f64N/A
inv-powN/A
lower-pow.f64N/A
+-commutativeN/A
lower-+.f6412.7
Applied rewrites12.7%
Taylor expanded in lambda2 around 0
lower-sin.f6455.5
Applied rewrites55.5%
if -1.49999999999999995e82 < lambda1 < 0.094Initial program 98.1%
Taylor expanded in phi1 around 0
lower-sin.f6478.9
Applied rewrites78.9%
Taylor expanded in phi2 around 0
lower-sin.f6477.7
Applied rewrites77.7%
Taylor expanded in lambda1 around 0
cos-negN/A
lower-cos.f6477.6
Applied rewrites77.6%
if 0.094 < lambda1 Initial program 55.6%
Taylor expanded in phi1 around 0
lower-sin.f6446.5
Applied rewrites46.5%
Taylor expanded in phi2 around 0
lower-sin.f6446.3
Applied rewrites46.3%
Taylor expanded in lambda2 around 0
lower-cos.f6446.3
Applied rewrites46.3%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (sin (- lambda1 lambda2)) (cos phi2)) (- (sin phi2) (* (sin phi1) (cos (- lambda1 lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((sin((lambda1 - lambda2)) * cos(phi2)), (sin(phi2) - (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((sin((lambda1 - lambda2)) * cos(phi2)), (sin(phi2) - (sin(phi1) * 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.sin(phi2) - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)))));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2((math.sin((lambda1 - lambda2)) * math.cos(phi2)), (math.sin(phi2) - (math.sin(phi1) * math.cos((lambda1 - lambda2)))))
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), Float64(sin(phi2) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), (sin(phi2) - (sin(phi1) * 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[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $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}{\sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
Initial program 79.4%
Taylor expanded in phi1 around 0
lower-sin.f6465.3
Applied rewrites65.3%
Taylor expanded in phi2 around 0
lower-sin.f6464.4
Applied rewrites64.4%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (fma -0.5 (* phi2 phi2) 1.0) (sin (- lambda1 lambda2))) (- (sin phi2) (* (* (fma (* phi2 phi2) -0.5 1.0) (sin phi1)) (cos (- lambda1 lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((fma(-0.5, (phi2 * phi2), 1.0) * sin((lambda1 - lambda2))), (sin(phi2) - ((fma((phi2 * phi2), -0.5, 1.0) * sin(phi1)) * cos((lambda1 - lambda2)))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(fma(-0.5, Float64(phi2 * phi2), 1.0) * sin(Float64(lambda1 - lambda2))), Float64(sin(phi2) - Float64(Float64(fma(Float64(phi2 * phi2), -0.5, 1.0) * sin(phi1)) * cos(Float64(lambda1 - lambda2))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[(-0.5 * N[(phi2 * phi2), $MachinePrecision] + 1.0), $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[(N[(N[(phi2 * phi2), $MachinePrecision] * -0.5 + 1.0), $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\mathsf{fma}\left(-0.5, \phi_2 \cdot \phi_2, 1\right) \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 - \left(\mathsf{fma}\left(\phi_2 \cdot \phi_2, -0.5, 1\right) \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
Initial program 79.4%
Taylor expanded in phi1 around 0
lower-sin.f6465.3
Applied rewrites65.3%
Taylor expanded in phi2 around 0
lower-sin.f6464.4
Applied rewrites64.4%
Taylor expanded in phi2 around 0
associate-*r*N/A
distribute-rgt1-inN/A
lower-*.f64N/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-sin.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f6448.3
Applied rewrites48.3%
Taylor expanded in phi2 around 0
associate-*r*N/A
distribute-rgt1-inN/A
+-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
lower-sin.f6448.6
Applied rewrites48.6%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (fma -0.5 (* phi2 phi2) 1.0) (sin (- lambda1 lambda2)))))
(if (<= lambda1 -1.5e+82)
(atan2
(* (fma (* phi2 phi2) -0.5 1.0) (sin lambda1))
(- (sin phi2) (* (sin phi1) (cos (- lambda1 lambda2)))))
(if (<= lambda1 2800000.0)
(atan2 t_0 (- (sin phi2) (* (sin phi1) (cos lambda2))))
(atan2 t_0 (- (sin phi2) (* (sin phi1) (cos lambda1))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = fma(-0.5, (phi2 * phi2), 1.0) * sin((lambda1 - lambda2));
double tmp;
if (lambda1 <= -1.5e+82) {
tmp = atan2((fma((phi2 * phi2), -0.5, 1.0) * sin(lambda1)), (sin(phi2) - (sin(phi1) * cos((lambda1 - lambda2)))));
} else if (lambda1 <= 2800000.0) {
tmp = atan2(t_0, (sin(phi2) - (sin(phi1) * cos(lambda2))));
} else {
tmp = atan2(t_0, (sin(phi2) - (sin(phi1) * cos(lambda1))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(fma(-0.5, Float64(phi2 * phi2), 1.0) * sin(Float64(lambda1 - lambda2))) tmp = 0.0 if (lambda1 <= -1.5e+82) tmp = atan(Float64(fma(Float64(phi2 * phi2), -0.5, 1.0) * sin(lambda1)), Float64(sin(phi2) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))); elseif (lambda1 <= 2800000.0) tmp = atan(t_0, Float64(sin(phi2) - Float64(sin(phi1) * cos(lambda2)))); else tmp = atan(t_0, Float64(sin(phi2) - Float64(sin(phi1) * cos(lambda1)))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(-0.5 * N[(phi2 * phi2), $MachinePrecision] + 1.0), $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda1, -1.5e+82], N[ArcTan[N[(N[(N[(phi2 * phi2), $MachinePrecision] * -0.5 + 1.0), $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda1, 2800000.0], N[ArcTan[t$95$0 / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$0 / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \mathsf{fma}\left(-0.5, \phi_2 \cdot \phi_2, 1\right) \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\lambda_1 \leq -1.5 \cdot 10^{+82}:\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\phi_2 \cdot \phi_2, -0.5, 1\right) \cdot \sin \lambda_1}{\sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\mathbf{elif}\;\lambda_1 \leq 2800000:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\sin \phi_2 - \sin \phi_1 \cdot \cos \lambda_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\sin \phi_2 - \sin \phi_1 \cdot \cos \lambda_1}\\
\end{array}
\end{array}
if lambda1 < -1.49999999999999995e82Initial program 61.2%
Taylor expanded in phi1 around 0
lower-sin.f6453.6
Applied rewrites53.6%
Taylor expanded in phi2 around 0
lower-sin.f6452.7
Applied rewrites52.7%
Taylor expanded in phi2 around 0
associate-*r*N/A
distribute-rgt1-inN/A
lower-*.f64N/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-sin.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f6440.2
Applied rewrites40.2%
Taylor expanded in lambda2 around 0
Applied rewrites43.1%
if -1.49999999999999995e82 < lambda1 < 2.8e6Initial program 97.4%
Taylor expanded in phi1 around 0
lower-sin.f6478.1
Applied rewrites78.1%
Taylor expanded in phi2 around 0
lower-sin.f6476.9
Applied rewrites76.9%
Taylor expanded in phi2 around 0
associate-*r*N/A
distribute-rgt1-inN/A
lower-*.f64N/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-sin.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f6454.5
Applied rewrites54.5%
Taylor expanded in lambda1 around 0
cos-negN/A
lower-cos.f6454.5
Applied rewrites54.5%
if 2.8e6 < lambda1 Initial program 55.1%
Taylor expanded in phi1 around 0
lower-sin.f6446.7
Applied rewrites46.7%
Taylor expanded in phi2 around 0
lower-sin.f6446.6
Applied rewrites46.6%
Taylor expanded in phi2 around 0
associate-*r*N/A
distribute-rgt1-inN/A
lower-*.f64N/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-sin.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f6441.3
Applied rewrites41.3%
Taylor expanded in lambda2 around 0
lower-cos.f6441.3
Applied rewrites41.3%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (fma -0.5 (* phi2 phi2) 1.0) (sin (- lambda1 lambda2))) (- (sin phi2) (* (sin phi1) (cos (- lambda1 lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((fma(-0.5, (phi2 * phi2), 1.0) * sin((lambda1 - lambda2))), (sin(phi2) - (sin(phi1) * cos((lambda1 - lambda2)))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(fma(-0.5, Float64(phi2 * phi2), 1.0) * sin(Float64(lambda1 - lambda2))), Float64(sin(phi2) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[(-0.5 * N[(phi2 * phi2), $MachinePrecision] + 1.0), $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\mathsf{fma}\left(-0.5, \phi_2 \cdot \phi_2, 1\right) \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
Initial program 79.4%
Taylor expanded in phi1 around 0
lower-sin.f6465.3
Applied rewrites65.3%
Taylor expanded in phi2 around 0
lower-sin.f6464.4
Applied rewrites64.4%
Taylor expanded in phi2 around 0
associate-*r*N/A
distribute-rgt1-inN/A
lower-*.f64N/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-sin.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f6448.3
Applied rewrites48.3%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (fma -0.5 (* phi2 phi2) 1.0) (sin (- lambda1 lambda2))) (- (sin phi2) (* (sin phi1) (cos lambda1)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((fma(-0.5, (phi2 * phi2), 1.0) * sin((lambda1 - lambda2))), (sin(phi2) - (sin(phi1) * cos(lambda1))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(fma(-0.5, Float64(phi2 * phi2), 1.0) * sin(Float64(lambda1 - lambda2))), Float64(sin(phi2) - Float64(sin(phi1) * cos(lambda1)))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[(-0.5 * N[(phi2 * phi2), $MachinePrecision] + 1.0), $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\mathsf{fma}\left(-0.5, \phi_2 \cdot \phi_2, 1\right) \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 - \sin \phi_1 \cdot \cos \lambda_1}
\end{array}
Initial program 79.4%
Taylor expanded in phi1 around 0
lower-sin.f6465.3
Applied rewrites65.3%
Taylor expanded in phi2 around 0
lower-sin.f6464.4
Applied rewrites64.4%
Taylor expanded in phi2 around 0
associate-*r*N/A
distribute-rgt1-inN/A
lower-*.f64N/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-sin.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f6448.3
Applied rewrites48.3%
Taylor expanded in lambda2 around 0
lower-cos.f6443.0
Applied rewrites43.0%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (fma (* phi2 phi2) -0.5 1.0) (sin lambda1)) (- (sin phi2) (* (sin phi1) (cos (- lambda1 lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((fma((phi2 * phi2), -0.5, 1.0) * sin(lambda1)), (sin(phi2) - (sin(phi1) * cos((lambda1 - lambda2)))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(fma(Float64(phi2 * phi2), -0.5, 1.0) * sin(lambda1)), Float64(sin(phi2) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[(N[(phi2 * phi2), $MachinePrecision] * -0.5 + 1.0), $MachinePrecision] * N[Sin[lambda1], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\mathsf{fma}\left(\phi_2 \cdot \phi_2, -0.5, 1\right) \cdot \sin \lambda_1}{\sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
Initial program 79.4%
Taylor expanded in phi1 around 0
lower-sin.f6465.3
Applied rewrites65.3%
Taylor expanded in phi2 around 0
lower-sin.f6464.4
Applied rewrites64.4%
Taylor expanded in phi2 around 0
associate-*r*N/A
distribute-rgt1-inN/A
lower-*.f64N/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-sin.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f6448.3
Applied rewrites48.3%
Taylor expanded in lambda2 around 0
Applied rewrites32.8%
herbie shell --seed 2024318
(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))))))