
(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 37 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (sin (- lambda1 lambda2)) (cos phi2)) (- (* (cos phi1) (sin phi2)) (* (* (sin phi1) (cos phi2)) (cos (- lambda1 lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((sin((lambda1 - lambda2)) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2)))));
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
code = atan2((sin((lambda1 - lambda2)) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2)))))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
return Math.atan2((Math.sin((lambda1 - lambda2)) * Math.cos(phi2)), ((Math.cos(phi1) * Math.sin(phi2)) - ((Math.sin(phi1) * Math.cos(phi2)) * Math.cos((lambda1 - lambda2)))));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2((math.sin((lambda1 - lambda2)) * math.cos(phi2)), ((math.cos(phi1) * math.sin(phi2)) - ((math.sin(phi1) * math.cos(phi2)) * math.cos((lambda1 - lambda2)))))
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(sin(Float64(lambda1 - lambda2)) * cos(phi2)), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(sin(phi1) * cos(phi2)) * cos(Float64(lambda1 - lambda2))))) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2((sin((lambda1 - lambda2)) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((sin(phi1) * cos(phi2)) * cos((lambda1 - lambda2))))); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Sin[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\sin \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(atan2
(*
(fma (sin lambda1) (cos lambda2) (* (sin (- lambda2)) (cos lambda1)))
(cos phi2))
(-
(* (cos phi1) (sin phi2))
(*
(* (cos phi2) (sin phi1))
(+ (* (sin lambda1) (sin lambda2)) (* (cos lambda2) (cos lambda1)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((fma(sin(lambda1), cos(lambda2), (sin(-lambda2) * cos(lambda1))) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * ((sin(lambda1) * sin(lambda2)) + (cos(lambda2) * cos(lambda1))))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(fma(sin(lambda1), cos(lambda2), Float64(sin(Float64(-lambda2)) * cos(lambda1))) * cos(phi2)), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * Float64(Float64(sin(lambda1) * sin(lambda2)) + Float64(cos(lambda2) * cos(lambda1)))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision] + N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \left(-\lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_2 \cdot \cos \lambda_1\right)}
\end{array}
Initial program 77.2%
sin-diff90.1%
sub-neg90.1%
Applied egg-rr90.1%
fma-define90.1%
distribute-rgt-neg-in90.1%
sin-neg90.1%
*-commutative90.1%
Simplified90.1%
cos-diff99.8%
+-commutative99.8%
*-commutative99.8%
Applied egg-rr99.8%
Final simplification99.8%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2)))
(t_1 (- t_0 (* (* (cos phi2) (sin phi1)) (cos (- lambda1 lambda2)))))
(t_2
(*
(fma (sin lambda1) (cos lambda2) (* (sin (- lambda2)) (cos lambda1)))
(cos phi2))))
(if (<= phi2 -11.5)
(atan2 t_2 t_1)
(if (<= phi2 1.9e-25)
(atan2
t_2
(-
t_0
(*
(sin phi1)
(+
(* (sin lambda1) (sin lambda2))
(* (cos lambda2) (cos lambda1))))))
(atan2
(*
(cos phi2)
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2))))
t_1)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double t_1 = t_0 - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2)));
double t_2 = fma(sin(lambda1), cos(lambda2), (sin(-lambda2) * cos(lambda1))) * cos(phi2);
double tmp;
if (phi2 <= -11.5) {
tmp = atan2(t_2, t_1);
} else if (phi2 <= 1.9e-25) {
tmp = atan2(t_2, (t_0 - (sin(phi1) * ((sin(lambda1) * sin(lambda2)) + (cos(lambda2) * cos(lambda1))))));
} else {
tmp = atan2((cos(phi2) * ((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2)))), t_1);
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = Float64(t_0 - Float64(Float64(cos(phi2) * sin(phi1)) * cos(Float64(lambda1 - lambda2)))) t_2 = Float64(fma(sin(lambda1), cos(lambda2), Float64(sin(Float64(-lambda2)) * cos(lambda1))) * cos(phi2)) tmp = 0.0 if (phi2 <= -11.5) tmp = atan(t_2, t_1); elseif (phi2 <= 1.9e-25) tmp = atan(t_2, Float64(t_0 - Float64(sin(phi1) * Float64(Float64(sin(lambda1) * sin(lambda2)) + Float64(cos(lambda2) * cos(lambda1)))))); else tmp = atan(Float64(cos(phi2) * Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2)))), t_1); 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[(t$95$0 - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[phi2, -11.5], N[ArcTan[t$95$2 / t$95$1], $MachinePrecision], If[LessEqual[phi2, 1.9e-25], N[ArcTan[t$95$2 / N[(t$95$0 - N[(N[Sin[phi1], $MachinePrecision] * N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision] + N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / t$95$1], $MachinePrecision]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
t_1 := t\_0 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
t_2 := \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \left(-\lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2\\
\mathbf{if}\;\phi_2 \leq -11.5:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_1}\\
\mathbf{elif}\;\phi_2 \leq 1.9 \cdot 10^{-25}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - \sin \phi_1 \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_2 \cdot \cos \lambda_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}{t\_1}\\
\end{array}
\end{array}
if phi2 < -11.5Initial program 78.1%
sin-diff91.0%
sub-neg91.0%
Applied egg-rr91.0%
fma-define91.1%
distribute-rgt-neg-in91.1%
sin-neg91.1%
*-commutative91.1%
Simplified91.1%
if -11.5 < phi2 < 1.8999999999999999e-25Initial program 74.0%
sin-diff87.3%
sub-neg87.3%
Applied egg-rr87.3%
fma-define87.3%
distribute-rgt-neg-in87.3%
sin-neg87.3%
*-commutative87.3%
Simplified87.3%
cos-diff99.9%
+-commutative99.9%
*-commutative99.9%
Applied egg-rr99.9%
Taylor expanded in phi2 around 0 99.5%
if 1.8999999999999999e-25 < phi2 Initial program 82.6%
sin-diff94.4%
Applied egg-rr94.4%
Final simplification96.1%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(atan2
(*
(cos phi2)
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2))))
(-
(* (cos phi1) (sin phi2))
(*
(* (cos phi2) (sin phi1))
(+ (* (sin lambda1) (sin lambda2)) (* (cos lambda2) (cos lambda1)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((cos(phi2) * ((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2)))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * ((sin(lambda1) * sin(lambda2)) + (cos(lambda2) * cos(lambda1))))));
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
code = atan2((cos(phi2) * ((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2)))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * ((sin(lambda1) * sin(lambda2)) + (cos(lambda2) * cos(lambda1))))))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
return Math.atan2((Math.cos(phi2) * ((Math.sin(lambda1) * Math.cos(lambda2)) - (Math.cos(lambda1) * Math.sin(lambda2)))), ((Math.cos(phi1) * Math.sin(phi2)) - ((Math.cos(phi2) * Math.sin(phi1)) * ((Math.sin(lambda1) * Math.sin(lambda2)) + (Math.cos(lambda2) * Math.cos(lambda1))))));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2((math.cos(phi2) * ((math.sin(lambda1) * math.cos(lambda2)) - (math.cos(lambda1) * math.sin(lambda2)))), ((math.cos(phi1) * math.sin(phi2)) - ((math.cos(phi2) * math.sin(phi1)) * ((math.sin(lambda1) * math.sin(lambda2)) + (math.cos(lambda2) * math.cos(lambda1))))))
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2)))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * Float64(Float64(sin(lambda1) * sin(lambda2)) + Float64(cos(lambda2) * cos(lambda1)))))) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2((cos(phi2) * ((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2)))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * ((sin(lambda1) * sin(lambda2)) + (cos(lambda2) * cos(lambda1)))))); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $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[(N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $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 \left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_2 \cdot \cos \lambda_1\right)}
\end{array}
Initial program 77.2%
sin-diff90.1%
sub-neg90.1%
Applied egg-rr90.1%
fma-define90.1%
distribute-rgt-neg-in90.1%
sin-neg90.1%
*-commutative90.1%
Simplified90.1%
cos-diff99.8%
+-commutative99.8%
*-commutative99.8%
Applied egg-rr99.8%
Taylor expanded in lambda1 around inf 99.8%
sin-neg99.8%
distribute-rgt-neg-in99.8%
+-commutative99.8%
cos-neg99.8%
*-commutative99.8%
cos-neg99.8%
sub-neg99.8%
Simplified99.8%
Final simplification99.8%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2))))
(t_1 (* (cos phi1) (sin phi2)))
(t_2 (* (cos phi2) (sin phi1)))
(t_3 (- t_1 (* t_2 (cos (- lambda1 lambda2))))))
(if (<= phi2 -0.00038)
(atan2
(*
(fma (sin lambda1) (cos lambda2) (* (sin (- lambda2)) (cos lambda1)))
(cos phi2))
t_3)
(if (<= phi2 1.9e-25)
(atan2
t_0
(-
t_1
(*
t_2
(+
(* (sin lambda1) (sin lambda2))
(* (cos lambda2) (cos lambda1))))))
(atan2 (* (cos phi2) t_0) t_3)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = (sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2));
double t_1 = cos(phi1) * sin(phi2);
double t_2 = cos(phi2) * sin(phi1);
double t_3 = t_1 - (t_2 * cos((lambda1 - lambda2)));
double tmp;
if (phi2 <= -0.00038) {
tmp = atan2((fma(sin(lambda1), cos(lambda2), (sin(-lambda2) * cos(lambda1))) * cos(phi2)), t_3);
} else if (phi2 <= 1.9e-25) {
tmp = atan2(t_0, (t_1 - (t_2 * ((sin(lambda1) * sin(lambda2)) + (cos(lambda2) * cos(lambda1))))));
} else {
tmp = atan2((cos(phi2) * t_0), t_3);
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2))) t_1 = Float64(cos(phi1) * sin(phi2)) t_2 = Float64(cos(phi2) * sin(phi1)) t_3 = Float64(t_1 - Float64(t_2 * cos(Float64(lambda1 - lambda2)))) tmp = 0.0 if (phi2 <= -0.00038) tmp = atan(Float64(fma(sin(lambda1), cos(lambda2), Float64(sin(Float64(-lambda2)) * cos(lambda1))) * cos(phi2)), t_3); elseif (phi2 <= 1.9e-25) tmp = atan(t_0, Float64(t_1 - Float64(t_2 * Float64(Float64(sin(lambda1) * sin(lambda2)) + Float64(cos(lambda2) * cos(lambda1)))))); else tmp = atan(Float64(cos(phi2) * t_0), t_3); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[(t$95$1 - N[(t$95$2 * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[phi2, -0.00038], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / t$95$3], $MachinePrecision], If[LessEqual[phi2, 1.9e-25], N[ArcTan[t$95$0 / N[(t$95$1 - N[(t$95$2 * N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision] + N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * t$95$0), $MachinePrecision] / t$95$3], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\\
t_1 := \cos \phi_1 \cdot \sin \phi_2\\
t_2 := \cos \phi_2 \cdot \sin \phi_1\\
t_3 := t\_1 - t\_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq -0.00038:\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \left(-\lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{t\_3}\\
\mathbf{elif}\;\phi_2 \leq 1.9 \cdot 10^{-25}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{t\_1 - t\_2 \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_2 \cdot \cos \lambda_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot t\_0}{t\_3}\\
\end{array}
\end{array}
if phi2 < -3.8000000000000002e-4Initial program 78.8%
sin-diff91.3%
sub-neg91.3%
Applied egg-rr91.3%
fma-define91.4%
distribute-rgt-neg-in91.4%
sin-neg91.4%
*-commutative91.4%
Simplified91.4%
if -3.8000000000000002e-4 < phi2 < 1.8999999999999999e-25Initial program 73.5%
sin-diff87.1%
sub-neg87.1%
Applied egg-rr87.1%
fma-define87.1%
distribute-rgt-neg-in87.1%
sin-neg87.1%
*-commutative87.1%
Simplified87.1%
cos-diff99.9%
+-commutative99.9%
*-commutative99.9%
Applied egg-rr99.9%
Taylor expanded in phi2 around 0 99.4%
sin-neg99.4%
distribute-rgt-neg-in99.4%
+-commutative99.4%
cos-neg99.4%
*-commutative99.4%
cos-neg99.4%
sub-neg99.4%
Simplified99.4%
if 1.8999999999999999e-25 < phi2 Initial program 82.6%
sin-diff94.4%
Applied egg-rr94.4%
Final simplification96.1%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (fma (sin lambda1) (cos lambda2) (* (sin (- lambda2)) (cos lambda1))) (cos phi2)) (- (* (cos phi1) (sin phi2)) (* (* (cos phi2) (sin phi1)) (cos (- lambda1 lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((fma(sin(lambda1), cos(lambda2), (sin(-lambda2) * cos(lambda1))) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2)))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(fma(sin(lambda1), cos(lambda2), Float64(sin(Float64(-lambda2)) * cos(lambda1))) * cos(phi2)), 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[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \left(-\lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
Initial program 77.2%
sin-diff90.1%
sub-neg90.1%
Applied egg-rr90.1%
fma-define90.1%
distribute-rgt-neg-in90.1%
sin-neg90.1%
*-commutative90.1%
Simplified90.1%
Final simplification90.1%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi2) (sin phi1))))
(if (or (<= phi1 -0.01) (not (<= phi1 1.95e-13)))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(-
(* (cos phi1) (sin phi2))
(*
t_0
(+ (* (sin lambda1) (sin lambda2)) (* (cos lambda2) (cos lambda1))))))
(atan2
(*
(fma (sin lambda1) (cos lambda2) (* (sin (- lambda2)) (cos lambda1)))
(cos phi2))
(- (sin phi2) (* t_0 (cos (- lambda1 lambda2))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi2) * sin(phi1);
double tmp;
if ((phi1 <= -0.01) || !(phi1 <= 1.95e-13)) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - (t_0 * ((sin(lambda1) * sin(lambda2)) + (cos(lambda2) * cos(lambda1))))));
} else {
tmp = atan2((fma(sin(lambda1), cos(lambda2), (sin(-lambda2) * cos(lambda1))) * cos(phi2)), (sin(phi2) - (t_0 * cos((lambda1 - lambda2)))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi2) * sin(phi1)) tmp = 0.0 if ((phi1 <= -0.01) || !(phi1 <= 1.95e-13)) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(t_0 * Float64(Float64(sin(lambda1) * sin(lambda2)) + Float64(cos(lambda2) * cos(lambda1)))))); else tmp = atan(Float64(fma(sin(lambda1), cos(lambda2), Float64(sin(Float64(-lambda2)) * cos(lambda1))) * cos(phi2)), Float64(sin(phi2) - Float64(t_0 * cos(Float64(lambda1 - lambda2))))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]}, If[Or[LessEqual[phi1, -0.01], N[Not[LessEqual[phi1, 1.95e-13]], $MachinePrecision]], 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[(t$95$0 * N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision] + N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(t$95$0 * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_2 \cdot \sin \phi_1\\
\mathbf{if}\;\phi_1 \leq -0.01 \lor \neg \left(\phi_1 \leq 1.95 \cdot 10^{-13}\right):\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - t\_0 \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_2 \cdot \cos \lambda_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \left(-\lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\sin \phi_2 - t\_0 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\end{array}
\end{array}
if phi1 < -0.0100000000000000002 or 1.95000000000000002e-13 < phi1 Initial program 77.1%
cos-diff99.7%
+-commutative99.7%
*-commutative99.7%
Applied egg-rr77.5%
if -0.0100000000000000002 < phi1 < 1.95000000000000002e-13Initial program 77.4%
sin-diff99.8%
sub-neg99.8%
Applied egg-rr99.8%
fma-define99.9%
distribute-rgt-neg-in99.9%
sin-neg99.9%
*-commutative99.9%
Simplified99.9%
Taylor expanded in phi1 around 0 99.9%
Final simplification88.9%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2)))
(t_1 (* (cos phi2) (sin (- lambda1 lambda2))))
(t_2 (cos (- lambda1 lambda2)))
(t_3 (* (* (cos phi2) (sin phi1)) t_2)))
(if (<= phi1 -0.01)
(atan2 t_1 (- t_0 (expm1 (log1p t_3))))
(if (<= phi1 1.95e-13)
(atan2
(*
(fma (sin lambda1) (cos lambda2) (* (sin (- lambda2)) (cos lambda1)))
(cos phi2))
(- (sin phi2) t_3))
(atan2
t_1
(- t_0 (expm1 (log1p (* (sin phi1) (* (cos phi2) t_2))))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double t_1 = cos(phi2) * sin((lambda1 - lambda2));
double t_2 = cos((lambda1 - lambda2));
double t_3 = (cos(phi2) * sin(phi1)) * t_2;
double tmp;
if (phi1 <= -0.01) {
tmp = atan2(t_1, (t_0 - expm1(log1p(t_3))));
} else if (phi1 <= 1.95e-13) {
tmp = atan2((fma(sin(lambda1), cos(lambda2), (sin(-lambda2) * cos(lambda1))) * cos(phi2)), (sin(phi2) - t_3));
} else {
tmp = atan2(t_1, (t_0 - expm1(log1p((sin(phi1) * (cos(phi2) * t_2))))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) t_2 = cos(Float64(lambda1 - lambda2)) t_3 = Float64(Float64(cos(phi2) * sin(phi1)) * t_2) tmp = 0.0 if (phi1 <= -0.01) tmp = atan(t_1, Float64(t_0 - expm1(log1p(t_3)))); elseif (phi1 <= 1.95e-13) tmp = atan(Float64(fma(sin(lambda1), cos(lambda2), Float64(sin(Float64(-lambda2)) * cos(lambda1))) * cos(phi2)), Float64(sin(phi2) - t_3)); else tmp = atan(t_1, Float64(t_0 - expm1(log1p(Float64(sin(phi1) * Float64(cos(phi2) * t_2)))))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$3 = N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * t$95$2), $MachinePrecision]}, If[LessEqual[phi1, -0.01], N[ArcTan[t$95$1 / N[(t$95$0 - N[(Exp[N[Log[1 + t$95$3], $MachinePrecision]] - 1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi1, 1.95e-13], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - t$95$3), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / N[(t$95$0 - N[(Exp[N[Log[1 + N[(N[Sin[phi1], $MachinePrecision] * N[(N[Cos[phi2], $MachinePrecision] * t$95$2), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]] - 1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
t_1 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
t_2 := \cos \left(\lambda_1 - \lambda_2\right)\\
t_3 := \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t\_2\\
\mathbf{if}\;\phi_1 \leq -0.01:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \mathsf{expm1}\left(\mathsf{log1p}\left(t\_3\right)\right)}\\
\mathbf{elif}\;\phi_1 \leq 1.95 \cdot 10^{-13}:\\
\;\;\;\;\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \sin \left(-\lambda_2\right) \cdot \cos \lambda_1\right) \cdot \cos \phi_2}{\sin \phi_2 - t\_3}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \mathsf{expm1}\left(\mathsf{log1p}\left(\sin \phi_1 \cdot \left(\cos \phi_2 \cdot t\_2\right)\right)\right)}\\
\end{array}
\end{array}
if phi1 < -0.0100000000000000002Initial program 80.4%
*-commutative80.4%
associate-*l*80.4%
Simplified80.4%
associate-*r*80.4%
*-commutative80.4%
expm1-log1p-u80.5%
*-commutative80.5%
*-commutative80.5%
Applied egg-rr80.5%
if -0.0100000000000000002 < phi1 < 1.95000000000000002e-13Initial program 77.4%
sin-diff99.8%
sub-neg99.8%
Applied egg-rr99.8%
fma-define99.9%
distribute-rgt-neg-in99.9%
sin-neg99.9%
*-commutative99.9%
Simplified99.9%
Taylor expanded in phi1 around 0 99.9%
if 1.95000000000000002e-13 < phi1 Initial program 74.2%
*-commutative74.2%
associate-*l*74.2%
Simplified74.2%
associate-*r*74.2%
*-commutative74.2%
add-exp-log35.6%
*-commutative35.6%
*-commutative35.6%
Applied egg-rr35.6%
expm1-log1p-u35.7%
expm1-undefine35.6%
rem-exp-log74.1%
*-commutative74.1%
*-commutative74.1%
associate-*l*74.1%
Applied egg-rr74.1%
expm1-define74.3%
Simplified74.3%
Final simplification88.7%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (cos phi2) (- (* (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) * ((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2)))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2)))));
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
code = atan2((cos(phi2) * ((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2)))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2)))))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
return Math.atan2((Math.cos(phi2) * ((Math.sin(lambda1) * Math.cos(lambda2)) - (Math.cos(lambda1) * Math.sin(lambda2)))), ((Math.cos(phi1) * Math.sin(phi2)) - ((Math.cos(phi2) * Math.sin(phi1)) * Math.cos((lambda1 - lambda2)))));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2((math.cos(phi2) * ((math.sin(lambda1) * math.cos(lambda2)) - (math.cos(lambda1) * math.sin(lambda2)))), ((math.cos(phi1) * math.sin(phi2)) - ((math.cos(phi2) * math.sin(phi1)) * math.cos((lambda1 - lambda2)))))
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2)))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * cos(Float64(lambda1 - lambda2))))) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2((cos(phi2) * ((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2)))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2))))); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $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 \left(\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
Initial program 77.2%
sin-diff90.1%
Applied egg-rr90.1%
Final simplification90.1%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2)))
(t_1 (* (cos phi2) (sin (- lambda1 lambda2))))
(t_2 (cos (- lambda1 lambda2)))
(t_3 (* (* (cos phi2) (sin phi1)) t_2)))
(if (<= phi2 -0.00095)
(atan2 t_1 (- t_0 (expm1 (log1p (* (sin phi1) (* (cos phi2) t_2))))))
(if (<= phi2 1.95e-8)
(atan2
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2)))
(- t_0 t_3))
(atan2 t_1 (- t_0 (expm1 (log1p t_3))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double t_1 = cos(phi2) * sin((lambda1 - lambda2));
double t_2 = cos((lambda1 - lambda2));
double t_3 = (cos(phi2) * sin(phi1)) * t_2;
double tmp;
if (phi2 <= -0.00095) {
tmp = atan2(t_1, (t_0 - expm1(log1p((sin(phi1) * (cos(phi2) * t_2))))));
} else if (phi2 <= 1.95e-8) {
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (t_0 - t_3));
} else {
tmp = atan2(t_1, (t_0 - expm1(log1p(t_3))));
}
return tmp;
}
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.cos(phi2) * Math.sin((lambda1 - lambda2));
double t_2 = Math.cos((lambda1 - lambda2));
double t_3 = (Math.cos(phi2) * Math.sin(phi1)) * t_2;
double tmp;
if (phi2 <= -0.00095) {
tmp = Math.atan2(t_1, (t_0 - Math.expm1(Math.log1p((Math.sin(phi1) * (Math.cos(phi2) * t_2))))));
} else if (phi2 <= 1.95e-8) {
tmp = Math.atan2(((Math.sin(lambda1) * Math.cos(lambda2)) - (Math.cos(lambda1) * Math.sin(lambda2))), (t_0 - t_3));
} else {
tmp = Math.atan2(t_1, (t_0 - Math.expm1(Math.log1p(t_3))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi1) * math.sin(phi2) t_1 = math.cos(phi2) * math.sin((lambda1 - lambda2)) t_2 = math.cos((lambda1 - lambda2)) t_3 = (math.cos(phi2) * math.sin(phi1)) * t_2 tmp = 0 if phi2 <= -0.00095: tmp = math.atan2(t_1, (t_0 - math.expm1(math.log1p((math.sin(phi1) * (math.cos(phi2) * t_2)))))) elif phi2 <= 1.95e-8: tmp = math.atan2(((math.sin(lambda1) * math.cos(lambda2)) - (math.cos(lambda1) * math.sin(lambda2))), (t_0 - t_3)) else: tmp = math.atan2(t_1, (t_0 - math.expm1(math.log1p(t_3)))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) t_2 = cos(Float64(lambda1 - lambda2)) t_3 = Float64(Float64(cos(phi2) * sin(phi1)) * t_2) tmp = 0.0 if (phi2 <= -0.00095) tmp = atan(t_1, Float64(t_0 - expm1(log1p(Float64(sin(phi1) * Float64(cos(phi2) * t_2)))))); elseif (phi2 <= 1.95e-8) tmp = atan(Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2))), Float64(t_0 - t_3)); else tmp = atan(t_1, Float64(t_0 - expm1(log1p(t_3)))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$3 = N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * t$95$2), $MachinePrecision]}, If[LessEqual[phi2, -0.00095], N[ArcTan[t$95$1 / N[(t$95$0 - N[(Exp[N[Log[1 + N[(N[Sin[phi1], $MachinePrecision] * N[(N[Cos[phi2], $MachinePrecision] * t$95$2), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]] - 1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi2, 1.95e-8], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - t$95$3), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / N[(t$95$0 - N[(Exp[N[Log[1 + t$95$3], $MachinePrecision]] - 1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
t_1 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
t_2 := \cos \left(\lambda_1 - \lambda_2\right)\\
t_3 := \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t\_2\\
\mathbf{if}\;\phi_2 \leq -0.00095:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \mathsf{expm1}\left(\mathsf{log1p}\left(\sin \phi_1 \cdot \left(\cos \phi_2 \cdot t\_2\right)\right)\right)}\\
\mathbf{elif}\;\phi_2 \leq 1.95 \cdot 10^{-8}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2}{t\_0 - t\_3}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \mathsf{expm1}\left(\mathsf{log1p}\left(t\_3\right)\right)}\\
\end{array}
\end{array}
if phi2 < -9.49999999999999998e-4Initial program 78.8%
*-commutative78.8%
associate-*l*78.9%
Simplified78.9%
associate-*r*78.8%
*-commutative78.8%
add-exp-log37.1%
*-commutative37.1%
*-commutative37.1%
Applied egg-rr37.1%
expm1-log1p-u37.1%
expm1-undefine37.0%
rem-exp-log78.7%
*-commutative78.7%
*-commutative78.7%
associate-*l*78.7%
Applied egg-rr78.7%
expm1-define78.9%
Simplified78.9%
if -9.49999999999999998e-4 < phi2 < 1.94999999999999992e-8Initial program 73.2%
sin-diff87.7%
sub-neg87.7%
Applied egg-rr87.7%
fma-define87.7%
distribute-rgt-neg-in87.7%
sin-neg87.7%
*-commutative87.7%
Simplified87.7%
Taylor expanded in phi2 around 0 87.6%
sin-neg99.5%
distribute-rgt-neg-in99.5%
+-commutative99.5%
cos-neg99.5%
*-commutative99.5%
cos-neg99.5%
sub-neg99.5%
Simplified87.6%
if 1.94999999999999992e-8 < phi2 Initial program 84.1%
*-commutative84.1%
associate-*l*84.0%
Simplified84.0%
associate-*r*84.1%
*-commutative84.1%
expm1-log1p-u84.1%
*-commutative84.1%
*-commutative84.1%
Applied egg-rr84.1%
Final simplification84.5%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2)))
(t_1 (* (cos phi2) (sin (- lambda1 lambda2))))
(t_2 (cos (- lambda1 lambda2))))
(if (<= phi2 -2.9e-39)
(atan2 t_1 (- t_0 (expm1 (log1p (* (sin phi1) (* (cos phi2) t_2))))))
(if (<= phi2 8e-23)
(atan2
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2)))
(* (sin phi1) (- t_2)))
(atan2
t_1
(- t_0 (expm1 (log1p (* (* (cos phi2) (sin phi1)) t_2)))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double t_1 = cos(phi2) * sin((lambda1 - lambda2));
double t_2 = cos((lambda1 - lambda2));
double tmp;
if (phi2 <= -2.9e-39) {
tmp = atan2(t_1, (t_0 - expm1(log1p((sin(phi1) * (cos(phi2) * t_2))))));
} else if (phi2 <= 8e-23) {
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_2));
} else {
tmp = atan2(t_1, (t_0 - expm1(log1p(((cos(phi2) * sin(phi1)) * t_2)))));
}
return tmp;
}
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.cos(phi2) * Math.sin((lambda1 - lambda2));
double t_2 = Math.cos((lambda1 - lambda2));
double tmp;
if (phi2 <= -2.9e-39) {
tmp = Math.atan2(t_1, (t_0 - Math.expm1(Math.log1p((Math.sin(phi1) * (Math.cos(phi2) * t_2))))));
} else if (phi2 <= 8e-23) {
tmp = Math.atan2(((Math.sin(lambda1) * Math.cos(lambda2)) - (Math.cos(lambda1) * Math.sin(lambda2))), (Math.sin(phi1) * -t_2));
} else {
tmp = Math.atan2(t_1, (t_0 - Math.expm1(Math.log1p(((Math.cos(phi2) * Math.sin(phi1)) * t_2)))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi1) * math.sin(phi2) t_1 = math.cos(phi2) * math.sin((lambda1 - lambda2)) t_2 = math.cos((lambda1 - lambda2)) tmp = 0 if phi2 <= -2.9e-39: tmp = math.atan2(t_1, (t_0 - math.expm1(math.log1p((math.sin(phi1) * (math.cos(phi2) * t_2)))))) elif phi2 <= 8e-23: tmp = math.atan2(((math.sin(lambda1) * math.cos(lambda2)) - (math.cos(lambda1) * math.sin(lambda2))), (math.sin(phi1) * -t_2)) else: tmp = math.atan2(t_1, (t_0 - math.expm1(math.log1p(((math.cos(phi2) * math.sin(phi1)) * t_2))))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) t_2 = cos(Float64(lambda1 - lambda2)) tmp = 0.0 if (phi2 <= -2.9e-39) tmp = atan(t_1, Float64(t_0 - expm1(log1p(Float64(sin(phi1) * Float64(cos(phi2) * t_2)))))); elseif (phi2 <= 8e-23) tmp = atan(Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2))), Float64(sin(phi1) * Float64(-t_2))); else tmp = atan(t_1, Float64(t_0 - expm1(log1p(Float64(Float64(cos(phi2) * sin(phi1)) * t_2))))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi2, -2.9e-39], N[ArcTan[t$95$1 / N[(t$95$0 - N[(Exp[N[Log[1 + N[(N[Sin[phi1], $MachinePrecision] * N[(N[Cos[phi2], $MachinePrecision] * t$95$2), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]] - 1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi2, 8e-23], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$2)), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / N[(t$95$0 - N[(Exp[N[Log[1 + N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * t$95$2), $MachinePrecision]], $MachinePrecision]] - 1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
t_1 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
t_2 := \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq -2.9 \cdot 10^{-39}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \mathsf{expm1}\left(\mathsf{log1p}\left(\sin \phi_1 \cdot \left(\cos \phi_2 \cdot t\_2\right)\right)\right)}\\
\mathbf{elif}\;\phi_2 \leq 8 \cdot 10^{-23}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2}{\sin \phi_1 \cdot \left(-t\_2\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \mathsf{expm1}\left(\mathsf{log1p}\left(\left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t\_2\right)\right)}\\
\end{array}
\end{array}
if phi2 < -2.89999999999999988e-39Initial program 77.9%
*-commutative77.9%
associate-*l*77.9%
Simplified77.9%
associate-*r*77.9%
*-commutative77.9%
add-exp-log37.9%
*-commutative37.9%
*-commutative37.9%
Applied egg-rr37.9%
expm1-log1p-u38.0%
expm1-undefine37.9%
rem-exp-log77.8%
*-commutative77.8%
*-commutative77.8%
associate-*l*77.8%
Applied egg-rr77.8%
expm1-define77.9%
Simplified77.9%
if -2.89999999999999988e-39 < phi2 < 7.99999999999999968e-23Initial program 73.6%
*-commutative73.6%
associate-*l*73.6%
Simplified73.6%
associate-*r*73.6%
*-commutative73.6%
add-exp-log31.4%
*-commutative31.4%
*-commutative31.4%
Applied egg-rr31.4%
Taylor expanded in phi2 around 0 71.2%
associate-*r*71.2%
neg-mul-171.2%
Simplified71.2%
Taylor expanded in phi2 around 0 71.2%
sin-diff87.9%
Applied egg-rr85.4%
if 7.99999999999999968e-23 < phi2 Initial program 83.3%
*-commutative83.3%
associate-*l*83.3%
Simplified83.3%
associate-*r*83.3%
*-commutative83.3%
expm1-log1p-u83.3%
*-commutative83.3%
*-commutative83.3%
Applied egg-rr83.3%
Final simplification82.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 (- lambda1 lambda2)))))
(if (<= phi2 -1.1e-39)
(atan2 t_2 (- t_0 (* (cos phi2) (* (sin phi1) t_1))))
(if (<= phi2 1.5e-22)
(atan2
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2)))
(* (sin phi1) (- t_1)))
(atan2
t_2
(- t_0 (expm1 (log1p (* (* (cos phi2) (sin phi1)) t_1)))))))))
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((lambda1 - lambda2));
double tmp;
if (phi2 <= -1.1e-39) {
tmp = atan2(t_2, (t_0 - (cos(phi2) * (sin(phi1) * t_1))));
} else if (phi2 <= 1.5e-22) {
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_1));
} else {
tmp = atan2(t_2, (t_0 - expm1(log1p(((cos(phi2) * sin(phi1)) * t_1)))));
}
return tmp;
}
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.cos((lambda1 - lambda2));
double t_2 = Math.cos(phi2) * Math.sin((lambda1 - lambda2));
double tmp;
if (phi2 <= -1.1e-39) {
tmp = Math.atan2(t_2, (t_0 - (Math.cos(phi2) * (Math.sin(phi1) * t_1))));
} else if (phi2 <= 1.5e-22) {
tmp = Math.atan2(((Math.sin(lambda1) * Math.cos(lambda2)) - (Math.cos(lambda1) * Math.sin(lambda2))), (Math.sin(phi1) * -t_1));
} else {
tmp = Math.atan2(t_2, (t_0 - Math.expm1(Math.log1p(((Math.cos(phi2) * Math.sin(phi1)) * t_1)))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi1) * math.sin(phi2) t_1 = math.cos((lambda1 - lambda2)) t_2 = math.cos(phi2) * math.sin((lambda1 - lambda2)) tmp = 0 if phi2 <= -1.1e-39: tmp = math.atan2(t_2, (t_0 - (math.cos(phi2) * (math.sin(phi1) * t_1)))) elif phi2 <= 1.5e-22: tmp = math.atan2(((math.sin(lambda1) * math.cos(lambda2)) - (math.cos(lambda1) * math.sin(lambda2))), (math.sin(phi1) * -t_1)) else: tmp = math.atan2(t_2, (t_0 - math.expm1(math.log1p(((math.cos(phi2) * math.sin(phi1)) * t_1))))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = cos(Float64(lambda1 - lambda2)) t_2 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) tmp = 0.0 if (phi2 <= -1.1e-39) tmp = atan(t_2, Float64(t_0 - Float64(cos(phi2) * Float64(sin(phi1) * t_1)))); elseif (phi2 <= 1.5e-22) tmp = atan(Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2))), Float64(sin(phi1) * Float64(-t_1))); else tmp = atan(t_2, Float64(t_0 - expm1(log1p(Float64(Float64(cos(phi2) * sin(phi1)) * t_1))))); 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[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[phi2, -1.1e-39], N[ArcTan[t$95$2 / N[(t$95$0 - N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi2, 1.5e-22], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$1)), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$2 / N[(t$95$0 - N[(Exp[N[Log[1 + N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * t$95$1), $MachinePrecision]], $MachinePrecision]] - 1), $MachinePrecision]), $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 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq -1.1 \cdot 10^{-39}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot t\_1\right)}\\
\mathbf{elif}\;\phi_2 \leq 1.5 \cdot 10^{-22}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2}{\sin \phi_1 \cdot \left(-t\_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - \mathsf{expm1}\left(\mathsf{log1p}\left(\left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t\_1\right)\right)}\\
\end{array}
\end{array}
if phi2 < -1.1e-39Initial program 77.9%
*-commutative77.9%
associate-*l*77.9%
Simplified77.9%
if -1.1e-39 < phi2 < 1.5e-22Initial program 73.6%
*-commutative73.6%
associate-*l*73.6%
Simplified73.6%
associate-*r*73.6%
*-commutative73.6%
add-exp-log31.4%
*-commutative31.4%
*-commutative31.4%
Applied egg-rr31.4%
Taylor expanded in phi2 around 0 71.2%
associate-*r*71.2%
neg-mul-171.2%
Simplified71.2%
Taylor expanded in phi2 around 0 71.2%
sin-diff87.9%
Applied egg-rr85.4%
if 1.5e-22 < phi2 Initial program 83.3%
*-commutative83.3%
associate-*l*83.3%
Simplified83.3%
associate-*r*83.3%
*-commutative83.3%
expm1-log1p-u83.3%
*-commutative83.3%
*-commutative83.3%
Applied egg-rr83.3%
Final simplification82.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2))))
(if (or (<= phi2 -9.5e-35) (not (<= phi2 1.35e-22)))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(- (* (cos phi1) (sin phi2)) (* (cos phi2) (* (sin phi1) t_0))))
(atan2
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2)))
(* (sin phi1) (- t_0))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double tmp;
if ((phi2 <= -9.5e-35) || !(phi2 <= 1.35e-22)) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - (cos(phi2) * (sin(phi1) * t_0))));
} else {
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -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 = cos((lambda1 - lambda2))
if ((phi2 <= (-9.5d-35)) .or. (.not. (phi2 <= 1.35d-22))) then
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - (cos(phi2) * (sin(phi1) * t_0))))
else
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_0))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos((lambda1 - lambda2));
double tmp;
if ((phi2 <= -9.5e-35) || !(phi2 <= 1.35e-22)) {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), ((Math.cos(phi1) * Math.sin(phi2)) - (Math.cos(phi2) * (Math.sin(phi1) * t_0))));
} else {
tmp = Math.atan2(((Math.sin(lambda1) * Math.cos(lambda2)) - (Math.cos(lambda1) * Math.sin(lambda2))), (Math.sin(phi1) * -t_0));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) tmp = 0 if (phi2 <= -9.5e-35) or not (phi2 <= 1.35e-22): tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), ((math.cos(phi1) * math.sin(phi2)) - (math.cos(phi2) * (math.sin(phi1) * t_0)))) else: tmp = math.atan2(((math.sin(lambda1) * math.cos(lambda2)) - (math.cos(lambda1) * math.sin(lambda2))), (math.sin(phi1) * -t_0)) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) tmp = 0.0 if ((phi2 <= -9.5e-35) || !(phi2 <= 1.35e-22)) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(cos(phi2) * Float64(sin(phi1) * t_0)))); else tmp = atan(Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2))), Float64(sin(phi1) * Float64(-t_0))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos((lambda1 - lambda2)); tmp = 0.0; if ((phi2 <= -9.5e-35) || ~((phi2 <= 1.35e-22))) tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - (cos(phi2) * (sin(phi1) * t_0)))); else tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_0)); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[Or[LessEqual[phi2, -9.5e-35], N[Not[LessEqual[phi2, 1.35e-22]], $MachinePrecision]], 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[Cos[phi2], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq -9.5 \cdot 10^{-35} \lor \neg \left(\phi_2 \leq 1.35 \cdot 10^{-22}\right):\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot t\_0\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2}{\sin \phi_1 \cdot \left(-t\_0\right)}\\
\end{array}
\end{array}
if phi2 < -9.5000000000000003e-35 or 1.3500000000000001e-22 < phi2 Initial program 80.4%
*-commutative80.4%
associate-*l*80.4%
Simplified80.4%
if -9.5000000000000003e-35 < phi2 < 1.3500000000000001e-22Initial program 73.6%
*-commutative73.6%
associate-*l*73.6%
Simplified73.6%
associate-*r*73.6%
*-commutative73.6%
add-exp-log31.4%
*-commutative31.4%
*-commutative31.4%
Applied egg-rr31.4%
Taylor expanded in phi2 around 0 71.2%
associate-*r*71.2%
neg-mul-171.2%
Simplified71.2%
Taylor expanded in phi2 around 0 71.2%
sin-diff87.9%
Applied egg-rr85.4%
Final simplification82.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 (- lambda1 lambda2)))))
(if (<= phi2 -2.3e-38)
(atan2 t_2 (- t_0 (* (cos phi2) (* (sin phi1) t_1))))
(if (<= phi2 5.2e-23)
(atan2
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2)))
(* (sin phi1) (- t_1)))
(atan2 t_2 (- t_0 (* (* (cos phi2) (sin phi1)) t_1)))))))
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((lambda1 - lambda2));
double tmp;
if (phi2 <= -2.3e-38) {
tmp = atan2(t_2, (t_0 - (cos(phi2) * (sin(phi1) * t_1))));
} else if (phi2 <= 5.2e-23) {
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_1));
} else {
tmp = atan2(t_2, (t_0 - ((cos(phi2) * sin(phi1)) * t_1)));
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: t_1
real(8) :: t_2
real(8) :: tmp
t_0 = cos(phi1) * sin(phi2)
t_1 = cos((lambda1 - lambda2))
t_2 = cos(phi2) * sin((lambda1 - lambda2))
if (phi2 <= (-2.3d-38)) then
tmp = atan2(t_2, (t_0 - (cos(phi2) * (sin(phi1) * t_1))))
else if (phi2 <= 5.2d-23) then
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_1))
else
tmp = atan2(t_2, (t_0 - ((cos(phi2) * sin(phi1)) * 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.cos((lambda1 - lambda2));
double t_2 = Math.cos(phi2) * Math.sin((lambda1 - lambda2));
double tmp;
if (phi2 <= -2.3e-38) {
tmp = Math.atan2(t_2, (t_0 - (Math.cos(phi2) * (Math.sin(phi1) * t_1))));
} else if (phi2 <= 5.2e-23) {
tmp = Math.atan2(((Math.sin(lambda1) * Math.cos(lambda2)) - (Math.cos(lambda1) * Math.sin(lambda2))), (Math.sin(phi1) * -t_1));
} else {
tmp = Math.atan2(t_2, (t_0 - ((Math.cos(phi2) * Math.sin(phi1)) * t_1)));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi1) * math.sin(phi2) t_1 = math.cos((lambda1 - lambda2)) t_2 = math.cos(phi2) * math.sin((lambda1 - lambda2)) tmp = 0 if phi2 <= -2.3e-38: tmp = math.atan2(t_2, (t_0 - (math.cos(phi2) * (math.sin(phi1) * t_1)))) elif phi2 <= 5.2e-23: tmp = math.atan2(((math.sin(lambda1) * math.cos(lambda2)) - (math.cos(lambda1) * math.sin(lambda2))), (math.sin(phi1) * -t_1)) else: tmp = math.atan2(t_2, (t_0 - ((math.cos(phi2) * math.sin(phi1)) * t_1))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = cos(Float64(lambda1 - lambda2)) t_2 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) tmp = 0.0 if (phi2 <= -2.3e-38) tmp = atan(t_2, Float64(t_0 - Float64(cos(phi2) * Float64(sin(phi1) * t_1)))); elseif (phi2 <= 5.2e-23) tmp = atan(Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2))), Float64(sin(phi1) * Float64(-t_1))); else tmp = atan(t_2, Float64(t_0 - Float64(Float64(cos(phi2) * sin(phi1)) * t_1))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos(phi1) * sin(phi2); t_1 = cos((lambda1 - lambda2)); t_2 = cos(phi2) * sin((lambda1 - lambda2)); tmp = 0.0; if (phi2 <= -2.3e-38) tmp = atan2(t_2, (t_0 - (cos(phi2) * (sin(phi1) * t_1)))); elseif (phi2 <= 5.2e-23) tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_1)); else tmp = atan2(t_2, (t_0 - ((cos(phi2) * sin(phi1)) * 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[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[phi2, -2.3e-38], N[ArcTan[t$95$2 / N[(t$95$0 - N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi2, 5.2e-23], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$1)), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$2 / N[(t$95$0 - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * t$95$1), $MachinePrecision]), $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 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq -2.3 \cdot 10^{-38}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot t\_1\right)}\\
\mathbf{elif}\;\phi_2 \leq 5.2 \cdot 10^{-23}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2}{\sin \phi_1 \cdot \left(-t\_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot t\_1}\\
\end{array}
\end{array}
if phi2 < -2.30000000000000002e-38Initial program 77.9%
*-commutative77.9%
associate-*l*77.9%
Simplified77.9%
if -2.30000000000000002e-38 < phi2 < 5.2e-23Initial program 73.6%
*-commutative73.6%
associate-*l*73.6%
Simplified73.6%
associate-*r*73.6%
*-commutative73.6%
add-exp-log31.4%
*-commutative31.4%
*-commutative31.4%
Applied egg-rr31.4%
Taylor expanded in phi2 around 0 71.2%
associate-*r*71.2%
neg-mul-171.2%
Simplified71.2%
Taylor expanded in phi2 around 0 71.2%
sin-diff87.9%
Applied egg-rr85.4%
if 5.2e-23 < phi2 Initial program 83.3%
Final simplification82.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2))) (t_1 (* (cos phi2) (sin phi1))))
(if (or (<= lambda2 -12000.0) (not (<= lambda2 4.2e+16)))
(atan2 (* (sin (- lambda2)) (cos phi2)) (- t_0 (* (cos lambda2) t_1)))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(- t_0 (* (cos lambda1) t_1))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double t_1 = cos(phi2) * sin(phi1);
double tmp;
if ((lambda2 <= -12000.0) || !(lambda2 <= 4.2e+16)) {
tmp = atan2((sin(-lambda2) * cos(phi2)), (t_0 - (cos(lambda2) * t_1)));
} else {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_0 - (cos(lambda1) * 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 = cos(phi2) * sin(phi1)
if ((lambda2 <= (-12000.0d0)) .or. (.not. (lambda2 <= 4.2d+16))) then
tmp = atan2((sin(-lambda2) * cos(phi2)), (t_0 - (cos(lambda2) * t_1)))
else
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_0 - (cos(lambda1) * 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.cos(phi2) * Math.sin(phi1);
double tmp;
if ((lambda2 <= -12000.0) || !(lambda2 <= 4.2e+16)) {
tmp = Math.atan2((Math.sin(-lambda2) * Math.cos(phi2)), (t_0 - (Math.cos(lambda2) * t_1)));
} else {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), (t_0 - (Math.cos(lambda1) * t_1)));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi1) * math.sin(phi2) t_1 = math.cos(phi2) * math.sin(phi1) tmp = 0 if (lambda2 <= -12000.0) or not (lambda2 <= 4.2e+16): tmp = math.atan2((math.sin(-lambda2) * math.cos(phi2)), (t_0 - (math.cos(lambda2) * t_1))) else: tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), (t_0 - (math.cos(lambda1) * t_1))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = Float64(cos(phi2) * sin(phi1)) tmp = 0.0 if ((lambda2 <= -12000.0) || !(lambda2 <= 4.2e+16)) tmp = atan(Float64(sin(Float64(-lambda2)) * cos(phi2)), Float64(t_0 - Float64(cos(lambda2) * t_1))); else tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(t_0 - Float64(cos(lambda1) * t_1))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos(phi1) * sin(phi2); t_1 = cos(phi2) * sin(phi1); tmp = 0.0; if ((lambda2 <= -12000.0) || ~((lambda2 <= 4.2e+16))) tmp = atan2((sin(-lambda2) * cos(phi2)), (t_0 - (cos(lambda2) * t_1))); else tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_0 - (cos(lambda1) * 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[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]}, If[Or[LessEqual[lambda2, -12000.0], N[Not[LessEqual[lambda2, 4.2e+16]], $MachinePrecision]], N[ArcTan[N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Cos[lambda2], $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Cos[lambda1], $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
t_1 := \cos \phi_2 \cdot \sin \phi_1\\
\mathbf{if}\;\lambda_2 \leq -12000 \lor \neg \left(\lambda_2 \leq 4.2 \cdot 10^{+16}\right):\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \cos \phi_2}{t\_0 - \cos \lambda_2 \cdot t\_1}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t\_0 - \cos \lambda_1 \cdot t\_1}\\
\end{array}
\end{array}
if lambda2 < -12000 or 4.2e16 < lambda2 Initial program 56.2%
Taylor expanded in lambda1 around 0 60.1%
Taylor expanded in lambda1 around 0 60.1%
cos-neg60.1%
Simplified60.1%
if -12000 < lambda2 < 4.2e16Initial program 96.7%
Taylor expanded in lambda1 around inf 96.7%
Final simplification79.1%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi2) (sin phi1)))
(t_1 (* (sin (- lambda2)) (cos phi2)))
(t_2 (* (cos phi1) (sin phi2))))
(if (<= lambda2 -64000.0)
(atan2 t_1 (- t_2 (* t_0 (cos (- lambda1 lambda2)))))
(if (<= lambda2 4.2e+16)
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(- t_2 (* (cos lambda1) t_0)))
(atan2 t_1 (- t_2 (* (cos lambda2) t_0)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi2) * sin(phi1);
double t_1 = sin(-lambda2) * cos(phi2);
double t_2 = cos(phi1) * sin(phi2);
double tmp;
if (lambda2 <= -64000.0) {
tmp = atan2(t_1, (t_2 - (t_0 * cos((lambda1 - lambda2)))));
} else if (lambda2 <= 4.2e+16) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_2 - (cos(lambda1) * t_0)));
} else {
tmp = atan2(t_1, (t_2 - (cos(lambda2) * t_0)));
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: t_1
real(8) :: t_2
real(8) :: tmp
t_0 = cos(phi2) * sin(phi1)
t_1 = sin(-lambda2) * cos(phi2)
t_2 = cos(phi1) * sin(phi2)
if (lambda2 <= (-64000.0d0)) then
tmp = atan2(t_1, (t_2 - (t_0 * cos((lambda1 - lambda2)))))
else if (lambda2 <= 4.2d+16) then
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_2 - (cos(lambda1) * t_0)))
else
tmp = atan2(t_1, (t_2 - (cos(lambda2) * t_0)))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos(phi2) * Math.sin(phi1);
double t_1 = Math.sin(-lambda2) * Math.cos(phi2);
double t_2 = Math.cos(phi1) * Math.sin(phi2);
double tmp;
if (lambda2 <= -64000.0) {
tmp = Math.atan2(t_1, (t_2 - (t_0 * Math.cos((lambda1 - lambda2)))));
} else if (lambda2 <= 4.2e+16) {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), (t_2 - (Math.cos(lambda1) * t_0)));
} else {
tmp = Math.atan2(t_1, (t_2 - (Math.cos(lambda2) * t_0)));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi2) * math.sin(phi1) t_1 = math.sin(-lambda2) * math.cos(phi2) t_2 = math.cos(phi1) * math.sin(phi2) tmp = 0 if lambda2 <= -64000.0: tmp = math.atan2(t_1, (t_2 - (t_0 * math.cos((lambda1 - lambda2))))) elif lambda2 <= 4.2e+16: tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), (t_2 - (math.cos(lambda1) * t_0))) else: tmp = math.atan2(t_1, (t_2 - (math.cos(lambda2) * t_0))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi2) * sin(phi1)) t_1 = Float64(sin(Float64(-lambda2)) * cos(phi2)) t_2 = Float64(cos(phi1) * sin(phi2)) tmp = 0.0 if (lambda2 <= -64000.0) tmp = atan(t_1, Float64(t_2 - Float64(t_0 * cos(Float64(lambda1 - lambda2))))); elseif (lambda2 <= 4.2e+16) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(t_2 - Float64(cos(lambda1) * t_0))); else tmp = atan(t_1, Float64(t_2 - Float64(cos(lambda2) * t_0))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos(phi2) * sin(phi1); t_1 = sin(-lambda2) * cos(phi2); t_2 = cos(phi1) * sin(phi2); tmp = 0.0; if (lambda2 <= -64000.0) tmp = atan2(t_1, (t_2 - (t_0 * cos((lambda1 - lambda2))))); elseif (lambda2 <= 4.2e+16) tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_2 - (cos(lambda1) * t_0))); else tmp = atan2(t_1, (t_2 - (cos(lambda2) * t_0))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda2, -64000.0], N[ArcTan[t$95$1 / N[(t$95$2 - N[(t$95$0 * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda2, 4.2e+16], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(t$95$2 - N[(N[Cos[lambda1], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / N[(t$95$2 - N[(N[Cos[lambda2], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_2 \cdot \sin \phi_1\\
t_1 := \sin \left(-\lambda_2\right) \cdot \cos \phi_2\\
t_2 := \cos \phi_1 \cdot \sin \phi_2\\
\mathbf{if}\;\lambda_2 \leq -64000:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_2 - t\_0 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\mathbf{elif}\;\lambda_2 \leq 4.2 \cdot 10^{+16}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t\_2 - \cos \lambda_1 \cdot t\_0}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_2 - \cos \lambda_2 \cdot t\_0}\\
\end{array}
\end{array}
if lambda2 < -64000Initial program 53.6%
Taylor expanded in lambda1 around 0 56.9%
if -64000 < lambda2 < 4.2e16Initial program 96.7%
Taylor expanded in lambda1 around inf 96.7%
if 4.2e16 < lambda2 Initial program 59.4%
Taylor expanded in lambda1 around 0 64.0%
Taylor expanded in lambda1 around 0 64.0%
cos-neg64.0%
Simplified64.0%
Final simplification79.1%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2))) (t_1 (* (cos phi1) (sin phi2))))
(if (<= lambda1 -0.0024)
(atan2
(* (sin lambda1) (cos phi2))
(- t_1 (* (cos phi2) (* (sin phi1) t_0))))
(if (<= lambda1 5600000.0)
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(- t_1 (* (cos phi2) (* (cos lambda2) (sin phi1)))))
(atan2
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2)))
(* (sin phi1) (- t_0)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double t_1 = cos(phi1) * sin(phi2);
double tmp;
if (lambda1 <= -0.0024) {
tmp = atan2((sin(lambda1) * cos(phi2)), (t_1 - (cos(phi2) * (sin(phi1) * t_0))));
} else if (lambda1 <= 5600000.0) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_1 - (cos(phi2) * (cos(lambda2) * sin(phi1)))));
} else {
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -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) :: t_1
real(8) :: tmp
t_0 = cos((lambda1 - lambda2))
t_1 = cos(phi1) * sin(phi2)
if (lambda1 <= (-0.0024d0)) then
tmp = atan2((sin(lambda1) * cos(phi2)), (t_1 - (cos(phi2) * (sin(phi1) * t_0))))
else if (lambda1 <= 5600000.0d0) then
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_1 - (cos(phi2) * (cos(lambda2) * sin(phi1)))))
else
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_0))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos((lambda1 - lambda2));
double t_1 = Math.cos(phi1) * Math.sin(phi2);
double tmp;
if (lambda1 <= -0.0024) {
tmp = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (t_1 - (Math.cos(phi2) * (Math.sin(phi1) * t_0))));
} else if (lambda1 <= 5600000.0) {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), (t_1 - (Math.cos(phi2) * (Math.cos(lambda2) * Math.sin(phi1)))));
} else {
tmp = Math.atan2(((Math.sin(lambda1) * Math.cos(lambda2)) - (Math.cos(lambda1) * Math.sin(lambda2))), (Math.sin(phi1) * -t_0));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) t_1 = math.cos(phi1) * math.sin(phi2) tmp = 0 if lambda1 <= -0.0024: tmp = math.atan2((math.sin(lambda1) * math.cos(phi2)), (t_1 - (math.cos(phi2) * (math.sin(phi1) * t_0)))) elif lambda1 <= 5600000.0: tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), (t_1 - (math.cos(phi2) * (math.cos(lambda2) * math.sin(phi1))))) else: tmp = math.atan2(((math.sin(lambda1) * math.cos(lambda2)) - (math.cos(lambda1) * math.sin(lambda2))), (math.sin(phi1) * -t_0)) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) t_1 = Float64(cos(phi1) * sin(phi2)) tmp = 0.0 if (lambda1 <= -0.0024) tmp = atan(Float64(sin(lambda1) * cos(phi2)), Float64(t_1 - Float64(cos(phi2) * Float64(sin(phi1) * t_0)))); elseif (lambda1 <= 5600000.0) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(t_1 - Float64(cos(phi2) * Float64(cos(lambda2) * sin(phi1))))); else tmp = atan(Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2))), Float64(sin(phi1) * Float64(-t_0))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos((lambda1 - lambda2)); t_1 = cos(phi1) * sin(phi2); tmp = 0.0; if (lambda1 <= -0.0024) tmp = atan2((sin(lambda1) * cos(phi2)), (t_1 - (cos(phi2) * (sin(phi1) * t_0)))); elseif (lambda1 <= 5600000.0) tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_1 - (cos(phi2) * (cos(lambda2) * sin(phi1))))); else tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_0)); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda1, -0.0024], N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$1 - N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda1, 5600000.0], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(t$95$1 - N[(N[Cos[phi2], $MachinePrecision] * N[(N[Cos[lambda2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]], $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
t_1 := \cos \phi_1 \cdot \sin \phi_2\\
\mathbf{if}\;\lambda_1 \leq -0.0024:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_1 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot t\_0\right)}\\
\mathbf{elif}\;\lambda_1 \leq 5600000:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t\_1 - \cos \phi_2 \cdot \left(\cos \lambda_2 \cdot \sin \phi_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2}{\sin \phi_1 \cdot \left(-t\_0\right)}\\
\end{array}
\end{array}
if lambda1 < -0.00239999999999999979Initial program 60.4%
*-commutative60.4%
associate-*l*60.5%
Simplified60.5%
Taylor expanded in lambda2 around 0 62.7%
if -0.00239999999999999979 < lambda1 < 5.6e6Initial program 99.4%
*-commutative99.4%
associate-*l*99.4%
Simplified99.4%
Taylor expanded in lambda1 around 0 99.4%
cos-neg76.8%
Simplified99.4%
if 5.6e6 < lambda1 Initial program 44.2%
*-commutative44.2%
associate-*l*44.2%
Simplified44.2%
associate-*r*44.2%
*-commutative44.2%
add-exp-log17.8%
*-commutative17.8%
*-commutative17.8%
Applied egg-rr17.8%
Taylor expanded in phi2 around 0 25.7%
associate-*r*25.7%
neg-mul-125.7%
Simplified25.7%
Taylor expanded in phi2 around 0 23.5%
sin-diff80.3%
Applied egg-rr45.3%
Final simplification78.1%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2)))
(t_1 (* (sin phi1) t_0))
(t_2 (* (cos phi1) (sin phi2))))
(if (<= lambda1 -4.8e-19)
(atan2 (* (sin lambda1) (cos phi2)) (- t_2 (* (cos phi2) t_1)))
(if (<= lambda1 6.2e-246)
(atan2
(* (sin (- lambda2)) (cos phi2))
(- t_2 (* (cos lambda2) (* (cos phi2) (sin phi1)))))
(if (<= lambda1 7500000.0)
(atan2 (* (cos phi2) (sin (- lambda1 lambda2))) (- t_2 t_1))
(atan2
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2)))
(* (sin phi1) (- t_0))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double t_1 = sin(phi1) * t_0;
double t_2 = cos(phi1) * sin(phi2);
double tmp;
if (lambda1 <= -4.8e-19) {
tmp = atan2((sin(lambda1) * cos(phi2)), (t_2 - (cos(phi2) * t_1)));
} else if (lambda1 <= 6.2e-246) {
tmp = atan2((sin(-lambda2) * cos(phi2)), (t_2 - (cos(lambda2) * (cos(phi2) * sin(phi1)))));
} else if (lambda1 <= 7500000.0) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_2 - t_1));
} else {
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -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) :: t_1
real(8) :: t_2
real(8) :: tmp
t_0 = cos((lambda1 - lambda2))
t_1 = sin(phi1) * t_0
t_2 = cos(phi1) * sin(phi2)
if (lambda1 <= (-4.8d-19)) then
tmp = atan2((sin(lambda1) * cos(phi2)), (t_2 - (cos(phi2) * t_1)))
else if (lambda1 <= 6.2d-246) then
tmp = atan2((sin(-lambda2) * cos(phi2)), (t_2 - (cos(lambda2) * (cos(phi2) * sin(phi1)))))
else if (lambda1 <= 7500000.0d0) then
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_2 - t_1))
else
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_0))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos((lambda1 - lambda2));
double t_1 = Math.sin(phi1) * t_0;
double t_2 = Math.cos(phi1) * Math.sin(phi2);
double tmp;
if (lambda1 <= -4.8e-19) {
tmp = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (t_2 - (Math.cos(phi2) * t_1)));
} else if (lambda1 <= 6.2e-246) {
tmp = Math.atan2((Math.sin(-lambda2) * Math.cos(phi2)), (t_2 - (Math.cos(lambda2) * (Math.cos(phi2) * Math.sin(phi1)))));
} else if (lambda1 <= 7500000.0) {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), (t_2 - t_1));
} else {
tmp = Math.atan2(((Math.sin(lambda1) * Math.cos(lambda2)) - (Math.cos(lambda1) * Math.sin(lambda2))), (Math.sin(phi1) * -t_0));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) t_1 = math.sin(phi1) * t_0 t_2 = math.cos(phi1) * math.sin(phi2) tmp = 0 if lambda1 <= -4.8e-19: tmp = math.atan2((math.sin(lambda1) * math.cos(phi2)), (t_2 - (math.cos(phi2) * t_1))) elif lambda1 <= 6.2e-246: tmp = math.atan2((math.sin(-lambda2) * math.cos(phi2)), (t_2 - (math.cos(lambda2) * (math.cos(phi2) * math.sin(phi1))))) elif lambda1 <= 7500000.0: tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), (t_2 - t_1)) else: tmp = math.atan2(((math.sin(lambda1) * math.cos(lambda2)) - (math.cos(lambda1) * math.sin(lambda2))), (math.sin(phi1) * -t_0)) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) t_1 = Float64(sin(phi1) * t_0) t_2 = Float64(cos(phi1) * sin(phi2)) tmp = 0.0 if (lambda1 <= -4.8e-19) tmp = atan(Float64(sin(lambda1) * cos(phi2)), Float64(t_2 - Float64(cos(phi2) * t_1))); elseif (lambda1 <= 6.2e-246) tmp = atan(Float64(sin(Float64(-lambda2)) * cos(phi2)), Float64(t_2 - Float64(cos(lambda2) * Float64(cos(phi2) * sin(phi1))))); elseif (lambda1 <= 7500000.0) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(t_2 - t_1)); else tmp = atan(Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2))), Float64(sin(phi1) * Float64(-t_0))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos((lambda1 - lambda2)); t_1 = sin(phi1) * t_0; t_2 = cos(phi1) * sin(phi2); tmp = 0.0; if (lambda1 <= -4.8e-19) tmp = atan2((sin(lambda1) * cos(phi2)), (t_2 - (cos(phi2) * t_1))); elseif (lambda1 <= 6.2e-246) tmp = atan2((sin(-lambda2) * cos(phi2)), (t_2 - (cos(lambda2) * (cos(phi2) * sin(phi1))))); elseif (lambda1 <= 7500000.0) tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_2 - t_1)); else tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_0)); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(N[Sin[phi1], $MachinePrecision] * t$95$0), $MachinePrecision]}, Block[{t$95$2 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda1, -4.8e-19], N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$2 - N[(N[Cos[phi2], $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda1, 6.2e-246], N[ArcTan[N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$2 - N[(N[Cos[lambda2], $MachinePrecision] * N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda1, 7500000.0], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(t$95$2 - t$95$1), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
t_1 := \sin \phi_1 \cdot t\_0\\
t_2 := \cos \phi_1 \cdot \sin \phi_2\\
\mathbf{if}\;\lambda_1 \leq -4.8 \cdot 10^{-19}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_2 - \cos \phi_2 \cdot t\_1}\\
\mathbf{elif}\;\lambda_1 \leq 6.2 \cdot 10^{-246}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \cos \phi_2}{t\_2 - \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \phi_1\right)}\\
\mathbf{elif}\;\lambda_1 \leq 7500000:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t\_2 - t\_1}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2}{\sin \phi_1 \cdot \left(-t\_0\right)}\\
\end{array}
\end{array}
if lambda1 < -4.80000000000000046e-19Initial program 61.5%
*-commutative61.5%
associate-*l*61.5%
Simplified61.5%
Taylor expanded in lambda2 around 0 63.7%
if -4.80000000000000046e-19 < lambda1 < 6.2000000000000001e-246Initial program 99.8%
Taylor expanded in lambda1 around 0 86.9%
Taylor expanded in lambda1 around 0 86.9%
cos-neg86.9%
Simplified86.9%
if 6.2000000000000001e-246 < lambda1 < 7.5e6Initial program 99.0%
*-commutative99.0%
associate-*l*99.0%
Simplified99.0%
associate-*r*99.0%
*-commutative99.0%
add-exp-log46.6%
*-commutative46.6%
*-commutative46.6%
Applied egg-rr46.6%
Taylor expanded in phi2 around 0 86.0%
if 7.5e6 < lambda1 Initial program 44.2%
*-commutative44.2%
associate-*l*44.2%
Simplified44.2%
associate-*r*44.2%
*-commutative44.2%
add-exp-log17.8%
*-commutative17.8%
*-commutative17.8%
Applied egg-rr17.8%
Taylor expanded in phi2 around 0 25.7%
associate-*r*25.7%
neg-mul-125.7%
Simplified25.7%
Taylor expanded in phi2 around 0 23.5%
sin-diff80.3%
Applied egg-rr45.3%
Final simplification71.5%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(if (or (<= phi2 -9.5e-35) (not (<= phi2 4e-20)))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(-
(* (cos phi1) (sin phi2))
(* (* (cos phi2) (sin phi1)) (+ (* lambda1 lambda2) 1.0))))
(atan2
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2)))
(* (sin phi1) (- (cos (- lambda1 lambda2)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((phi2 <= -9.5e-35) || !(phi2 <= 4e-20)) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * ((lambda1 * lambda2) + 1.0))));
} else {
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -cos((lambda1 - lambda2))));
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if ((phi2 <= (-9.5d-35)) .or. (.not. (phi2 <= 4d-20))) then
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * ((lambda1 * lambda2) + 1.0d0))))
else
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -cos((lambda1 - lambda2))))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((phi2 <= -9.5e-35) || !(phi2 <= 4e-20)) {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), ((Math.cos(phi1) * Math.sin(phi2)) - ((Math.cos(phi2) * Math.sin(phi1)) * ((lambda1 * lambda2) + 1.0))));
} else {
tmp = Math.atan2(((Math.sin(lambda1) * Math.cos(lambda2)) - (Math.cos(lambda1) * Math.sin(lambda2))), (Math.sin(phi1) * -Math.cos((lambda1 - lambda2))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): tmp = 0 if (phi2 <= -9.5e-35) or not (phi2 <= 4e-20): tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), ((math.cos(phi1) * math.sin(phi2)) - ((math.cos(phi2) * math.sin(phi1)) * ((lambda1 * lambda2) + 1.0)))) else: tmp = math.atan2(((math.sin(lambda1) * math.cos(lambda2)) - (math.cos(lambda1) * math.sin(lambda2))), (math.sin(phi1) * -math.cos((lambda1 - lambda2)))) return tmp
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if ((phi2 <= -9.5e-35) || !(phi2 <= 4e-20)) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * Float64(Float64(lambda1 * lambda2) + 1.0)))); else tmp = atan(Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2))), Float64(sin(phi1) * Float64(-cos(Float64(lambda1 - lambda2))))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) tmp = 0.0; if ((phi2 <= -9.5e-35) || ~((phi2 <= 4e-20))) tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * ((lambda1 * lambda2) + 1.0)))); else tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -cos((lambda1 - lambda2)))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := If[Or[LessEqual[phi2, -9.5e-35], N[Not[LessEqual[phi2, 4e-20]], $MachinePrecision]], 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[(N[(lambda1 * lambda2), $MachinePrecision] + 1.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision])), $MachinePrecision]], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\phi_2 \leq -9.5 \cdot 10^{-35} \lor \neg \left(\phi_2 \leq 4 \cdot 10^{-20}\right):\\
\;\;\;\;\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 \left(\lambda_1 \cdot \lambda_2 + 1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2}{\sin \phi_1 \cdot \left(-\cos \left(\lambda_1 - \lambda_2\right)\right)}\\
\end{array}
\end{array}
if phi2 < -9.5000000000000003e-35 or 3.99999999999999978e-20 < phi2 Initial program 80.4%
Taylor expanded in lambda1 around 0 67.0%
cos-neg67.0%
mul-1-neg67.0%
distribute-rgt-neg-in67.0%
sin-neg67.0%
remove-double-neg67.0%
Simplified67.0%
Taylor expanded in lambda2 around 0 56.3%
associate-*r*56.3%
distribute-lft1-in56.3%
*-commutative56.3%
Simplified56.3%
if -9.5000000000000003e-35 < phi2 < 3.99999999999999978e-20Initial program 73.6%
*-commutative73.6%
associate-*l*73.6%
Simplified73.6%
associate-*r*73.6%
*-commutative73.6%
add-exp-log31.4%
*-commutative31.4%
*-commutative31.4%
Applied egg-rr31.4%
Taylor expanded in phi2 around 0 71.2%
associate-*r*71.2%
neg-mul-171.2%
Simplified71.2%
Taylor expanded in phi2 around 0 71.2%
sin-diff87.9%
Applied egg-rr85.4%
Final simplification69.8%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2))))
(if (or (<= phi2 -7e-42) (not (<= phi2 7e-23)))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(- (* (cos phi1) (sin phi2)) (* (sin phi1) t_0)))
(atan2
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2)))
(* (sin phi1) (- t_0))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double tmp;
if ((phi2 <= -7e-42) || !(phi2 <= 7e-23)) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - (sin(phi1) * t_0)));
} else {
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -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 = cos((lambda1 - lambda2))
if ((phi2 <= (-7d-42)) .or. (.not. (phi2 <= 7d-23))) then
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - (sin(phi1) * t_0)))
else
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_0))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos((lambda1 - lambda2));
double tmp;
if ((phi2 <= -7e-42) || !(phi2 <= 7e-23)) {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), ((Math.cos(phi1) * Math.sin(phi2)) - (Math.sin(phi1) * t_0)));
} else {
tmp = Math.atan2(((Math.sin(lambda1) * Math.cos(lambda2)) - (Math.cos(lambda1) * Math.sin(lambda2))), (Math.sin(phi1) * -t_0));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) tmp = 0 if (phi2 <= -7e-42) or not (phi2 <= 7e-23): tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), ((math.cos(phi1) * math.sin(phi2)) - (math.sin(phi1) * t_0))) else: tmp = math.atan2(((math.sin(lambda1) * math.cos(lambda2)) - (math.cos(lambda1) * math.sin(lambda2))), (math.sin(phi1) * -t_0)) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) tmp = 0.0 if ((phi2 <= -7e-42) || !(phi2 <= 7e-23)) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(sin(phi1) * t_0))); else tmp = atan(Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2))), Float64(sin(phi1) * Float64(-t_0))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos((lambda1 - lambda2)); tmp = 0.0; if ((phi2 <= -7e-42) || ~((phi2 <= 7e-23))) tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - (sin(phi1) * t_0))); else tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_0)); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[Or[LessEqual[phi2, -7e-42], N[Not[LessEqual[phi2, 7e-23]], $MachinePrecision]], 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] * t$95$0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq -7 \cdot 10^{-42} \lor \neg \left(\phi_2 \leq 7 \cdot 10^{-23}\right):\\
\;\;\;\;\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 t\_0}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2}{\sin \phi_1 \cdot \left(-t\_0\right)}\\
\end{array}
\end{array}
if phi2 < -7.0000000000000004e-42 or 6.99999999999999987e-23 < phi2 Initial program 80.4%
*-commutative80.4%
associate-*l*80.4%
Simplified80.4%
associate-*r*80.4%
*-commutative80.4%
add-exp-log35.2%
*-commutative35.2%
*-commutative35.2%
Applied egg-rr35.2%
Taylor expanded in phi2 around 0 53.5%
if -7.0000000000000004e-42 < phi2 < 6.99999999999999987e-23Initial program 73.6%
*-commutative73.6%
associate-*l*73.6%
Simplified73.6%
associate-*r*73.6%
*-commutative73.6%
add-exp-log31.4%
*-commutative31.4%
*-commutative31.4%
Applied egg-rr31.4%
Taylor expanded in phi2 around 0 71.2%
associate-*r*71.2%
neg-mul-171.2%
Simplified71.2%
Taylor expanded in phi2 around 0 71.2%
sin-diff87.9%
Applied egg-rr85.4%
Final simplification68.3%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2))))
(if (or (<= phi2 -0.00038) (not (<= phi2 500000000.0)))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(- (sin phi2) (* t_0 (* (cos phi2) phi1))))
(atan2
(- (* (sin lambda1) (cos lambda2)) (* (cos lambda1) (sin lambda2)))
(* (sin phi1) (- t_0))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double tmp;
if ((phi2 <= -0.00038) || !(phi2 <= 500000000.0)) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (sin(phi2) - (t_0 * (cos(phi2) * phi1))));
} else {
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -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 = cos((lambda1 - lambda2))
if ((phi2 <= (-0.00038d0)) .or. (.not. (phi2 <= 500000000.0d0))) then
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (sin(phi2) - (t_0 * (cos(phi2) * phi1))))
else
tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_0))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos((lambda1 - lambda2));
double tmp;
if ((phi2 <= -0.00038) || !(phi2 <= 500000000.0)) {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), (Math.sin(phi2) - (t_0 * (Math.cos(phi2) * phi1))));
} else {
tmp = Math.atan2(((Math.sin(lambda1) * Math.cos(lambda2)) - (Math.cos(lambda1) * Math.sin(lambda2))), (Math.sin(phi1) * -t_0));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) tmp = 0 if (phi2 <= -0.00038) or not (phi2 <= 500000000.0): tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), (math.sin(phi2) - (t_0 * (math.cos(phi2) * phi1)))) else: tmp = math.atan2(((math.sin(lambda1) * math.cos(lambda2)) - (math.cos(lambda1) * math.sin(lambda2))), (math.sin(phi1) * -t_0)) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) tmp = 0.0 if ((phi2 <= -0.00038) || !(phi2 <= 500000000.0)) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(sin(phi2) - Float64(t_0 * Float64(cos(phi2) * phi1)))); else tmp = atan(Float64(Float64(sin(lambda1) * cos(lambda2)) - Float64(cos(lambda1) * sin(lambda2))), Float64(sin(phi1) * Float64(-t_0))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos((lambda1 - lambda2)); tmp = 0.0; if ((phi2 <= -0.00038) || ~((phi2 <= 500000000.0))) tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (sin(phi2) - (t_0 * (cos(phi2) * phi1)))); else tmp = atan2(((sin(lambda1) * cos(lambda2)) - (cos(lambda1) * sin(lambda2))), (sin(phi1) * -t_0)); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[Or[LessEqual[phi2, -0.00038], N[Not[LessEqual[phi2, 500000000.0]], $MachinePrecision]], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(t$95$0 * N[(N[Cos[phi2], $MachinePrecision] * phi1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq -0.00038 \lor \neg \left(\phi_2 \leq 500000000\right):\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 - t\_0 \cdot \left(\cos \phi_2 \cdot \phi_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \lambda_2 - \cos \lambda_1 \cdot \sin \lambda_2}{\sin \phi_1 \cdot \left(-t\_0\right)}\\
\end{array}
\end{array}
if phi2 < -3.8000000000000002e-4 or 5e8 < phi2 Initial program 80.6%
*-commutative80.6%
associate-*l*80.6%
Simplified80.6%
associate-*r*80.6%
*-commutative80.6%
add-exp-log31.9%
*-commutative31.9%
*-commutative31.9%
Applied egg-rr31.9%
Taylor expanded in phi1 around 0 50.2%
mul-1-neg50.2%
unsub-neg50.2%
associate-*r*50.2%
Simplified50.2%
if -3.8000000000000002e-4 < phi2 < 5e8Initial program 74.2%
*-commutative74.2%
associate-*l*74.2%
Simplified74.2%
associate-*r*74.2%
*-commutative74.2%
add-exp-log34.8%
*-commutative34.8%
*-commutative34.8%
Applied egg-rr34.8%
Taylor expanded in phi2 around 0 68.1%
associate-*r*68.1%
neg-mul-168.1%
Simplified68.1%
Taylor expanded in phi2 around 0 67.9%
sin-diff88.1%
Applied egg-rr81.4%
Final simplification66.6%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2)))
(t_1 (* (cos phi2) (sin (- lambda1 lambda2)))))
(if (<= phi1 -0.00082)
(atan2 t_1 (* (sin phi1) (- t_0)))
(if (<= phi1 0.0045)
(atan2 t_1 (- (sin phi2) (* t_0 (* (cos phi2) phi1))))
(atan2 t_1 (* (sin phi1) (- (expm1 (log1p t_0)))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double t_1 = cos(phi2) * sin((lambda1 - lambda2));
double tmp;
if (phi1 <= -0.00082) {
tmp = atan2(t_1, (sin(phi1) * -t_0));
} else if (phi1 <= 0.0045) {
tmp = atan2(t_1, (sin(phi2) - (t_0 * (cos(phi2) * phi1))));
} else {
tmp = atan2(t_1, (sin(phi1) * -expm1(log1p(t_0))));
}
return tmp;
}
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos((lambda1 - lambda2));
double t_1 = Math.cos(phi2) * Math.sin((lambda1 - lambda2));
double tmp;
if (phi1 <= -0.00082) {
tmp = Math.atan2(t_1, (Math.sin(phi1) * -t_0));
} else if (phi1 <= 0.0045) {
tmp = Math.atan2(t_1, (Math.sin(phi2) - (t_0 * (Math.cos(phi2) * phi1))));
} else {
tmp = Math.atan2(t_1, (Math.sin(phi1) * -Math.expm1(Math.log1p(t_0))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) t_1 = math.cos(phi2) * math.sin((lambda1 - lambda2)) tmp = 0 if phi1 <= -0.00082: tmp = math.atan2(t_1, (math.sin(phi1) * -t_0)) elif phi1 <= 0.0045: tmp = math.atan2(t_1, (math.sin(phi2) - (t_0 * (math.cos(phi2) * phi1)))) else: tmp = math.atan2(t_1, (math.sin(phi1) * -math.expm1(math.log1p(t_0)))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) t_1 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) tmp = 0.0 if (phi1 <= -0.00082) tmp = atan(t_1, Float64(sin(phi1) * Float64(-t_0))); elseif (phi1 <= 0.0045) tmp = atan(t_1, Float64(sin(phi2) - Float64(t_0 * Float64(cos(phi2) * phi1)))); else tmp = atan(t_1, Float64(sin(phi1) * Float64(-expm1(log1p(t_0))))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[phi1, -0.00082], N[ArcTan[t$95$1 / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi1, 0.0045], N[ArcTan[t$95$1 / N[(N[Sin[phi2], $MachinePrecision] - N[(t$95$0 * N[(N[Cos[phi2], $MachinePrecision] * phi1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / N[(N[Sin[phi1], $MachinePrecision] * (-N[(Exp[N[Log[1 + t$95$0], $MachinePrecision]] - 1), $MachinePrecision])), $MachinePrecision]], $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
t_1 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_1 \leq -0.00082:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{\sin \phi_1 \cdot \left(-t\_0\right)}\\
\mathbf{elif}\;\phi_1 \leq 0.0045:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{\sin \phi_2 - t\_0 \cdot \left(\cos \phi_2 \cdot \phi_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{\sin \phi_1 \cdot \left(-\mathsf{expm1}\left(\mathsf{log1p}\left(t\_0\right)\right)\right)}\\
\end{array}
\end{array}
if phi1 < -8.1999999999999998e-4Initial program 80.7%
*-commutative80.7%
associate-*l*80.7%
Simplified80.7%
associate-*r*80.7%
*-commutative80.7%
add-exp-log33.3%
*-commutative33.3%
*-commutative33.3%
Applied egg-rr33.3%
Taylor expanded in phi2 around 0 45.3%
associate-*r*45.3%
neg-mul-145.3%
Simplified45.3%
if -8.1999999999999998e-4 < phi1 < 0.00449999999999999966Initial program 77.9%
*-commutative77.9%
associate-*l*77.9%
Simplified77.9%
associate-*r*77.9%
*-commutative77.9%
add-exp-log32.9%
*-commutative32.9%
*-commutative32.9%
Applied egg-rr32.9%
Taylor expanded in phi1 around 0 77.8%
mul-1-neg77.8%
unsub-neg77.8%
associate-*r*77.8%
Simplified77.8%
if 0.00449999999999999966 < phi1 Initial program 72.6%
*-commutative72.6%
associate-*l*72.6%
Simplified72.6%
associate-*r*72.6%
*-commutative72.6%
add-exp-log34.7%
*-commutative34.7%
*-commutative34.7%
Applied egg-rr34.7%
Taylor expanded in phi2 around 0 45.3%
associate-*r*45.3%
neg-mul-145.3%
Simplified45.3%
expm1-log1p-u45.3%
expm1-undefine45.3%
Applied egg-rr45.3%
expm1-define45.3%
Simplified45.3%
Final simplification62.2%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2)))
(t_1 (* (cos phi2) (sin (- lambda1 lambda2)))))
(if (or (<= phi1 -0.00078) (not (<= phi1 0.0017)))
(atan2 t_1 (* (sin phi1) (- t_0)))
(atan2 t_1 (- (sin phi2) (* t_0 (* (cos phi2) phi1)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double t_1 = cos(phi2) * sin((lambda1 - lambda2));
double tmp;
if ((phi1 <= -0.00078) || !(phi1 <= 0.0017)) {
tmp = atan2(t_1, (sin(phi1) * -t_0));
} else {
tmp = atan2(t_1, (sin(phi2) - (t_0 * (cos(phi2) * phi1))));
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: t_1
real(8) :: tmp
t_0 = cos((lambda1 - lambda2))
t_1 = cos(phi2) * sin((lambda1 - lambda2))
if ((phi1 <= (-0.00078d0)) .or. (.not. (phi1 <= 0.0017d0))) then
tmp = atan2(t_1, (sin(phi1) * -t_0))
else
tmp = atan2(t_1, (sin(phi2) - (t_0 * (cos(phi2) * phi1))))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos((lambda1 - lambda2));
double t_1 = Math.cos(phi2) * Math.sin((lambda1 - lambda2));
double tmp;
if ((phi1 <= -0.00078) || !(phi1 <= 0.0017)) {
tmp = Math.atan2(t_1, (Math.sin(phi1) * -t_0));
} else {
tmp = Math.atan2(t_1, (Math.sin(phi2) - (t_0 * (Math.cos(phi2) * phi1))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) t_1 = math.cos(phi2) * math.sin((lambda1 - lambda2)) tmp = 0 if (phi1 <= -0.00078) or not (phi1 <= 0.0017): tmp = math.atan2(t_1, (math.sin(phi1) * -t_0)) else: tmp = math.atan2(t_1, (math.sin(phi2) - (t_0 * (math.cos(phi2) * phi1)))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) t_1 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) tmp = 0.0 if ((phi1 <= -0.00078) || !(phi1 <= 0.0017)) tmp = atan(t_1, Float64(sin(phi1) * Float64(-t_0))); else tmp = atan(t_1, Float64(sin(phi2) - Float64(t_0 * Float64(cos(phi2) * phi1)))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos((lambda1 - lambda2)); t_1 = cos(phi2) * sin((lambda1 - lambda2)); tmp = 0.0; if ((phi1 <= -0.00078) || ~((phi1 <= 0.0017))) tmp = atan2(t_1, (sin(phi1) * -t_0)); else tmp = atan2(t_1, (sin(phi2) - (t_0 * (cos(phi2) * phi1)))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[Or[LessEqual[phi1, -0.00078], N[Not[LessEqual[phi1, 0.0017]], $MachinePrecision]], N[ArcTan[t$95$1 / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / N[(N[Sin[phi2], $MachinePrecision] - N[(t$95$0 * N[(N[Cos[phi2], $MachinePrecision] * phi1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
t_1 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_1 \leq -0.00078 \lor \neg \left(\phi_1 \leq 0.0017\right):\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{\sin \phi_1 \cdot \left(-t\_0\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{\sin \phi_2 - t\_0 \cdot \left(\cos \phi_2 \cdot \phi_1\right)}\\
\end{array}
\end{array}
if phi1 < -7.79999999999999986e-4 or 0.00169999999999999991 < phi1 Initial program 76.5%
*-commutative76.5%
associate-*l*76.5%
Simplified76.5%
associate-*r*76.5%
*-commutative76.5%
add-exp-log34.0%
*-commutative34.0%
*-commutative34.0%
Applied egg-rr34.0%
Taylor expanded in phi2 around 0 45.3%
associate-*r*45.3%
neg-mul-145.3%
Simplified45.3%
if -7.79999999999999986e-4 < phi1 < 0.00169999999999999991Initial program 77.9%
*-commutative77.9%
associate-*l*77.9%
Simplified77.9%
associate-*r*77.9%
*-commutative77.9%
add-exp-log32.9%
*-commutative32.9%
*-commutative32.9%
Applied egg-rr32.9%
Taylor expanded in phi1 around 0 77.8%
mul-1-neg77.8%
unsub-neg77.8%
associate-*r*77.8%
Simplified77.8%
Final simplification62.2%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2))))
(if (or (<= lambda1 -1.3e+29) (not (<= lambda1 36.0)))
(atan2
(* (cos phi2) (- (sin lambda1) (* lambda2 (cos lambda1))))
(* (sin phi1) (- t_0)))
(atan2
(sin (- lambda1 lambda2))
(- (* (cos phi1) (sin phi2)) (* (sin phi1) t_0))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double tmp;
if ((lambda1 <= -1.3e+29) || !(lambda1 <= 36.0)) {
tmp = atan2((cos(phi2) * (sin(lambda1) - (lambda2 * cos(lambda1)))), (sin(phi1) * -t_0));
} else {
tmp = atan2(sin((lambda1 - lambda2)), ((cos(phi1) * sin(phi2)) - (sin(phi1) * 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 = cos((lambda1 - lambda2))
if ((lambda1 <= (-1.3d+29)) .or. (.not. (lambda1 <= 36.0d0))) then
tmp = atan2((cos(phi2) * (sin(lambda1) - (lambda2 * cos(lambda1)))), (sin(phi1) * -t_0))
else
tmp = atan2(sin((lambda1 - lambda2)), ((cos(phi1) * sin(phi2)) - (sin(phi1) * t_0)))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos((lambda1 - lambda2));
double tmp;
if ((lambda1 <= -1.3e+29) || !(lambda1 <= 36.0)) {
tmp = Math.atan2((Math.cos(phi2) * (Math.sin(lambda1) - (lambda2 * Math.cos(lambda1)))), (Math.sin(phi1) * -t_0));
} else {
tmp = Math.atan2(Math.sin((lambda1 - lambda2)), ((Math.cos(phi1) * Math.sin(phi2)) - (Math.sin(phi1) * t_0)));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) tmp = 0 if (lambda1 <= -1.3e+29) or not (lambda1 <= 36.0): tmp = math.atan2((math.cos(phi2) * (math.sin(lambda1) - (lambda2 * math.cos(lambda1)))), (math.sin(phi1) * -t_0)) else: tmp = math.atan2(math.sin((lambda1 - lambda2)), ((math.cos(phi1) * math.sin(phi2)) - (math.sin(phi1) * t_0))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) tmp = 0.0 if ((lambda1 <= -1.3e+29) || !(lambda1 <= 36.0)) tmp = atan(Float64(cos(phi2) * Float64(sin(lambda1) - Float64(lambda2 * cos(lambda1)))), Float64(sin(phi1) * Float64(-t_0))); else tmp = atan(sin(Float64(lambda1 - lambda2)), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(sin(phi1) * t_0))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos((lambda1 - lambda2)); tmp = 0.0; if ((lambda1 <= -1.3e+29) || ~((lambda1 <= 36.0))) tmp = atan2((cos(phi2) * (sin(lambda1) - (lambda2 * cos(lambda1)))), (sin(phi1) * -t_0)); else tmp = atan2(sin((lambda1 - lambda2)), ((cos(phi1) * sin(phi2)) - (sin(phi1) * t_0))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[Or[LessEqual[lambda1, -1.3e+29], N[Not[LessEqual[lambda1, 36.0]], $MachinePrecision]], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] - N[(lambda2 * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\lambda_1 \leq -1.3 \cdot 10^{+29} \lor \neg \left(\lambda_1 \leq 36\right):\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 - \lambda_2 \cdot \cos \lambda_1\right)}{\sin \phi_1 \cdot \left(-t\_0\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \sin \phi_1 \cdot t\_0}\\
\end{array}
\end{array}
if lambda1 < -1.3e29 or 36 < lambda1 Initial program 51.0%
*-commutative51.0%
associate-*l*51.0%
Simplified51.0%
associate-*r*51.0%
*-commutative51.0%
add-exp-log21.7%
*-commutative21.7%
*-commutative21.7%
Applied egg-rr21.7%
Taylor expanded in phi2 around 0 29.3%
associate-*r*29.3%
neg-mul-129.3%
Simplified29.3%
Taylor expanded in lambda2 around 0 37.2%
mul-1-neg37.2%
unsub-neg37.2%
Simplified37.2%
if -1.3e29 < lambda1 < 36Initial program 98.3%
*-commutative98.3%
associate-*l*98.3%
Simplified98.3%
Taylor expanded in phi2 around 0 58.7%
Taylor expanded in phi2 around 0 58.7%
Final simplification49.1%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2))))
(if (or (<= lambda1 -1.4e+31) (not (<= lambda1 0.8)))
(atan2
(* (cos phi2) (- (sin lambda1) (* lambda2 (cos lambda1))))
(* (sin phi1) (- t_0)))
(atan2
(sin (- lambda1 lambda2))
(- (sin phi2) (* (cos phi2) (* (sin phi1) t_0)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double tmp;
if ((lambda1 <= -1.4e+31) || !(lambda1 <= 0.8)) {
tmp = atan2((cos(phi2) * (sin(lambda1) - (lambda2 * cos(lambda1)))), (sin(phi1) * -t_0));
} else {
tmp = atan2(sin((lambda1 - lambda2)), (sin(phi2) - (cos(phi2) * (sin(phi1) * 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 = cos((lambda1 - lambda2))
if ((lambda1 <= (-1.4d+31)) .or. (.not. (lambda1 <= 0.8d0))) then
tmp = atan2((cos(phi2) * (sin(lambda1) - (lambda2 * cos(lambda1)))), (sin(phi1) * -t_0))
else
tmp = atan2(sin((lambda1 - lambda2)), (sin(phi2) - (cos(phi2) * (sin(phi1) * t_0))))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos((lambda1 - lambda2));
double tmp;
if ((lambda1 <= -1.4e+31) || !(lambda1 <= 0.8)) {
tmp = Math.atan2((Math.cos(phi2) * (Math.sin(lambda1) - (lambda2 * Math.cos(lambda1)))), (Math.sin(phi1) * -t_0));
} else {
tmp = Math.atan2(Math.sin((lambda1 - lambda2)), (Math.sin(phi2) - (Math.cos(phi2) * (Math.sin(phi1) * t_0))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) tmp = 0 if (lambda1 <= -1.4e+31) or not (lambda1 <= 0.8): tmp = math.atan2((math.cos(phi2) * (math.sin(lambda1) - (lambda2 * math.cos(lambda1)))), (math.sin(phi1) * -t_0)) else: tmp = math.atan2(math.sin((lambda1 - lambda2)), (math.sin(phi2) - (math.cos(phi2) * (math.sin(phi1) * t_0)))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) tmp = 0.0 if ((lambda1 <= -1.4e+31) || !(lambda1 <= 0.8)) tmp = atan(Float64(cos(phi2) * Float64(sin(lambda1) - Float64(lambda2 * cos(lambda1)))), Float64(sin(phi1) * Float64(-t_0))); else tmp = atan(sin(Float64(lambda1 - lambda2)), Float64(sin(phi2) - Float64(cos(phi2) * Float64(sin(phi1) * t_0)))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos((lambda1 - lambda2)); tmp = 0.0; if ((lambda1 <= -1.4e+31) || ~((lambda1 <= 0.8))) tmp = atan2((cos(phi2) * (sin(lambda1) - (lambda2 * cos(lambda1)))), (sin(phi1) * -t_0)); else tmp = atan2(sin((lambda1 - lambda2)), (sin(phi2) - (cos(phi2) * (sin(phi1) * t_0)))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[Or[LessEqual[lambda1, -1.4e+31], N[Not[LessEqual[lambda1, 0.8]], $MachinePrecision]], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] - N[(lambda2 * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\lambda_1 \leq -1.4 \cdot 10^{+31} \lor \neg \left(\lambda_1 \leq 0.8\right):\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \left(\sin \lambda_1 - \lambda_2 \cdot \cos \lambda_1\right)}{\sin \phi_1 \cdot \left(-t\_0\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot t\_0\right)}\\
\end{array}
\end{array}
if lambda1 < -1.40000000000000008e31 or 0.80000000000000004 < lambda1 Initial program 51.0%
*-commutative51.0%
associate-*l*51.0%
Simplified51.0%
associate-*r*51.0%
*-commutative51.0%
add-exp-log21.7%
*-commutative21.7%
*-commutative21.7%
Applied egg-rr21.7%
Taylor expanded in phi2 around 0 29.3%
associate-*r*29.3%
neg-mul-129.3%
Simplified29.3%
Taylor expanded in lambda2 around 0 37.2%
mul-1-neg37.2%
unsub-neg37.2%
Simplified37.2%
if -1.40000000000000008e31 < lambda1 < 0.80000000000000004Initial program 98.3%
*-commutative98.3%
associate-*l*98.3%
Simplified98.3%
Taylor expanded in phi2 around 0 58.7%
Taylor expanded in phi1 around 0 57.3%
Final simplification48.4%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2)))
(t_1 (sin (- lambda2)))
(t_2 (* (sin phi1) (- t_0))))
(if (<= lambda2 -3.9e+30)
(atan2 (+ t_1 (* lambda1 (cos lambda2))) t_2)
(if (<= lambda2 1.1)
(atan2
(sin (- lambda1 lambda2))
(- (sin phi2) (* (cos phi2) (* (sin phi1) t_0))))
(atan2 (* t_1 (cos phi2)) t_2)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double t_1 = sin(-lambda2);
double t_2 = sin(phi1) * -t_0;
double tmp;
if (lambda2 <= -3.9e+30) {
tmp = atan2((t_1 + (lambda1 * cos(lambda2))), t_2);
} else if (lambda2 <= 1.1) {
tmp = atan2(sin((lambda1 - lambda2)), (sin(phi2) - (cos(phi2) * (sin(phi1) * t_0))));
} else {
tmp = atan2((t_1 * cos(phi2)), t_2);
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: t_1
real(8) :: t_2
real(8) :: tmp
t_0 = cos((lambda1 - lambda2))
t_1 = sin(-lambda2)
t_2 = sin(phi1) * -t_0
if (lambda2 <= (-3.9d+30)) then
tmp = atan2((t_1 + (lambda1 * cos(lambda2))), t_2)
else if (lambda2 <= 1.1d0) then
tmp = atan2(sin((lambda1 - lambda2)), (sin(phi2) - (cos(phi2) * (sin(phi1) * t_0))))
else
tmp = atan2((t_1 * cos(phi2)), t_2)
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos((lambda1 - lambda2));
double t_1 = Math.sin(-lambda2);
double t_2 = Math.sin(phi1) * -t_0;
double tmp;
if (lambda2 <= -3.9e+30) {
tmp = Math.atan2((t_1 + (lambda1 * Math.cos(lambda2))), t_2);
} else if (lambda2 <= 1.1) {
tmp = Math.atan2(Math.sin((lambda1 - lambda2)), (Math.sin(phi2) - (Math.cos(phi2) * (Math.sin(phi1) * t_0))));
} else {
tmp = Math.atan2((t_1 * Math.cos(phi2)), t_2);
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) t_1 = math.sin(-lambda2) t_2 = math.sin(phi1) * -t_0 tmp = 0 if lambda2 <= -3.9e+30: tmp = math.atan2((t_1 + (lambda1 * math.cos(lambda2))), t_2) elif lambda2 <= 1.1: tmp = math.atan2(math.sin((lambda1 - lambda2)), (math.sin(phi2) - (math.cos(phi2) * (math.sin(phi1) * t_0)))) else: tmp = math.atan2((t_1 * math.cos(phi2)), t_2) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) t_1 = sin(Float64(-lambda2)) t_2 = Float64(sin(phi1) * Float64(-t_0)) tmp = 0.0 if (lambda2 <= -3.9e+30) tmp = atan(Float64(t_1 + Float64(lambda1 * cos(lambda2))), t_2); elseif (lambda2 <= 1.1) tmp = atan(sin(Float64(lambda1 - lambda2)), Float64(sin(phi2) - Float64(cos(phi2) * Float64(sin(phi1) * t_0)))); else tmp = atan(Float64(t_1 * cos(phi2)), t_2); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos((lambda1 - lambda2)); t_1 = sin(-lambda2); t_2 = sin(phi1) * -t_0; tmp = 0.0; if (lambda2 <= -3.9e+30) tmp = atan2((t_1 + (lambda1 * cos(lambda2))), t_2); elseif (lambda2 <= 1.1) tmp = atan2(sin((lambda1 - lambda2)), (sin(phi2) - (cos(phi2) * (sin(phi1) * t_0)))); else tmp = atan2((t_1 * cos(phi2)), t_2); end tmp_2 = 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[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]}, If[LessEqual[lambda2, -3.9e+30], N[ArcTan[N[(t$95$1 + N[(lambda1 * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / t$95$2], $MachinePrecision], If[LessEqual[lambda2, 1.1], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(t$95$1 * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / t$95$2], $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 := \sin \phi_1 \cdot \left(-t\_0\right)\\
\mathbf{if}\;\lambda_2 \leq -3.9 \cdot 10^{+30}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1 + \lambda_1 \cdot \cos \lambda_2}{t\_2}\\
\mathbf{elif}\;\lambda_2 \leq 1.1:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot t\_0\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1 \cdot \cos \phi_2}{t\_2}\\
\end{array}
\end{array}
if lambda2 < -3.90000000000000011e30Initial program 55.6%
*-commutative55.6%
associate-*l*55.6%
Simplified55.6%
associate-*r*55.6%
*-commutative55.6%
add-exp-log25.7%
*-commutative25.7%
*-commutative25.7%
Applied egg-rr25.7%
Taylor expanded in phi2 around 0 38.2%
associate-*r*38.2%
neg-mul-138.2%
Simplified38.2%
Taylor expanded in phi2 around 0 36.3%
Taylor expanded in lambda1 around 0 45.9%
cos-neg45.9%
Simplified45.9%
if -3.90000000000000011e30 < lambda2 < 1.1000000000000001Initial program 95.9%
*-commutative95.9%
associate-*l*95.9%
Simplified95.9%
Taylor expanded in phi2 around 0 53.6%
Taylor expanded in phi1 around 0 52.3%
if 1.1000000000000001 < lambda2 Initial program 58.4%
*-commutative58.4%
associate-*l*58.5%
Simplified58.5%
associate-*r*58.4%
*-commutative58.4%
add-exp-log22.7%
*-commutative22.7%
*-commutative22.7%
Applied egg-rr22.7%
Taylor expanded in phi2 around 0 36.5%
associate-*r*36.5%
neg-mul-136.5%
Simplified36.5%
Taylor expanded in lambda1 around 0 40.7%
Final simplification48.0%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(if (or (<= lambda2 -17000.0) (not (<= lambda2 2.25e+27)))
(atan2
(* (sin (- lambda2)) (cos phi2))
(* (sin phi1) (- (cos (- lambda1 lambda2)))))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(* (cos lambda1) (- (sin phi1))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((lambda2 <= -17000.0) || !(lambda2 <= 2.25e+27)) {
tmp = atan2((sin(-lambda2) * cos(phi2)), (sin(phi1) * -cos((lambda1 - lambda2))));
} else {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (cos(lambda1) * -sin(phi1)));
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if ((lambda2 <= (-17000.0d0)) .or. (.not. (lambda2 <= 2.25d+27))) then
tmp = atan2((sin(-lambda2) * cos(phi2)), (sin(phi1) * -cos((lambda1 - lambda2))))
else
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (cos(lambda1) * -sin(phi1)))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((lambda2 <= -17000.0) || !(lambda2 <= 2.25e+27)) {
tmp = Math.atan2((Math.sin(-lambda2) * Math.cos(phi2)), (Math.sin(phi1) * -Math.cos((lambda1 - lambda2))));
} else {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), (Math.cos(lambda1) * -Math.sin(phi1)));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): tmp = 0 if (lambda2 <= -17000.0) or not (lambda2 <= 2.25e+27): tmp = math.atan2((math.sin(-lambda2) * math.cos(phi2)), (math.sin(phi1) * -math.cos((lambda1 - lambda2)))) else: tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), (math.cos(lambda1) * -math.sin(phi1))) return tmp
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if ((lambda2 <= -17000.0) || !(lambda2 <= 2.25e+27)) tmp = atan(Float64(sin(Float64(-lambda2)) * cos(phi2)), Float64(sin(phi1) * Float64(-cos(Float64(lambda1 - lambda2))))); else tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(cos(lambda1) * Float64(-sin(phi1)))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) tmp = 0.0; if ((lambda2 <= -17000.0) || ~((lambda2 <= 2.25e+27))) tmp = atan2((sin(-lambda2) * cos(phi2)), (sin(phi1) * -cos((lambda1 - lambda2)))); else tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (cos(lambda1) * -sin(phi1))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := If[Or[LessEqual[lambda2, -17000.0], N[Not[LessEqual[lambda2, 2.25e+27]], $MachinePrecision]], N[ArcTan[N[(N[Sin[(-lambda2)], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision])), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[phi1], $MachinePrecision])), $MachinePrecision]], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\lambda_2 \leq -17000 \lor \neg \left(\lambda_2 \leq 2.25 \cdot 10^{+27}\right):\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) \cdot \cos \phi_2}{\sin \phi_1 \cdot \left(-\cos \left(\lambda_1 - \lambda_2\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \lambda_1 \cdot \left(-\sin \phi_1\right)}\\
\end{array}
\end{array}
if lambda2 < -17000 or 2.25e27 < lambda2 Initial program 55.7%
*-commutative55.7%
associate-*l*55.7%
Simplified55.7%
associate-*r*55.7%
*-commutative55.7%
add-exp-log24.7%
*-commutative24.7%
*-commutative24.7%
Applied egg-rr24.7%
Taylor expanded in phi2 around 0 37.6%
associate-*r*37.6%
neg-mul-137.6%
Simplified37.6%
Taylor expanded in lambda1 around 0 42.1%
if -17000 < lambda2 < 2.25e27Initial program 95.6%
*-commutative95.6%
associate-*l*95.6%
Simplified95.6%
associate-*r*95.6%
*-commutative95.6%
add-exp-log40.9%
*-commutative40.9%
*-commutative40.9%
Applied egg-rr40.9%
Taylor expanded in phi2 around 0 48.4%
associate-*r*48.4%
neg-mul-148.4%
Simplified48.4%
Taylor expanded in lambda2 around 0 48.4%
mul-1-neg48.4%
*-commutative48.4%
distribute-rgt-neg-in48.4%
Simplified48.4%
Final simplification45.5%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(if (or (<= lambda2 -41000.0) (not (<= lambda2 6.5e+63)))
(atan2 (sin (- lambda2)) (* (sin phi1) (- (cos (- lambda1 lambda2)))))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(* (cos lambda1) (- (sin phi1))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((lambda2 <= -41000.0) || !(lambda2 <= 6.5e+63)) {
tmp = atan2(sin(-lambda2), (sin(phi1) * -cos((lambda1 - lambda2))));
} else {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (cos(lambda1) * -sin(phi1)));
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if ((lambda2 <= (-41000.0d0)) .or. (.not. (lambda2 <= 6.5d+63))) then
tmp = atan2(sin(-lambda2), (sin(phi1) * -cos((lambda1 - lambda2))))
else
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (cos(lambda1) * -sin(phi1)))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((lambda2 <= -41000.0) || !(lambda2 <= 6.5e+63)) {
tmp = Math.atan2(Math.sin(-lambda2), (Math.sin(phi1) * -Math.cos((lambda1 - lambda2))));
} else {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), (Math.cos(lambda1) * -Math.sin(phi1)));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): tmp = 0 if (lambda2 <= -41000.0) or not (lambda2 <= 6.5e+63): tmp = math.atan2(math.sin(-lambda2), (math.sin(phi1) * -math.cos((lambda1 - lambda2)))) else: tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), (math.cos(lambda1) * -math.sin(phi1))) return tmp
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if ((lambda2 <= -41000.0) || !(lambda2 <= 6.5e+63)) tmp = atan(sin(Float64(-lambda2)), Float64(sin(phi1) * Float64(-cos(Float64(lambda1 - lambda2))))); else tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(cos(lambda1) * Float64(-sin(phi1)))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) tmp = 0.0; if ((lambda2 <= -41000.0) || ~((lambda2 <= 6.5e+63))) tmp = atan2(sin(-lambda2), (sin(phi1) * -cos((lambda1 - lambda2)))); else tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (cos(lambda1) * -sin(phi1))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := If[Or[LessEqual[lambda2, -41000.0], N[Not[LessEqual[lambda2, 6.5e+63]], $MachinePrecision]], N[ArcTan[N[Sin[(-lambda2)], $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision])), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[phi1], $MachinePrecision])), $MachinePrecision]], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\lambda_2 \leq -41000 \lor \neg \left(\lambda_2 \leq 6.5 \cdot 10^{+63}\right):\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{\sin \phi_1 \cdot \left(-\cos \left(\lambda_1 - \lambda_2\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \lambda_1 \cdot \left(-\sin \phi_1\right)}\\
\end{array}
\end{array}
if lambda2 < -41000 or 6.49999999999999992e63 < lambda2 Initial program 56.8%
*-commutative56.8%
associate-*l*56.9%
Simplified56.9%
associate-*r*56.8%
*-commutative56.8%
add-exp-log26.0%
*-commutative26.0%
*-commutative26.0%
Applied egg-rr26.0%
Taylor expanded in phi2 around 0 39.2%
associate-*r*39.2%
neg-mul-139.2%
Simplified39.2%
Taylor expanded in phi2 around 0 37.5%
Taylor expanded in lambda1 around 0 41.9%
if -41000 < lambda2 < 6.49999999999999992e63Initial program 93.1%
*-commutative93.1%
associate-*l*93.1%
Simplified93.1%
associate-*r*93.1%
*-commutative93.1%
add-exp-log39.2%
*-commutative39.2%
*-commutative39.2%
Applied egg-rr39.2%
Taylor expanded in phi2 around 0 46.7%
associate-*r*46.7%
neg-mul-146.7%
Simplified46.7%
Taylor expanded in lambda2 around 0 46.7%
mul-1-neg46.7%
*-commutative46.7%
distribute-rgt-neg-in46.7%
Simplified46.7%
Final simplification44.6%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (sin phi1) (- (cos (- lambda1 lambda2))))))
(if (<= lambda2 -6.6e+28)
(atan2 (+ (sin (- lambda2)) (* lambda1 (cos lambda2))) t_0)
(atan2 (* (cos phi2) (sin (- lambda1 lambda2))) t_0))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = sin(phi1) * -cos((lambda1 - lambda2));
double tmp;
if (lambda2 <= -6.6e+28) {
tmp = atan2((sin(-lambda2) + (lambda1 * cos(lambda2))), t_0);
} else {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), t_0);
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: tmp
t_0 = sin(phi1) * -cos((lambda1 - lambda2))
if (lambda2 <= (-6.6d+28)) then
tmp = atan2((sin(-lambda2) + (lambda1 * cos(lambda2))), t_0)
else
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), t_0)
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.sin(phi1) * -Math.cos((lambda1 - lambda2));
double tmp;
if (lambda2 <= -6.6e+28) {
tmp = Math.atan2((Math.sin(-lambda2) + (lambda1 * Math.cos(lambda2))), t_0);
} else {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), t_0);
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.sin(phi1) * -math.cos((lambda1 - lambda2)) tmp = 0 if lambda2 <= -6.6e+28: tmp = math.atan2((math.sin(-lambda2) + (lambda1 * math.cos(lambda2))), t_0) else: tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), t_0) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(sin(phi1) * Float64(-cos(Float64(lambda1 - lambda2)))) tmp = 0.0 if (lambda2 <= -6.6e+28) tmp = atan(Float64(sin(Float64(-lambda2)) + Float64(lambda1 * cos(lambda2))), t_0); else tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), t_0); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = sin(phi1) * -cos((lambda1 - lambda2)); tmp = 0.0; if (lambda2 <= -6.6e+28) tmp = atan2((sin(-lambda2) + (lambda1 * cos(lambda2))), t_0); else tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), t_0); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision])), $MachinePrecision]}, If[LessEqual[lambda2, -6.6e+28], N[ArcTan[N[(N[Sin[(-lambda2)], $MachinePrecision] + N[(lambda1 * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / t$95$0], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / t$95$0], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \sin \phi_1 \cdot \left(-\cos \left(\lambda_1 - \lambda_2\right)\right)\\
\mathbf{if}\;\lambda_2 \leq -6.6 \cdot 10^{+28}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right) + \lambda_1 \cdot \cos \lambda_2}{t\_0}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t\_0}\\
\end{array}
\end{array}
if lambda2 < -6.6e28Initial program 55.6%
*-commutative55.6%
associate-*l*55.6%
Simplified55.6%
associate-*r*55.6%
*-commutative55.6%
add-exp-log25.7%
*-commutative25.7%
*-commutative25.7%
Applied egg-rr25.7%
Taylor expanded in phi2 around 0 38.2%
associate-*r*38.2%
neg-mul-138.2%
Simplified38.2%
Taylor expanded in phi2 around 0 36.3%
Taylor expanded in lambda1 around 0 45.9%
cos-neg45.9%
Simplified45.9%
if -6.6e28 < lambda2 Initial program 84.3%
*-commutative84.3%
associate-*l*84.3%
Simplified84.3%
associate-*r*84.3%
*-commutative84.3%
add-exp-log35.9%
*-commutative35.9%
*-commutative35.9%
Applied egg-rr35.9%
Taylor expanded in phi2 around 0 45.1%
associate-*r*45.1%
neg-mul-145.1%
Simplified45.1%
Final simplification45.3%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(if (<= lambda1 -0.003)
(atan2
(* (sin lambda1) (cos phi2))
(* (sin phi1) (- (cos (- lambda1 lambda2)))))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(* (sin phi1) (- (cos lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda1 <= -0.003) {
tmp = atan2((sin(lambda1) * cos(phi2)), (sin(phi1) * -cos((lambda1 - lambda2))));
} else {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (sin(phi1) * -cos(lambda2)));
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (lambda1 <= (-0.003d0)) then
tmp = atan2((sin(lambda1) * cos(phi2)), (sin(phi1) * -cos((lambda1 - lambda2))))
else
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (sin(phi1) * -cos(lambda2)))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda1 <= -0.003) {
tmp = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (Math.sin(phi1) * -Math.cos((lambda1 - lambda2))));
} else {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), (Math.sin(phi1) * -Math.cos(lambda2)));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): tmp = 0 if lambda1 <= -0.003: tmp = math.atan2((math.sin(lambda1) * math.cos(phi2)), (math.sin(phi1) * -math.cos((lambda1 - lambda2)))) else: tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), (math.sin(phi1) * -math.cos(lambda2))) return tmp
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if (lambda1 <= -0.003) tmp = atan(Float64(sin(lambda1) * cos(phi2)), Float64(sin(phi1) * Float64(-cos(Float64(lambda1 - lambda2))))); else tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(sin(phi1) * Float64(-cos(lambda2)))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) tmp = 0.0; if (lambda1 <= -0.003) tmp = atan2((sin(lambda1) * cos(phi2)), (sin(phi1) * -cos((lambda1 - lambda2)))); else tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (sin(phi1) * -cos(lambda2))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[lambda1, -0.003], N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision])), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[lambda2], $MachinePrecision])), $MachinePrecision]], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\lambda_1 \leq -0.003:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_1 \cdot \left(-\cos \left(\lambda_1 - \lambda_2\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_1 \cdot \left(-\cos \lambda_2\right)}\\
\end{array}
\end{array}
if lambda1 < -0.0030000000000000001Initial program 60.4%
*-commutative60.4%
associate-*l*60.5%
Simplified60.5%
associate-*r*60.4%
*-commutative60.4%
add-exp-log24.3%
*-commutative24.3%
*-commutative24.3%
Applied egg-rr24.3%
Taylor expanded in phi2 around 0 34.7%
associate-*r*34.7%
neg-mul-134.7%
Simplified34.7%
Taylor expanded in lambda2 around 0 37.3%
if -0.0030000000000000001 < lambda1 Initial program 83.8%
*-commutative83.8%
associate-*l*83.8%
Simplified83.8%
associate-*r*83.8%
*-commutative83.8%
add-exp-log37.0%
*-commutative37.0%
*-commutative37.0%
Applied egg-rr37.0%
Taylor expanded in phi2 around 0 46.8%
associate-*r*46.8%
neg-mul-146.8%
Simplified46.8%
Taylor expanded in lambda1 around 0 45.7%
mul-1-neg45.7%
cos-neg45.7%
*-commutative45.7%
distribute-rgt-neg-in45.7%
Simplified45.7%
Final simplification43.3%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (cos phi2) (sin (- lambda1 lambda2))) (* (sin phi1) (- (cos (- lambda1 lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((cos(phi2) * sin((lambda1 - lambda2))), (sin(phi1) * -cos((lambda1 - lambda2))));
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
code = atan2((cos(phi2) * sin((lambda1 - lambda2))), (sin(phi1) * -cos((lambda1 - lambda2))))
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(phi1) * -Math.cos((lambda1 - lambda2))));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), (math.sin(phi1) * -math.cos((lambda1 - lambda2))))
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(sin(phi1) * Float64(-cos(Float64(lambda1 - lambda2))))) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (sin(phi1) * -cos((lambda1 - lambda2)))); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision])), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_1 \cdot \left(-\cos \left(\lambda_1 - \lambda_2\right)\right)}
\end{array}
Initial program 77.2%
*-commutative77.2%
associate-*l*77.2%
Simplified77.2%
associate-*r*77.2%
*-commutative77.2%
add-exp-log33.4%
*-commutative33.4%
*-commutative33.4%
Applied egg-rr33.4%
Taylor expanded in phi2 around 0 43.4%
associate-*r*43.4%
neg-mul-143.4%
Simplified43.4%
Final simplification43.4%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (if (or (<= lambda2 -2.25e-17) (not (<= lambda2 1.2e+27))) (atan2 (sin (- lambda2)) (* (sin phi1) (- (cos (- lambda1 lambda2))))) (atan2 (sin (- lambda1 lambda2)) (* (cos lambda1) (- (sin phi1))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((lambda2 <= -2.25e-17) || !(lambda2 <= 1.2e+27)) {
tmp = atan2(sin(-lambda2), (sin(phi1) * -cos((lambda1 - lambda2))));
} else {
tmp = atan2(sin((lambda1 - lambda2)), (cos(lambda1) * -sin(phi1)));
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if ((lambda2 <= (-2.25d-17)) .or. (.not. (lambda2 <= 1.2d+27))) then
tmp = atan2(sin(-lambda2), (sin(phi1) * -cos((lambda1 - lambda2))))
else
tmp = atan2(sin((lambda1 - lambda2)), (cos(lambda1) * -sin(phi1)))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((lambda2 <= -2.25e-17) || !(lambda2 <= 1.2e+27)) {
tmp = Math.atan2(Math.sin(-lambda2), (Math.sin(phi1) * -Math.cos((lambda1 - lambda2))));
} else {
tmp = Math.atan2(Math.sin((lambda1 - lambda2)), (Math.cos(lambda1) * -Math.sin(phi1)));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): tmp = 0 if (lambda2 <= -2.25e-17) or not (lambda2 <= 1.2e+27): tmp = math.atan2(math.sin(-lambda2), (math.sin(phi1) * -math.cos((lambda1 - lambda2)))) else: tmp = math.atan2(math.sin((lambda1 - lambda2)), (math.cos(lambda1) * -math.sin(phi1))) return tmp
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if ((lambda2 <= -2.25e-17) || !(lambda2 <= 1.2e+27)) tmp = atan(sin(Float64(-lambda2)), Float64(sin(phi1) * Float64(-cos(Float64(lambda1 - lambda2))))); else tmp = atan(sin(Float64(lambda1 - lambda2)), Float64(cos(lambda1) * Float64(-sin(phi1)))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) tmp = 0.0; if ((lambda2 <= -2.25e-17) || ~((lambda2 <= 1.2e+27))) tmp = atan2(sin(-lambda2), (sin(phi1) * -cos((lambda1 - lambda2)))); else tmp = atan2(sin((lambda1 - lambda2)), (cos(lambda1) * -sin(phi1))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := If[Or[LessEqual[lambda2, -2.25e-17], N[Not[LessEqual[lambda2, 1.2e+27]], $MachinePrecision]], N[ArcTan[N[Sin[(-lambda2)], $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision])), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[phi1], $MachinePrecision])), $MachinePrecision]], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\lambda_2 \leq -2.25 \cdot 10^{-17} \lor \neg \left(\lambda_2 \leq 1.2 \cdot 10^{+27}\right):\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{\sin \phi_1 \cdot \left(-\cos \left(\lambda_1 - \lambda_2\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \lambda_1 \cdot \left(-\sin \phi_1\right)}\\
\end{array}
\end{array}
if lambda2 < -2.24999999999999989e-17 or 1.19999999999999999e27 < lambda2 Initial program 56.6%
*-commutative56.6%
associate-*l*56.6%
Simplified56.6%
associate-*r*56.6%
*-commutative56.6%
add-exp-log25.5%
*-commutative25.5%
*-commutative25.5%
Applied egg-rr25.5%
Taylor expanded in phi2 around 0 37.9%
associate-*r*37.9%
neg-mul-137.9%
Simplified37.9%
Taylor expanded in phi2 around 0 35.6%
Taylor expanded in lambda1 around 0 39.9%
if -2.24999999999999989e-17 < lambda2 < 1.19999999999999999e27Initial program 96.6%
*-commutative96.6%
associate-*l*96.6%
Simplified96.6%
associate-*r*96.6%
*-commutative96.6%
add-exp-log40.8%
*-commutative40.8%
*-commutative40.8%
Applied egg-rr40.8%
Taylor expanded in phi2 around 0 48.6%
associate-*r*48.6%
neg-mul-148.6%
Simplified48.6%
Taylor expanded in phi2 around 0 44.9%
Taylor expanded in lambda2 around 0 44.9%
mul-1-neg48.6%
*-commutative48.6%
distribute-rgt-neg-in48.6%
Simplified44.9%
Final simplification42.5%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2))))
(if (or (<= lambda1 -9e-51) (not (<= lambda1 1.2e-180)))
(atan2 (sin lambda1) (* (sin phi1) (- t_0)))
(atan2 (sin (- lambda1 lambda2)) (* t_0 (- phi1))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double tmp;
if ((lambda1 <= -9e-51) || !(lambda1 <= 1.2e-180)) {
tmp = atan2(sin(lambda1), (sin(phi1) * -t_0));
} else {
tmp = atan2(sin((lambda1 - lambda2)), (t_0 * -phi1));
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: tmp
t_0 = cos((lambda1 - lambda2))
if ((lambda1 <= (-9d-51)) .or. (.not. (lambda1 <= 1.2d-180))) then
tmp = atan2(sin(lambda1), (sin(phi1) * -t_0))
else
tmp = atan2(sin((lambda1 - lambda2)), (t_0 * -phi1))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos((lambda1 - lambda2));
double tmp;
if ((lambda1 <= -9e-51) || !(lambda1 <= 1.2e-180)) {
tmp = Math.atan2(Math.sin(lambda1), (Math.sin(phi1) * -t_0));
} else {
tmp = Math.atan2(Math.sin((lambda1 - lambda2)), (t_0 * -phi1));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) tmp = 0 if (lambda1 <= -9e-51) or not (lambda1 <= 1.2e-180): tmp = math.atan2(math.sin(lambda1), (math.sin(phi1) * -t_0)) else: tmp = math.atan2(math.sin((lambda1 - lambda2)), (t_0 * -phi1)) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) tmp = 0.0 if ((lambda1 <= -9e-51) || !(lambda1 <= 1.2e-180)) tmp = atan(sin(lambda1), Float64(sin(phi1) * Float64(-t_0))); else tmp = atan(sin(Float64(lambda1 - lambda2)), Float64(t_0 * Float64(-phi1))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos((lambda1 - lambda2)); tmp = 0.0; if ((lambda1 <= -9e-51) || ~((lambda1 <= 1.2e-180))) tmp = atan2(sin(lambda1), (sin(phi1) * -t_0)); else tmp = atan2(sin((lambda1 - lambda2)), (t_0 * -phi1)); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[Or[LessEqual[lambda1, -9e-51], N[Not[LessEqual[lambda1, 1.2e-180]], $MachinePrecision]], N[ArcTan[N[Sin[lambda1], $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(t$95$0 * (-phi1)), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\lambda_1 \leq -9 \cdot 10^{-51} \lor \neg \left(\lambda_1 \leq 1.2 \cdot 10^{-180}\right):\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1}{\sin \phi_1 \cdot \left(-t\_0\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{t\_0 \cdot \left(-\phi_1\right)}\\
\end{array}
\end{array}
if lambda1 < -8.99999999999999948e-51 or 1.1999999999999999e-180 < lambda1 Initial program 67.5%
*-commutative67.5%
associate-*l*67.5%
Simplified67.5%
associate-*r*67.5%
*-commutative67.5%
add-exp-log29.4%
*-commutative29.4%
*-commutative29.4%
Applied egg-rr29.4%
Taylor expanded in phi2 around 0 38.8%
associate-*r*38.8%
neg-mul-138.8%
Simplified38.8%
Taylor expanded in phi2 around 0 35.8%
Taylor expanded in lambda2 around 0 33.4%
if -8.99999999999999948e-51 < lambda1 < 1.1999999999999999e-180Initial program 99.8%
*-commutative99.8%
associate-*l*99.8%
Simplified99.8%
associate-*r*99.8%
*-commutative99.8%
add-exp-log42.7%
*-commutative42.7%
*-commutative42.7%
Applied egg-rr42.7%
Taylor expanded in phi2 around 0 54.1%
associate-*r*54.1%
neg-mul-154.1%
Simplified54.1%
Taylor expanded in phi2 around 0 51.2%
Taylor expanded in phi1 around 0 32.6%
mul-1-neg36.3%
*-commutative36.3%
distribute-rgt-neg-in36.3%
Simplified32.6%
Final simplification33.2%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2))) (t_1 (sin (- lambda1 lambda2))))
(if (<= phi2 -3.1e+118)
(atan2 (* (cos phi2) t_1) (* t_0 (- phi1)))
(atan2 t_1 (* (sin phi1) (- t_0))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos((lambda1 - lambda2));
double t_1 = sin((lambda1 - lambda2));
double tmp;
if (phi2 <= -3.1e+118) {
tmp = atan2((cos(phi2) * t_1), (t_0 * -phi1));
} else {
tmp = atan2(t_1, (sin(phi1) * -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) :: t_1
real(8) :: tmp
t_0 = cos((lambda1 - lambda2))
t_1 = sin((lambda1 - lambda2))
if (phi2 <= (-3.1d+118)) then
tmp = atan2((cos(phi2) * t_1), (t_0 * -phi1))
else
tmp = atan2(t_1, (sin(phi1) * -t_0))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos((lambda1 - lambda2));
double t_1 = Math.sin((lambda1 - lambda2));
double tmp;
if (phi2 <= -3.1e+118) {
tmp = Math.atan2((Math.cos(phi2) * t_1), (t_0 * -phi1));
} else {
tmp = Math.atan2(t_1, (Math.sin(phi1) * -t_0));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) t_1 = math.sin((lambda1 - lambda2)) tmp = 0 if phi2 <= -3.1e+118: tmp = math.atan2((math.cos(phi2) * t_1), (t_0 * -phi1)) else: tmp = math.atan2(t_1, (math.sin(phi1) * -t_0)) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = cos(Float64(lambda1 - lambda2)) t_1 = sin(Float64(lambda1 - lambda2)) tmp = 0.0 if (phi2 <= -3.1e+118) tmp = atan(Float64(cos(phi2) * t_1), Float64(t_0 * Float64(-phi1))); else tmp = atan(t_1, Float64(sin(phi1) * Float64(-t_0))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos((lambda1 - lambda2)); t_1 = sin((lambda1 - lambda2)); tmp = 0.0; if (phi2 <= -3.1e+118) tmp = atan2((cos(phi2) * t_1), (t_0 * -phi1)); else tmp = atan2(t_1, (sin(phi1) * -t_0)); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[phi2, -3.1e+118], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * t$95$1), $MachinePrecision] / N[(t$95$0 * (-phi1)), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \left(\lambda_1 - \lambda_2\right)\\
t_1 := \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq -3.1 \cdot 10^{+118}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot t\_1}{t\_0 \cdot \left(-\phi_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{\sin \phi_1 \cdot \left(-t\_0\right)}\\
\end{array}
\end{array}
if phi2 < -3.09999999999999986e118Initial program 80.3%
*-commutative80.3%
associate-*l*80.3%
Simplified80.3%
associate-*r*80.3%
*-commutative80.3%
add-exp-log43.7%
*-commutative43.7%
*-commutative43.7%
Applied egg-rr43.7%
Taylor expanded in phi2 around 0 16.3%
associate-*r*16.3%
neg-mul-116.3%
Simplified16.3%
Taylor expanded in phi1 around 0 17.1%
mul-1-neg17.1%
*-commutative17.1%
distribute-rgt-neg-in17.1%
Simplified17.1%
if -3.09999999999999986e118 < phi2 Initial program 76.6%
*-commutative76.6%
associate-*l*76.6%
Simplified76.6%
associate-*r*76.6%
*-commutative76.6%
add-exp-log31.4%
*-commutative31.4%
*-commutative31.4%
Applied egg-rr31.4%
Taylor expanded in phi2 around 0 48.9%
associate-*r*48.9%
neg-mul-148.9%
Simplified48.9%
Taylor expanded in phi2 around 0 47.1%
Final simplification42.0%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (sin phi1) (- (cos (- lambda1 lambda2))))))
(if (<= lambda1 4e+144)
(atan2 (sin (- lambda1 lambda2)) t_0)
(atan2 (sin (- lambda2)) t_0))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = sin(phi1) * -cos((lambda1 - lambda2));
double tmp;
if (lambda1 <= 4e+144) {
tmp = atan2(sin((lambda1 - lambda2)), t_0);
} else {
tmp = atan2(sin(-lambda2), t_0);
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: tmp
t_0 = sin(phi1) * -cos((lambda1 - lambda2))
if (lambda1 <= 4d+144) then
tmp = atan2(sin((lambda1 - lambda2)), t_0)
else
tmp = atan2(sin(-lambda2), t_0)
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.sin(phi1) * -Math.cos((lambda1 - lambda2));
double tmp;
if (lambda1 <= 4e+144) {
tmp = Math.atan2(Math.sin((lambda1 - lambda2)), t_0);
} else {
tmp = Math.atan2(Math.sin(-lambda2), t_0);
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.sin(phi1) * -math.cos((lambda1 - lambda2)) tmp = 0 if lambda1 <= 4e+144: tmp = math.atan2(math.sin((lambda1 - lambda2)), t_0) else: tmp = math.atan2(math.sin(-lambda2), t_0) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(sin(phi1) * Float64(-cos(Float64(lambda1 - lambda2)))) tmp = 0.0 if (lambda1 <= 4e+144) tmp = atan(sin(Float64(lambda1 - lambda2)), t_0); else tmp = atan(sin(Float64(-lambda2)), t_0); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = sin(phi1) * -cos((lambda1 - lambda2)); tmp = 0.0; if (lambda1 <= 4e+144) tmp = atan2(sin((lambda1 - lambda2)), t_0); else tmp = atan2(sin(-lambda2), t_0); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision])), $MachinePrecision]}, If[LessEqual[lambda1, 4e+144], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / t$95$0], $MachinePrecision], N[ArcTan[N[Sin[(-lambda2)], $MachinePrecision] / t$95$0], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \sin \phi_1 \cdot \left(-\cos \left(\lambda_1 - \lambda_2\right)\right)\\
\mathbf{if}\;\lambda_1 \leq 4 \cdot 10^{+144}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{t\_0}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(-\lambda_2\right)}{t\_0}\\
\end{array}
\end{array}
if lambda1 < 4.00000000000000009e144Initial program 80.7%
*-commutative80.7%
associate-*l*80.8%
Simplified80.8%
associate-*r*80.7%
*-commutative80.7%
add-exp-log35.4%
*-commutative35.4%
*-commutative35.4%
Applied egg-rr35.4%
Taylor expanded in phi2 around 0 46.2%
associate-*r*46.2%
neg-mul-146.2%
Simplified46.2%
Taylor expanded in phi2 around 0 43.3%
if 4.00000000000000009e144 < lambda1 Initial program 41.7%
*-commutative41.7%
associate-*l*41.7%
Simplified41.7%
associate-*r*41.7%
*-commutative41.7%
add-exp-log13.6%
*-commutative13.6%
*-commutative13.6%
Applied egg-rr13.6%
Taylor expanded in phi2 around 0 14.9%
associate-*r*14.9%
neg-mul-114.9%
Simplified14.9%
Taylor expanded in phi2 around 0 11.2%
Taylor expanded in lambda1 around 0 28.6%
Final simplification42.0%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (if (<= lambda1 -0.0026) (atan2 (sin lambda1) (* (sin phi1) (- (cos (- lambda1 lambda2))))) (atan2 (sin (- lambda1 lambda2)) (* (sin phi1) (- (cos lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda1 <= -0.0026) {
tmp = atan2(sin(lambda1), (sin(phi1) * -cos((lambda1 - lambda2))));
} else {
tmp = atan2(sin((lambda1 - lambda2)), (sin(phi1) * -cos(lambda2)));
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (lambda1 <= (-0.0026d0)) then
tmp = atan2(sin(lambda1), (sin(phi1) * -cos((lambda1 - lambda2))))
else
tmp = atan2(sin((lambda1 - lambda2)), (sin(phi1) * -cos(lambda2)))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda1 <= -0.0026) {
tmp = Math.atan2(Math.sin(lambda1), (Math.sin(phi1) * -Math.cos((lambda1 - lambda2))));
} else {
tmp = Math.atan2(Math.sin((lambda1 - lambda2)), (Math.sin(phi1) * -Math.cos(lambda2)));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): tmp = 0 if lambda1 <= -0.0026: tmp = math.atan2(math.sin(lambda1), (math.sin(phi1) * -math.cos((lambda1 - lambda2)))) else: tmp = math.atan2(math.sin((lambda1 - lambda2)), (math.sin(phi1) * -math.cos(lambda2))) return tmp
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if (lambda1 <= -0.0026) tmp = atan(sin(lambda1), Float64(sin(phi1) * Float64(-cos(Float64(lambda1 - lambda2))))); else tmp = atan(sin(Float64(lambda1 - lambda2)), Float64(sin(phi1) * Float64(-cos(lambda2)))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) tmp = 0.0; if (lambda1 <= -0.0026) tmp = atan2(sin(lambda1), (sin(phi1) * -cos((lambda1 - lambda2)))); else tmp = atan2(sin((lambda1 - lambda2)), (sin(phi1) * -cos(lambda2))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[lambda1, -0.0026], N[ArcTan[N[Sin[lambda1], $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision])), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[lambda2], $MachinePrecision])), $MachinePrecision]], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\lambda_1 \leq -0.0026:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1}{\sin \phi_1 \cdot \left(-\cos \left(\lambda_1 - \lambda_2\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_1 \cdot \left(-\cos \lambda_2\right)}\\
\end{array}
\end{array}
if lambda1 < -0.0025999999999999999Initial program 60.4%
*-commutative60.4%
associate-*l*60.5%
Simplified60.5%
associate-*r*60.4%
*-commutative60.4%
add-exp-log24.3%
*-commutative24.3%
*-commutative24.3%
Applied egg-rr24.3%
Taylor expanded in phi2 around 0 34.7%
associate-*r*34.7%
neg-mul-134.7%
Simplified34.7%
Taylor expanded in phi2 around 0 32.0%
Taylor expanded in lambda2 around 0 35.1%
if -0.0025999999999999999 < lambda1 Initial program 83.8%
*-commutative83.8%
associate-*l*83.8%
Simplified83.8%
associate-*r*83.8%
*-commutative83.8%
add-exp-log37.0%
*-commutative37.0%
*-commutative37.0%
Applied egg-rr37.0%
Taylor expanded in phi2 around 0 46.8%
associate-*r*46.8%
neg-mul-146.8%
Simplified46.8%
Taylor expanded in phi2 around 0 43.7%
Taylor expanded in lambda1 around 0 42.5%
mul-1-neg45.7%
cos-neg45.7%
*-commutative45.7%
distribute-rgt-neg-in45.7%
Simplified42.5%
Final simplification40.4%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (sin (- lambda1 lambda2)) (* (cos lambda1) (- (sin phi1)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2(sin((lambda1 - lambda2)), (cos(lambda1) * -sin(phi1)));
}
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(lambda1) * -sin(phi1)))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
return Math.atan2(Math.sin((lambda1 - lambda2)), (Math.cos(lambda1) * -Math.sin(phi1)));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2(math.sin((lambda1 - lambda2)), (math.cos(lambda1) * -math.sin(phi1)))
function code(lambda1, lambda2, phi1, phi2) return atan(sin(Float64(lambda1 - lambda2)), Float64(cos(lambda1) * Float64(-sin(phi1)))) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2(sin((lambda1 - lambda2)), (cos(lambda1) * -sin(phi1))); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[phi1], $MachinePrecision])), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \lambda_1 \cdot \left(-\sin \phi_1\right)}
\end{array}
Initial program 77.2%
*-commutative77.2%
associate-*l*77.2%
Simplified77.2%
associate-*r*77.2%
*-commutative77.2%
add-exp-log33.4%
*-commutative33.4%
*-commutative33.4%
Applied egg-rr33.4%
Taylor expanded in phi2 around 0 43.4%
associate-*r*43.4%
neg-mul-143.4%
Simplified43.4%
Taylor expanded in phi2 around 0 40.4%
Taylor expanded in lambda2 around 0 35.5%
mul-1-neg38.6%
*-commutative38.6%
distribute-rgt-neg-in38.6%
Simplified35.5%
Final simplification35.5%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (sin (- lambda1 lambda2)) (* (cos (- lambda1 lambda2)) (- phi1))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2(sin((lambda1 - lambda2)), (cos((lambda1 - lambda2)) * -phi1));
}
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((lambda1 - lambda2)) * -phi1))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
return Math.atan2(Math.sin((lambda1 - lambda2)), (Math.cos((lambda1 - lambda2)) * -phi1));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2(math.sin((lambda1 - lambda2)), (math.cos((lambda1 - lambda2)) * -phi1))
function code(lambda1, lambda2, phi1, phi2) return atan(sin(Float64(lambda1 - lambda2)), Float64(cos(Float64(lambda1 - lambda2)) * Float64(-phi1))) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2(sin((lambda1 - lambda2)), (cos((lambda1 - lambda2)) * -phi1)); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] / N[(N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * (-phi1)), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\sin \left(\lambda_1 - \lambda_2\right)}{\cos \left(\lambda_1 - \lambda_2\right) \cdot \left(-\phi_1\right)}
\end{array}
Initial program 77.2%
*-commutative77.2%
associate-*l*77.2%
Simplified77.2%
associate-*r*77.2%
*-commutative77.2%
add-exp-log33.4%
*-commutative33.4%
*-commutative33.4%
Applied egg-rr33.4%
Taylor expanded in phi2 around 0 43.4%
associate-*r*43.4%
neg-mul-143.4%
Simplified43.4%
Taylor expanded in phi2 around 0 40.4%
Taylor expanded in phi1 around 0 25.9%
mul-1-neg28.7%
*-commutative28.7%
distribute-rgt-neg-in28.7%
Simplified25.9%
herbie shell --seed 2024148
(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))))))