
(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 31 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)
(- (log1p (expm1 (* (cos lambda1) (sin lambda2))))))
(cos phi2))
(-
(* (cos phi1) (sin phi2))
(*
(* (cos phi2) (sin phi1))
(fma (cos lambda2) (cos lambda1) (* (sin lambda1) (sin lambda2)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((fma(sin(lambda1), cos(lambda2), -log1p(expm1((cos(lambda1) * sin(lambda2))))) * cos(phi2)), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * fma(cos(lambda2), cos(lambda1), (sin(lambda1) * sin(lambda2))))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(fma(sin(lambda1), cos(lambda2), Float64(-log1p(expm1(Float64(cos(lambda1) * sin(lambda2)))))) * cos(phi2)), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * fma(cos(lambda2), cos(lambda1), Float64(sin(lambda1) * sin(lambda2)))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + (-N[Log[1 + N[(Exp[N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]] - 1), $MachinePrecision]], $MachinePrecision])), $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, -\mathsf{log1p}\left(\mathsf{expm1}\left(\cos \lambda_1 \cdot \sin \lambda_2\right)\right)\right) \cdot \cos \phi_2}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \sin \lambda_2\right)}
\end{array}
Initial program 78.9%
sin-diff89.3%
fma-neg89.3%
Applied egg-rr89.3%
cos-diff99.7%
*-commutative99.7%
Applied egg-rr99.7%
fma-define99.7%
Simplified99.7%
log1p-expm1-u99.7%
Applied egg-rr99.7%
Final simplification99.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))
(fma (cos lambda2) (cos lambda1) (* (sin lambda1) (sin 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)) * fma(cos(lambda2), cos(lambda1), (sin(lambda1) * sin(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)) * fma(cos(lambda2), cos(lambda1), Float64(sin(lambda1) * sin(lambda2)))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[(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[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \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 \mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \sin \lambda_2\right)}
\end{array}
Initial program 78.9%
sin-diff89.3%
fma-neg89.3%
Applied egg-rr89.3%
cos-diff99.7%
*-commutative99.7%
Applied egg-rr99.7%
fma-define99.7%
Simplified99.7%
fma-neg99.7%
Applied egg-rr99.7%
Final simplification99.7%
(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_2 (cos (- lambda1 lambda2)))))
(if (<= phi2 -2.5e-6)
(atan2
(*
(cos phi2)
(fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2)))))
(- (log1p (expm1 t_1)) t_3))
(if (<= phi2 3.35e-28)
(atan2
t_0
(-
t_1
(*
t_2
(fma (cos lambda2) (cos lambda1) (* (sin lambda1) (sin lambda2))))))
(atan2 (* (cos phi2) t_0) (- t_1 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_2 * cos((lambda1 - lambda2));
double tmp;
if (phi2 <= -2.5e-6) {
tmp = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), (log1p(expm1(t_1)) - t_3));
} else if (phi2 <= 3.35e-28) {
tmp = atan2(t_0, (t_1 - (t_2 * fma(cos(lambda2), cos(lambda1), (sin(lambda1) * sin(lambda2))))));
} else {
tmp = atan2((cos(phi2) * t_0), (t_1 - 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_2 * cos(Float64(lambda1 - lambda2))) tmp = 0.0 if (phi2 <= -2.5e-6) tmp = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(log1p(expm1(t_1)) - t_3)); elseif (phi2 <= 3.35e-28) tmp = atan(t_0, Float64(t_1 - Float64(t_2 * fma(cos(lambda2), cos(lambda1), Float64(sin(lambda1) * sin(lambda2)))))); else tmp = atan(Float64(cos(phi2) * t_0), Float64(t_1 - 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$2 * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[phi2, -2.5e-6], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Log[1 + N[(Exp[t$95$1] - 1), $MachinePrecision]], $MachinePrecision] - t$95$3), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi2, 3.35e-28], N[ArcTan[t$95$0 / N[(t$95$1 - N[(t$95$2 * N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * t$95$0), $MachinePrecision] / N[(t$95$1 - t$95$3), $MachinePrecision]], $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\_2 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq -2.5 \cdot 10^{-6}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\mathsf{log1p}\left(\mathsf{expm1}\left(t\_1\right)\right) - t\_3}\\
\mathbf{elif}\;\phi_2 \leq 3.35 \cdot 10^{-28}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{t\_1 - t\_2 \cdot \mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \sin \lambda_2\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot t\_0}{t\_1 - t\_3}\\
\end{array}
\end{array}
if phi2 < -2.5000000000000002e-6Initial program 73.4%
sin-diff86.6%
fma-neg86.6%
Applied egg-rr86.6%
log1p-expm1-u86.6%
Applied egg-rr86.6%
if -2.5000000000000002e-6 < phi2 < 3.35000000000000011e-28Initial program 85.7%
sin-diff89.2%
fma-neg89.2%
Applied egg-rr89.2%
cos-diff99.9%
*-commutative99.9%
Applied egg-rr99.9%
fma-define99.9%
Simplified99.9%
log1p-expm1-u99.9%
Applied egg-rr99.9%
Taylor expanded in phi2 around 0 99.9%
*-commutative99.9%
Simplified99.9%
if 3.35000000000000011e-28 < phi2 Initial program 73.4%
sin-diff92.9%
Applied egg-rr92.9%
Final simplification94.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(cos(phi2) * Float64(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[Cos[phi2], $MachinePrecision] * 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]], $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 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_2 \cdot \cos \lambda_1\right)\right)}
\end{array}
Initial program 78.9%
sin-diff89.3%
fma-neg89.3%
Applied egg-rr89.3%
cos-diff99.7%
*-commutative99.7%
Applied egg-rr99.7%
fma-define99.7%
Simplified99.7%
Taylor expanded in lambda1 around 0 99.7%
Final simplification99.7%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (cos phi2) (fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2))))) (- (* (cos phi1) (sin phi2)) (* (* (cos phi2) (sin phi1)) (cos (- lambda1 lambda2))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), ((cos(phi1) * sin(phi2)) - ((cos(phi2) * sin(phi1)) * cos((lambda1 - lambda2)))));
}
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(Float64(cos(phi2) * sin(phi1)) * cos(Float64(lambda1 - lambda2))))) end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\cos \phi_1 \cdot \sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
Initial program 78.9%
sin-diff89.3%
fma-neg89.3%
Applied egg-rr89.3%
Final simplification89.3%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2))))
(if (or (<= phi1 -0.0029) (not (<= phi1 4.2e-32)))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(-
t_0
(*
(* (cos phi2) (sin phi1))
(+ (* (sin lambda1) (sin lambda2)) (* (cos lambda2) (cos lambda1))))))
(atan2
(*
(cos phi2)
(fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2)))))
(- t_0 (* (cos (- lambda1 lambda2)) (* (cos phi2) phi1)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi1) * sin(phi2);
double tmp;
if ((phi1 <= -0.0029) || !(phi1 <= 4.2e-32)) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_0 - ((cos(phi2) * sin(phi1)) * ((sin(lambda1) * sin(lambda2)) + (cos(lambda2) * cos(lambda1))))));
} else {
tmp = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), (t_0 - (cos((lambda1 - lambda2)) * (cos(phi2) * phi1))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) tmp = 0.0 if ((phi1 <= -0.0029) || !(phi1 <= 4.2e-32)) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(t_0 - Float64(Float64(cos(phi2) * sin(phi1)) * Float64(Float64(sin(lambda1) * sin(lambda2)) + Float64(cos(lambda2) * cos(lambda1)))))); else tmp = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(t_0 - Float64(cos(Float64(lambda1 - lambda2)) * Float64(cos(phi2) * phi1)))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, If[Or[LessEqual[phi1, -0.0029], N[Not[LessEqual[phi1, 4.2e-32]], $MachinePrecision]], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - 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], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * N[(N[Cos[phi2], $MachinePrecision] * phi1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_1 \cdot \sin \phi_2\\
\mathbf{if}\;\phi_1 \leq -0.0029 \lor \neg \left(\phi_1 \leq 4.2 \cdot 10^{-32}\right):\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t\_0 - \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)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{t\_0 - \cos \left(\lambda_1 - \lambda_2\right) \cdot \left(\cos \phi_2 \cdot \phi_1\right)}\\
\end{array}
\end{array}
if phi1 < -0.0029 or 4.1999999999999998e-32 < phi1 Initial program 77.1%
cos-diff77.5%
+-commutative77.5%
*-commutative77.5%
Applied egg-rr77.5%
if -0.0029 < phi1 < 4.1999999999999998e-32Initial program 81.0%
sin-diff99.3%
fma-neg99.3%
Applied egg-rr99.3%
Taylor expanded in phi1 around 0 99.3%
associate-*r*99.3%
Simplified99.3%
Final simplification87.8%
(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 (<= phi1 -0.0029)
(atan2 t_2 (- t_0 (* (cos phi2) (* (sin phi1) t_1))))
(if (<= phi1 4.2e-32)
(atan2
(*
(cos phi2)
(fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2)))))
(- t_0 (* t_1 (* (cos phi2) phi1))))
(atan2
t_2
(- t_0 (* t_1 (* (sin phi1) (log1p (expm1 (cos phi2)))))))))))
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 (phi1 <= -0.0029) {
tmp = atan2(t_2, (t_0 - (cos(phi2) * (sin(phi1) * t_1))));
} else if (phi1 <= 4.2e-32) {
tmp = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), (t_0 - (t_1 * (cos(phi2) * phi1))));
} else {
tmp = atan2(t_2, (t_0 - (t_1 * (sin(phi1) * log1p(expm1(cos(phi2)))))));
}
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 (phi1 <= -0.0029) tmp = atan(t_2, Float64(t_0 - Float64(cos(phi2) * Float64(sin(phi1) * t_1)))); elseif (phi1 <= 4.2e-32) tmp = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(t_0 - Float64(t_1 * Float64(cos(phi2) * phi1)))); else tmp = atan(t_2, Float64(t_0 - Float64(t_1 * Float64(sin(phi1) * log1p(expm1(cos(phi2))))))); 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[phi1, -0.0029], 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[phi1, 4.2e-32], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 - N[(t$95$1 * N[(N[Cos[phi2], $MachinePrecision] * phi1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$2 / N[(t$95$0 - N[(t$95$1 * N[(N[Sin[phi1], $MachinePrecision] * N[Log[1 + N[(Exp[N[Cos[phi2], $MachinePrecision]] - 1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $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_1 \leq -0.0029:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot t\_1\right)}\\
\mathbf{elif}\;\phi_1 \leq 4.2 \cdot 10^{-32}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{t\_0 - t\_1 \cdot \left(\cos \phi_2 \cdot \phi_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - t\_1 \cdot \left(\sin \phi_1 \cdot \mathsf{log1p}\left(\mathsf{expm1}\left(\cos \phi_2\right)\right)\right)}\\
\end{array}
\end{array}
if phi1 < -0.0029Initial program 74.8%
*-commutative74.8%
associate-*l*74.8%
Simplified74.8%
if -0.0029 < phi1 < 4.1999999999999998e-32Initial program 81.0%
sin-diff99.3%
fma-neg99.3%
Applied egg-rr99.3%
Taylor expanded in phi1 around 0 99.3%
associate-*r*99.3%
Simplified99.3%
if 4.1999999999999998e-32 < phi1 Initial program 79.4%
log1p-expm1-u79.4%
Applied egg-rr79.4%
Final simplification87.6%
(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 (<= phi1 -360000.0)
(atan2 t_2 (- t_0 (* (cos phi2) (* (sin phi1) t_1))))
(if (<= phi1 4.2e-32)
(atan2
(*
(cos phi2)
(fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2)))))
(- (sin phi2) (* (cos lambda2) (* (cos phi2) (sin phi1)))))
(atan2
t_2
(- t_0 (* t_1 (* (sin phi1) (log1p (expm1 (cos phi2)))))))))))
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 (phi1 <= -360000.0) {
tmp = atan2(t_2, (t_0 - (cos(phi2) * (sin(phi1) * t_1))));
} else if (phi1 <= 4.2e-32) {
tmp = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), (sin(phi2) - (cos(lambda2) * (cos(phi2) * sin(phi1)))));
} else {
tmp = atan2(t_2, (t_0 - (t_1 * (sin(phi1) * log1p(expm1(cos(phi2)))))));
}
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 (phi1 <= -360000.0) tmp = atan(t_2, Float64(t_0 - Float64(cos(phi2) * Float64(sin(phi1) * t_1)))); elseif (phi1 <= 4.2e-32) tmp = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(sin(phi2) - Float64(cos(lambda2) * Float64(cos(phi2) * sin(phi1))))); else tmp = atan(t_2, Float64(t_0 - Float64(t_1 * Float64(sin(phi1) * log1p(expm1(cos(phi2))))))); 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[phi1, -360000.0], 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[phi1, 4.2e-32], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Cos[lambda2], $MachinePrecision] * N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$2 / N[(t$95$0 - N[(t$95$1 * N[(N[Sin[phi1], $MachinePrecision] * N[Log[1 + N[(Exp[N[Cos[phi2], $MachinePrecision]] - 1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $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_1 \leq -360000:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot t\_1\right)}\\
\mathbf{elif}\;\phi_1 \leq 4.2 \cdot 10^{-32}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 - \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \phi_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - t\_1 \cdot \left(\sin \phi_1 \cdot \mathsf{log1p}\left(\mathsf{expm1}\left(\cos \phi_2\right)\right)\right)}\\
\end{array}
\end{array}
if phi1 < -3.6e5Initial program 74.4%
*-commutative74.4%
associate-*l*74.5%
Simplified74.5%
if -3.6e5 < phi1 < 4.1999999999999998e-32Initial program 81.2%
sin-diff99.3%
fma-neg99.3%
Applied egg-rr99.3%
Taylor expanded in phi1 around 0 99.3%
Taylor expanded in lambda1 around 0 99.3%
cos-neg99.3%
Simplified99.3%
if 4.1999999999999998e-32 < phi1 Initial program 79.4%
log1p-expm1-u79.4%
Applied egg-rr79.4%
Final simplification87.6%
(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 78.9%
sin-diff89.3%
Applied egg-rr89.3%
Final simplification89.3%
(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 (<= phi1 -0.0029)
(atan2 t_2 (- t_0 (* (cos phi2) (* (sin phi1) t_1))))
(if (<= phi1 4e-32)
(atan2
(*
(cos phi2)
(fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2)))))
(- (sin phi2) (* t_1 (* (cos phi2) phi1))))
(atan2
t_2
(- t_0 (* t_1 (* (sin phi1) (log1p (expm1 (cos phi2)))))))))))
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 (phi1 <= -0.0029) {
tmp = atan2(t_2, (t_0 - (cos(phi2) * (sin(phi1) * t_1))));
} else if (phi1 <= 4e-32) {
tmp = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), (sin(phi2) - (t_1 * (cos(phi2) * phi1))));
} else {
tmp = atan2(t_2, (t_0 - (t_1 * (sin(phi1) * log1p(expm1(cos(phi2)))))));
}
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 (phi1 <= -0.0029) tmp = atan(t_2, Float64(t_0 - Float64(cos(phi2) * Float64(sin(phi1) * t_1)))); elseif (phi1 <= 4e-32) tmp = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(sin(phi2) - Float64(t_1 * Float64(cos(phi2) * phi1)))); else tmp = atan(t_2, Float64(t_0 - Float64(t_1 * Float64(sin(phi1) * log1p(expm1(cos(phi2))))))); 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[phi1, -0.0029], 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[phi1, 4e-32], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(t$95$1 * N[(N[Cos[phi2], $MachinePrecision] * phi1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$2 / N[(t$95$0 - N[(t$95$1 * N[(N[Sin[phi1], $MachinePrecision] * N[Log[1 + N[(Exp[N[Cos[phi2], $MachinePrecision]] - 1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $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_1 \leq -0.0029:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot t\_1\right)}\\
\mathbf{elif}\;\phi_1 \leq 4 \cdot 10^{-32}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 - t\_1 \cdot \left(\cos \phi_2 \cdot \phi_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - t\_1 \cdot \left(\sin \phi_1 \cdot \mathsf{log1p}\left(\mathsf{expm1}\left(\cos \phi_2\right)\right)\right)}\\
\end{array}
\end{array}
if phi1 < -0.0029Initial program 74.8%
*-commutative74.8%
associate-*l*74.8%
Simplified74.8%
if -0.0029 < phi1 < 4.00000000000000022e-32Initial program 81.0%
sin-diff99.3%
fma-neg99.3%
Applied egg-rr99.3%
Taylor expanded in phi1 around 0 99.3%
Taylor expanded in phi1 around 0 99.3%
associate-*r*99.3%
Simplified99.3%
if 4.00000000000000022e-32 < phi1 Initial program 79.4%
log1p-expm1-u79.4%
Applied egg-rr79.4%
Final simplification87.6%
(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 (<= phi1 -360000.0)
(atan2 t_2 (- t_0 (* (cos phi2) (* (sin phi1) t_1))))
(if (<= phi1 4.2e-32)
(atan2
(*
(cos phi2)
(fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2)))))
(- (sin phi2) (* (sin phi1) (cos (- lambda2 lambda1)))))
(atan2
t_2
(- t_0 (* t_1 (* (sin phi1) (log1p (expm1 (cos phi2)))))))))))
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 (phi1 <= -360000.0) {
tmp = atan2(t_2, (t_0 - (cos(phi2) * (sin(phi1) * t_1))));
} else if (phi1 <= 4.2e-32) {
tmp = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), (sin(phi2) - (sin(phi1) * cos((lambda2 - lambda1)))));
} else {
tmp = atan2(t_2, (t_0 - (t_1 * (sin(phi1) * log1p(expm1(cos(phi2)))))));
}
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 (phi1 <= -360000.0) tmp = atan(t_2, Float64(t_0 - Float64(cos(phi2) * Float64(sin(phi1) * t_1)))); elseif (phi1 <= 4.2e-32) tmp = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(sin(phi2) - Float64(sin(phi1) * cos(Float64(lambda2 - lambda1))))); else tmp = atan(t_2, Float64(t_0 - Float64(t_1 * Float64(sin(phi1) * log1p(expm1(cos(phi2))))))); 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[phi1, -360000.0], 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[phi1, 4.2e-32], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$2 / N[(t$95$0 - N[(t$95$1 * N[(N[Sin[phi1], $MachinePrecision] * N[Log[1 + N[(Exp[N[Cos[phi2], $MachinePrecision]] - 1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $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_1 \leq -360000:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot t\_1\right)}\\
\mathbf{elif}\;\phi_1 \leq 4.2 \cdot 10^{-32}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_2 - \lambda_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_2}{t\_0 - t\_1 \cdot \left(\sin \phi_1 \cdot \mathsf{log1p}\left(\mathsf{expm1}\left(\cos \phi_2\right)\right)\right)}\\
\end{array}
\end{array}
if phi1 < -3.6e5Initial program 74.4%
*-commutative74.4%
associate-*l*74.5%
Simplified74.5%
if -3.6e5 < phi1 < 4.1999999999999998e-32Initial program 81.2%
sin-diff99.3%
fma-neg99.3%
Applied egg-rr99.3%
Taylor expanded in phi1 around 0 99.3%
Taylor expanded in phi2 around 0 99.3%
sub-neg99.3%
neg-mul-199.3%
neg-mul-199.3%
remove-double-neg99.3%
mul-1-neg99.3%
distribute-neg-in99.3%
+-commutative99.3%
cos-neg99.3%
mul-1-neg99.3%
unsub-neg99.3%
Simplified99.3%
if 4.1999999999999998e-32 < phi1 Initial program 79.4%
log1p-expm1-u79.4%
Applied egg-rr79.4%
Final simplification87.6%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(if (or (<= phi1 -360000.0) (not (<= phi1 4e-32)))
(atan2
(* (cos phi2) (sin (- lambda1 lambda2)))
(-
(* (cos phi1) (sin phi2))
(* (cos phi2) (* (sin phi1) (cos (- lambda1 lambda2))))))
(atan2
(*
(cos phi2)
(fma (sin lambda1) (cos lambda2) (* (cos lambda1) (- (sin lambda2)))))
(- (sin phi2) (* (sin phi1) (cos (- lambda2 lambda1)))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if ((phi1 <= -360000.0) || !(phi1 <= 4e-32)) {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), ((cos(phi1) * sin(phi2)) - (cos(phi2) * (sin(phi1) * cos((lambda1 - lambda2))))));
} else {
tmp = atan2((cos(phi2) * fma(sin(lambda1), cos(lambda2), (cos(lambda1) * -sin(lambda2)))), (sin(phi2) - (sin(phi1) * cos((lambda2 - lambda1)))));
}
return tmp;
}
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if ((phi1 <= -360000.0) || !(phi1 <= 4e-32)) tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(cos(phi2) * Float64(sin(phi1) * cos(Float64(lambda1 - lambda2)))))); else tmp = atan(Float64(cos(phi2) * fma(sin(lambda1), cos(lambda2), Float64(cos(lambda1) * Float64(-sin(lambda2))))), Float64(sin(phi2) - Float64(sin(phi1) * cos(Float64(lambda2 - lambda1))))); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := If[Or[LessEqual[phi1, -360000.0], N[Not[LessEqual[phi1, 4e-32]], $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] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[lambda2], $MachinePrecision] + N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[lambda2], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi2], $MachinePrecision] - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\phi_1 \leq -360000 \lor \neg \left(\phi_1 \leq 4 \cdot 10^{-32}\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 \cos \left(\lambda_1 - \lambda_2\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \mathsf{fma}\left(\sin \lambda_1, \cos \lambda_2, \cos \lambda_1 \cdot \left(-\sin \lambda_2\right)\right)}{\sin \phi_2 - \sin \phi_1 \cdot \cos \left(\lambda_2 - \lambda_1\right)}\\
\end{array}
\end{array}
if phi1 < -3.6e5 or 4.00000000000000022e-32 < phi1 Initial program 76.9%
*-commutative76.9%
associate-*l*76.9%
Simplified76.9%
if -3.6e5 < phi1 < 4.00000000000000022e-32Initial program 81.2%
sin-diff99.3%
fma-neg99.3%
Applied egg-rr99.3%
Taylor expanded in phi1 around 0 99.3%
Taylor expanded in phi2 around 0 99.3%
sub-neg99.3%
neg-mul-199.3%
neg-mul-199.3%
remove-double-neg99.3%
mul-1-neg99.3%
distribute-neg-in99.3%
+-commutative99.3%
cos-neg99.3%
mul-1-neg99.3%
unsub-neg99.3%
Simplified99.3%
Final simplification87.6%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi2) (sin (- lambda1 lambda2))))
(t_1 (* (cos phi1) (sin phi2))))
(if (<= lambda1 -12.5)
(atan2
(* (sin lambda1) (cos phi2))
(- t_1 (* (cos phi2) (* (sin phi1) (cos (- lambda1 lambda2))))))
(if (<= lambda1 9000000000.0)
(atan2 t_0 (- t_1 (* (cos lambda2) (* (cos phi2) (sin phi1)))))
(atan2 t_0 (- t_1 (* (cos phi2) (* (cos lambda1) (sin phi1)))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi2) * sin((lambda1 - lambda2));
double t_1 = cos(phi1) * sin(phi2);
double tmp;
if (lambda1 <= -12.5) {
tmp = atan2((sin(lambda1) * cos(phi2)), (t_1 - (cos(phi2) * (sin(phi1) * cos((lambda1 - lambda2))))));
} else if (lambda1 <= 9000000000.0) {
tmp = atan2(t_0, (t_1 - (cos(lambda2) * (cos(phi2) * sin(phi1)))));
} else {
tmp = atan2(t_0, (t_1 - (cos(phi2) * (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) :: t_0
real(8) :: t_1
real(8) :: tmp
t_0 = cos(phi2) * sin((lambda1 - lambda2))
t_1 = cos(phi1) * sin(phi2)
if (lambda1 <= (-12.5d0)) then
tmp = atan2((sin(lambda1) * cos(phi2)), (t_1 - (cos(phi2) * (sin(phi1) * cos((lambda1 - lambda2))))))
else if (lambda1 <= 9000000000.0d0) then
tmp = atan2(t_0, (t_1 - (cos(lambda2) * (cos(phi2) * sin(phi1)))))
else
tmp = atan2(t_0, (t_1 - (cos(phi2) * (cos(lambda1) * sin(phi1)))))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos(phi2) * Math.sin((lambda1 - lambda2));
double t_1 = Math.cos(phi1) * Math.sin(phi2);
double tmp;
if (lambda1 <= -12.5) {
tmp = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (t_1 - (Math.cos(phi2) * (Math.sin(phi1) * Math.cos((lambda1 - lambda2))))));
} else if (lambda1 <= 9000000000.0) {
tmp = Math.atan2(t_0, (t_1 - (Math.cos(lambda2) * (Math.cos(phi2) * Math.sin(phi1)))));
} else {
tmp = Math.atan2(t_0, (t_1 - (Math.cos(phi2) * (Math.cos(lambda1) * Math.sin(phi1)))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi2) * math.sin((lambda1 - lambda2)) t_1 = math.cos(phi1) * math.sin(phi2) tmp = 0 if lambda1 <= -12.5: tmp = math.atan2((math.sin(lambda1) * math.cos(phi2)), (t_1 - (math.cos(phi2) * (math.sin(phi1) * math.cos((lambda1 - lambda2)))))) elif lambda1 <= 9000000000.0: tmp = math.atan2(t_0, (t_1 - (math.cos(lambda2) * (math.cos(phi2) * math.sin(phi1))))) else: tmp = math.atan2(t_0, (t_1 - (math.cos(phi2) * (math.cos(lambda1) * math.sin(phi1))))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) t_1 = Float64(cos(phi1) * sin(phi2)) tmp = 0.0 if (lambda1 <= -12.5) tmp = atan(Float64(sin(lambda1) * cos(phi2)), Float64(t_1 - Float64(cos(phi2) * Float64(sin(phi1) * cos(Float64(lambda1 - lambda2)))))); elseif (lambda1 <= 9000000000.0) tmp = atan(t_0, Float64(t_1 - Float64(cos(lambda2) * Float64(cos(phi2) * sin(phi1))))); else tmp = atan(t_0, Float64(t_1 - Float64(cos(phi2) * Float64(cos(lambda1) * sin(phi1))))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos(phi2) * sin((lambda1 - lambda2)); t_1 = cos(phi1) * sin(phi2); tmp = 0.0; if (lambda1 <= -12.5) tmp = atan2((sin(lambda1) * cos(phi2)), (t_1 - (cos(phi2) * (sin(phi1) * cos((lambda1 - lambda2)))))); elseif (lambda1 <= 9000000000.0) tmp = atan2(t_0, (t_1 - (cos(lambda2) * (cos(phi2) * sin(phi1))))); else tmp = atan2(t_0, (t_1 - (cos(phi2) * (cos(lambda1) * sin(phi1))))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda1, -12.5], 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] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], If[LessEqual[lambda1, 9000000000.0], N[ArcTan[t$95$0 / N[(t$95$1 - N[(N[Cos[lambda2], $MachinePrecision] * N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$0 / N[(t$95$1 - N[(N[Cos[phi2], $MachinePrecision] * N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
t_1 := \cos \phi_1 \cdot \sin \phi_2\\
\mathbf{if}\;\lambda_1 \leq -12.5:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_1 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)}\\
\mathbf{elif}\;\lambda_1 \leq 9000000000:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{t\_1 - \cos \lambda_2 \cdot \left(\cos \phi_2 \cdot \sin \phi_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{t\_1 - \cos \phi_2 \cdot \left(\cos \lambda_1 \cdot \sin \phi_1\right)}\\
\end{array}
\end{array}
if lambda1 < -12.5Initial program 67.9%
*-commutative67.9%
associate-*l*67.9%
Simplified67.9%
Taylor expanded in lambda2 around 0 67.9%
if -12.5 < lambda1 < 9e9Initial program 96.9%
Taylor expanded in lambda1 around 0 96.9%
cos-neg78.1%
Simplified96.9%
if 9e9 < lambda1 Initial program 58.1%
*-commutative58.1%
associate-*l*58.1%
Simplified58.1%
Taylor expanded in lambda2 around 0 58.3%
Final simplification79.0%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi1) (sin phi2)))
(t_1 (* (cos phi2) (sin (- lambda1 lambda2)))))
(if (<= lambda2 6.6e-37)
(atan2 t_1 (- t_0 (* (cos phi2) (* (cos lambda1) (sin phi1)))))
(atan2 t_1 (- t_0 (* (sin phi1) (cos (- lambda1 lambda2))))))))
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 tmp;
if (lambda2 <= 6.6e-37) {
tmp = atan2(t_1, (t_0 - (cos(phi2) * (cos(lambda1) * sin(phi1)))));
} else {
tmp = atan2(t_1, (t_0 - (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) :: t_0
real(8) :: t_1
real(8) :: tmp
t_0 = cos(phi1) * sin(phi2)
t_1 = cos(phi2) * sin((lambda1 - lambda2))
if (lambda2 <= 6.6d-37) then
tmp = atan2(t_1, (t_0 - (cos(phi2) * (cos(lambda1) * sin(phi1)))))
else
tmp = atan2(t_1, (t_0 - (sin(phi1) * cos((lambda1 - lambda2)))))
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((lambda1 - lambda2));
double tmp;
if (lambda2 <= 6.6e-37) {
tmp = Math.atan2(t_1, (t_0 - (Math.cos(phi2) * (Math.cos(lambda1) * Math.sin(phi1)))));
} else {
tmp = Math.atan2(t_1, (t_0 - (Math.sin(phi1) * Math.cos((lambda1 - lambda2)))));
}
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)) tmp = 0 if lambda2 <= 6.6e-37: tmp = math.atan2(t_1, (t_0 - (math.cos(phi2) * (math.cos(lambda1) * math.sin(phi1))))) else: tmp = math.atan2(t_1, (t_0 - (math.sin(phi1) * math.cos((lambda1 - lambda2))))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi1) * sin(phi2)) t_1 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) tmp = 0.0 if (lambda2 <= 6.6e-37) tmp = atan(t_1, Float64(t_0 - Float64(cos(phi2) * Float64(cos(lambda1) * sin(phi1))))); else tmp = atan(t_1, Float64(t_0 - Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos(phi1) * sin(phi2); t_1 = cos(phi2) * sin((lambda1 - lambda2)); tmp = 0.0; if (lambda2 <= 6.6e-37) tmp = atan2(t_1, (t_0 - (cos(phi2) * (cos(lambda1) * sin(phi1))))); else tmp = atan2(t_1, (t_0 - (sin(phi1) * cos((lambda1 - lambda2))))); 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[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda2, 6.6e-37], N[ArcTan[t$95$1 / N[(t$95$0 - N[(N[Cos[phi2], $MachinePrecision] * N[(N[Cos[lambda1], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / N[(t$95$0 - N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $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)\\
\mathbf{if}\;\lambda_2 \leq 6.6 \cdot 10^{-37}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \cos \phi_2 \cdot \left(\cos \lambda_1 \cdot \sin \phi_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0 - \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)}\\
\end{array}
\end{array}
if lambda2 < 6.59999999999999964e-37Initial program 83.8%
*-commutative83.8%
associate-*l*83.8%
Simplified83.8%
Taylor expanded in lambda2 around 0 78.1%
if 6.59999999999999964e-37 < lambda2 Initial program 65.3%
Taylor expanded in phi2 around 0 53.9%
Final simplification71.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (sin phi1) (cos (- lambda1 lambda2))))
(t_1 (* (cos phi1) (sin phi2))))
(if (<= lambda1 -4.1e-25)
(atan2 (* (sin lambda1) (cos phi2)) (- t_1 (* (cos phi2) t_0)))
(atan2 (* (cos phi2) (sin (- lambda1 lambda2))) (- t_1 t_0)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = sin(phi1) * cos((lambda1 - lambda2));
double t_1 = cos(phi1) * sin(phi2);
double tmp;
if (lambda1 <= -4.1e-25) {
tmp = atan2((sin(lambda1) * cos(phi2)), (t_1 - (cos(phi2) * t_0)));
} else {
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_1 - 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 = sin(phi1) * cos((lambda1 - lambda2))
t_1 = cos(phi1) * sin(phi2)
if (lambda1 <= (-4.1d-25)) then
tmp = atan2((sin(lambda1) * cos(phi2)), (t_1 - (cos(phi2) * t_0)))
else
tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_1 - 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 t_1 = Math.cos(phi1) * Math.sin(phi2);
double tmp;
if (lambda1 <= -4.1e-25) {
tmp = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (t_1 - (Math.cos(phi2) * t_0)));
} else {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), (t_1 - t_0));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.sin(phi1) * math.cos((lambda1 - lambda2)) t_1 = math.cos(phi1) * math.sin(phi2) tmp = 0 if lambda1 <= -4.1e-25: tmp = math.atan2((math.sin(lambda1) * math.cos(phi2)), (t_1 - (math.cos(phi2) * t_0))) else: tmp = math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), (t_1 - t_0)) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(sin(phi1) * cos(Float64(lambda1 - lambda2))) t_1 = Float64(cos(phi1) * sin(phi2)) tmp = 0.0 if (lambda1 <= -4.1e-25) tmp = atan(Float64(sin(lambda1) * cos(phi2)), Float64(t_1 - Float64(cos(phi2) * t_0))); else tmp = atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(t_1 - t_0)); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = sin(phi1) * cos((lambda1 - lambda2)); t_1 = cos(phi1) * sin(phi2); tmp = 0.0; if (lambda1 <= -4.1e-25) tmp = atan2((sin(lambda1) * cos(phi2)), (t_1 - (cos(phi2) * t_0))); else tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (t_1 - 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]}, Block[{t$95$1 = N[(N[Cos[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[lambda1, -4.1e-25], N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(t$95$1 - N[(N[Cos[phi2], $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(t$95$1 - t$95$0), $MachinePrecision]], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\\
t_1 := \cos \phi_1 \cdot \sin \phi_2\\
\mathbf{if}\;\lambda_1 \leq -4.1 \cdot 10^{-25}:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{t\_1 - \cos \phi_2 \cdot t\_0}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t\_1 - t\_0}\\
\end{array}
\end{array}
if lambda1 < -4.09999999999999987e-25Initial program 69.7%
*-commutative69.7%
associate-*l*69.7%
Simplified69.7%
Taylor expanded in lambda2 around 0 67.7%
if -4.09999999999999987e-25 < lambda1 Initial program 82.4%
Taylor expanded in phi2 around 0 68.3%
Final simplification68.1%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (cos phi2) (sin (- lambda1 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 - 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 - 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 - 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 - 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) * sin(Float64(lambda1 - lambda2))), Float64(Float64(cos(phi1) * sin(phi2)) - Float64(cos(phi2) * Float64(sin(phi1) * cos(Float64(lambda1 - lambda2)))))) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2((cos(phi2) * sin((lambda1 - 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[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] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \phi_1 \cdot \sin \phi_2 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)}
\end{array}
Initial program 78.9%
*-commutative78.9%
associate-*l*78.9%
Simplified78.9%
Final simplification78.9%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (sin phi1) (- (cos (- lambda1 lambda2)))))
(t_1 (* (cos phi2) (sin (- lambda1 lambda2)))))
(if (<= phi1 -410000.0)
(atan2 t_1 (expm1 (log1p t_0)))
(if (<= phi1 3.5e-35)
(atan2
t_1
(- (sin phi2) (* phi1 (* (cos phi2) (cos (- lambda2 lambda1))))))
(atan2 t_1 t_0)))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = sin(phi1) * -cos((lambda1 - lambda2));
double t_1 = cos(phi2) * sin((lambda1 - lambda2));
double tmp;
if (phi1 <= -410000.0) {
tmp = atan2(t_1, expm1(log1p(t_0)));
} else if (phi1 <= 3.5e-35) {
tmp = atan2(t_1, (sin(phi2) - (phi1 * (cos(phi2) * cos((lambda2 - lambda1))))));
} else {
tmp = atan2(t_1, t_0);
}
return tmp;
}
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.sin(phi1) * -Math.cos((lambda1 - lambda2));
double t_1 = Math.cos(phi2) * Math.sin((lambda1 - lambda2));
double tmp;
if (phi1 <= -410000.0) {
tmp = Math.atan2(t_1, Math.expm1(Math.log1p(t_0)));
} else if (phi1 <= 3.5e-35) {
tmp = Math.atan2(t_1, (Math.sin(phi2) - (phi1 * (Math.cos(phi2) * Math.cos((lambda2 - lambda1))))));
} else {
tmp = Math.atan2(t_1, t_0);
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.sin(phi1) * -math.cos((lambda1 - lambda2)) t_1 = math.cos(phi2) * math.sin((lambda1 - lambda2)) tmp = 0 if phi1 <= -410000.0: tmp = math.atan2(t_1, math.expm1(math.log1p(t_0))) elif phi1 <= 3.5e-35: tmp = math.atan2(t_1, (math.sin(phi2) - (phi1 * (math.cos(phi2) * math.cos((lambda2 - lambda1)))))) else: tmp = math.atan2(t_1, t_0) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(sin(phi1) * Float64(-cos(Float64(lambda1 - lambda2)))) t_1 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) tmp = 0.0 if (phi1 <= -410000.0) tmp = atan(t_1, expm1(log1p(t_0))); elseif (phi1 <= 3.5e-35) tmp = atan(t_1, Float64(sin(phi2) - Float64(phi1 * Float64(cos(phi2) * cos(Float64(lambda2 - lambda1)))))); else tmp = atan(t_1, t_0); end return tmp end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision])), $MachinePrecision]}, Block[{t$95$1 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[phi1, -410000.0], N[ArcTan[t$95$1 / N[(Exp[N[Log[1 + t$95$0], $MachinePrecision]] - 1), $MachinePrecision]], $MachinePrecision], If[LessEqual[phi1, 3.5e-35], N[ArcTan[t$95$1 / N[(N[Sin[phi2], $MachinePrecision] - N[(phi1 * N[(N[Cos[phi2], $MachinePrecision] * N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$1 / 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)\\
t_1 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_1 \leq -410000:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{\mathsf{expm1}\left(\mathsf{log1p}\left(t\_0\right)\right)}\\
\mathbf{elif}\;\phi_1 \leq 3.5 \cdot 10^{-35}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{\sin \phi_2 - \phi_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_2 - \lambda_1\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_1}{t\_0}\\
\end{array}
\end{array}
if phi1 < -4.1e5Initial program 74.1%
log1p-expm1-u74.0%
Applied egg-rr74.0%
Taylor expanded in phi2 around 0 44.1%
associate-*r*44.1%
neg-mul-144.1%
Simplified44.1%
expm1-log1p-u44.1%
expm1-undefine43.9%
*-commutative43.9%
Applied egg-rr43.9%
expm1-define44.1%
Simplified44.1%
if -4.1e5 < phi1 < 3.49999999999999996e-35Initial program 82.0%
log1p-expm1-u82.0%
Applied egg-rr82.0%
Taylor expanded in phi1 around 0 81.3%
mul-1-neg81.3%
unsub-neg81.3%
sub-neg81.3%
neg-mul-181.3%
neg-mul-181.3%
remove-double-neg81.3%
mul-1-neg81.3%
distribute-neg-in81.3%
+-commutative81.3%
cos-neg81.3%
mul-1-neg81.3%
unsub-neg81.3%
Simplified81.3%
if 3.49999999999999996e-35 < phi1 Initial program 78.3%
log1p-expm1-u78.2%
Applied egg-rr78.2%
Taylor expanded in phi2 around 0 50.2%
associate-*r*50.2%
neg-mul-150.2%
Simplified50.2%
Final simplification63.4%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (cos phi2) (sin (- lambda1 lambda2))) (- (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 - lambda2))), (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 - lambda2))), (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 - lambda2))), (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 - lambda2))), (math.sin(phi2) - ((math.cos(phi2) * math.sin(phi1)) * math.cos((lambda1 - lambda2)))))
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(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 - lambda2))), (sin(phi2) - ((cos(phi2) * 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[phi2], $MachinePrecision] - N[(N[(N[Cos[phi2], $MachinePrecision] * N[Sin[phi1], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 - \left(\cos \phi_2 \cdot \sin \phi_1\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)}
\end{array}
Initial program 78.9%
sin-diff89.3%
fma-neg89.3%
Applied egg-rr89.3%
Taylor expanded in phi1 around 0 74.9%
add-cbrt-cube71.2%
pow371.3%
*-commutative71.3%
fma-neg71.2%
sin-diff61.2%
Applied egg-rr61.2%
Taylor expanded in phi2 around inf 64.9%
*-commutative64.9%
Simplified64.9%
Final simplification64.9%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (cos phi2) (sin (- lambda1 lambda2))) (- (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 - lambda2))), (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 - lambda2))), (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 - lambda2))), (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 - lambda2))), (math.sin(phi2) - (math.cos(phi2) * (math.sin(phi1) * math.cos((lambda1 - lambda2))))))
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(sin(phi2) - Float64(cos(phi2) * Float64(sin(phi1) * cos(Float64(lambda1 - lambda2)))))) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (sin(phi2) - (cos(phi2) * (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[phi2], $MachinePrecision] - N[(N[Cos[phi2], $MachinePrecision] * N[(N[Sin[phi1], $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\sin \phi_2 - \cos \phi_2 \cdot \left(\sin \phi_1 \cdot \cos \left(\lambda_1 - \lambda_2\right)\right)}
\end{array}
Initial program 78.9%
sin-diff89.3%
fma-neg89.3%
Applied egg-rr89.3%
Taylor expanded in phi1 around 0 74.9%
*-un-lft-identity74.9%
*-commutative74.9%
fma-neg74.9%
sin-diff64.9%
associate-*l*64.9%
Applied egg-rr64.9%
*-lft-identity64.9%
*-commutative64.9%
associate-*r*64.9%
*-commutative64.9%
Simplified64.9%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi2) (sin (- lambda1 lambda2)))))
(if (or (<= phi1 -410000.0) (not (<= phi1 3.5e-35)))
(atan2 t_0 (* (sin phi1) (- (cos (- lambda1 lambda2)))))
(atan2
t_0
(- (sin phi2) (* phi1 (* (cos phi2) (cos (- lambda2 lambda1)))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi2) * sin((lambda1 - lambda2));
double tmp;
if ((phi1 <= -410000.0) || !(phi1 <= 3.5e-35)) {
tmp = atan2(t_0, (sin(phi1) * -cos((lambda1 - lambda2))));
} else {
tmp = atan2(t_0, (sin(phi2) - (phi1 * (cos(phi2) * cos((lambda2 - lambda1))))));
}
return tmp;
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: tmp
t_0 = cos(phi2) * sin((lambda1 - lambda2))
if ((phi1 <= (-410000.0d0)) .or. (.not. (phi1 <= 3.5d-35))) then
tmp = atan2(t_0, (sin(phi1) * -cos((lambda1 - lambda2))))
else
tmp = atan2(t_0, (sin(phi2) - (phi1 * (cos(phi2) * cos((lambda2 - lambda1))))))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos(phi2) * Math.sin((lambda1 - lambda2));
double tmp;
if ((phi1 <= -410000.0) || !(phi1 <= 3.5e-35)) {
tmp = Math.atan2(t_0, (Math.sin(phi1) * -Math.cos((lambda1 - lambda2))));
} else {
tmp = Math.atan2(t_0, (Math.sin(phi2) - (phi1 * (Math.cos(phi2) * Math.cos((lambda2 - lambda1))))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi2) * math.sin((lambda1 - lambda2)) tmp = 0 if (phi1 <= -410000.0) or not (phi1 <= 3.5e-35): tmp = math.atan2(t_0, (math.sin(phi1) * -math.cos((lambda1 - lambda2)))) else: tmp = math.atan2(t_0, (math.sin(phi2) - (phi1 * (math.cos(phi2) * math.cos((lambda2 - lambda1)))))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) tmp = 0.0 if ((phi1 <= -410000.0) || !(phi1 <= 3.5e-35)) tmp = atan(t_0, Float64(sin(phi1) * Float64(-cos(Float64(lambda1 - lambda2))))); else tmp = atan(t_0, Float64(sin(phi2) - Float64(phi1 * Float64(cos(phi2) * cos(Float64(lambda2 - lambda1)))))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos(phi2) * sin((lambda1 - lambda2)); tmp = 0.0; if ((phi1 <= -410000.0) || ~((phi1 <= 3.5e-35))) tmp = atan2(t_0, (sin(phi1) * -cos((lambda1 - lambda2)))); else tmp = atan2(t_0, (sin(phi2) - (phi1 * (cos(phi2) * cos((lambda2 - lambda1)))))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[Or[LessEqual[phi1, -410000.0], N[Not[LessEqual[phi1, 3.5e-35]], $MachinePrecision]], N[ArcTan[t$95$0 / N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision])), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$0 / N[(N[Sin[phi2], $MachinePrecision] - N[(phi1 * N[(N[Cos[phi2], $MachinePrecision] * N[Cos[N[(lambda2 - lambda1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_1 \leq -410000 \lor \neg \left(\phi_1 \leq 3.5 \cdot 10^{-35}\right):\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\sin \phi_1 \cdot \left(-\cos \left(\lambda_1 - \lambda_2\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\sin \phi_2 - \phi_1 \cdot \left(\cos \phi_2 \cdot \cos \left(\lambda_2 - \lambda_1\right)\right)}\\
\end{array}
\end{array}
if phi1 < -4.1e5 or 3.49999999999999996e-35 < phi1 Initial program 76.2%
log1p-expm1-u76.1%
Applied egg-rr76.1%
Taylor expanded in phi2 around 0 47.2%
associate-*r*47.2%
neg-mul-147.2%
Simplified47.2%
if -4.1e5 < phi1 < 3.49999999999999996e-35Initial program 82.0%
log1p-expm1-u82.0%
Applied egg-rr82.0%
Taylor expanded in phi1 around 0 81.3%
mul-1-neg81.3%
unsub-neg81.3%
sub-neg81.3%
neg-mul-181.3%
neg-mul-181.3%
remove-double-neg81.3%
mul-1-neg81.3%
distribute-neg-in81.3%
+-commutative81.3%
cos-neg81.3%
mul-1-neg81.3%
unsub-neg81.3%
Simplified81.3%
Final simplification63.4%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi2) (sin (- lambda1 lambda2)))))
(if (<= phi2 3.3e-29)
(atan2 t_0 (* (sin phi1) (- (cos (- lambda1 lambda2)))))
(atan2 t_0 (* phi2 (+ 1.0 (* -0.16666666666666666 (pow phi2 2.0))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi2) * sin((lambda1 - lambda2));
double tmp;
if (phi2 <= 3.3e-29) {
tmp = atan2(t_0, (sin(phi1) * -cos((lambda1 - lambda2))));
} else {
tmp = atan2(t_0, (phi2 * (1.0 + (-0.16666666666666666 * pow(phi2, 2.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(phi2) * sin((lambda1 - lambda2))
if (phi2 <= 3.3d-29) then
tmp = atan2(t_0, (sin(phi1) * -cos((lambda1 - lambda2))))
else
tmp = atan2(t_0, (phi2 * (1.0d0 + ((-0.16666666666666666d0) * (phi2 ** 2.0d0)))))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos(phi2) * Math.sin((lambda1 - lambda2));
double tmp;
if (phi2 <= 3.3e-29) {
tmp = Math.atan2(t_0, (Math.sin(phi1) * -Math.cos((lambda1 - lambda2))));
} else {
tmp = Math.atan2(t_0, (phi2 * (1.0 + (-0.16666666666666666 * Math.pow(phi2, 2.0)))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi2) * math.sin((lambda1 - lambda2)) tmp = 0 if phi2 <= 3.3e-29: tmp = math.atan2(t_0, (math.sin(phi1) * -math.cos((lambda1 - lambda2)))) else: tmp = math.atan2(t_0, (phi2 * (1.0 + (-0.16666666666666666 * math.pow(phi2, 2.0))))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) tmp = 0.0 if (phi2 <= 3.3e-29) tmp = atan(t_0, Float64(sin(phi1) * Float64(-cos(Float64(lambda1 - lambda2))))); else tmp = atan(t_0, Float64(phi2 * Float64(1.0 + Float64(-0.16666666666666666 * (phi2 ^ 2.0))))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos(phi2) * sin((lambda1 - lambda2)); tmp = 0.0; if (phi2 <= 3.3e-29) tmp = atan2(t_0, (sin(phi1) * -cos((lambda1 - lambda2)))); else tmp = atan2(t_0, (phi2 * (1.0 + (-0.16666666666666666 * (phi2 ^ 2.0))))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[phi2, 3.3e-29], N[ArcTan[t$95$0 / N[(N[Sin[phi1], $MachinePrecision] * (-N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision])), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$0 / N[(phi2 * N[(1.0 + N[(-0.16666666666666666 * N[Power[phi2, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq 3.3 \cdot 10^{-29}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\sin \phi_1 \cdot \left(-\cos \left(\lambda_1 - \lambda_2\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\phi_2 \cdot \left(1 + -0.16666666666666666 \cdot {\phi_2}^{2}\right)}\\
\end{array}
\end{array}
if phi2 < 3.30000000000000028e-29Initial program 81.5%
log1p-expm1-u81.5%
Applied egg-rr81.5%
Taylor expanded in phi2 around 0 58.9%
associate-*r*58.9%
neg-mul-158.9%
Simplified58.9%
if 3.30000000000000028e-29 < phi2 Initial program 71.6%
log1p-expm1-u71.6%
Applied egg-rr71.6%
Taylor expanded in phi2 around 0 29.2%
Taylor expanded in phi1 around 0 31.1%
+-commutative31.1%
Simplified31.1%
Final simplification51.7%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi2) (sin (- lambda1 lambda2)))))
(if (<= phi2 2.3e-28)
(atan2 t_0 (* (cos lambda1) (- (sin phi1))))
(atan2 t_0 (* phi2 (+ 1.0 (* -0.16666666666666666 (pow phi2 2.0))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi2) * sin((lambda1 - lambda2));
double tmp;
if (phi2 <= 2.3e-28) {
tmp = atan2(t_0, (cos(lambda1) * -sin(phi1)));
} else {
tmp = atan2(t_0, (phi2 * (1.0 + (-0.16666666666666666 * pow(phi2, 2.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(phi2) * sin((lambda1 - lambda2))
if (phi2 <= 2.3d-28) then
tmp = atan2(t_0, (cos(lambda1) * -sin(phi1)))
else
tmp = atan2(t_0, (phi2 * (1.0d0 + ((-0.16666666666666666d0) * (phi2 ** 2.0d0)))))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos(phi2) * Math.sin((lambda1 - lambda2));
double tmp;
if (phi2 <= 2.3e-28) {
tmp = Math.atan2(t_0, (Math.cos(lambda1) * -Math.sin(phi1)));
} else {
tmp = Math.atan2(t_0, (phi2 * (1.0 + (-0.16666666666666666 * Math.pow(phi2, 2.0)))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi2) * math.sin((lambda1 - lambda2)) tmp = 0 if phi2 <= 2.3e-28: tmp = math.atan2(t_0, (math.cos(lambda1) * -math.sin(phi1))) else: tmp = math.atan2(t_0, (phi2 * (1.0 + (-0.16666666666666666 * math.pow(phi2, 2.0))))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) tmp = 0.0 if (phi2 <= 2.3e-28) tmp = atan(t_0, Float64(cos(lambda1) * Float64(-sin(phi1)))); else tmp = atan(t_0, Float64(phi2 * Float64(1.0 + Float64(-0.16666666666666666 * (phi2 ^ 2.0))))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos(phi2) * sin((lambda1 - lambda2)); tmp = 0.0; if (phi2 <= 2.3e-28) tmp = atan2(t_0, (cos(lambda1) * -sin(phi1))); else tmp = atan2(t_0, (phi2 * (1.0 + (-0.16666666666666666 * (phi2 ^ 2.0))))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[phi2, 2.3e-28], N[ArcTan[t$95$0 / N[(N[Cos[lambda1], $MachinePrecision] * (-N[Sin[phi1], $MachinePrecision])), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$0 / N[(phi2 * N[(1.0 + N[(-0.16666666666666666 * N[Power[phi2, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq 2.3 \cdot 10^{-28}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\cos \lambda_1 \cdot \left(-\sin \phi_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\phi_2 \cdot \left(1 + -0.16666666666666666 \cdot {\phi_2}^{2}\right)}\\
\end{array}
\end{array}
if phi2 < 2.29999999999999986e-28Initial program 81.2%
log1p-expm1-u81.1%
Applied egg-rr81.1%
Taylor expanded in phi2 around 0 58.8%
associate-*r*58.8%
neg-mul-158.8%
Simplified58.8%
Taylor expanded in lambda2 around 0 54.2%
if 2.29999999999999986e-28 < phi2 Initial program 72.3%
log1p-expm1-u72.2%
Applied egg-rr72.2%
Taylor expanded in phi2 around 0 28.5%
Taylor expanded in phi1 around 0 30.4%
+-commutative30.4%
Simplified30.4%
Final simplification48.3%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (cos (- lambda1 lambda2))))
(if (<= phi1 -410000.0)
(atan2 (* (sin lambda1) (cos phi2)) (* (sin phi1) (- t_0)))
(atan2 (* (cos phi2) (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 (phi1 <= -410000.0) {
tmp = atan2((sin(lambda1) * cos(phi2)), (sin(phi1) * -t_0));
} else {
tmp = atan2((cos(phi2) * 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 (phi1 <= (-410000.0d0)) then
tmp = atan2((sin(lambda1) * cos(phi2)), (sin(phi1) * -t_0))
else
tmp = atan2((cos(phi2) * 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 (phi1 <= -410000.0) {
tmp = Math.atan2((Math.sin(lambda1) * Math.cos(phi2)), (Math.sin(phi1) * -t_0));
} else {
tmp = Math.atan2((Math.cos(phi2) * Math.sin((lambda1 - lambda2))), (t_0 * -phi1));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos((lambda1 - lambda2)) tmp = 0 if phi1 <= -410000.0: tmp = math.atan2((math.sin(lambda1) * math.cos(phi2)), (math.sin(phi1) * -t_0)) else: tmp = math.atan2((math.cos(phi2) * 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 (phi1 <= -410000.0) tmp = atan(Float64(sin(lambda1) * cos(phi2)), Float64(sin(phi1) * Float64(-t_0))); else tmp = atan(Float64(cos(phi2) * 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 (phi1 <= -410000.0) tmp = atan2((sin(lambda1) * cos(phi2)), (sin(phi1) * -t_0)); else tmp = atan2((cos(phi2) * 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[LessEqual[phi1, -410000.0], N[ArcTan[N[(N[Sin[lambda1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[phi1], $MachinePrecision] * (-t$95$0)), $MachinePrecision]], $MachinePrecision], N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $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}\;\phi_1 \leq -410000:\\
\;\;\;\;\tan^{-1}_* \frac{\sin \lambda_1 \cdot \cos \phi_2}{\sin \phi_1 \cdot \left(-t\_0\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{t\_0 \cdot \left(-\phi_1\right)}\\
\end{array}
\end{array}
if phi1 < -4.1e5Initial program 74.1%
log1p-expm1-u74.0%
Applied egg-rr74.0%
Taylor expanded in phi2 around 0 44.1%
associate-*r*44.1%
neg-mul-144.1%
Simplified44.1%
Taylor expanded in lambda2 around 0 28.6%
if -4.1e5 < phi1 Initial program 80.7%
log1p-expm1-u80.7%
Applied egg-rr80.7%
Taylor expanded in phi2 around 0 51.4%
associate-*r*51.4%
neg-mul-151.4%
Simplified51.4%
Taylor expanded in phi1 around 0 43.9%
mul-1-neg43.9%
*-commutative43.9%
distribute-rgt-neg-in43.9%
Simplified43.9%
Final simplification39.9%
(FPCore (lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* (cos phi2) (sin (- lambda1 lambda2)))))
(if (<= phi2 -5e-210)
(atan2 t_0 (* (cos (- lambda1 lambda2)) (- phi1)))
(atan2 t_0 (* phi2 (+ 1.0 (* -0.16666666666666666 (pow phi2 2.0))))))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = cos(phi2) * sin((lambda1 - lambda2));
double tmp;
if (phi2 <= -5e-210) {
tmp = atan2(t_0, (cos((lambda1 - lambda2)) * -phi1));
} else {
tmp = atan2(t_0, (phi2 * (1.0 + (-0.16666666666666666 * pow(phi2, 2.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(phi2) * sin((lambda1 - lambda2))
if (phi2 <= (-5d-210)) then
tmp = atan2(t_0, (cos((lambda1 - lambda2)) * -phi1))
else
tmp = atan2(t_0, (phi2 * (1.0d0 + ((-0.16666666666666666d0) * (phi2 ** 2.0d0)))))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = Math.cos(phi2) * Math.sin((lambda1 - lambda2));
double tmp;
if (phi2 <= -5e-210) {
tmp = Math.atan2(t_0, (Math.cos((lambda1 - lambda2)) * -phi1));
} else {
tmp = Math.atan2(t_0, (phi2 * (1.0 + (-0.16666666666666666 * Math.pow(phi2, 2.0)))));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): t_0 = math.cos(phi2) * math.sin((lambda1 - lambda2)) tmp = 0 if phi2 <= -5e-210: tmp = math.atan2(t_0, (math.cos((lambda1 - lambda2)) * -phi1)) else: tmp = math.atan2(t_0, (phi2 * (1.0 + (-0.16666666666666666 * math.pow(phi2, 2.0))))) return tmp
function code(lambda1, lambda2, phi1, phi2) t_0 = Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))) tmp = 0.0 if (phi2 <= -5e-210) tmp = atan(t_0, Float64(cos(Float64(lambda1 - lambda2)) * Float64(-phi1))); else tmp = atan(t_0, Float64(phi2 * Float64(1.0 + Float64(-0.16666666666666666 * (phi2 ^ 2.0))))); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) t_0 = cos(phi2) * sin((lambda1 - lambda2)); tmp = 0.0; if (phi2 <= -5e-210) tmp = atan2(t_0, (cos((lambda1 - lambda2)) * -phi1)); else tmp = atan2(t_0, (phi2 * (1.0 + (-0.16666666666666666 * (phi2 ^ 2.0))))); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[phi2, -5e-210], N[ArcTan[t$95$0 / N[(N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * (-phi1)), $MachinePrecision]], $MachinePrecision], N[ArcTan[t$95$0 / N[(phi2 * N[(1.0 + N[(-0.16666666666666666 * N[Power[phi2, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)\\
\mathbf{if}\;\phi_2 \leq -5 \cdot 10^{-210}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\cos \left(\lambda_1 - \lambda_2\right) \cdot \left(-\phi_1\right)}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{t\_0}{\phi_2 \cdot \left(1 + -0.16666666666666666 \cdot {\phi_2}^{2}\right)}\\
\end{array}
\end{array}
if phi2 < -5.0000000000000002e-210Initial program 74.9%
log1p-expm1-u74.8%
Applied egg-rr74.8%
Taylor expanded in phi2 around 0 38.2%
associate-*r*38.2%
neg-mul-138.2%
Simplified38.2%
Taylor expanded in phi1 around 0 29.9%
mul-1-neg29.9%
*-commutative29.9%
distribute-rgt-neg-in29.9%
Simplified29.9%
if -5.0000000000000002e-210 < phi2 Initial program 82.4%
log1p-expm1-u82.3%
Applied egg-rr82.3%
Taylor expanded in phi2 around 0 62.2%
Taylor expanded in phi1 around 0 43.5%
+-commutative43.5%
Simplified43.5%
Final simplification37.3%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (if (<= lambda2 5.5e-37) (atan2 (- (* lambda1 (cos lambda2)) (sin lambda2)) (sin phi2)) (atan2 (- (sin lambda2)) (sin phi2))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda2 <= 5.5e-37) {
tmp = atan2(((lambda1 * cos(lambda2)) - sin(lambda2)), sin(phi2));
} else {
tmp = atan2(-sin(lambda2), sin(phi2));
}
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 <= 5.5d-37) then
tmp = atan2(((lambda1 * cos(lambda2)) - sin(lambda2)), sin(phi2))
else
tmp = atan2(-sin(lambda2), sin(phi2))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda2 <= 5.5e-37) {
tmp = Math.atan2(((lambda1 * Math.cos(lambda2)) - Math.sin(lambda2)), Math.sin(phi2));
} else {
tmp = Math.atan2(-Math.sin(lambda2), Math.sin(phi2));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): tmp = 0 if lambda2 <= 5.5e-37: tmp = math.atan2(((lambda1 * math.cos(lambda2)) - math.sin(lambda2)), math.sin(phi2)) else: tmp = math.atan2(-math.sin(lambda2), math.sin(phi2)) return tmp
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if (lambda2 <= 5.5e-37) tmp = atan(Float64(Float64(lambda1 * cos(lambda2)) - sin(lambda2)), sin(phi2)); else tmp = atan(Float64(-sin(lambda2)), sin(phi2)); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) tmp = 0.0; if (lambda2 <= 5.5e-37) tmp = atan2(((lambda1 * cos(lambda2)) - sin(lambda2)), sin(phi2)); else tmp = atan2(-sin(lambda2), sin(phi2)); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[lambda2, 5.5e-37], N[ArcTan[N[(N[(lambda1 * N[Cos[lambda2], $MachinePrecision]), $MachinePrecision] - N[Sin[lambda2], $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], N[ArcTan[(-N[Sin[lambda2], $MachinePrecision]) / N[Sin[phi2], $MachinePrecision]], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\lambda_2 \leq 5.5 \cdot 10^{-37}:\\
\;\;\;\;\tan^{-1}_* \frac{\lambda_1 \cdot \cos \lambda_2 - \sin \lambda_2}{\sin \phi_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{-\sin \lambda_2}{\sin \phi_2}\\
\end{array}
\end{array}
if lambda2 < 5.4999999999999998e-37Initial program 83.8%
*-commutative83.8%
associate-*l*83.8%
Simplified83.8%
Taylor expanded in phi2 around 0 52.8%
Taylor expanded in lambda1 around 0 37.6%
+-commutative37.6%
sin-neg37.6%
unsub-neg37.6%
*-commutative37.6%
cos-neg37.6%
Simplified37.6%
Taylor expanded in phi1 around 0 27.1%
if 5.4999999999999998e-37 < lambda2 Initial program 65.3%
*-commutative65.3%
associate-*l*65.3%
Simplified65.3%
Taylor expanded in phi2 around 0 39.9%
Taylor expanded in lambda1 around 0 28.5%
+-commutative28.5%
sin-neg28.5%
unsub-neg28.5%
*-commutative28.5%
cos-neg28.5%
Simplified28.5%
Taylor expanded in phi1 around 0 20.6%
Taylor expanded in lambda1 around 0 29.1%
neg-mul-129.1%
Simplified29.1%
Final simplification27.6%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (* (cos phi2) (sin (- lambda1 lambda2))) (* (cos (- lambda1 lambda2)) (- phi1))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((cos(phi2) * 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((cos(phi2) * 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.cos(phi2) * Math.sin((lambda1 - lambda2))), (Math.cos((lambda1 - lambda2)) * -phi1));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2((math.cos(phi2) * math.sin((lambda1 - lambda2))), (math.cos((lambda1 - lambda2)) * -phi1))
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(cos(phi2) * sin(Float64(lambda1 - lambda2))), Float64(cos(Float64(lambda1 - lambda2)) * Float64(-phi1))) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2((cos(phi2) * sin((lambda1 - lambda2))), (cos((lambda1 - lambda2)) * -phi1)); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(N[Cos[phi2], $MachinePrecision] * N[Sin[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] / N[(N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision] * (-phi1)), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\cos \phi_2 \cdot \sin \left(\lambda_1 - \lambda_2\right)}{\cos \left(\lambda_1 - \lambda_2\right) \cdot \left(-\phi_1\right)}
\end{array}
Initial program 78.9%
log1p-expm1-u78.9%
Applied egg-rr78.9%
Taylor expanded in phi2 around 0 49.5%
associate-*r*49.5%
neg-mul-149.5%
Simplified49.5%
Taylor expanded in phi1 around 0 34.8%
mul-1-neg34.8%
*-commutative34.8%
distribute-rgt-neg-in34.8%
Simplified34.8%
Final simplification34.8%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (if (<= lambda2 4.2e-37) (atan2 (- lambda1 (sin lambda2)) (sin phi2)) (atan2 (- (sin lambda2)) (sin phi2))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda2 <= 4.2e-37) {
tmp = atan2((lambda1 - sin(lambda2)), sin(phi2));
} else {
tmp = atan2(-sin(lambda2), sin(phi2));
}
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 <= 4.2d-37) then
tmp = atan2((lambda1 - sin(lambda2)), sin(phi2))
else
tmp = atan2(-sin(lambda2), sin(phi2))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda2 <= 4.2e-37) {
tmp = Math.atan2((lambda1 - Math.sin(lambda2)), Math.sin(phi2));
} else {
tmp = Math.atan2(-Math.sin(lambda2), Math.sin(phi2));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): tmp = 0 if lambda2 <= 4.2e-37: tmp = math.atan2((lambda1 - math.sin(lambda2)), math.sin(phi2)) else: tmp = math.atan2(-math.sin(lambda2), math.sin(phi2)) return tmp
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if (lambda2 <= 4.2e-37) tmp = atan(Float64(lambda1 - sin(lambda2)), sin(phi2)); else tmp = atan(Float64(-sin(lambda2)), sin(phi2)); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) tmp = 0.0; if (lambda2 <= 4.2e-37) tmp = atan2((lambda1 - sin(lambda2)), sin(phi2)); else tmp = atan2(-sin(lambda2), sin(phi2)); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[lambda2, 4.2e-37], N[ArcTan[N[(lambda1 - N[Sin[lambda2], $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], N[ArcTan[(-N[Sin[lambda2], $MachinePrecision]) / N[Sin[phi2], $MachinePrecision]], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\lambda_2 \leq 4.2 \cdot 10^{-37}:\\
\;\;\;\;\tan^{-1}_* \frac{\lambda_1 - \sin \lambda_2}{\sin \phi_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{-\sin \lambda_2}{\sin \phi_2}\\
\end{array}
\end{array}
if lambda2 < 4.2000000000000002e-37Initial program 83.8%
*-commutative83.8%
associate-*l*83.8%
Simplified83.8%
Taylor expanded in phi2 around 0 52.8%
Taylor expanded in lambda1 around 0 37.6%
+-commutative37.6%
sin-neg37.6%
unsub-neg37.6%
*-commutative37.6%
cos-neg37.6%
Simplified37.6%
Taylor expanded in phi1 around 0 27.1%
Taylor expanded in lambda2 around 0 26.9%
if 4.2000000000000002e-37 < lambda2 Initial program 65.3%
*-commutative65.3%
associate-*l*65.3%
Simplified65.3%
Taylor expanded in phi2 around 0 39.9%
Taylor expanded in lambda1 around 0 28.5%
+-commutative28.5%
sin-neg28.5%
unsub-neg28.5%
*-commutative28.5%
cos-neg28.5%
Simplified28.5%
Taylor expanded in phi1 around 0 20.6%
Taylor expanded in lambda1 around 0 29.1%
neg-mul-129.1%
Simplified29.1%
Final simplification27.5%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (if (<= lambda2 1.22e-14) (atan2 (- lambda1 lambda2) (sin phi2)) (atan2 (- (sin lambda2)) (sin phi2))))
double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda2 <= 1.22e-14) {
tmp = atan2((lambda1 - lambda2), sin(phi2));
} else {
tmp = atan2(-sin(lambda2), sin(phi2));
}
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 <= 1.22d-14) then
tmp = atan2((lambda1 - lambda2), sin(phi2))
else
tmp = atan2(-sin(lambda2), sin(phi2))
end if
code = tmp
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda2 <= 1.22e-14) {
tmp = Math.atan2((lambda1 - lambda2), Math.sin(phi2));
} else {
tmp = Math.atan2(-Math.sin(lambda2), Math.sin(phi2));
}
return tmp;
}
def code(lambda1, lambda2, phi1, phi2): tmp = 0 if lambda2 <= 1.22e-14: tmp = math.atan2((lambda1 - lambda2), math.sin(phi2)) else: tmp = math.atan2(-math.sin(lambda2), math.sin(phi2)) return tmp
function code(lambda1, lambda2, phi1, phi2) tmp = 0.0 if (lambda2 <= 1.22e-14) tmp = atan(Float64(lambda1 - lambda2), sin(phi2)); else tmp = atan(Float64(-sin(lambda2)), sin(phi2)); end return tmp end
function tmp_2 = code(lambda1, lambda2, phi1, phi2) tmp = 0.0; if (lambda2 <= 1.22e-14) tmp = atan2((lambda1 - lambda2), sin(phi2)); else tmp = atan2(-sin(lambda2), sin(phi2)); end tmp_2 = tmp; end
code[lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[lambda2, 1.22e-14], N[ArcTan[N[(lambda1 - lambda2), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision], N[ArcTan[(-N[Sin[lambda2], $MachinePrecision]) / N[Sin[phi2], $MachinePrecision]], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\lambda_2 \leq 1.22 \cdot 10^{-14}:\\
\;\;\;\;\tan^{-1}_* \frac{\lambda_1 - \lambda_2}{\sin \phi_2}\\
\mathbf{else}:\\
\;\;\;\;\tan^{-1}_* \frac{-\sin \lambda_2}{\sin \phi_2}\\
\end{array}
\end{array}
if lambda2 < 1.21999999999999994e-14Initial program 83.9%
*-commutative83.9%
associate-*l*83.9%
Simplified83.9%
Taylor expanded in phi2 around 0 53.2%
Taylor expanded in lambda1 around 0 37.7%
+-commutative37.7%
sin-neg37.7%
unsub-neg37.7%
*-commutative37.7%
cos-neg37.7%
Simplified37.7%
Taylor expanded in phi1 around 0 27.3%
Taylor expanded in lambda2 around 0 25.1%
neg-mul-125.1%
sub-neg25.1%
Simplified25.1%
if 1.21999999999999994e-14 < lambda2 Initial program 64.4%
*-commutative64.4%
associate-*l*64.4%
Simplified64.4%
Taylor expanded in phi2 around 0 38.2%
Taylor expanded in lambda1 around 0 27.8%
+-commutative27.8%
sin-neg27.8%
unsub-neg27.8%
*-commutative27.8%
cos-neg27.8%
Simplified27.8%
Taylor expanded in phi1 around 0 19.6%
Taylor expanded in lambda1 around 0 28.5%
neg-mul-128.5%
Simplified28.5%
Final simplification25.9%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (+ lambda1 (* lambda2 (+ (* -0.5 (* lambda1 lambda2)) -1.0))) (sin phi2)))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((lambda1 + (lambda2 * ((-0.5 * (lambda1 * lambda2)) + -1.0))), sin(phi2));
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
code = atan2((lambda1 + (lambda2 * (((-0.5d0) * (lambda1 * lambda2)) + (-1.0d0)))), sin(phi2))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
return Math.atan2((lambda1 + (lambda2 * ((-0.5 * (lambda1 * lambda2)) + -1.0))), Math.sin(phi2));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2((lambda1 + (lambda2 * ((-0.5 * (lambda1 * lambda2)) + -1.0))), math.sin(phi2))
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(lambda1 + Float64(lambda2 * Float64(Float64(-0.5 * Float64(lambda1 * lambda2)) + -1.0))), sin(phi2)) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2((lambda1 + (lambda2 * ((-0.5 * (lambda1 * lambda2)) + -1.0))), sin(phi2)); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(lambda1 + N[(lambda2 * N[(N[(-0.5 * N[(lambda1 * lambda2), $MachinePrecision]), $MachinePrecision] + -1.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\lambda_1 + \lambda_2 \cdot \left(-0.5 \cdot \left(\lambda_1 \cdot \lambda_2\right) + -1\right)}{\sin \phi_2}
\end{array}
Initial program 78.9%
*-commutative78.9%
associate-*l*78.9%
Simplified78.9%
Taylor expanded in phi2 around 0 49.4%
Taylor expanded in lambda1 around 0 35.2%
+-commutative35.2%
sin-neg35.2%
unsub-neg35.2%
*-commutative35.2%
cos-neg35.2%
Simplified35.2%
Taylor expanded in phi1 around 0 25.4%
Taylor expanded in lambda2 around 0 23.7%
Final simplification23.7%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 (- lambda1 lambda2) (sin phi2)))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2((lambda1 - lambda2), sin(phi2));
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
code = atan2((lambda1 - lambda2), sin(phi2))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
return Math.atan2((lambda1 - lambda2), Math.sin(phi2));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2((lambda1 - lambda2), math.sin(phi2))
function code(lambda1, lambda2, phi1, phi2) return atan(Float64(lambda1 - lambda2), sin(phi2)) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2((lambda1 - lambda2), sin(phi2)); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[N[(lambda1 - lambda2), $MachinePrecision] / N[Sin[phi2], $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\lambda_1 - \lambda_2}{\sin \phi_2}
\end{array}
Initial program 78.9%
*-commutative78.9%
associate-*l*78.9%
Simplified78.9%
Taylor expanded in phi2 around 0 49.4%
Taylor expanded in lambda1 around 0 35.2%
+-commutative35.2%
sin-neg35.2%
unsub-neg35.2%
*-commutative35.2%
cos-neg35.2%
Simplified35.2%
Taylor expanded in phi1 around 0 25.4%
Taylor expanded in lambda2 around 0 23.3%
neg-mul-123.3%
sub-neg23.3%
Simplified23.3%
Final simplification23.3%
(FPCore (lambda1 lambda2 phi1 phi2) :precision binary64 (atan2 lambda1 (sin phi2)))
double code(double lambda1, double lambda2, double phi1, double phi2) {
return atan2(lambda1, sin(phi2));
}
real(8) function code(lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
code = atan2(lambda1, sin(phi2))
end function
public static double code(double lambda1, double lambda2, double phi1, double phi2) {
return Math.atan2(lambda1, Math.sin(phi2));
}
def code(lambda1, lambda2, phi1, phi2): return math.atan2(lambda1, math.sin(phi2))
function code(lambda1, lambda2, phi1, phi2) return atan(lambda1, sin(phi2)) end
function tmp = code(lambda1, lambda2, phi1, phi2) tmp = atan2(lambda1, sin(phi2)); end
code[lambda1_, lambda2_, phi1_, phi2_] := N[ArcTan[lambda1 / N[Sin[phi2], $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\tan^{-1}_* \frac{\lambda_1}{\sin \phi_2}
\end{array}
Initial program 78.9%
*-commutative78.9%
associate-*l*78.9%
Simplified78.9%
Taylor expanded in phi2 around 0 49.4%
Taylor expanded in lambda1 around 0 35.2%
+-commutative35.2%
sin-neg35.2%
unsub-neg35.2%
*-commutative35.2%
cos-neg35.2%
Simplified35.2%
Taylor expanded in phi1 around 0 25.4%
Taylor expanded in lambda2 around 0 19.7%
Final simplification19.7%
herbie shell --seed 2024121
(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))))))