
(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 33 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
(*
(- (* (sin lambda1) (cos lambda2)) (* (sin lambda2) (cos lambda1)))
(cos phi2))
(-
(* (cos phi1) (sin phi2))
(fma
(* (cos phi2) (* (sin lambda1) (sin phi1)))
(sin lambda2)
(* (cos phi2) (* (sin phi1) (* (cos lambda2) (cos lambda1))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((((sin(lambda1) * cos(lambda2)) - (sin(lambda2) * cos(lambda1))) * cos(phi2)), ((cos(phi1) * sin(phi2)) - fma((cos(phi2) * (sin(lambda1) * sin(phi1))), sin(lambda2), (cos(phi2) * (sin(phi1) * (cos(lambda2) * cos(lambda1)))))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(sin(lambda2) * cos(lambda1))) * cos(phi2)), Float64(Float64(cos(phi1) * sin(phi2)) - fma(Float64(cos(phi2) * Float64(sin(lambda1) * sin(phi1))), sin(lambda2), Float64(cos(phi2) * Float64(sin(phi1) * Float64(cos(lambda2) * cos(lambda1))))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sin[lambda2], $MachinePrecision] + N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\left(\sin \lambda_1 \cdot \cos \lambda_2 - \sin \lambda_2 \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \mathsf{fma}\left(\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \sin \phi_1\right), \sin \lambda_2, \cos \phi_2 \cdot \left(\sin \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \lambda_1\right)\right)\right)}
\end{array}
Initial program 76.8%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6486.5
Applied rewrites86.5%
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
cos-diffN/A
distribute-lft-inN/A
lower-+.f64N/A
lower-*.f64N/A
lift-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lift-cos.f64N/A
lift-cos.f64N/A
lower-*.f64N/A
lower-*.f64N/A
lift-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lift-sin.f64N/A
lower-*.f64N/A
lower-sin.f6499.8
Applied rewrites99.8%
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-*.f64N/A
+-commutativeN/A
Applied rewrites99.8%
lift-neg.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lift-sin.f64N/A
lift-neg.f64N/A
sin-negN/A
lift-sin.f64N/A
distribute-rgt-neg-outN/A
lift-cos.f64N/A
lift-sin.f64N/A
sub-negN/A
lower--.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
Applied rewrites99.8%
Final simplification99.8%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(atan2
(*
(cos phi2)
(fma (sin (- lambda2)) (cos lambda1) (* (sin lambda1) (cos lambda2))))
(-
(* (cos phi1) (sin phi2))
(*
(* (cos phi2) (sin phi1))
(fma (sin lambda2) (sin lambda1) (* (cos lambda2) (cos lambda1)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * fma(sin(lambda2), sin(lambda1), (cos(lambda2) * cos(lambda1))))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * fma(sin(lambda2), sin(lambda1), Float64(cos(lambda2) * cos(lambda1)))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[(N[Sin[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision] + N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \mathsf{fma}\left(\sin \lambda_2, \sin \lambda_1, \cos \lambda_2 \cdot \cos \lambda_1\right)}
\end{array}
Initial program 76.8%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6486.5
Applied rewrites86.5%
cos-diffN/A
+-commutativeN/A
lift-sin.f64N/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lift-cos.f64N/A
lift-cos.f64N/A
lower-*.f6499.7
Applied rewrites99.7%
Final simplification99.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(atan2
(*
(cos phi2)
(fma (sin (- lambda2)) (cos lambda1) (* (sin lambda1) (cos lambda2))))
(-
(* (cos phi1) (sin phi2))
(*
(* (cos phi2) (sin phi1))
(fma (cos lambda2) (cos lambda1) (* (sin lambda1) (sin lambda2)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * fma(cos(lambda2), cos(lambda1), (sin(lambda1) * sin(lambda2))))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * fma(cos(lambda2), cos(lambda1), Float64(sin(lambda1) * sin(lambda2)))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \sin \lambda_2\right)}
\end{array}
Initial program 76.8%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6486.5
Applied rewrites86.5%
cos-diffN/A
lift-cos.f64N/A
lift-cos.f64N/A
*-commutativeN/A
lower-fma.f64N/A
lift-sin.f64N/A
lower-*.f64N/A
lower-sin.f6499.7
Applied rewrites99.7%
Final simplification99.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (sin (- lambda2)))
(t_1 (* (cos phi1) (sin phi2)))
(t_2
(atan2
(*
(cos phi2)
(fma (sin lambda1) (cos lambda2) (* (cos lambda1) t_0)))
(- t_1 (* (* (cos phi2) (sin phi1)) (cos (- lambda1 lambda2)))))))
(if (<= phi2 -250.0)
t_2
(if (<= phi2 1.3e+22)
(atan2
(* (cos phi2) (fma t_0 (cos lambda1) (* (sin lambda1) (cos lambda2))))
(-
t_1
(*
(sin phi1)
(fma (cos lambda1) (cos lambda2) (* (sin lambda1) (sin lambda2))))))
t_2))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = sin(-lambda2);
double t_1 = cos(phi1) * sin(phi2);
double t_2 = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * t_0))), (t_1 - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2)))));
double tmp;
if (phi2 <= -250.0) {
tmp = t_2;
} else if (phi2 <= 1.3e+22) {
tmp = atan2((cos(phi2) * fma(t_0, cos(lambda1), (sin(lambda1) * cos(lambda2)))), (t_1 - (sin(phi1) * fma(cos(lambda1), cos(lambda2), (sin(lambda1) * sin(lambda2))))));
} else {
tmp = t_2;
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = sin(Float64(-lambda2)) t_1 = Float64(cos(phi1) * sin(phi2)) t_2 = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * t_0))), Float64(t_1 - Float64(Float64(cos(phi2) * sin(phi1)) * cos(Float64(lambda1 - lambda2))))) tmp = 0.0 if (phi2 <= -250.0) tmp = t_2; elseif (phi2 <= 1.3e+22) tmp = atan(Float64(cos(phi2) * fma(t_0, cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), Float64(t_1 - Float64(sin(phi1) * fma(cos(lambda1), cos(lambda2), Float64(sin(lambda1) * sin(lambda2)))))); else tmp = t_2; end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Sin[(-lambda2)], $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$1 - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi2, -250.0], t$95$2, If[LessEqual[phi2, 1.3e+22], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(t$95$0 * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$1 - N[(N[Sin[phi1], $MachinePrecision] * N[(N[Cos[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$2]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \sin \left(-\lambda_2\right)\\
t_1 := \cos \phi_1 \cdot \sin \phi_2\\
t_2 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot t\_0\right)}{t\_1 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\mathbf{if}\;\phi_2 \leq -250:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;\phi_2 \leq 1.3 \cdot 10^{+22}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(t\_0, \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{t\_1 - \sin \phi_1 \cdot \mathsf{fma}\left(\cos \lambda_1, \cos \lambda_2, \sin \lambda_1 \cdot \sin \lambda_2\right)}\\
\mathbf{else}:\\
\;\;\;\;t\_2\\
\end{array}
\end{array}
if phi2 < -250 or 1.3e22 < phi2 Initial program 73.4%
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
distribute-rgt-neg-inN/A
sin-negN/A
lower-*.f64N/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-neg.f6485.0
Applied rewrites85.0%
if -250 < phi2 < 1.3e22Initial program 79.7%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6487.8
Applied rewrites87.8%
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
cos-diffN/A
distribute-lft-inN/A
lower-+.f64N/A
lower-*.f64N/A
lift-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lift-cos.f64N/A
lift-cos.f64N/A
lower-*.f64N/A
lower-*.f64N/A
lift-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lift-sin.f64N/A
lower-*.f64N/A
lower-sin.f6499.9
Applied rewrites99.9%
Taylor expanded in phi2 around 0
associate-*r*N/A
associate-*r*N/A
distribute-rgt-outN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-fma.f64N/A
lower-cos.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sin.f6498.7
Applied rewrites98.7%
Final simplification92.4%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (- (sin phi1)))
(t_1 (* (cos phi1) (sin phi2)))
(t_2
(atan2
(*
(cos phi2)
(fma
(sin (- lambda2))
(cos lambda1)
(* (sin lambda1) (cos lambda2))))
(fma (cos phi2) (* (cos lambda2) t_0) t_1))))
(if (<= lambda2 -2.25e-7)
t_2
(if (<= lambda2 0.175)
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(fma
(*
(cos phi2)
(fma (sin lambda2) (sin lambda1) (* (cos lambda2) (cos lambda1))))
t_0
t_1))
t_2))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = -sin(phi1);
double t_1 = cos(phi1) * sin(phi2);
double t_2 = atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), fma(cos(phi2), (cos(lambda2) * t_0), t_1));
double tmp;
if (lambda2 <= -2.25e-7) {
tmp = t_2;
} else if (lambda2 <= 0.175) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), fma((cos(phi2) * fma(sin(lambda2), sin(lambda1), (cos(lambda2) * cos(lambda1)))), t_0, t_1));
} else {
tmp = t_2;
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(-sin(phi1)) t_1 = Float64(cos(phi1) * sin(phi2)) t_2 = atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), fma(cos(phi2), Float64(cos(lambda2) * t_0), t_1)) tmp = 0.0 if (lambda2 <= -2.25e-7) tmp = t_2; elseif (lambda2 <= 0.175) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), fma(Float64(cos(phi2) * fma(sin(lambda2), sin(lambda1), Float64(cos(lambda2) * cos(lambda1)))), t_0, t_1)); else tmp = t_2; end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = (-N[Sin[phi1], $MachinePrecision])}, Block[{t$95$1 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Cos[phi2], $MachinePrecision] * N[(N[Cos[lambda2], $MachinePrecision] * t$95$0), $MachinePrecision] + t$95$1), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda2, -2.25e-7], t$95$2, If[LessEqual[lambda2, 0.175], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision] + N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * t$95$0 + t$95$1), $MachinePrecision]], $MachinePrecision], t$95$2]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := -\sin \phi_1\\
t_1 := \cos \phi_1 \cdot \sin \phi_2\\
t_2 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{\mathsf{fma}\left(\cos \phi_2, \cos \lambda_2 \cdot t\_0, t\_1\right)}\\
\mathbf{if}\;\lambda_2 \leq -2.25 \cdot 10^{-7}:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;\lambda_2 \leq 0.175:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_2, \sin \lambda_1, \cos \lambda_2 \cdot \cos \lambda_1\right), t\_0, t\_1\right)}\\
\mathbf{else}:\\
\;\;\;\;t\_2\\
\end{array}
\end{array}
if lambda2 < -2.2499999999999999e-7 or 0.17499999999999999 < lambda2 Initial program 56.5%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6474.9
Applied rewrites74.9%
Taylor expanded in lambda1 around 0
sub-negN/A
+-commutativeN/A
distribute-rgt-neg-inN/A
lower-fma.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
lower-*.f64N/A
lower-neg.f64N/A
lower-sin.f64N/A
cos-negN/A
lower-cos.f64N/A
lower-*.f64N/A
lower-cos.f64N/A
lower-sin.f6474.8
Applied rewrites74.8%
if -2.2499999999999999e-7 < lambda2 < 0.17499999999999999Initial program 99.7%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites99.7%
cos-diffN/A
lift-cos.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
+-commutativeN/A
lift-*.f64N/A
*-commutativeN/A
lower-fma.f6499.7
Applied rewrites99.7%
Final simplification86.5%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (- (sin phi1)))
(t_1 (* (cos phi1) (sin phi2)))
(t_2
(atan2
(*
(cos phi2)
(fma
(sin (- lambda2))
(cos lambda1)
(* (sin lambda1) (cos lambda2))))
(fma (cos phi2) (* (cos lambda2) t_0) t_1))))
(if (<= lambda2 -2.25e-7)
t_2
(if (<= lambda2 0.175)
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(fma (* (cos phi2) (cos (- lambda1 lambda2))) t_0 t_1))
t_2))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = -sin(phi1);
double t_1 = cos(phi1) * sin(phi2);
double t_2 = atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), fma(cos(phi2), (cos(lambda2) * t_0), t_1));
double tmp;
if (lambda2 <= -2.25e-7) {
tmp = t_2;
} else if (lambda2 <= 0.175) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), fma((cos(phi2) * cos((lambda1 - lambda2))), t_0, t_1));
} else {
tmp = t_2;
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(-sin(phi1)) t_1 = Float64(cos(phi1) * sin(phi2)) t_2 = atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), fma(cos(phi2), Float64(cos(lambda2) * t_0), t_1)) tmp = 0.0 if (lambda2 <= -2.25e-7) tmp = t_2; elseif (lambda2 <= 0.175) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), fma(Float64(cos(phi2) * cos(Float64(lambda1 - lambda2))), t_0, t_1)); else tmp = t_2; end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = (-N[Sin[phi1], $MachinePrecision])}, Block[{t$95$1 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Cos[phi2], $MachinePrecision] * N[(N[Cos[lambda2], $MachinePrecision] * t$95$0), $MachinePrecision] + t$95$1), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda2, -2.25e-7], t$95$2, If[LessEqual[lambda2, 0.175], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi2], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * t$95$0 + t$95$1), $MachinePrecision]], $MachinePrecision], t$95$2]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := -\sin \phi_1\\
t_1 := \cos \phi_1 \cdot \sin \phi_2\\
t_2 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{\mathsf{fma}\left(\cos \phi_2, \cos \lambda_2 \cdot t\_0, t\_1\right)}\\
\mathbf{if}\;\lambda_2 \leq -2.25 \cdot 10^{-7}:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;\lambda_2 \leq 0.175:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right), t\_0, t\_1\right)}\\
\mathbf{else}:\\
\;\;\;\;t\_2\\
\end{array}
\end{array}
if lambda2 < -2.2499999999999999e-7 or 0.17499999999999999 < lambda2 Initial program 56.5%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6474.9
Applied rewrites74.9%
Taylor expanded in lambda1 around 0
sub-negN/A
+-commutativeN/A
distribute-rgt-neg-inN/A
lower-fma.f64N/A
lower-cos.f64N/A
*-commutativeN/A
distribute-lft-neg-inN/A
lower-*.f64N/A
lower-neg.f64N/A
lower-sin.f64N/A
cos-negN/A
lower-cos.f64N/A
lower-*.f64N/A
lower-cos.f64N/A
lower-sin.f6474.8
Applied rewrites74.8%
if -2.2499999999999999e-7 < lambda2 < 0.17499999999999999Initial program 99.7%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites99.7%
Final simplification86.5%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (- (sin phi1)))
(t_1 (* (cos phi1) (sin phi2)))
(t_2
(atan2
(*
(cos phi2)
(fma
(sin lambda1)
(cos lambda2)
(* (cos lambda1) (sin (- lambda2)))))
(fma (cos lambda1) (* (cos phi2) t_0) t_1))))
(if (<= lambda1 -0.00062)
t_2
(if (<= lambda1 3e-5)
(atan2
(* (cos phi2) (- (* lambda1 (cos lambda2)) (sin lambda2)))
(fma (* (cos phi2) (cos (- lambda1 lambda2))) t_0 t_1))
t_2))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = -sin(phi1);
double t_1 = cos(phi1) * sin(phi2);
double t_2 = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * sin(-lambda2)))), fma(cos(lambda1), (cos(phi2) * t_0), t_1));
double tmp;
if (lambda1 <= -0.00062) {
tmp = t_2;
} else if (lambda1 <= 3e-5) {
tmp = atan2((cos(phi2) * ((lambda1 * cos(lambda2)) - sin(lambda2))), fma((cos(phi2) * cos((lambda1 - lambda2))), t_0, t_1));
} else {
tmp = t_2;
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(-sin(phi1)) t_1 = Float64(cos(phi1) * sin(phi2)) t_2 = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * sin(Float64(-lambda2))))), fma(cos(lambda1), Float64(cos(phi2) * t_0), t_1)) tmp = 0.0 if (lambda1 <= -0.00062) tmp = t_2; elseif (lambda1 <= 3e-5) tmp = atan(Float64(cos(phi2) * Float64(Float64(lambda1 * cos(lambda2)) - sin(lambda2))), fma(Float64(cos(phi2) * cos(Float64(lambda1 - lambda2))), t_0, t_1)); else tmp = t_2; end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = (-N[Sin[phi1], $MachinePrecision])}, Block[{t$95$1 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[(-lambda2)], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Cos[lambda1], $MachinePrecision] * N[(N[Cos[phi2], $MachinePrecision] * t$95$0), $MachinePrecision] + t$95$1), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda1, -0.00062], t$95$2, If[LessEqual[lambda1, 3e-5], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[(lambda1 * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi2], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * t$95$0 + t$95$1), $MachinePrecision]], $MachinePrecision], t$95$2]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := -\sin \phi_1\\
t_1 := \cos \phi_1 \cdot \sin \phi_2\\
t_2 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \sin \left(-\lambda_2\right)\right)}{\mathsf{fma}\left(\cos \lambda_1, \cos \phi_2 \cdot t\_0, t\_1\right)}\\
\mathbf{if}\;\lambda_1 \leq -0.00062:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;\lambda_1 \leq 3 \cdot 10^{-5}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\lambda_1 \cdot \cos \lambda_2 - \sin \lambda_2\right)}{\mathsf{fma}\left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right), t\_0, t\_1\right)}\\
\mathbf{else}:\\
\;\;\;\;t\_2\\
\end{array}
\end{array}
if lambda1 < -6.2e-4 or 3.00000000000000008e-5 < lambda1 Initial program 57.5%
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
distribute-rgt-neg-inN/A
sin-negN/A
lower-*.f64N/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-neg.f6475.5
Applied rewrites75.5%
Taylor expanded in lambda2 around 0
sub-negN/A
+-commutativeN/A
distribute-rgt-neg-inN/A
lower-fma.f64N/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
mul-1-negN/A
lower-*.f64N/A
mul-1-negN/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-*.f64N/A
lower-cos.f64N/A
lower-sin.f6475.4
Applied rewrites75.4%
if -6.2e-4 < lambda1 < 3.00000000000000008e-5Initial program 99.3%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites99.3%
Taylor expanded in lambda1 around 0
+-commutativeN/A
cos-negN/A
sin-negN/A
unsub-negN/A
lower--.f64N/A
lower-*.f64N/A
lower-cos.f64N/A
lower-sin.f6499.4
Applied rewrites99.4%
Final simplification86.5%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (cos phi2) (fma (sin (- lambda2)) (cos lambda1) (* (sin lambda1) (cos lambda2)))) (- (* (cos phi1) (sin phi2)) (* (* (cos phi2) (sin phi1)) (cos (- lambda1 lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2)))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * cos(Float64(lambda1 - lambda2))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
Initial program 76.8%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6486.5
Applied rewrites86.5%
Final simplification86.5%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (cos phi2) (fma (sin lambda1) (cos lambda2) (* (cos lambda1) (sin (- lambda2))))) (- (* (cos phi1) (sin phi2)) (* (* (cos phi2) (sin phi1)) (cos (- lambda1 lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * sin(-lambda2)))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2)))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * sin(Float64(-lambda2))))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * cos(Float64(lambda1 - lambda2))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[(-lambda2)], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \sin \left(-\lambda_2\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
Initial program 76.8%
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
distribute-rgt-neg-inN/A
sin-negN/A
lower-*.f64N/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-neg.f6486.5
Applied rewrites86.5%
Final simplification86.5%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2))) (t_1 (cos (- lambda1 lambda2))))
(if (<= phi1 -2.25e-9)
(atan2
(*
(cos phi2)
(sin
(* (+ lambda1 lambda2) (/ (- lambda1 lambda2) (+ lambda1 lambda2)))))
(- t_0 (* (* (cos phi2) (sin phi1)) t_1)))
(if (<= phi1 1.75e-6)
(atan2
(*
(cos phi2)
(fma (sin (- lambda2)) (cos lambda1) (* (sin lambda1) (cos lambda2))))
(- t_0 (* (sin phi1) (cos (- lambda2 lambda1)))))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(fma (* (cos phi2) t_1) (- (sin phi1)) t_0))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double t_1 = cos((lambda1 - lambda2));
double tmp;
if (phi1 <= -2.25e-9) {
tmp = atan2((cos(phi2) * sin(((lambda1 + lambda2) * ((lambda1 - lambda2) / (lambda1 + lambda2))))), (t_0 - ((cos(phi2) * sin(phi1)) * t_1)));
} else if (phi1 <= 1.75e-6) {
tmp = atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), (t_0 - (sin(phi1) * cos((lambda2 - lambda1)))));
} else {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), fma((cos(phi2) * t_1), -sin(phi1), t_0));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = cos(Float64(lambda1 - lambda2)) tmp = 0.0 if (phi1 <= -2.25e-9) tmp = atan(Float64(cos(phi2) * sin(Float64(Float64(lambda1 + lambda2) * Float64(Float64(lambda1 - lambda2) / Float64(lambda1 + lambda2))))), Float64(t_0 - Float64(Float64(cos(phi2) * sin(phi1)) * t_1))); elseif (phi1 <= 1.75e-6) tmp = atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), Float64(t_0 - Float64(sin(phi1) * cos(Float64(lambda2 - lambda1))))); else tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), fma(Float64(cos(phi2) * t_1), Float64(-sin(phi1)), t_0)); 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[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi1, -2.25e-9], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(N[(lambda1 + lambda2), $MachinePrecision] * N[(N[(lambda1 - lambda2), $MachinePrecision] / N[(lambda1 + lambda2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi1, 1.75e-6], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi2], $MachinePrecision] * t$95$1), $MachinePrecision] * (-N[Sin[phi1], $MachinePrecision]) + t$95$0), $MachinePrecision]], $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
t_1 := \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_1 \leq -2.25 \cdot 10^{-9}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\left(\lambda_1 + \lambda_2\right) \cdot \frac{\lambda_1 - \lambda_2}{\lambda_1 + \lambda_2}\right)}{t\_0 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t\_1}\\
\mathbf{elif}\;\phi_1 \leq 1.75 \cdot 10^{-6}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{t\_0 - \sin \phi_1 \cdot \cos \left(\lambda_2 - \lambda_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\cos \phi_2 \cdot t\_1, -\sin \phi_1, t\_0\right)}\\
\end{array}
\end{array}
if phi1 < -2.24999999999999988e-9Initial program 73.9%
flip--N/A
difference-of-squaresN/A
lift--.f64N/A
associate-/l*N/A
lower-*.f64N/A
lower-+.f64N/A
lower-/.f64N/A
lower-+.f6474.6
Applied rewrites74.6%
if -2.24999999999999988e-9 < phi1 < 1.74999999999999997e-6Initial program 82.1%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6499.0
Applied rewrites99.0%
Taylor expanded in phi2 around 0
lower-*.f64N/A
sub-negN/A
remove-double-negN/A
mul-1-negN/A
distribute-neg-inN/A
+-commutativeN/A
cos-negN/A
lower-cos.f64N/A
mul-1-negN/A
unsub-negN/A
lower--.f64N/A
lower-sin.f6499.0
Applied rewrites99.0%
if 1.74999999999999997e-6 < phi1 Initial program 71.0%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites71.0%
Final simplification84.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2)))
(t_1 (cos (- lambda1 lambda2)))
(t_2 (* (* (cos phi2) (sin phi1)) t_1)))
(if (<= phi1 -1.12e-5)
(atan2
(*
(cos phi2)
(sin
(* (+ lambda1 lambda2) (/ (- lambda1 lambda2) (+ lambda1 lambda2)))))
(- t_0 t_2))
(if (<= phi1 0.00018)
(atan2
(*
(cos phi2)
(fma (sin (- lambda2)) (cos lambda1) (* (sin lambda1) (cos lambda2))))
(- (sin phi2) t_2))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(fma (* (cos phi2) t_1) (- (sin phi1)) t_0))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double t_1 = cos((lambda1 - lambda2));
double t_2 = (cos(phi2) * sin(phi1)) * t_1;
double tmp;
if (phi1 <= -1.12e-5) {
tmp = atan2((cos(phi2) * sin(((lambda1 + lambda2) * ((lambda1 - lambda2) / (lambda1 + lambda2))))), (t_0 - t_2));
} else if (phi1 <= 0.00018) {
tmp = atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), (sin(phi2) - t_2));
} else {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), fma((cos(phi2) * t_1), -sin(phi1), t_0));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = cos(Float64(lambda1 - lambda2)) t_2 = Float64(Float64(cos(phi2) * sin(phi1)) * t_1) tmp = 0.0 if (phi1 <= -1.12e-5) tmp = atan(Float64(cos(phi2) * sin(Float64(Float64(lambda1 + lambda2) * Float64(Float64(lambda1 - lambda2) / Float64(lambda1 + lambda2))))), Float64(t_0 - t_2)); elseif (phi1 <= 0.00018) tmp = atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), Float64(sin(phi2) - t_2)); else tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), fma(Float64(cos(phi2) * t_1), Float64(-sin(phi1)), t_0)); 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[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * t$95$1), $MachinePrecision]}, If[LessEqual[phi1, -1.12e-5], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(N[(lambda1 + lambda2), $MachinePrecision] * N[(N[(lambda1 - lambda2), $MachinePrecision] / N[(lambda1 + lambda2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - t$95$2), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi1, 0.00018], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - t$95$2), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi2], $MachinePrecision] * t$95$1), $MachinePrecision] * (-N[Sin[phi1], $MachinePrecision]) + t$95$0), $MachinePrecision]], $MachinePrecision]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
t_1 := \cos \left(\lambda_1 - \lambda_2\right)\\
t_2 := \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t\_1\\
\mathbf{if}\;\phi_1 \leq -1.12 \cdot 10^{-5}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\left(\lambda_1 + \lambda_2\right) \cdot \frac{\lambda_1 - \lambda_2}{\lambda_1 + \lambda_2}\right)}{t\_0 - t\_2}\\
\mathbf{elif}\;\phi_1 \leq 0.00018:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{\sin \phi_2 - t\_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\cos \phi_2 \cdot t\_1, -\sin \phi_1, t\_0\right)}\\
\end{array}
\end{array}
if phi1 < -1.11999999999999995e-5Initial program 73.9%
flip--N/A
difference-of-squaresN/A
lift--.f64N/A
associate-/l*N/A
lower-*.f64N/A
lower-+.f64N/A
lower-/.f64N/A
lower-+.f6474.6
Applied rewrites74.6%
if -1.11999999999999995e-5 < phi1 < 1.80000000000000011e-4Initial program 82.1%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6499.0
Applied rewrites99.0%
Taylor expanded in phi1 around 0
lower-sin.f6499.0
Applied rewrites99.0%
if 1.80000000000000011e-4 < phi1 Initial program 71.0%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites71.0%
Final simplification84.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2))) (t_1 (cos (- lambda1 lambda2))))
(if (<= phi1 -1.82e-9)
(atan2
(*
(cos phi2)
(sin
(* (+ lambda1 lambda2) (/ (- lambda1 lambda2) (+ lambda1 lambda2)))))
(- t_0 (* (* (cos phi2) (sin phi1)) t_1)))
(if (<= phi1 6.3e-74)
(atan2
(*
(cos phi2)
(fma (sin (- lambda2)) (cos lambda1) (* (sin lambda1) (cos lambda2))))
(sin phi2))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(fma (* (cos phi2) t_1) (- (sin phi1)) t_0))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double t_1 = cos((lambda1 - lambda2));
double tmp;
if (phi1 <= -1.82e-9) {
tmp = atan2((cos(phi2) * sin(((lambda1 + lambda2) * ((lambda1 - lambda2) / (lambda1 + lambda2))))), (t_0 - ((cos(phi2) * sin(phi1)) * t_1)));
} else if (phi1 <= 6.3e-74) {
tmp = atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), sin(phi2));
} else {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), fma((cos(phi2) * t_1), -sin(phi1), t_0));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = cos(Float64(lambda1 - lambda2)) tmp = 0.0 if (phi1 <= -1.82e-9) tmp = atan(Float64(cos(phi2) * sin(Float64(Float64(lambda1 + lambda2) * Float64(Float64(lambda1 - lambda2) / Float64(lambda1 + lambda2))))), Float64(t_0 - Float64(Float64(cos(phi2) * sin(phi1)) * t_1))); elseif (phi1 <= 6.3e-74) tmp = atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), sin(phi2)); else tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), fma(Float64(cos(phi2) * t_1), Float64(-sin(phi1)), t_0)); 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[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi1, -1.82e-9], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(N[(lambda1 + lambda2), $MachinePrecision] * N[(N[(lambda1 - lambda2), $MachinePrecision] / N[(lambda1 + lambda2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi1, 6.3e-74], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi2], $MachinePrecision] * t$95$1), $MachinePrecision] * (-N[Sin[phi1], $MachinePrecision]) + t$95$0), $MachinePrecision]], $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
t_1 := \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_1 \leq -1.82 \cdot 10^{-9}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\left(\lambda_1 + \lambda_2\right) \cdot \frac{\lambda_1 - \lambda_2}{\lambda_1 + \lambda_2}\right)}{t\_0 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t\_1}\\
\mathbf{elif}\;\phi_1 \leq 6.3 \cdot 10^{-74}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{\sin \phi_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\cos \phi_2 \cdot t\_1, -\sin \phi_1, t\_0\right)}\\
\end{array}
\end{array}
if phi1 < -1.8199999999999999e-9Initial program 73.9%
flip--N/A
difference-of-squaresN/A
lift--.f64N/A
associate-/l*N/A
lower-*.f64N/A
lower-+.f64N/A
lower-/.f64N/A
lower-+.f6474.6
Applied rewrites74.6%
if -1.8199999999999999e-9 < phi1 < 6.30000000000000003e-74Initial program 82.2%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6499.5
Applied rewrites99.5%
Taylor expanded in phi1 around 0
lower-sin.f6497.8
Applied rewrites97.8%
if 6.30000000000000003e-74 < phi1 Initial program 72.4%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites72.4%
Final simplification83.4%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2)))
(t_1 (sin (- lambda2)))
(t_2 (* (cos phi1) (sin phi2))))
(if (<= lambda2 -9e-43)
(atan2
(* (cos phi2) (fma (sin lambda1) (cos lambda2) (* (cos lambda1) t_1)))
(sin phi2))
(if (<= lambda2 9e-115)
(atan2
(* (sin lambda1) (cos phi2))
(- t_2 (* (* (cos phi2) (sin phi1)) t_0)))
(if (<= lambda2 4.8e+26)
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(- t_2 (* (sin phi1) t_0)))
(atan2
(* (cos phi2) t_1)
(- t_2 (* (sin phi1) (* (cos lambda2) (cos phi2))))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double t_1 = sin(-lambda2);
double t_2 = cos(phi1) * sin(phi2);
double tmp;
if (lambda2 <= -9e-43) {
tmp = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * t_1))), sin(phi2));
} else if (lambda2 <= 9e-115) {
tmp = atan2((sin(lambda1) * cos(phi2)), (t_2 - ((cos(phi2) * sin(phi1)) * t_0)));
} else if (lambda2 <= 4.8e+26) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_2 - (sin(phi1) * t_0)));
} else {
tmp = atan2((cos(phi2) * t_1), (t_2 - (sin(phi1) * (cos(lambda2) * cos(phi2)))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) t_1 = sin(Float64(-lambda2)) t_2 = Float64(cos(phi1) * sin(phi2)) tmp = 0.0 if (lambda2 <= -9e-43) tmp = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * t_1))), sin(phi2)); elseif (lambda2 <= 9e-115) tmp = atan(Float64(sin(lambda1) * cos(phi2)), Float64(t_2 - Float64(Float64(cos(phi2) * sin(phi1)) * t_0))); elseif (lambda2 <= 4.8e+26) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(t_2 - Float64(sin(phi1) * t_0))); else tmp = atan(Float64(cos(phi2) * t_1), Float64(t_2 - Float64(sin(phi1) * Float64(cos(lambda2) * cos(phi2))))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[Sin[(-lambda2)], $MachinePrecision]}, Block[{t$95$2 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda2, -9e-43], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda2, 9e-115], N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$2 - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda2, 4.8e+26], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(t$95$2 - N[(N[Sin[phi1], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * t$95$1), $MachinePrecision] / N[(t$95$2 - N[(N[Sin[phi1], $MachinePrecision] * N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
t_1 := \sin \left(-\lambda_2\right)\\
t_2 := \cos \phi_1 \cdot \sin \phi_2\\
\mathbf{if}\;\lambda_2 \leq -9 \cdot 10^{-43}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot t\_1\right)}{\sin \phi_2}\\
\mathbf{elif}\;\lambda_2 \leq 9 \cdot 10^{-115}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t\_0}\\
\mathbf{elif}\;\lambda_2 \leq 4.8 \cdot 10^{+26}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t\_2 - \sin \phi_1 \cdot t\_0}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot t\_1}{t\_2 - \sin \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \phi_2\right)}\\
\end{array}
\end{array}
if lambda2 < -9.0000000000000005e-43Initial program 60.5%
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
distribute-rgt-neg-inN/A
sin-negN/A
lower-*.f64N/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-neg.f6479.2
Applied rewrites79.2%
Taylor expanded in phi1 around 0
lower-sin.f6462.5
Applied rewrites62.5%
if -9.0000000000000005e-43 < lambda2 < 9.00000000000000046e-115Initial program 99.7%
Taylor expanded in lambda2 around 0
lower-sin.f6496.1
Applied rewrites96.1%
if 9.00000000000000046e-115 < lambda2 < 4.80000000000000009e26Initial program 92.9%
Taylor expanded in phi2 around 0
lower-*.f64N/A
lower-cos.f64N/A
lower--.f64N/A
lower-sin.f6474.3
Applied rewrites74.3%
if 4.80000000000000009e26 < lambda2 Initial program 56.4%
Taylor expanded in lambda1 around 0
lower-sin.f64N/A
lower-neg.f6462.5
Applied rewrites62.5%
Taylor expanded in lambda1 around 0
associate-*r*N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-*.f64N/A
lower-cos.f64N/A
cos-negN/A
lower-cos.f6462.7
Applied rewrites62.7%
Final simplification75.0%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(fma
(* (cos phi2) (cos (- lambda1 lambda2)))
(- (sin phi1))
(* (cos phi1) (sin phi2))))))
(if (<= phi1 -1.82e-9)
t_0
(if (<= phi1 6.3e-74)
(atan2
(*
(cos phi2)
(fma (sin (- lambda2)) (cos lambda1) (* (sin lambda1) (cos lambda2))))
(sin phi2))
t_0))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = atan2((cos(phi2) * sin((lambda1 - lambda2))), fma((cos(phi2) * cos((lambda1 - lambda2))), -sin(phi1), (cos(phi1) * sin(phi2))));
double tmp;
if (phi1 <= -1.82e-9) {
tmp = t_0;
} else if (phi1 <= 6.3e-74) {
tmp = atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), sin(phi2));
} else {
tmp = t_0;
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), fma(Float64(cos(phi2) * cos(Float64(lambda1 - lambda2))), Float64(-sin(phi1)), Float64(cos(phi1) * sin(phi2)))) tmp = 0.0 if (phi1 <= -1.82e-9) tmp = t_0; elseif (phi1 <= 6.3e-74) tmp = atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), sin(phi2)); else tmp = t_0; end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi2], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * (-N[Sin[phi1], $MachinePrecision]) + N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi1, -1.82e-9], t$95$0, If[LessEqual[phi1, 6.3e-74], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], t$95$0]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\cos \phi_2 \cdot \cos \left(\lambda_1 - \lambda_2\right), -\sin \phi_1, \cos \phi_1 \cdot \sin \phi_2\right)}\\
\mathbf{if}\;\phi_1 \leq -1.82 \cdot 10^{-9}:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;\phi_1 \leq 6.3 \cdot 10^{-74}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{\sin \phi_2}\\
\mathbf{else}:\\
\;\;\;\;t\_0\\
\end{array}
\end{array}
if phi1 < -1.8199999999999999e-9 or 6.30000000000000003e-74 < phi1 Initial program 72.9%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites73.0%
if -1.8199999999999999e-9 < phi1 < 6.30000000000000003e-74Initial program 82.2%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6499.5
Applied rewrites99.5%
Taylor expanded in phi1 around 0
lower-sin.f6497.8
Applied rewrites97.8%
Final simplification83.3%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(-
(* (cos phi1) (sin phi2))
(* (* (cos phi2) (sin phi1)) (cos (- lambda1 lambda2)))))))
(if (<= phi1 -1.82e-9)
t_0
(if (<= phi1 6.3e-74)
(atan2
(*
(cos phi2)
(fma (sin (- lambda2)) (cos lambda1) (* (sin lambda1) (cos lambda2))))
(sin phi2))
t_0))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2)))));
double tmp;
if (phi1 <= -1.82e-9) {
tmp = t_0;
} else if (phi1 <= 6.3e-74) {
tmp = atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), sin(phi2));
} else {
tmp = t_0;
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * cos(Float64(lambda1 - lambda2))))) tmp = 0.0 if (phi1 <= -1.82e-9) tmp = t_0; elseif (phi1 <= 6.3e-74) tmp = atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), sin(phi2)); else tmp = t_0; end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi1, -1.82e-9], t$95$0, If[LessEqual[phi1, 6.3e-74], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], t$95$0]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\mathbf{if}\;\phi_1 \leq -1.82 \cdot 10^{-9}:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;\phi_1 \leq 6.3 \cdot 10^{-74}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{\sin \phi_2}\\
\mathbf{else}:\\
\;\;\;\;t\_0\\
\end{array}
\end{array}
if phi1 < -1.8199999999999999e-9 or 6.30000000000000003e-74 < phi1 Initial program 72.9%
if -1.8199999999999999e-9 < phi1 < 6.30000000000000003e-74Initial program 82.2%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6499.5
Applied rewrites99.5%
Taylor expanded in phi1 around 0
lower-sin.f6497.8
Applied rewrites97.8%
Final simplification83.2%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (sin (- lambda2))) (t_1 (* (cos phi1) (sin phi2))))
(if (<= lambda2 -2.25e-7)
(atan2
(* (cos phi2) (fma (sin lambda1) (cos lambda2) (* (cos lambda1) t_0)))
(sin phi2))
(if (<= lambda2 4.8e+26)
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(- t_1 (* (sin phi1) (* (cos lambda1) (cos phi2)))))
(atan2
(* (cos phi2) t_0)
(- t_1 (* (sin phi1) (* (cos lambda2) (cos phi2)))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = sin(-lambda2);
double t_1 = cos(phi1) * sin(phi2);
double tmp;
if (lambda2 <= -2.25e-7) {
tmp = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * t_0))), sin(phi2));
} else if (lambda2 <= 4.8e+26) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_1 - (sin(phi1) * (cos(lambda1) * cos(phi2)))));
} else {
tmp = atan2((cos(phi2) * t_0), (t_1 - (sin(phi1) * (cos(lambda2) * cos(phi2)))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = sin(Float64(-lambda2)) t_1 = Float64(cos(phi1) * sin(phi2)) tmp = 0.0 if (lambda2 <= -2.25e-7) tmp = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * t_0))), sin(phi2)); elseif (lambda2 <= 4.8e+26) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(t_1 - Float64(sin(phi1) * Float64(cos(lambda1) * cos(phi2))))); else tmp = atan(Float64(cos(phi2) * t_0), Float64(t_1 - Float64(sin(phi1) * Float64(cos(lambda2) * cos(phi2))))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Sin[(-lambda2)], $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda2, -2.25e-7], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda2, 4.8e+26], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(t$95$1 - N[(N[Sin[phi1], $MachinePrecision] * N[(N[Cos[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * t$95$0), $MachinePrecision] / N[(t$95$1 - N[(N[Sin[phi1], $MachinePrecision] * N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \sin \left(-\lambda_2\right)\\
t_1 := \cos \phi_1 \cdot \sin \phi_2\\
\mathbf{if}\;\lambda_2 \leq -2.25 \cdot 10^{-7}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot t\_0\right)}{\sin \phi_2}\\
\mathbf{elif}\;\lambda_2 \leq 4.8 \cdot 10^{+26}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t\_1 - \sin \phi_1 \cdot \left(\cos \lambda_1 \cdot \cos \phi_2\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot t\_0}{t\_1 - \sin \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \phi_2\right)}\\
\end{array}
\end{array}
if lambda2 < -2.2499999999999999e-7Initial program 56.1%
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
distribute-rgt-neg-inN/A
sin-negN/A
lower-*.f64N/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-neg.f6476.9
Applied rewrites76.9%
Taylor expanded in phi1 around 0
lower-sin.f6459.7
Applied rewrites59.7%
if -2.2499999999999999e-7 < lambda2 < 4.80000000000000009e26Initial program 97.6%
Taylor expanded in lambda2 around 0
associate-*r*N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-cos.f64N/A
lower-cos.f6496.5
Applied rewrites96.5%
if 4.80000000000000009e26 < lambda2 Initial program 56.4%
Taylor expanded in lambda1 around 0
lower-sin.f64N/A
lower-neg.f6462.5
Applied rewrites62.5%
Taylor expanded in lambda1 around 0
associate-*r*N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-*.f64N/A
lower-cos.f64N/A
cos-negN/A
lower-cos.f6462.7
Applied rewrites62.7%
Final simplification78.6%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2)))
(t_1
(atan2
(* (sin lambda1) (cos phi2))
(- t_0 (* (* (cos phi2) (sin phi1)) (cos (- lambda1 lambda2)))))))
(if (<= lambda1 -0.05)
t_1
(if (<= lambda1 1.5e+22)
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(- t_0 (* (cos phi2) (* (cos lambda2) (sin phi1)))))
t_1))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double t_1 = atan2((sin(lambda1) * cos(phi2)), (t_0 - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2)))));
double tmp;
if (lambda1 <= -0.05) {
tmp = t_1;
} else if (lambda1 <= 1.5e+22) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_0 - (cos(phi2) * (cos(lambda2) * sin(phi1)))));
} else {
tmp = t_1;
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: t_1
real(8) :: tmp
t_0 = cos(phi1) * sin(phi2)
t_1 = atan2((sin(lambda1) * cos(phi2)), (t_0 - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2)))))
if (lambda1 <= (-0.05d0)) then
tmp = t_1
else if (lambda1 <= 1.5d+22) then
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_0 - (cos(phi2) * (cos(lambda2) * sin(phi1)))))
else
tmp = t_1
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos(phi1) * Math.sin(phi2);
double t_1 = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (t_0 - ((Math.cos(phi2) * Math.sin(phi1)) * Math.cos((lambda1 - lambda2)))));
double tmp;
if (lambda1 <= -0.05) {
tmp = t_1;
} else if (lambda1 <= 1.5e+22) {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), (t_0 - (Math.cos(phi2) * (Math.cos(lambda2) * Math.sin(phi1)))));
} 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(lambda1) * math.cos(phi2)), (t_0 - ((math.cos(phi2) * math.sin(phi1)) * math.cos((lambda1 - lambda2))))) tmp = 0 if lambda1 <= -0.05: tmp = t_1 elif lambda1 <= 1.5e+22: tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), (t_0 - (math.cos(phi2) * (math.cos(lambda2) * math.sin(phi1))))) else: tmp = t_1 return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = atan(Float64(sin(lambda1) * cos(phi2)), Float64(t_0 - Float64(Float64(cos(phi2) * sin(phi1)) * cos(Float64(lambda1 - lambda2))))) tmp = 0.0 if (lambda1 <= -0.05) tmp = t_1; elseif (lambda1 <= 1.5e+22) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(t_0 - Float64(cos(phi2) * Float64(cos(lambda2) * sin(phi1))))); 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(lambda1) * cos(phi2)), (t_0 - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2))))); tmp = 0.0; if (lambda1 <= -0.05) tmp = t_1; elseif (lambda1 <= 1.5e+22) tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_0 - (cos(phi2) * (cos(lambda2) * sin(phi1))))); 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[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda1, -0.05], t$95$1, If[LessEqual[lambda1, 1.5e+22], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Cos[phi2], $MachinePrecision] * N[(N[Cos[lambda2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $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 \lambda_1 \cdot \cos \phi_2}{t\_0 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\mathbf{if}\;\lambda_1 \leq -0.05:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;\lambda_1 \leq 1.5 \cdot 10^{+22}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t\_0 - \cos \phi_2 \cdot \left(\cos \lambda_2 \cdot \sin \phi_1\right)}\\
\mathbf{else}:\\
\;\;\;\;t\_1\\
\end{array}
\end{array}
if lambda1 < -0.050000000000000003 or 1.5e22 < lambda1 Initial program 56.9%
Taylor expanded in lambda2 around 0
lower-sin.f6459.2
Applied rewrites59.2%
if -0.050000000000000003 < lambda1 < 1.5e22Initial program 97.6%
Taylor expanded in lambda1 around 0
lower-*.f64N/A
lower-cos.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
cos-negN/A
lower-cos.f6497.2
Applied rewrites97.2%
Final simplification77.8%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(-
(* (cos phi1) (sin phi2))
(* (sin phi1) (cos (- lambda1 lambda2)))))))
(if (<= phi1 -6.6)
t_0
(if (<= phi1 36.0)
(atan2
(*
(cos phi2)
(fma (sin (- lambda2)) (cos lambda1) (* (sin lambda1) (cos lambda2))))
(sin phi2))
t_0))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - (sin(phi1) * cos((lambda1 - lambda2)))));
double tmp;
if (phi1 <= -6.6) {
tmp = t_0;
} else if (phi1 <= 36.0) {
tmp = atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), sin(phi2));
} else {
tmp = t_0;
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))) tmp = 0.0 if (phi1 <= -6.6) tmp = t_0; elseif (phi1 <= 36.0) tmp = atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), sin(phi2)); else tmp = t_0; end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi1, -6.6], t$95$0, If[LessEqual[phi1, 36.0], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], t$95$0]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\mathbf{if}\;\phi_1 \leq -6.6:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;\phi_1 \leq 36:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{\sin \phi_2}\\
\mathbf{else}:\\
\;\;\;\;t\_0\\
\end{array}
\end{array}
if phi1 < -6.5999999999999996 or 36 < phi1 Initial program 71.6%
Taylor expanded in phi2 around 0
lower-*.f64N/A
lower-cos.f64N/A
lower--.f64N/A
lower-sin.f6447.6
Applied rewrites47.6%
if -6.5999999999999996 < phi1 < 36Initial program 82.5%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6499.0
Applied rewrites99.0%
Taylor expanded in phi1 around 0
lower-sin.f6494.4
Applied rewrites94.4%
Final simplification69.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi2) (sin (- lambda1 lambda2)))))
(if (<= phi1 -6.6)
(atan2 t_0 (* (- (sin phi1)) (cos (- lambda2 lambda1))))
(if (<= phi1 6.3e-74)
(atan2
(*
(cos phi2)
(fma (sin (- lambda2)) (cos lambda1) (* (sin lambda1) (cos lambda2))))
(sin phi2))
(atan2
t_0
(-
(sin phi2)
(* (* (cos phi2) (sin phi1)) (cos (- lambda1 lambda2)))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi2) * sin((lambda1 - lambda2));
double tmp;
if (phi1 <= -6.6) {
tmp = atan2(t_0, (-sin(phi1) * cos((lambda2 - lambda1))));
} else if (phi1 <= 6.3e-74) {
tmp = atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), sin(phi2));
} else {
tmp = atan2(t_0, (sin(phi2) - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2)))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) tmp = 0.0 if (phi1 <= -6.6) tmp = atan(t_0, Float64(Float64(-sin(phi1)) * cos(Float64(lambda2 - lambda1)))); elseif (phi1 <= 6.3e-74) tmp = atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), sin(phi2)); else tmp = atan(t_0, Float64(sin(phi2) - Float64(Float64(cos(phi2) * sin(phi1)) * cos(Float64(lambda1 - lambda2))))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[phi1, -6.6], N[ArcTan[t$95$0 / N[((-N[Sin[phi1], $MachinePrecision]) * N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi1, 6.3e-74], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$0 / N[(N[Sin[phi2], $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_1 \leq -6.6:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_2 - \lambda_1\right)}\\
\mathbf{elif}\;\phi_1 \leq 6.3 \cdot 10^{-74}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{\sin \phi_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\end{array}
\end{array}
if phi1 < -6.5999999999999996Initial program 73.4%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites73.5%
Taylor expanded in phi2 around 0
mul-1-negN/A
distribute-rgt-neg-inN/A
sub-negN/A
remove-double-negN/A
distribute-neg-inN/A
+-commutativeN/A
neg-mul-1N/A
cos-negN/A
neg-mul-1N/A
sub-negN/A
mul-1-negN/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-cos.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f64N/A
mul-1-negN/A
lower-neg.f64N/A
lower-sin.f6445.2
Applied rewrites45.2%
if -6.5999999999999996 < phi1 < 6.30000000000000003e-74Initial program 82.3%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6499.5
Applied rewrites99.5%
Taylor expanded in phi1 around 0
lower-sin.f6497.1
Applied rewrites97.1%
if 6.30000000000000003e-74 < phi1 Initial program 72.4%
Taylor expanded in phi1 around 0
lower-sin.f6452.2
Applied rewrites52.2%
Final simplification69.4%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(* (- (sin phi1)) (cos (- lambda2 lambda1))))))
(if (<= phi1 -6.6)
t_0
(if (<= phi1 36.0)
(atan2
(*
(cos phi2)
(fma (sin (- lambda2)) (cos lambda1) (* (sin lambda1) (cos lambda2))))
(sin phi2))
t_0))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = atan2((cos(phi2) * sin((lambda1 - lambda2))), (-sin(phi1) * cos((lambda2 - lambda1))));
double tmp;
if (phi1 <= -6.6) {
tmp = t_0;
} else if (phi1 <= 36.0) {
tmp = atan2((cos(phi2) * fma(sin(-lambda2), cos(lambda1), (sin(lambda1) * cos(lambda2)))), sin(phi2));
} else {
tmp = t_0;
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(Float64(-sin(phi1)) * cos(Float64(lambda2 - lambda1)))) tmp = 0.0 if (phi1 <= -6.6) tmp = t_0; elseif (phi1 <= 36.0) tmp = atan(Float64(cos(phi2) * fma(sin(Float64(-lambda2)), cos(lambda1), Float64(sin(lambda1) * cos(lambda2)))), sin(phi2)); else tmp = t_0; end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[((-N[Sin[phi1], $MachinePrecision]) * N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi1, -6.6], t$95$0, If[LessEqual[phi1, 36.0], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], t$95$0]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_2 - \lambda_1\right)}\\
\mathbf{if}\;\phi_1 \leq -6.6:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;\phi_1 \leq 36:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \cos \lambda_2\right)}{\sin \phi_2}\\
\mathbf{else}:\\
\;\;\;\;t\_0\\
\end{array}
\end{array}
if phi1 < -6.5999999999999996 or 36 < phi1 Initial program 71.6%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites71.6%
Taylor expanded in phi2 around 0
mul-1-negN/A
distribute-rgt-neg-inN/A
sub-negN/A
remove-double-negN/A
distribute-neg-inN/A
+-commutativeN/A
neg-mul-1N/A
cos-negN/A
neg-mul-1N/A
sub-negN/A
mul-1-negN/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-cos.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f64N/A
mul-1-negN/A
lower-neg.f64N/A
lower-sin.f6446.6
Applied rewrites46.6%
if -6.5999999999999996 < phi1 < 36Initial program 82.5%
sub-negN/A
+-commutativeN/A
sin-sumN/A
cos-negN/A
*-commutativeN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-neg.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
lower-sin.f64N/A
lower-cos.f6499.0
Applied rewrites99.0%
Taylor expanded in phi1 around 0
lower-sin.f6494.4
Applied rewrites94.4%
Final simplification69.2%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(* (- (sin phi1)) (cos (- lambda2 lambda1))))))
(if (<= phi1 -6.6)
t_0
(if (<= phi1 36.0)
(atan2
(*
(cos phi2)
(fma (sin lambda1) (cos lambda2) (* (cos lambda1) (sin (- lambda2)))))
(sin phi2))
t_0))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = atan2((cos(phi2) * sin((lambda1 - lambda2))), (-sin(phi1) * cos((lambda2 - lambda1))));
double tmp;
if (phi1 <= -6.6) {
tmp = t_0;
} else if (phi1 <= 36.0) {
tmp = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * sin(-lambda2)))), sin(phi2));
} else {
tmp = t_0;
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(Float64(-sin(phi1)) * cos(Float64(lambda2 - lambda1)))) tmp = 0.0 if (phi1 <= -6.6) tmp = t_0; elseif (phi1 <= 36.0) tmp = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * sin(Float64(-lambda2))))), sin(phi2)); else tmp = t_0; end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[((-N[Sin[phi1], $MachinePrecision]) * N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi1, -6.6], t$95$0, If[LessEqual[phi1, 36.0], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[(-lambda2)], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], t$95$0]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_2 - \lambda_1\right)}\\
\mathbf{if}\;\phi_1 \leq -6.6:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;\phi_1 \leq 36:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \sin \left(-\lambda_2\right)\right)}{\sin \phi_2}\\
\mathbf{else}:\\
\;\;\;\;t\_0\\
\end{array}
\end{array}
if phi1 < -6.5999999999999996 or 36 < phi1 Initial program 71.6%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites71.6%
Taylor expanded in phi2 around 0
mul-1-negN/A
distribute-rgt-neg-inN/A
sub-negN/A
remove-double-negN/A
distribute-neg-inN/A
+-commutativeN/A
neg-mul-1N/A
cos-negN/A
neg-mul-1N/A
sub-negN/A
mul-1-negN/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-cos.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f64N/A
mul-1-negN/A
lower-neg.f64N/A
lower-sin.f6446.6
Applied rewrites46.6%
if -6.5999999999999996 < phi1 < 36Initial program 82.5%
sin-diffN/A
sub-negN/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-cos.f64N/A
distribute-rgt-neg-inN/A
sin-negN/A
lower-*.f64N/A
lower-cos.f64N/A
lower-sin.f64N/A
lower-neg.f6499.0
Applied rewrites99.0%
Taylor expanded in phi1 around 0
lower-sin.f6494.4
Applied rewrites94.4%
Final simplification69.2%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda2 lambda1)))
(t_1 (* (cos phi2) (sin (- lambda1 lambda2))))
(t_2 (atan2 t_1 (* (- (sin phi1)) t_0))))
(if (<= phi1 -0.0027)
t_2
(if (<= phi1 0.015)
(atan2 t_1 (fma (- (* (cos phi2) phi1)) t_0 (sin phi2)))
t_2))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda2 - lambda1));
double t_1 = cos(phi2) * sin((lambda1 - lambda2));
double t_2 = atan2(t_1, (-sin(phi1) * t_0));
double tmp;
if (phi1 <= -0.0027) {
tmp = t_2;
} else if (phi1 <= 0.015) {
tmp = atan2(t_1, fma(-(cos(phi2) * phi1), t_0, sin(phi2)));
} else {
tmp = t_2;
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda2 - lambda1)) t_1 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) t_2 = atan(t_1, Float64(Float64(-sin(phi1)) * t_0)) tmp = 0.0 if (phi1 <= -0.0027) tmp = t_2; elseif (phi1 <= 0.015) tmp = atan(t_1, fma(Float64(-Float64(cos(phi2) * phi1)), t_0, sin(phi2))); else tmp = t_2; end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[ArcTan[t$95$1 / N[((-N[Sin[phi1], $MachinePrecision]) * t$95$0), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi1, -0.0027], t$95$2, If[LessEqual[phi1, 0.015], N[ArcTan[t$95$1 / N[((-N[(N[Cos[phi2], $MachinePrecision] * phi1), $MachinePrecision]) * t$95$0 + N[Sin[phi2], $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$2]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_2 - \lambda_1\right)\\
t_1 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
t_2 := \tan^{-1}_* \frac{t\_1}{\left(-\sin \phi_1\right) \cdot t\_0}\\
\mathbf{if}\;\phi_1 \leq -0.0027:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;\phi_1 \leq 0.015:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{\mathsf{fma}\left(-\cos \phi_2 \cdot \phi_1, t\_0, \sin \phi_2\right)}\\
\mathbf{else}:\\
\;\;\;\;t\_2\\
\end{array}
\end{array}
if phi1 < -0.0027000000000000001 or 0.014999999999999999 < phi1 Initial program 72.0%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites72.0%
Taylor expanded in phi2 around 0
mul-1-negN/A
distribute-rgt-neg-inN/A
sub-negN/A
remove-double-negN/A
distribute-neg-inN/A
+-commutativeN/A
neg-mul-1N/A
cos-negN/A
neg-mul-1N/A
sub-negN/A
mul-1-negN/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-cos.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f64N/A
mul-1-negN/A
lower-neg.f64N/A
lower-sin.f6446.2
Applied rewrites46.2%
if -0.0027000000000000001 < phi1 < 0.014999999999999999Initial program 82.2%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites82.2%
Taylor expanded in phi1 around 0
+-commutativeN/A
mul-1-negN/A
associate-*r*N/A
distribute-lft-neg-inN/A
sub-negN/A
remove-double-negN/A
distribute-neg-inN/A
+-commutativeN/A
neg-mul-1N/A
cos-negN/A
neg-mul-1N/A
sub-negN/A
lower-fma.f64N/A
Applied rewrites81.8%
Final simplification62.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (sin (- lambda1 lambda2)))
(t_1 (atan2 (* (cos phi2) t_0) (sin phi2))))
(if (<= phi2 -0.015)
t_1
(if (<= phi2 8.2e-10)
(atan2
t_0
(- (* phi2 (cos phi1)) (* (sin phi1) (cos (- lambda2 lambda1)))))
t_1))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = sin((lambda1 - lambda2));
double t_1 = atan2((cos(phi2) * t_0), sin(phi2));
double tmp;
if (phi2 <= -0.015) {
tmp = t_1;
} else if (phi2 <= 8.2e-10) {
tmp = atan2(t_0, ((phi2 * cos(phi1)) - (sin(phi1) * cos((lambda2 - lambda1)))));
} else {
tmp = t_1;
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: t_1
real(8) :: tmp
t_0 = sin((lambda1 - lambda2))
t_1 = atan2((cos(phi2) * t_0), sin(phi2))
if (phi2 <= (-0.015d0)) then
tmp = t_1
else if (phi2 <= 8.2d-10) then
tmp = atan2(t_0, ((phi2 * cos(phi1)) - (sin(phi1) * cos((lambda2 - lambda1)))))
else
tmp = t_1
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.sin((lambda1 - lambda2));
double t_1 = Math.atan2((Math.cos(phi2) * t_0), Math.sin(phi2));
double tmp;
if (phi2 <= -0.015) {
tmp = t_1;
} else if (phi2 <= 8.2e-10) {
tmp = Math.atan2(t_0, ((phi2 * Math.cos(phi1)) - (Math.sin(phi1) * Math.cos((lambda2 - lambda1)))));
} else {
tmp = t_1;
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.sin((lambda1 - lambda2)) t_1 = math.atan2((math.cos(phi2) * t_0), math.sin(phi2)) tmp = 0 if phi2 <= -0.015: tmp = t_1 elif phi2 <= 8.2e-10: tmp = math.atan2(t_0, ((phi2 * math.cos(phi1)) - (math.sin(phi1) * math.cos((lambda2 - lambda1))))) else: tmp = t_1 return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = sin(Float64(lambda1 - lambda2)) t_1 = atan(Float64(cos(phi2) * t_0), sin(phi2)) tmp = 0.0 if (phi2 <= -0.015) tmp = t_1; elseif (phi2 <= 8.2e-10) tmp = atan(t_0, Float64(Float64(phi2 * cos(phi1)) - Float64(sin(phi1) * cos(Float64(lambda2 - lambda1))))); else tmp = t_1; end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = sin((lambda1 - lambda2)); t_1 = atan2((cos(phi2) * t_0), sin(phi2)); tmp = 0.0; if (phi2 <= -0.015) tmp = t_1; elseif (phi2 <= 8.2e-10) tmp = atan2(t_0, ((phi2 * cos(phi1)) - (sin(phi1) * cos((lambda2 - lambda1))))); else tmp = t_1; end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * t$95$0), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi2, -0.015], t$95$1, If[LessEqual[phi2, 8.2e-10], N[ArcTan[t$95$0 / N[(N[(phi2 * N[Cos[phi1], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$1]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \sin \left(\lambda_1 - \lambda_2\right)\\
t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot t\_0}{\sin \phi_2}\\
\mathbf{if}\;\phi_2 \leq -0.015:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;\phi_2 \leq 8.2 \cdot 10^{-10}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\phi_2 \cdot \cos \phi_1 - \sin \phi_1 \cdot \cos \left(\lambda_2 - \lambda_1\right)}\\
\mathbf{else}:\\
\;\;\;\;t\_1\\
\end{array}
\end{array}
if phi2 < -0.014999999999999999 or 8.1999999999999996e-10 < phi2 Initial program 72.3%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites72.4%
Taylor expanded in phi1 around 0
lower-sin.f6441.9
Applied rewrites41.9%
if -0.014999999999999999 < phi2 < 8.1999999999999996e-10Initial program 80.9%
Taylor expanded in phi2 around 0
lower-sin.f64N/A
lower--.f6480.9
Applied rewrites80.9%
Taylor expanded in phi2 around 0
lower--.f64N/A
lower-*.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
sub-negN/A
remove-double-negN/A
mul-1-negN/A
distribute-neg-inN/A
+-commutativeN/A
cos-negN/A
lower-cos.f64N/A
mul-1-negN/A
unsub-negN/A
lower--.f64N/A
lower-sin.f6480.9
Applied rewrites80.9%
Final simplification62.2%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi2) (sin (- lambda1 lambda2))))
(t_1 (atan2 t_0 (* (- (sin phi1)) (cos (- lambda2 lambda1))))))
(if (<= phi1 -4.2e-18)
t_1
(if (<= phi1 9e-32) (atan2 t_0 (sin phi2)) t_1))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi2) * sin((lambda1 - lambda2));
double t_1 = atan2(t_0, (-sin(phi1) * cos((lambda2 - lambda1))));
double tmp;
if (phi1 <= -4.2e-18) {
tmp = t_1;
} else if (phi1 <= 9e-32) {
tmp = atan2(t_0, sin(phi2));
} else {
tmp = t_1;
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: t_1
real(8) :: tmp
t_0 = cos(phi2) * sin((lambda1 - lambda2))
t_1 = atan2(t_0, (-sin(phi1) * cos((lambda2 - lambda1))))
if (phi1 <= (-4.2d-18)) then
tmp = t_1
else if (phi1 <= 9d-32) then
tmp = atan2(t_0, sin(phi2))
else
tmp = t_1
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos(phi2) * Math.sin((lambda1 - lambda2));
double t_1 = Math.atan2(t_0, (-Math.sin(phi1) * Math.cos((lambda2 - lambda1))));
double tmp;
if (phi1 <= -4.2e-18) {
tmp = t_1;
} else if (phi1 <= 9e-32) {
tmp = Math.atan2(t_0, Math.sin(phi2));
} else {
tmp = t_1;
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi2) * math.sin((lambda1 - lambda2)) t_1 = math.atan2(t_0, (-math.sin(phi1) * math.cos((lambda2 - lambda1)))) tmp = 0 if phi1 <= -4.2e-18: tmp = t_1 elif phi1 <= 9e-32: tmp = math.atan2(t_0, math.sin(phi2)) else: tmp = t_1 return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) t_1 = atan(t_0, Float64(Float64(-sin(phi1)) * cos(Float64(lambda2 - lambda1)))) tmp = 0.0 if (phi1 <= -4.2e-18) tmp = t_1; elseif (phi1 <= 9e-32) tmp = atan(t_0, sin(phi2)); else tmp = t_1; end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos(phi2) * sin((lambda1 - lambda2)); t_1 = atan2(t_0, (-sin(phi1) * cos((lambda2 - lambda1)))); tmp = 0.0; if (phi1 <= -4.2e-18) tmp = t_1; elseif (phi1 <= 9e-32) tmp = atan2(t_0, sin(phi2)); else tmp = t_1; end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[t$95$0 / N[((-N[Sin[phi1], $MachinePrecision]) * N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi1, -4.2e-18], t$95$1, If[LessEqual[phi1, 9e-32], N[ArcTan[t$95$0 / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], t$95$1]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
t_1 := \tan^{-1}_* \frac{t\_0}{\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_2 - \lambda_1\right)}\\
\mathbf{if}\;\phi_1 \leq -4.2 \cdot 10^{-18}:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;\phi_1 \leq 9 \cdot 10^{-32}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\sin \phi_2}\\
\mathbf{else}:\\
\;\;\;\;t\_1\\
\end{array}
\end{array}
if phi1 < -4.19999999999999999e-18 or 9.00000000000000009e-32 < phi1 Initial program 72.1%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites72.1%
Taylor expanded in phi2 around 0
mul-1-negN/A
distribute-rgt-neg-inN/A
sub-negN/A
remove-double-negN/A
distribute-neg-inN/A
+-commutativeN/A
neg-mul-1N/A
cos-negN/A
neg-mul-1N/A
sub-negN/A
mul-1-negN/A
lower-*.f64N/A
sub-negN/A
neg-mul-1N/A
lower-cos.f64N/A
neg-mul-1N/A
sub-negN/A
lower--.f64N/A
mul-1-negN/A
lower-neg.f64N/A
lower-sin.f6447.5
Applied rewrites47.5%
if -4.19999999999999999e-18 < phi1 < 9.00000000000000009e-32Initial program 83.2%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites83.2%
Taylor expanded in phi1 around 0
lower-sin.f6481.6
Applied rewrites81.6%
Final simplification61.9%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (sin (- lambda1 lambda2)))
(t_1 (atan2 (* (cos phi2) t_0) (sin phi2))))
(if (<= phi2 -5e-9)
t_1
(if (<= phi2 1.32e-14)
(atan2 t_0 (* (- (sin phi1)) (cos (- lambda2 lambda1))))
t_1))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = sin((lambda1 - lambda2));
double t_1 = atan2((cos(phi2) * t_0), sin(phi2));
double tmp;
if (phi2 <= -5e-9) {
tmp = t_1;
} else if (phi2 <= 1.32e-14) {
tmp = atan2(t_0, (-sin(phi1) * cos((lambda2 - lambda1))));
} else {
tmp = t_1;
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: t_1
real(8) :: tmp
t_0 = sin((lambda1 - lambda2))
t_1 = atan2((cos(phi2) * t_0), sin(phi2))
if (phi2 <= (-5d-9)) then
tmp = t_1
else if (phi2 <= 1.32d-14) then
tmp = atan2(t_0, (-sin(phi1) * cos((lambda2 - lambda1))))
else
tmp = t_1
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.sin((lambda1 - lambda2));
double t_1 = Math.atan2((Math.cos(phi2) * t_0), Math.sin(phi2));
double tmp;
if (phi2 <= -5e-9) {
tmp = t_1;
} else if (phi2 <= 1.32e-14) {
tmp = Math.atan2(t_0, (-Math.sin(phi1) * Math.cos((lambda2 - lambda1))));
} else {
tmp = t_1;
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.sin((lambda1 - lambda2)) t_1 = math.atan2((math.cos(phi2) * t_0), math.sin(phi2)) tmp = 0 if phi2 <= -5e-9: tmp = t_1 elif phi2 <= 1.32e-14: tmp = math.atan2(t_0, (-math.sin(phi1) * math.cos((lambda2 - lambda1)))) else: tmp = t_1 return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = sin(Float64(lambda1 - lambda2)) t_1 = atan(Float64(cos(phi2) * t_0), sin(phi2)) tmp = 0.0 if (phi2 <= -5e-9) tmp = t_1; elseif (phi2 <= 1.32e-14) tmp = atan(t_0, Float64(Float64(-sin(phi1)) * cos(Float64(lambda2 - lambda1)))); else tmp = t_1; end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = sin((lambda1 - lambda2)); t_1 = atan2((cos(phi2) * t_0), sin(phi2)); tmp = 0.0; if (phi2 <= -5e-9) tmp = t_1; elseif (phi2 <= 1.32e-14) tmp = atan2(t_0, (-sin(phi1) * cos((lambda2 - lambda1)))); else tmp = t_1; end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * t$95$0), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi2, -5e-9], t$95$1, If[LessEqual[phi2, 1.32e-14], N[ArcTan[t$95$0 / N[((-N[Sin[phi1], $MachinePrecision]) * N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$1]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \sin \left(\lambda_1 - \lambda_2\right)\\
t_1 := \tan^{-1}_* \frac{\cos \phi_2 \cdot t\_0}{\sin \phi_2}\\
\mathbf{if}\;\phi_2 \leq -5 \cdot 10^{-9}:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;\phi_2 \leq 1.32 \cdot 10^{-14}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\left(-\sin \phi_1\right) \cdot \cos \left(\lambda_2 - \lambda_1\right)}\\
\mathbf{else}:\\
\;\;\;\;t\_1\\
\end{array}
\end{array}
if phi2 < -5.0000000000000001e-9 or 1.32e-14 < phi2 Initial program 72.3%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites72.4%
Taylor expanded in phi1 around 0
lower-sin.f6441.9
Applied rewrites41.9%
if -5.0000000000000001e-9 < phi2 < 1.32e-14Initial program 80.9%
Taylor expanded in phi2 around 0
lower-sin.f64N/A
lower--.f6480.9
Applied rewrites80.9%
Taylor expanded in phi2 around 0
mul-1-negN/A
lower-neg.f64N/A
lower-*.f64N/A
sub-negN/A
remove-double-negN/A
mul-1-negN/A
distribute-neg-inN/A
+-commutativeN/A
cos-negN/A
lower-cos.f64N/A
mul-1-negN/A
unsub-negN/A
lower--.f64N/A
lower-sin.f6479.3
Applied rewrites79.3%
Final simplification61.3%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (atan2 (* (cos phi2) (sin (- lambda2))) (sin phi2))))
(if (<= lambda2 -3.5e-117)
t_0
(if (<= lambda2 2.8e-35)
(atan2 (sin (- lambda1 lambda2)) (sin phi2))
t_0))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = atan2((cos(phi2) * sin(-lambda2)), sin(phi2));
double tmp;
if (lambda2 <= -3.5e-117) {
tmp = t_0;
} else if (lambda2 <= 2.8e-35) {
tmp = atan2(sin((lambda1 - lambda2)), sin(phi2));
} else {
tmp = t_0;
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: tmp
t_0 = atan2((cos(phi2) * sin(-lambda2)), sin(phi2))
if (lambda2 <= (-3.5d-117)) then
tmp = t_0
else if (lambda2 <= 2.8d-35) then
tmp = atan2(sin((lambda1 - lambda2)), sin(phi2))
else
tmp = t_0
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.atan2((Math.cos(phi2) * Math.sin(-lambda2)), Math.sin(phi2));
double tmp;
if (lambda2 <= -3.5e-117) {
tmp = t_0;
} else if (lambda2 <= 2.8e-35) {
tmp = Math.atan2(Math.sin((lambda1 - lambda2)), Math.sin(phi2));
} else {
tmp = t_0;
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.atan2((math.cos(phi2) * math.sin(-lambda2)), math.sin(phi2)) tmp = 0 if lambda2 <= -3.5e-117: tmp = t_0 elif lambda2 <= 2.8e-35: tmp = math.atan2(math.sin((lambda1 - lambda2)), math.sin(phi2)) else: tmp = t_0 return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = atan(Float64(cos(phi2) * sin(Float64(-lambda2))), sin(phi2)) tmp = 0.0 if (lambda2 <= -3.5e-117) tmp = t_0; elseif (lambda2 <= 2.8e-35) tmp = atan(sin(Float64(lambda1 - lambda2)), sin(phi2)); else tmp = t_0; end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = atan2((cos(phi2) * sin(-lambda2)), sin(phi2)); tmp = 0.0; if (lambda2 <= -3.5e-117) tmp = t_0; elseif (lambda2 <= 2.8e-35) tmp = atan2(sin((lambda1 - lambda2)), sin(phi2)); else tmp = t_0; end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[(-lambda2)], $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision]}, If[LessEqual[lambda2, -3.5e-117], t$95$0, If[LessEqual[lambda2, 2.8e-35], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], t$95$0]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(-\lambda_2\right)}{\sin \phi_2}\\
\mathbf{if}\;\lambda_2 \leq -3.5 \cdot 10^{-117}:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;\lambda_2 \leq 2.8 \cdot 10^{-35}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2}\\
\mathbf{else}:\\
\;\;\;\;t\_0\\
\end{array}
\end{array}
if lambda2 < -3.4999999999999998e-117 or 2.8e-35 < lambda2 Initial program 64.1%
Taylor expanded in lambda1 around 0
lower-sin.f64N/A
lower-neg.f6459.5
Applied rewrites59.5%
Taylor expanded in phi1 around 0
lower-sin.f6442.6
Applied rewrites42.6%
if -3.4999999999999998e-117 < lambda2 < 2.8e-35Initial program 99.7%
Taylor expanded in phi2 around 0
lower-sin.f64N/A
lower--.f6462.7
Applied rewrites62.7%
Taylor expanded in phi1 around 0
lower-sin.f6433.4
Applied rewrites33.4%
Final simplification39.4%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (cos phi2) (sin (- lambda1 lambda2))) (sin phi2)))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((cos(phi2) * sin((lambda1 - lambda2))), sin(phi2));
}
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((cos(phi2) * sin((lambda1 - lambda2))), sin(phi2))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
return Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), Math.sin(phi2));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), math.sin(phi2))
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), sin(phi2)) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), sin(phi2)); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2}
\end{array}
Initial program 76.8%
lift--.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-cos.f64N/A
lift-sin.f64N/A
lift-*.f64N/A
lift-sin.f64N/A
lift-cos.f64N/A
lift--.f64N/A
lift-cos.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lift--.f64N/A
Applied rewrites76.8%
Taylor expanded in phi1 around 0
lower-sin.f6445.3
Applied rewrites45.3%
Final simplification45.3%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (sin (- lambda1 lambda2)) (sin phi2)))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2(sin((lambda1 - lambda2)), sin(phi2));
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
code = atan2(sin((lambda1 - lambda2)), sin(phi2))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
return Math.atan2(Math.sin((lambda1 - lambda2)), Math.sin(phi2));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2(math.sin((lambda1 - lambda2)), math.sin(phi2))
function code(lambda1, lambda2, phi1, phi2) return atan(sin(Float64(lambda1 - lambda2)), sin(phi2)) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2(sin((lambda1 - lambda2)), sin(phi2)); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2}
\end{array}
Initial program 76.8%
Taylor expanded in phi2 around 0
lower-sin.f64N/A
lower--.f6448.5
Applied rewrites48.5%
Taylor expanded in phi1 around 0
lower-sin.f6430.5
Applied rewrites30.5%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(if (<= phi2 1.32e+26)
(atan2
(sin (- lambda1 lambda2))
(*
phi2
(fma
(* phi2 phi2)
(fma (* phi2 phi2) 0.008333333333333333 -0.16666666666666666)
1.0)))
(atan2
(sin lambda1)
(fma phi2 (* (* phi2 phi2) -0.16666666666666666) phi2))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi2 <= 1.32e+26) {
tmp = atan2(sin((lambda1 - lambda2)), (phi2 * fma((phi2 * phi2), fma((phi2 * phi2), 0.008333333333333333, -0.16666666666666666), 1.0)));
} else {
tmp = atan2(sin(lambda1), fma(phi2, ((phi2 * phi2) * -0.16666666666666666), phi2));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi2 <= 1.32e+26) tmp = atan(sin(Float64(lambda1 - lambda2)), Float64(phi2 * fma(Float64(phi2 * phi2), fma(Float64(phi2 * phi2), 0.008333333333333333, -0.16666666666666666), 1.0))); else tmp = atan(sin(lambda1), fma(phi2, Float64(Float64(phi2 * phi2) * -0.16666666666666666), phi2)); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[phi2, 1.32e+26], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(phi2 * N[(N[(phi2 * phi2), $MachinePrecision] * N[(N[(phi2 * phi2), $MachinePrecision] * 0.008333333333333333 + -0.16666666666666666), $MachinePrecision] + 1.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[Sin[lambda1], $MachinePrecision] / N[(phi2 * N[(N[(phi2 * phi2), $MachinePrecision] * -0.16666666666666666), $MachinePrecision] + phi2), $MachinePrecision]], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\phi_2 \leq 1.32 \cdot 10^{+26}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\phi_2 \cdot \mathsf{fma}\left(\phi_2 \cdot \phi_2, \mathsf{fma}\left(\phi_2 \cdot \phi_2, 0.008333333333333333, -0.16666666666666666\right), 1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1}{\mathsf{fma}\left(\phi_2, \left(\phi_2 \cdot \phi_2\right) \cdot -0.16666666666666666, \phi_2\right)}\\
\end{array}
\end{array}
if phi2 < 1.32e26Initial program 78.7%
Taylor expanded in phi2 around 0
lower-sin.f64N/A
lower--.f6456.8
Applied rewrites56.8%
Taylor expanded in phi1 around 0
lower-sin.f6434.9
Applied rewrites34.9%
Taylor expanded in phi2 around 0
lower-*.f64N/A
+-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
sub-negN/A
*-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6435.6
Applied rewrites35.6%
if 1.32e26 < phi2 Initial program 68.2%
Taylor expanded in phi2 around 0
lower-sin.f64N/A
lower--.f6412.2
Applied rewrites12.2%
Taylor expanded in phi1 around 0
lower-sin.f6411.4
Applied rewrites11.4%
Taylor expanded in phi2 around 0
+-commutativeN/A
distribute-lft-inN/A
*-rgt-identityN/A
lower-fma.f64N/A
*-commutativeN/A
lower-*.f64N/A
unpow2N/A
lower-*.f6410.0
Applied rewrites10.0%
Taylor expanded in lambda2 around 0
lower-sin.f6414.3
Applied rewrites14.3%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (fma phi2 (* (* phi2 phi2) -0.16666666666666666) phi2))
(t_1 (atan2 (sin (- lambda2)) t_0)))
(if (<= lambda2 -8.5e-10)
t_1
(if (<= lambda2 5.2e+46) (atan2 (sin lambda1) t_0) t_1))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = fma(phi2, ((phi2 * phi2) * -0.16666666666666666), phi2);
double t_1 = atan2(sin(-lambda2), t_0);
double tmp;
if (lambda2 <= -8.5e-10) {
tmp = t_1;
} else if (lambda2 <= 5.2e+46) {
tmp = atan2(sin(lambda1), t_0);
} else {
tmp = t_1;
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = fma(phi2, Float64(Float64(phi2 * phi2) * -0.16666666666666666), phi2) t_1 = atan(sin(Float64(-lambda2)), t_0) tmp = 0.0 if (lambda2 <= -8.5e-10) tmp = t_1; elseif (lambda2 <= 5.2e+46) tmp = atan(sin(lambda1), t_0); else tmp = t_1; end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(phi2 * N[(N[(phi2 * phi2), $MachinePrecision] * -0.16666666666666666), $MachinePrecision] + phi2), $MachinePrecision]}, Block[{t$95$1 = N[ArcTan[N[Sin[(-lambda2)], $MachinePrecision] / t$95$0], $MachinePrecision]}, If[LessEqual[lambda2, -8.5e-10], t$95$1, If[LessEqual[lambda2, 5.2e+46], N[ArcTan[N[Sin[lambda1], $MachinePrecision] / t$95$0], $MachinePrecision], t$95$1]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \mathsf{fma}\left(\phi_2, \left(\phi_2 \cdot \phi_2\right) \cdot -0.16666666666666666, \phi_2\right)\\
t_1 := \tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{t\_0}\\
\mathbf{if}\;\lambda_2 \leq -8.5 \cdot 10^{-10}:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;\lambda_2 \leq 5.2 \cdot 10^{+46}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1}{t\_0}\\
\mathbf{else}:\\
\;\;\;\;t\_1\\
\end{array}
\end{array}
if lambda2 < -8.4999999999999996e-10 or 5.20000000000000027e46 < lambda2 Initial program 55.1%
Taylor expanded in phi2 around 0
lower-sin.f64N/A
lower--.f6438.4
Applied rewrites38.4%
Taylor expanded in phi1 around 0
lower-sin.f6428.4
Applied rewrites28.4%
Taylor expanded in phi2 around 0
+-commutativeN/A
distribute-lft-inN/A
*-rgt-identityN/A
lower-fma.f64N/A
*-commutativeN/A
lower-*.f64N/A
unpow2N/A
lower-*.f6426.3
Applied rewrites26.3%
Taylor expanded in lambda1 around 0
neg-mul-1N/A
lower-sin.f64N/A
neg-mul-1N/A
lower-neg.f6430.0
Applied rewrites30.0%
if -8.4999999999999996e-10 < lambda2 < 5.20000000000000027e46Initial program 96.8%
Taylor expanded in phi2 around 0
lower-sin.f64N/A
lower--.f6457.8
Applied rewrites57.8%
Taylor expanded in phi1 around 0
lower-sin.f6432.4
Applied rewrites32.4%
Taylor expanded in phi2 around 0
+-commutativeN/A
distribute-lft-inN/A
*-rgt-identityN/A
lower-fma.f64N/A
*-commutativeN/A
lower-*.f64N/A
unpow2N/A
lower-*.f6430.4
Applied rewrites30.4%
Taylor expanded in lambda2 around 0
lower-sin.f6430.1
Applied rewrites30.1%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (sin (- lambda1 lambda2)) (fma phi2 (* (* phi2 phi2) -0.16666666666666666) phi2)))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2(sin((lambda1 - lambda2)), fma(phi2, ((phi2 * phi2) * -0.16666666666666666), phi2));
}
function code(lambda1, lambda2, phi1, phi2) return atan(sin(Float64(lambda1 - lambda2)), fma(phi2, Float64(Float64(phi2 * phi2) * -0.16666666666666666), phi2)) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(phi2 * N[(N[(phi2 * phi2), $MachinePrecision] * -0.16666666666666666), $MachinePrecision] + phi2), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\mathsf{fma}\left(\phi_2, \left(\phi_2 \cdot \phi_2\right) \cdot -0.16666666666666666, \phi_2\right)}
\end{array}
Initial program 76.8%
Taylor expanded in phi2 around 0
lower-sin.f64N/A
lower--.f6448.5
Applied rewrites48.5%
Taylor expanded in phi1 around 0
lower-sin.f6430.5
Applied rewrites30.5%
Taylor expanded in phi2 around 0
+-commutativeN/A
distribute-lft-inN/A
*-rgt-identityN/A
lower-fma.f64N/A
*-commutativeN/A
lower-*.f64N/A
unpow2N/A
lower-*.f6428.4
Applied rewrites28.4%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (sin (- lambda1 lambda2)) (* -0.16666666666666666 (* phi2 (* phi2 phi2)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2(sin((lambda1 - lambda2)), (-0.16666666666666666 * (phi2 * (phi2 * phi2))));
}
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)), ((-0.16666666666666666d0) * (phi2 * (phi2 * phi2))))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
return Math.atan2(Math.sin((lambda1 - lambda2)), (-0.16666666666666666 * (phi2 * (phi2 * phi2))));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2(math.sin((lambda1 - lambda2)), (-0.16666666666666666 * (phi2 * (phi2 * phi2))))
function code(lambda1, lambda2, phi1, phi2) return atan(sin(Float64(lambda1 - lambda2)), Float64(-0.16666666666666666 * Float64(phi2 * Float64(phi2 * phi2)))) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2(sin((lambda1 - lambda2)), (-0.16666666666666666 * (phi2 * (phi2 * phi2)))); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(-0.16666666666666666 * N[(phi2 * N[(phi2 * phi2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{-0.16666666666666666 \cdot \left(\phi_2 \cdot \left(\phi_2 \cdot \phi_2\right)\right)}
\end{array}
Initial program 76.8%
Taylor expanded in phi2 around 0
lower-sin.f64N/A
lower--.f6448.5
Applied rewrites48.5%
Taylor expanded in phi1 around 0
lower-sin.f6430.5
Applied rewrites30.5%
Taylor expanded in phi2 around 0
+-commutativeN/A
distribute-lft-inN/A
*-rgt-identityN/A
lower-fma.f64N/A
*-commutativeN/A
lower-*.f64N/A
unpow2N/A
lower-*.f6428.4
Applied rewrites28.4%
Taylor expanded in phi2 around inf
lower-*.f64N/A
cube-multN/A
unpow2N/A
lower-*.f64N/A
unpow2N/A
lower-*.f6427.2
Applied rewrites27.2%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (sin lambda1) (fma phi2 (* (* phi2 phi2) -0.16666666666666666) phi2)))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2(sin(lambda1), fma(phi2, ((phi2 * phi2) * -0.16666666666666666), phi2));
}
function code(lambda1, lambda2, phi1, phi2) return atan(sin(lambda1), fma(phi2, Float64(Float64(phi2 * phi2) * -0.16666666666666666), phi2)) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[Sin[lambda1], $MachinePrecision] / N[(phi2 * N[(N[(phi2 * phi2), $MachinePrecision] * -0.16666666666666666), $MachinePrecision] + phi2), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\sin \lambda_1}{\mathsf{fma}\left(\phi_2, \left(\phi_2 \cdot \phi_2\right) \cdot -0.16666666666666666, \phi_2\right)}
\end{array}
Initial program 76.8%
Taylor expanded in phi2 around 0
lower-sin.f64N/A
lower--.f6448.5
Applied rewrites48.5%
Taylor expanded in phi1 around 0
lower-sin.f6430.5
Applied rewrites30.5%
Taylor expanded in phi2 around 0
+-commutativeN/A
distribute-lft-inN/A
*-rgt-identityN/A
lower-fma.f64N/A
*-commutativeN/A
lower-*.f64N/A
unpow2N/A
lower-*.f6428.4
Applied rewrites28.4%
Taylor expanded in lambda2 around 0
lower-sin.f6423.8
Applied rewrites23.8%
herbie shell --seed 2024225
(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))))))