
(FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (let* ((t_0 (* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0))))) (* R (sqrt (+ (* t_0 t_0) (* (- phi1 phi2) (- phi1 phi2)))))))
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = (lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0));
return R * sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))));
}
real(8) function code(r, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
t_0 = (lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0d0))
code = r * sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))))
end function
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = (lambda1 - lambda2) * Math.cos(((phi1 + phi2) / 2.0));
return R * Math.sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))));
}
def code(R, lambda1, lambda2, phi1, phi2): t_0 = (lambda1 - lambda2) * math.cos(((phi1 + phi2) / 2.0)) return R * math.sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))))
function code(R, lambda1, lambda2, phi1, phi2) t_0 = Float64(Float64(lambda1 - lambda2) * cos(Float64(Float64(phi1 + phi2) / 2.0))) return Float64(R * sqrt(Float64(Float64(t_0 * t_0) + Float64(Float64(phi1 - phi2) * Float64(phi1 - phi2))))) end
function tmp = code(R, lambda1, lambda2, phi1, phi2) t_0 = (lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0)); tmp = R * sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2)))); end
code[R_, lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[N[(N[(phi1 + phi2), $MachinePrecision] / 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(R * N[Sqrt[N[(N[(t$95$0 * t$95$0), $MachinePrecision] + N[(N[(phi1 - phi2), $MachinePrecision] * N[(phi1 - phi2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(\lambda_1 - \lambda_2\right) \cdot \cos \left(\frac{\phi_1 + \phi_2}{2}\right)\\
R \cdot \sqrt{t\_0 \cdot t\_0 + \left(\phi_1 - \phi_2\right) \cdot \left(\phi_1 - \phi_2\right)}
\end{array}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 16 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (let* ((t_0 (* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0))))) (* R (sqrt (+ (* t_0 t_0) (* (- phi1 phi2) (- phi1 phi2)))))))
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = (lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0));
return R * sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))));
}
real(8) function code(r, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
t_0 = (lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0d0))
code = r * sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))))
end function
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = (lambda1 - lambda2) * Math.cos(((phi1 + phi2) / 2.0));
return R * Math.sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))));
}
def code(R, lambda1, lambda2, phi1, phi2): t_0 = (lambda1 - lambda2) * math.cos(((phi1 + phi2) / 2.0)) return R * math.sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))))
function code(R, lambda1, lambda2, phi1, phi2) t_0 = Float64(Float64(lambda1 - lambda2) * cos(Float64(Float64(phi1 + phi2) / 2.0))) return Float64(R * sqrt(Float64(Float64(t_0 * t_0) + Float64(Float64(phi1 - phi2) * Float64(phi1 - phi2))))) end
function tmp = code(R, lambda1, lambda2, phi1, phi2) t_0 = (lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0)); tmp = R * sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2)))); end
code[R_, lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[N[(N[(phi1 + phi2), $MachinePrecision] / 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(R * N[Sqrt[N[(N[(t$95$0 * t$95$0), $MachinePrecision] + N[(N[(phi1 - phi2), $MachinePrecision] * N[(phi1 - phi2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(\lambda_1 - \lambda_2\right) \cdot \cos \left(\frac{\phi_1 + \phi_2}{2}\right)\\
R \cdot \sqrt{t\_0 \cdot t\_0 + \left(\phi_1 - \phi_2\right) \cdot \left(\phi_1 - \phi_2\right)}
\end{array}
\end{array}
R\_m = (fabs.f64 R)
R\_s = (copysign.f64 #s(literal 1 binary64) R)
(FPCore (R_s R_m lambda1 lambda2 phi1 phi2)
:precision binary64
(*
R_s
(pow
(sqrt
(*
R_m
(hypot
(*
(- lambda1 lambda2)
(-
(* (cos (* 0.5 phi1)) (cos (* phi2 0.5)))
(* (sin (* phi2 0.5)) (sin (* 0.5 phi1)))))
(- phi1 phi2))))
2.0)))R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
return R_s * pow(sqrt((R_m * hypot(((lambda1 - lambda2) * ((cos((0.5 * phi1)) * cos((phi2 * 0.5))) - (sin((phi2 * 0.5)) * sin((0.5 * phi1))))), (phi1 - phi2)))), 2.0);
}
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
return R_s * Math.pow(Math.sqrt((R_m * Math.hypot(((lambda1 - lambda2) * ((Math.cos((0.5 * phi1)) * Math.cos((phi2 * 0.5))) - (Math.sin((phi2 * 0.5)) * Math.sin((0.5 * phi1))))), (phi1 - phi2)))), 2.0);
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): return R_s * math.pow(math.sqrt((R_m * math.hypot(((lambda1 - lambda2) * ((math.cos((0.5 * phi1)) * math.cos((phi2 * 0.5))) - (math.sin((phi2 * 0.5)) * math.sin((0.5 * phi1))))), (phi1 - phi2)))), 2.0)
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) return Float64(R_s * (sqrt(Float64(R_m * hypot(Float64(Float64(lambda1 - lambda2) * Float64(Float64(cos(Float64(0.5 * phi1)) * cos(Float64(phi2 * 0.5))) - Float64(sin(Float64(phi2 * 0.5)) * sin(Float64(0.5 * phi1))))), Float64(phi1 - phi2)))) ^ 2.0)) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = R_s * (sqrt((R_m * hypot(((lambda1 - lambda2) * ((cos((0.5 * phi1)) * cos((phi2 * 0.5))) - (sin((phi2 * 0.5)) * sin((0.5 * phi1))))), (phi1 - phi2)))) ^ 2.0); end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * N[Power[N[Sqrt[N[(R$95$m * N[Sqrt[N[(N[(lambda1 - lambda2), $MachinePrecision] * N[(N[(N[Cos[N[(0.5 * phi1), $MachinePrecision]], $MachinePrecision] * N[Cos[N[(phi2 * 0.5), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] - N[(N[Sin[N[(phi2 * 0.5), $MachinePrecision]], $MachinePrecision] * N[Sin[N[(0.5 * phi1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] ^ 2 + N[(phi1 - phi2), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot {\left(\sqrt{R\_m \cdot \mathsf{hypot}\left(\left(\lambda_1 - \lambda_2\right) \cdot \left(\cos \left(0.5 \cdot \phi_1\right) \cdot \cos \left(\phi_2 \cdot 0.5\right) - \sin \left(\phi_2 \cdot 0.5\right) \cdot \sin \left(0.5 \cdot \phi_1\right)\right), \phi_1 - \phi_2\right)}\right)}^{2}
\end{array}
Initial program 58.3%
hypot-define96.0%
Simplified96.0%
add-log-exp96.0%
div-inv96.0%
metadata-eval96.0%
Applied egg-rr96.0%
add-sqr-sqrt50.9%
pow250.9%
rem-log-exp50.9%
*-commutative50.9%
+-commutative50.9%
Applied egg-rr50.9%
distribute-rgt-in50.9%
cos-sum53.2%
Applied egg-rr53.2%
Final simplification53.2%
R\_m = (fabs.f64 R)
R\_s = (copysign.f64 #s(literal 1 binary64) R)
(FPCore (R_s R_m lambda1 lambda2 phi1 phi2)
:precision binary64
(*
R_s
(if (<= phi1 -0.005)
(* R_m (hypot (* (- lambda1 lambda2) (cos (* 0.5 phi1))) (- phi1 phi2)))
(* R_m (hypot (* (- lambda1 lambda2) (cos (* phi2 0.5))) (- phi1 phi2))))))R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -0.005) {
tmp = R_m * hypot(((lambda1 - lambda2) * cos((0.5 * phi1))), (phi1 - phi2));
} else {
tmp = R_m * hypot(((lambda1 - lambda2) * cos((phi2 * 0.5))), (phi1 - phi2));
}
return R_s * tmp;
}
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -0.005) {
tmp = R_m * Math.hypot(((lambda1 - lambda2) * Math.cos((0.5 * phi1))), (phi1 - phi2));
} else {
tmp = R_m * Math.hypot(((lambda1 - lambda2) * Math.cos((phi2 * 0.5))), (phi1 - phi2));
}
return R_s * tmp;
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): tmp = 0 if phi1 <= -0.005: tmp = R_m * math.hypot(((lambda1 - lambda2) * math.cos((0.5 * phi1))), (phi1 - phi2)) else: tmp = R_m * math.hypot(((lambda1 - lambda2) * math.cos((phi2 * 0.5))), (phi1 - phi2)) return R_s * tmp
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi1 <= -0.005) tmp = Float64(R_m * hypot(Float64(Float64(lambda1 - lambda2) * cos(Float64(0.5 * phi1))), Float64(phi1 - phi2))); else tmp = Float64(R_m * hypot(Float64(Float64(lambda1 - lambda2) * cos(Float64(phi2 * 0.5))), Float64(phi1 - phi2))); end return Float64(R_s * tmp) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp_2 = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0; if (phi1 <= -0.005) tmp = R_m * hypot(((lambda1 - lambda2) * cos((0.5 * phi1))), (phi1 - phi2)); else tmp = R_m * hypot(((lambda1 - lambda2) * cos((phi2 * 0.5))), (phi1 - phi2)); end tmp_2 = R_s * tmp; end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * If[LessEqual[phi1, -0.005], N[(R$95$m * N[Sqrt[N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[N[(0.5 * phi1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] ^ 2 + N[(phi1 - phi2), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision], N[(R$95$m * N[Sqrt[N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[N[(phi2 * 0.5), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] ^ 2 + N[(phi1 - phi2), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \begin{array}{l}
\mathbf{if}\;\phi_1 \leq -0.005:\\
\;\;\;\;R\_m \cdot \mathsf{hypot}\left(\left(\lambda_1 - \lambda_2\right) \cdot \cos \left(0.5 \cdot \phi_1\right), \phi_1 - \phi_2\right)\\
\mathbf{else}:\\
\;\;\;\;R\_m \cdot \mathsf{hypot}\left(\left(\lambda_1 - \lambda_2\right) \cdot \cos \left(\phi_2 \cdot 0.5\right), \phi_1 - \phi_2\right)\\
\end{array}
\end{array}
if phi1 < -0.0050000000000000001Initial program 51.6%
hypot-define93.0%
Simplified93.0%
Taylor expanded in phi2 around 0 92.3%
if -0.0050000000000000001 < phi1 Initial program 60.5%
hypot-define97.0%
Simplified97.0%
Taylor expanded in phi1 around 0 90.6%
Final simplification91.0%
R\_m = (fabs.f64 R) R\_s = (copysign.f64 #s(literal 1 binary64) R) (FPCore (R_s R_m lambda1 lambda2 phi1 phi2) :precision binary64 (* R_s (* R_m (hypot (* (- lambda1 lambda2) (cos (/ (+ phi2 phi1) 2.0))) (- phi1 phi2)))))
R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
return R_s * (R_m * hypot(((lambda1 - lambda2) * cos(((phi2 + phi1) / 2.0))), (phi1 - phi2)));
}
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
return R_s * (R_m * Math.hypot(((lambda1 - lambda2) * Math.cos(((phi2 + phi1) / 2.0))), (phi1 - phi2)));
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): return R_s * (R_m * math.hypot(((lambda1 - lambda2) * math.cos(((phi2 + phi1) / 2.0))), (phi1 - phi2)))
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) return Float64(R_s * Float64(R_m * hypot(Float64(Float64(lambda1 - lambda2) * cos(Float64(Float64(phi2 + phi1) / 2.0))), Float64(phi1 - phi2)))) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = R_s * (R_m * hypot(((lambda1 - lambda2) * cos(((phi2 + phi1) / 2.0))), (phi1 - phi2))); end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * N[(R$95$m * N[Sqrt[N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[N[(N[(phi2 + phi1), $MachinePrecision] / 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] ^ 2 + N[(phi1 - phi2), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \left(R\_m \cdot \mathsf{hypot}\left(\left(\lambda_1 - \lambda_2\right) \cdot \cos \left(\frac{\phi_2 + \phi_1}{2}\right), \phi_1 - \phi_2\right)\right)
\end{array}
Initial program 58.3%
hypot-define96.0%
Simplified96.0%
Final simplification96.0%
R\_m = (fabs.f64 R) R\_s = (copysign.f64 #s(literal 1 binary64) R) (FPCore (R_s R_m lambda1 lambda2 phi1 phi2) :precision binary64 (* R_s (* R_m (hypot (* (- lambda1 lambda2) (cos (* 0.5 phi1))) (- phi1 phi2)))))
R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
return R_s * (R_m * hypot(((lambda1 - lambda2) * cos((0.5 * phi1))), (phi1 - phi2)));
}
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
return R_s * (R_m * Math.hypot(((lambda1 - lambda2) * Math.cos((0.5 * phi1))), (phi1 - phi2)));
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): return R_s * (R_m * math.hypot(((lambda1 - lambda2) * math.cos((0.5 * phi1))), (phi1 - phi2)))
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) return Float64(R_s * Float64(R_m * hypot(Float64(Float64(lambda1 - lambda2) * cos(Float64(0.5 * phi1))), Float64(phi1 - phi2)))) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = R_s * (R_m * hypot(((lambda1 - lambda2) * cos((0.5 * phi1))), (phi1 - phi2))); end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * N[(R$95$m * N[Sqrt[N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[N[(0.5 * phi1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] ^ 2 + N[(phi1 - phi2), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \left(R\_m \cdot \mathsf{hypot}\left(\left(\lambda_1 - \lambda_2\right) \cdot \cos \left(0.5 \cdot \phi_1\right), \phi_1 - \phi_2\right)\right)
\end{array}
Initial program 58.3%
hypot-define96.0%
Simplified96.0%
Taylor expanded in phi2 around 0 89.3%
R\_m = (fabs.f64 R)
R\_s = (copysign.f64 #s(literal 1 binary64) R)
(FPCore (R_s R_m lambda1 lambda2 phi1 phi2)
:precision binary64
(*
R_s
(if (<= phi2 -8.5e-143)
(* R_m (* phi1 (+ (/ phi2 phi1) -1.0)))
(if (<= phi2 2.2e+42)
(* lambda2 (* (cos (* phi2 0.5)) (- R_m (* lambda1 (/ R_m lambda2)))))
(- (* R_m phi2) (* R_m phi1))))))R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi2 <= -8.5e-143) {
tmp = R_m * (phi1 * ((phi2 / phi1) + -1.0));
} else if (phi2 <= 2.2e+42) {
tmp = lambda2 * (cos((phi2 * 0.5)) * (R_m - (lambda1 * (R_m / lambda2))));
} else {
tmp = (R_m * phi2) - (R_m * phi1);
}
return R_s * tmp;
}
R\_m = abs(r)
R\_s = copysign(1.0d0, r)
real(8) function code(r_s, r_m, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r_s
real(8), intent (in) :: r_m
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (phi2 <= (-8.5d-143)) then
tmp = r_m * (phi1 * ((phi2 / phi1) + (-1.0d0)))
else if (phi2 <= 2.2d+42) then
tmp = lambda2 * (cos((phi2 * 0.5d0)) * (r_m - (lambda1 * (r_m / lambda2))))
else
tmp = (r_m * phi2) - (r_m * phi1)
end if
code = r_s * tmp
end function
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi2 <= -8.5e-143) {
tmp = R_m * (phi1 * ((phi2 / phi1) + -1.0));
} else if (phi2 <= 2.2e+42) {
tmp = lambda2 * (Math.cos((phi2 * 0.5)) * (R_m - (lambda1 * (R_m / lambda2))));
} else {
tmp = (R_m * phi2) - (R_m * phi1);
}
return R_s * tmp;
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): tmp = 0 if phi2 <= -8.5e-143: tmp = R_m * (phi1 * ((phi2 / phi1) + -1.0)) elif phi2 <= 2.2e+42: tmp = lambda2 * (math.cos((phi2 * 0.5)) * (R_m - (lambda1 * (R_m / lambda2)))) else: tmp = (R_m * phi2) - (R_m * phi1) return R_s * tmp
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi2 <= -8.5e-143) tmp = Float64(R_m * Float64(phi1 * Float64(Float64(phi2 / phi1) + -1.0))); elseif (phi2 <= 2.2e+42) tmp = Float64(lambda2 * Float64(cos(Float64(phi2 * 0.5)) * Float64(R_m - Float64(lambda1 * Float64(R_m / lambda2))))); else tmp = Float64(Float64(R_m * phi2) - Float64(R_m * phi1)); end return Float64(R_s * tmp) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp_2 = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0; if (phi2 <= -8.5e-143) tmp = R_m * (phi1 * ((phi2 / phi1) + -1.0)); elseif (phi2 <= 2.2e+42) tmp = lambda2 * (cos((phi2 * 0.5)) * (R_m - (lambda1 * (R_m / lambda2)))); else tmp = (R_m * phi2) - (R_m * phi1); end tmp_2 = R_s * tmp; end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * If[LessEqual[phi2, -8.5e-143], N[(R$95$m * N[(phi1 * N[(N[(phi2 / phi1), $MachinePrecision] + -1.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[phi2, 2.2e+42], N[(lambda2 * N[(N[Cos[N[(phi2 * 0.5), $MachinePrecision]], $MachinePrecision] * N[(R$95$m - N[(lambda1 * N[(R$95$m / lambda2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(R$95$m * phi2), $MachinePrecision] - N[(R$95$m * phi1), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \begin{array}{l}
\mathbf{if}\;\phi_2 \leq -8.5 \cdot 10^{-143}:\\
\;\;\;\;R\_m \cdot \left(\phi_1 \cdot \left(\frac{\phi_2}{\phi_1} + -1\right)\right)\\
\mathbf{elif}\;\phi_2 \leq 2.2 \cdot 10^{+42}:\\
\;\;\;\;\lambda_2 \cdot \left(\cos \left(\phi_2 \cdot 0.5\right) \cdot \left(R\_m - \lambda_1 \cdot \frac{R\_m}{\lambda_2}\right)\right)\\
\mathbf{else}:\\
\;\;\;\;R\_m \cdot \phi_2 - R\_m \cdot \phi_1\\
\end{array}
\end{array}
if phi2 < -8.50000000000000072e-143Initial program 58.0%
hypot-define94.7%
Simplified94.7%
Taylor expanded in phi1 around -inf 15.1%
mul-1-neg15.1%
distribute-rgt-neg-in15.1%
mul-1-neg15.1%
unsub-neg15.1%
Simplified15.1%
if -8.50000000000000072e-143 < phi2 < 2.2000000000000001e42Initial program 62.8%
hypot-define97.8%
Simplified97.8%
Taylor expanded in lambda2 around -inf 40.9%
Simplified41.6%
add-sqr-sqrt21.0%
sqrt-unprod29.9%
sqr-neg29.9%
sqrt-unprod13.6%
add-sqr-sqrt28.0%
Applied egg-rr27.1%
distribute-lft-out28.0%
*-commutative28.0%
+-commutative28.0%
+-commutative28.0%
distribute-lft-out28.0%
distribute-rgt-neg-in28.0%
distribute-neg-frac28.0%
Simplified28.0%
Taylor expanded in phi1 around 0 27.5%
if 2.2000000000000001e42 < phi2 Initial program 47.2%
hypot-define94.1%
Simplified94.1%
Taylor expanded in phi1 around -inf 65.1%
associate-*r*65.1%
mul-1-neg65.1%
mul-1-neg65.1%
unsub-neg65.1%
*-commutative65.1%
associate-/l*58.4%
Simplified58.4%
Taylor expanded in phi1 around 0 67.2%
+-commutative67.2%
mul-1-neg67.2%
unsub-neg67.2%
*-commutative67.2%
*-commutative67.2%
Simplified67.2%
Final simplification30.0%
R\_m = (fabs.f64 R)
R\_s = (copysign.f64 #s(literal 1 binary64) R)
(FPCore (R_s R_m lambda1 lambda2 phi1 phi2)
:precision binary64
(*
R_s
(if (<= phi2 -8.5e-143)
(* R_m (* phi1 (+ (/ phi2 phi1) -1.0)))
(if (<= phi2 2.2e+42)
(* lambda2 (* (cos (* phi2 0.5)) (- R_m (/ (* R_m lambda1) lambda2))))
(- (* R_m phi2) (* R_m phi1))))))R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi2 <= -8.5e-143) {
tmp = R_m * (phi1 * ((phi2 / phi1) + -1.0));
} else if (phi2 <= 2.2e+42) {
tmp = lambda2 * (cos((phi2 * 0.5)) * (R_m - ((R_m * lambda1) / lambda2)));
} else {
tmp = (R_m * phi2) - (R_m * phi1);
}
return R_s * tmp;
}
R\_m = abs(r)
R\_s = copysign(1.0d0, r)
real(8) function code(r_s, r_m, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r_s
real(8), intent (in) :: r_m
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (phi2 <= (-8.5d-143)) then
tmp = r_m * (phi1 * ((phi2 / phi1) + (-1.0d0)))
else if (phi2 <= 2.2d+42) then
tmp = lambda2 * (cos((phi2 * 0.5d0)) * (r_m - ((r_m * lambda1) / lambda2)))
else
tmp = (r_m * phi2) - (r_m * phi1)
end if
code = r_s * tmp
end function
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi2 <= -8.5e-143) {
tmp = R_m * (phi1 * ((phi2 / phi1) + -1.0));
} else if (phi2 <= 2.2e+42) {
tmp = lambda2 * (Math.cos((phi2 * 0.5)) * (R_m - ((R_m * lambda1) / lambda2)));
} else {
tmp = (R_m * phi2) - (R_m * phi1);
}
return R_s * tmp;
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): tmp = 0 if phi2 <= -8.5e-143: tmp = R_m * (phi1 * ((phi2 / phi1) + -1.0)) elif phi2 <= 2.2e+42: tmp = lambda2 * (math.cos((phi2 * 0.5)) * (R_m - ((R_m * lambda1) / lambda2))) else: tmp = (R_m * phi2) - (R_m * phi1) return R_s * tmp
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi2 <= -8.5e-143) tmp = Float64(R_m * Float64(phi1 * Float64(Float64(phi2 / phi1) + -1.0))); elseif (phi2 <= 2.2e+42) tmp = Float64(lambda2 * Float64(cos(Float64(phi2 * 0.5)) * Float64(R_m - Float64(Float64(R_m * lambda1) / lambda2)))); else tmp = Float64(Float64(R_m * phi2) - Float64(R_m * phi1)); end return Float64(R_s * tmp) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp_2 = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0; if (phi2 <= -8.5e-143) tmp = R_m * (phi1 * ((phi2 / phi1) + -1.0)); elseif (phi2 <= 2.2e+42) tmp = lambda2 * (cos((phi2 * 0.5)) * (R_m - ((R_m * lambda1) / lambda2))); else tmp = (R_m * phi2) - (R_m * phi1); end tmp_2 = R_s * tmp; end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * If[LessEqual[phi2, -8.5e-143], N[(R$95$m * N[(phi1 * N[(N[(phi2 / phi1), $MachinePrecision] + -1.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[phi2, 2.2e+42], N[(lambda2 * N[(N[Cos[N[(phi2 * 0.5), $MachinePrecision]], $MachinePrecision] * N[(R$95$m - N[(N[(R$95$m * lambda1), $MachinePrecision] / lambda2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(R$95$m * phi2), $MachinePrecision] - N[(R$95$m * phi1), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \begin{array}{l}
\mathbf{if}\;\phi_2 \leq -8.5 \cdot 10^{-143}:\\
\;\;\;\;R\_m \cdot \left(\phi_1 \cdot \left(\frac{\phi_2}{\phi_1} + -1\right)\right)\\
\mathbf{elif}\;\phi_2 \leq 2.2 \cdot 10^{+42}:\\
\;\;\;\;\lambda_2 \cdot \left(\cos \left(\phi_2 \cdot 0.5\right) \cdot \left(R\_m - \frac{R\_m \cdot \lambda_1}{\lambda_2}\right)\right)\\
\mathbf{else}:\\
\;\;\;\;R\_m \cdot \phi_2 - R\_m \cdot \phi_1\\
\end{array}
\end{array}
if phi2 < -8.50000000000000072e-143Initial program 58.0%
hypot-define94.7%
Simplified94.7%
Taylor expanded in phi1 around -inf 15.1%
mul-1-neg15.1%
distribute-rgt-neg-in15.1%
mul-1-neg15.1%
unsub-neg15.1%
Simplified15.1%
if -8.50000000000000072e-143 < phi2 < 2.2000000000000001e42Initial program 62.8%
hypot-define97.8%
Simplified97.8%
Taylor expanded in lambda2 around -inf 40.9%
Simplified41.6%
add-sqr-sqrt21.0%
sqrt-unprod29.9%
sqr-neg29.9%
sqrt-unprod13.6%
add-sqr-sqrt28.0%
Applied egg-rr27.1%
distribute-lft-out28.0%
*-commutative28.0%
+-commutative28.0%
+-commutative28.0%
distribute-lft-out28.0%
distribute-rgt-neg-in28.0%
distribute-neg-frac28.0%
Simplified28.0%
Taylor expanded in phi1 around 0 27.3%
mul-1-neg27.3%
unsub-neg27.3%
*-commutative27.3%
Simplified27.3%
if 2.2000000000000001e42 < phi2 Initial program 47.2%
hypot-define94.1%
Simplified94.1%
Taylor expanded in phi1 around -inf 65.1%
associate-*r*65.1%
mul-1-neg65.1%
mul-1-neg65.1%
unsub-neg65.1%
*-commutative65.1%
associate-/l*58.4%
Simplified58.4%
Taylor expanded in phi1 around 0 67.2%
+-commutative67.2%
mul-1-neg67.2%
unsub-neg67.2%
*-commutative67.2%
*-commutative67.2%
Simplified67.2%
Final simplification29.9%
R\_m = (fabs.f64 R)
R\_s = (copysign.f64 #s(literal 1 binary64) R)
(FPCore (R_s R_m lambda1 lambda2 phi1 phi2)
:precision binary64
(*
R_s
(if (<= lambda1 -1.35e+164)
(* R_m (* (cos (* phi2 0.5)) (- lambda1)))
(if (<= lambda1 2.1e-121)
(- (* R_m phi2) (* R_m phi1))
(* (* R_m lambda2) (cos (* 0.5 (+ phi2 phi1))))))))R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda1 <= -1.35e+164) {
tmp = R_m * (cos((phi2 * 0.5)) * -lambda1);
} else if (lambda1 <= 2.1e-121) {
tmp = (R_m * phi2) - (R_m * phi1);
} else {
tmp = (R_m * lambda2) * cos((0.5 * (phi2 + phi1)));
}
return R_s * tmp;
}
R\_m = abs(r)
R\_s = copysign(1.0d0, r)
real(8) function code(r_s, r_m, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r_s
real(8), intent (in) :: r_m
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (lambda1 <= (-1.35d+164)) then
tmp = r_m * (cos((phi2 * 0.5d0)) * -lambda1)
else if (lambda1 <= 2.1d-121) then
tmp = (r_m * phi2) - (r_m * phi1)
else
tmp = (r_m * lambda2) * cos((0.5d0 * (phi2 + phi1)))
end if
code = r_s * tmp
end function
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda1 <= -1.35e+164) {
tmp = R_m * (Math.cos((phi2 * 0.5)) * -lambda1);
} else if (lambda1 <= 2.1e-121) {
tmp = (R_m * phi2) - (R_m * phi1);
} else {
tmp = (R_m * lambda2) * Math.cos((0.5 * (phi2 + phi1)));
}
return R_s * tmp;
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): tmp = 0 if lambda1 <= -1.35e+164: tmp = R_m * (math.cos((phi2 * 0.5)) * -lambda1) elif lambda1 <= 2.1e-121: tmp = (R_m * phi2) - (R_m * phi1) else: tmp = (R_m * lambda2) * math.cos((0.5 * (phi2 + phi1))) return R_s * tmp
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (lambda1 <= -1.35e+164) tmp = Float64(R_m * Float64(cos(Float64(phi2 * 0.5)) * Float64(-lambda1))); elseif (lambda1 <= 2.1e-121) tmp = Float64(Float64(R_m * phi2) - Float64(R_m * phi1)); else tmp = Float64(Float64(R_m * lambda2) * cos(Float64(0.5 * Float64(phi2 + phi1)))); end return Float64(R_s * tmp) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp_2 = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0; if (lambda1 <= -1.35e+164) tmp = R_m * (cos((phi2 * 0.5)) * -lambda1); elseif (lambda1 <= 2.1e-121) tmp = (R_m * phi2) - (R_m * phi1); else tmp = (R_m * lambda2) * cos((0.5 * (phi2 + phi1))); end tmp_2 = R_s * tmp; end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * If[LessEqual[lambda1, -1.35e+164], N[(R$95$m * N[(N[Cos[N[(phi2 * 0.5), $MachinePrecision]], $MachinePrecision] * (-lambda1)), $MachinePrecision]), $MachinePrecision], If[LessEqual[lambda1, 2.1e-121], N[(N[(R$95$m * phi2), $MachinePrecision] - N[(R$95$m * phi1), $MachinePrecision]), $MachinePrecision], N[(N[(R$95$m * lambda2), $MachinePrecision] * N[Cos[N[(0.5 * N[(phi2 + phi1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \begin{array}{l}
\mathbf{if}\;\lambda_1 \leq -1.35 \cdot 10^{+164}:\\
\;\;\;\;R\_m \cdot \left(\cos \left(\phi_2 \cdot 0.5\right) \cdot \left(-\lambda_1\right)\right)\\
\mathbf{elif}\;\lambda_1 \leq 2.1 \cdot 10^{-121}:\\
\;\;\;\;R\_m \cdot \phi_2 - R\_m \cdot \phi_1\\
\mathbf{else}:\\
\;\;\;\;\left(R\_m \cdot \lambda_2\right) \cdot \cos \left(0.5 \cdot \left(\phi_2 + \phi_1\right)\right)\\
\end{array}
\end{array}
if lambda1 < -1.35000000000000003e164Initial program 52.3%
hypot-define94.2%
Simplified94.2%
add-log-exp94.2%
div-inv94.2%
metadata-eval94.2%
Applied egg-rr94.2%
Taylor expanded in lambda1 around -inf 64.7%
associate-*r*64.7%
mul-1-neg64.7%
*-commutative64.7%
Simplified64.7%
Taylor expanded in phi1 around 0 54.0%
if -1.35000000000000003e164 < lambda1 < 2.0999999999999999e-121Initial program 61.4%
hypot-define97.0%
Simplified97.0%
Taylor expanded in phi1 around -inf 34.5%
associate-*r*34.5%
mul-1-neg34.5%
mul-1-neg34.5%
unsub-neg34.5%
*-commutative34.5%
associate-/l*36.0%
Simplified36.0%
Taylor expanded in phi1 around 0 35.3%
+-commutative35.3%
mul-1-neg35.3%
unsub-neg35.3%
*-commutative35.3%
*-commutative35.3%
Simplified35.3%
if 2.0999999999999999e-121 < lambda1 Initial program 55.5%
hypot-define95.1%
Simplified95.1%
add-log-exp95.0%
div-inv95.0%
metadata-eval95.0%
Applied egg-rr95.0%
Taylor expanded in lambda2 around inf 12.5%
associate-*r*12.5%
Simplified12.5%
Final simplification29.2%
R\_m = (fabs.f64 R)
R\_s = (copysign.f64 #s(literal 1 binary64) R)
(FPCore (R_s R_m lambda1 lambda2 phi1 phi2)
:precision binary64
(*
R_s
(if (<= lambda1 -6.8e+163)
(* R_m (* (cos (* phi2 0.5)) (- lambda1)))
(- (* R_m phi2) (* R_m phi1)))))R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda1 <= -6.8e+163) {
tmp = R_m * (cos((phi2 * 0.5)) * -lambda1);
} else {
tmp = (R_m * phi2) - (R_m * phi1);
}
return R_s * tmp;
}
R\_m = abs(r)
R\_s = copysign(1.0d0, r)
real(8) function code(r_s, r_m, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r_s
real(8), intent (in) :: r_m
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (lambda1 <= (-6.8d+163)) then
tmp = r_m * (cos((phi2 * 0.5d0)) * -lambda1)
else
tmp = (r_m * phi2) - (r_m * phi1)
end if
code = r_s * tmp
end function
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda1 <= -6.8e+163) {
tmp = R_m * (Math.cos((phi2 * 0.5)) * -lambda1);
} else {
tmp = (R_m * phi2) - (R_m * phi1);
}
return R_s * tmp;
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): tmp = 0 if lambda1 <= -6.8e+163: tmp = R_m * (math.cos((phi2 * 0.5)) * -lambda1) else: tmp = (R_m * phi2) - (R_m * phi1) return R_s * tmp
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (lambda1 <= -6.8e+163) tmp = Float64(R_m * Float64(cos(Float64(phi2 * 0.5)) * Float64(-lambda1))); else tmp = Float64(Float64(R_m * phi2) - Float64(R_m * phi1)); end return Float64(R_s * tmp) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp_2 = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0; if (lambda1 <= -6.8e+163) tmp = R_m * (cos((phi2 * 0.5)) * -lambda1); else tmp = (R_m * phi2) - (R_m * phi1); end tmp_2 = R_s * tmp; end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * If[LessEqual[lambda1, -6.8e+163], N[(R$95$m * N[(N[Cos[N[(phi2 * 0.5), $MachinePrecision]], $MachinePrecision] * (-lambda1)), $MachinePrecision]), $MachinePrecision], N[(N[(R$95$m * phi2), $MachinePrecision] - N[(R$95$m * phi1), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \begin{array}{l}
\mathbf{if}\;\lambda_1 \leq -6.8 \cdot 10^{+163}:\\
\;\;\;\;R\_m \cdot \left(\cos \left(\phi_2 \cdot 0.5\right) \cdot \left(-\lambda_1\right)\right)\\
\mathbf{else}:\\
\;\;\;\;R\_m \cdot \phi_2 - R\_m \cdot \phi_1\\
\end{array}
\end{array}
if lambda1 < -6.8000000000000002e163Initial program 52.3%
hypot-define94.2%
Simplified94.2%
add-log-exp94.2%
div-inv94.2%
metadata-eval94.2%
Applied egg-rr94.2%
Taylor expanded in lambda1 around -inf 64.7%
associate-*r*64.7%
mul-1-neg64.7%
*-commutative64.7%
Simplified64.7%
Taylor expanded in phi1 around 0 54.0%
if -6.8000000000000002e163 < lambda1 Initial program 59.0%
hypot-define96.3%
Simplified96.3%
Taylor expanded in phi1 around -inf 30.5%
associate-*r*30.5%
mul-1-neg30.5%
mul-1-neg30.5%
unsub-neg30.5%
*-commutative30.5%
associate-/l*30.9%
Simplified30.9%
Taylor expanded in phi1 around 0 30.1%
+-commutative30.1%
mul-1-neg30.1%
unsub-neg30.1%
*-commutative30.1%
*-commutative30.1%
Simplified30.1%
Final simplification32.7%
R\_m = (fabs.f64 R)
R\_s = (copysign.f64 #s(literal 1 binary64) R)
(FPCore (R_s R_m lambda1 lambda2 phi1 phi2)
:precision binary64
(*
R_s
(if (<= lambda1 -3.6e+159)
(* (- R_m) (* lambda1 (cos (* 0.5 phi1))))
(- (* R_m phi2) (* R_m phi1)))))R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda1 <= -3.6e+159) {
tmp = -R_m * (lambda1 * cos((0.5 * phi1)));
} else {
tmp = (R_m * phi2) - (R_m * phi1);
}
return R_s * tmp;
}
R\_m = abs(r)
R\_s = copysign(1.0d0, r)
real(8) function code(r_s, r_m, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r_s
real(8), intent (in) :: r_m
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (lambda1 <= (-3.6d+159)) then
tmp = -r_m * (lambda1 * cos((0.5d0 * phi1)))
else
tmp = (r_m * phi2) - (r_m * phi1)
end if
code = r_s * tmp
end function
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda1 <= -3.6e+159) {
tmp = -R_m * (lambda1 * Math.cos((0.5 * phi1)));
} else {
tmp = (R_m * phi2) - (R_m * phi1);
}
return R_s * tmp;
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): tmp = 0 if lambda1 <= -3.6e+159: tmp = -R_m * (lambda1 * math.cos((0.5 * phi1))) else: tmp = (R_m * phi2) - (R_m * phi1) return R_s * tmp
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (lambda1 <= -3.6e+159) tmp = Float64(Float64(-R_m) * Float64(lambda1 * cos(Float64(0.5 * phi1)))); else tmp = Float64(Float64(R_m * phi2) - Float64(R_m * phi1)); end return Float64(R_s * tmp) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp_2 = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0; if (lambda1 <= -3.6e+159) tmp = -R_m * (lambda1 * cos((0.5 * phi1))); else tmp = (R_m * phi2) - (R_m * phi1); end tmp_2 = R_s * tmp; end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * If[LessEqual[lambda1, -3.6e+159], N[((-R$95$m) * N[(lambda1 * N[Cos[N[(0.5 * phi1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(R$95$m * phi2), $MachinePrecision] - N[(R$95$m * phi1), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \begin{array}{l}
\mathbf{if}\;\lambda_1 \leq -3.6 \cdot 10^{+159}:\\
\;\;\;\;\left(-R\_m\right) \cdot \left(\lambda_1 \cdot \cos \left(0.5 \cdot \phi_1\right)\right)\\
\mathbf{else}:\\
\;\;\;\;R\_m \cdot \phi_2 - R\_m \cdot \phi_1\\
\end{array}
\end{array}
if lambda1 < -3.60000000000000037e159Initial program 52.3%
hypot-define94.2%
Simplified94.2%
add-log-exp94.2%
div-inv94.2%
metadata-eval94.2%
Applied egg-rr94.2%
Taylor expanded in lambda1 around -inf 64.7%
associate-*r*64.7%
mul-1-neg64.7%
*-commutative64.7%
Simplified64.7%
Taylor expanded in phi2 around 0 66.0%
if -3.60000000000000037e159 < lambda1 Initial program 59.0%
hypot-define96.3%
Simplified96.3%
Taylor expanded in phi1 around -inf 30.5%
associate-*r*30.5%
mul-1-neg30.5%
mul-1-neg30.5%
unsub-neg30.5%
*-commutative30.5%
associate-/l*30.9%
Simplified30.9%
Taylor expanded in phi1 around 0 30.1%
+-commutative30.1%
mul-1-neg30.1%
unsub-neg30.1%
*-commutative30.1%
*-commutative30.1%
Simplified30.1%
Final simplification34.0%
R\_m = (fabs.f64 R)
R\_s = (copysign.f64 #s(literal 1 binary64) R)
(FPCore (R_s R_m lambda1 lambda2 phi1 phi2)
:precision binary64
(*
R_s
(if (<= phi1 -1.5e+99)
(* R_m (* phi1 (+ (/ phi2 phi1) -1.0)))
(* phi2 (- R_m (* phi1 (/ R_m phi2)))))))R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -1.5e+99) {
tmp = R_m * (phi1 * ((phi2 / phi1) + -1.0));
} else {
tmp = phi2 * (R_m - (phi1 * (R_m / phi2)));
}
return R_s * tmp;
}
R\_m = abs(r)
R\_s = copysign(1.0d0, r)
real(8) function code(r_s, r_m, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r_s
real(8), intent (in) :: r_m
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (phi1 <= (-1.5d+99)) then
tmp = r_m * (phi1 * ((phi2 / phi1) + (-1.0d0)))
else
tmp = phi2 * (r_m - (phi1 * (r_m / phi2)))
end if
code = r_s * tmp
end function
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -1.5e+99) {
tmp = R_m * (phi1 * ((phi2 / phi1) + -1.0));
} else {
tmp = phi2 * (R_m - (phi1 * (R_m / phi2)));
}
return R_s * tmp;
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): tmp = 0 if phi1 <= -1.5e+99: tmp = R_m * (phi1 * ((phi2 / phi1) + -1.0)) else: tmp = phi2 * (R_m - (phi1 * (R_m / phi2))) return R_s * tmp
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi1 <= -1.5e+99) tmp = Float64(R_m * Float64(phi1 * Float64(Float64(phi2 / phi1) + -1.0))); else tmp = Float64(phi2 * Float64(R_m - Float64(phi1 * Float64(R_m / phi2)))); end return Float64(R_s * tmp) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp_2 = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0; if (phi1 <= -1.5e+99) tmp = R_m * (phi1 * ((phi2 / phi1) + -1.0)); else tmp = phi2 * (R_m - (phi1 * (R_m / phi2))); end tmp_2 = R_s * tmp; end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * If[LessEqual[phi1, -1.5e+99], N[(R$95$m * N[(phi1 * N[(N[(phi2 / phi1), $MachinePrecision] + -1.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(phi2 * N[(R$95$m - N[(phi1 * N[(R$95$m / phi2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \begin{array}{l}
\mathbf{if}\;\phi_1 \leq -1.5 \cdot 10^{+99}:\\
\;\;\;\;R\_m \cdot \left(\phi_1 \cdot \left(\frac{\phi_2}{\phi_1} + -1\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\phi_2 \cdot \left(R\_m - \phi_1 \cdot \frac{R\_m}{\phi_2}\right)\\
\end{array}
\end{array}
if phi1 < -1.50000000000000007e99Initial program 40.5%
hypot-define93.6%
Simplified93.6%
Taylor expanded in phi1 around -inf 72.6%
mul-1-neg72.6%
distribute-rgt-neg-in72.6%
mul-1-neg72.6%
unsub-neg72.6%
Simplified72.6%
if -1.50000000000000007e99 < phi1 Initial program 61.4%
hypot-define96.5%
Simplified96.5%
Taylor expanded in phi2 around inf 23.2%
mul-1-neg23.2%
unsub-neg23.2%
*-commutative23.2%
associate-/l*23.5%
Simplified23.5%
Final simplification30.8%
R\_m = (fabs.f64 R)
R\_s = (copysign.f64 #s(literal 1 binary64) R)
(FPCore (R_s R_m lambda1 lambda2 phi1 phi2)
:precision binary64
(*
R_s
(if (<= R_m 9.2e+109)
(- (* R_m phi2) (* R_m phi1))
(* phi2 (- R_m (* phi1 (/ R_m phi2)))))))R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (R_m <= 9.2e+109) {
tmp = (R_m * phi2) - (R_m * phi1);
} else {
tmp = phi2 * (R_m - (phi1 * (R_m / phi2)));
}
return R_s * tmp;
}
R\_m = abs(r)
R\_s = copysign(1.0d0, r)
real(8) function code(r_s, r_m, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r_s
real(8), intent (in) :: r_m
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (r_m <= 9.2d+109) then
tmp = (r_m * phi2) - (r_m * phi1)
else
tmp = phi2 * (r_m - (phi1 * (r_m / phi2)))
end if
code = r_s * tmp
end function
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (R_m <= 9.2e+109) {
tmp = (R_m * phi2) - (R_m * phi1);
} else {
tmp = phi2 * (R_m - (phi1 * (R_m / phi2)));
}
return R_s * tmp;
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): tmp = 0 if R_m <= 9.2e+109: tmp = (R_m * phi2) - (R_m * phi1) else: tmp = phi2 * (R_m - (phi1 * (R_m / phi2))) return R_s * tmp
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (R_m <= 9.2e+109) tmp = Float64(Float64(R_m * phi2) - Float64(R_m * phi1)); else tmp = Float64(phi2 * Float64(R_m - Float64(phi1 * Float64(R_m / phi2)))); end return Float64(R_s * tmp) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp_2 = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0; if (R_m <= 9.2e+109) tmp = (R_m * phi2) - (R_m * phi1); else tmp = phi2 * (R_m - (phi1 * (R_m / phi2))); end tmp_2 = R_s * tmp; end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * If[LessEqual[R$95$m, 9.2e+109], N[(N[(R$95$m * phi2), $MachinePrecision] - N[(R$95$m * phi1), $MachinePrecision]), $MachinePrecision], N[(phi2 * N[(R$95$m - N[(phi1 * N[(R$95$m / phi2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \begin{array}{l}
\mathbf{if}\;R\_m \leq 9.2 \cdot 10^{+109}:\\
\;\;\;\;R\_m \cdot \phi_2 - R\_m \cdot \phi_1\\
\mathbf{else}:\\
\;\;\;\;\phi_2 \cdot \left(R\_m - \phi_1 \cdot \frac{R\_m}{\phi_2}\right)\\
\end{array}
\end{array}
if R < 9.20000000000000042e109Initial program 52.7%
hypot-define95.5%
Simplified95.5%
Taylor expanded in phi1 around -inf 27.0%
associate-*r*27.0%
mul-1-neg27.0%
mul-1-neg27.0%
unsub-neg27.0%
*-commutative27.0%
associate-/l*27.0%
Simplified27.0%
Taylor expanded in phi1 around 0 26.6%
+-commutative26.6%
mul-1-neg26.6%
unsub-neg26.6%
*-commutative26.6%
*-commutative26.6%
Simplified26.6%
if 9.20000000000000042e109 < R Initial program 92.5%
hypot-define99.2%
Simplified99.2%
Taylor expanded in phi2 around inf 49.3%
mul-1-neg49.3%
unsub-neg49.3%
*-commutative49.3%
associate-/l*49.2%
Simplified49.2%
Final simplification29.8%
R\_m = (fabs.f64 R)
R\_s = (copysign.f64 #s(literal 1 binary64) R)
(FPCore (R_s R_m lambda1 lambda2 phi1 phi2)
:precision binary64
(*
R_s
(if (<= R_m 2.15e+110)
(- (* R_m phi2) (* R_m phi1))
(* phi2 (- R_m (* R_m (/ phi1 phi2)))))))R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (R_m <= 2.15e+110) {
tmp = (R_m * phi2) - (R_m * phi1);
} else {
tmp = phi2 * (R_m - (R_m * (phi1 / phi2)));
}
return R_s * tmp;
}
R\_m = abs(r)
R\_s = copysign(1.0d0, r)
real(8) function code(r_s, r_m, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r_s
real(8), intent (in) :: r_m
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (r_m <= 2.15d+110) then
tmp = (r_m * phi2) - (r_m * phi1)
else
tmp = phi2 * (r_m - (r_m * (phi1 / phi2)))
end if
code = r_s * tmp
end function
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (R_m <= 2.15e+110) {
tmp = (R_m * phi2) - (R_m * phi1);
} else {
tmp = phi2 * (R_m - (R_m * (phi1 / phi2)));
}
return R_s * tmp;
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): tmp = 0 if R_m <= 2.15e+110: tmp = (R_m * phi2) - (R_m * phi1) else: tmp = phi2 * (R_m - (R_m * (phi1 / phi2))) return R_s * tmp
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (R_m <= 2.15e+110) tmp = Float64(Float64(R_m * phi2) - Float64(R_m * phi1)); else tmp = Float64(phi2 * Float64(R_m - Float64(R_m * Float64(phi1 / phi2)))); end return Float64(R_s * tmp) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp_2 = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0; if (R_m <= 2.15e+110) tmp = (R_m * phi2) - (R_m * phi1); else tmp = phi2 * (R_m - (R_m * (phi1 / phi2))); end tmp_2 = R_s * tmp; end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * If[LessEqual[R$95$m, 2.15e+110], N[(N[(R$95$m * phi2), $MachinePrecision] - N[(R$95$m * phi1), $MachinePrecision]), $MachinePrecision], N[(phi2 * N[(R$95$m - N[(R$95$m * N[(phi1 / phi2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \begin{array}{l}
\mathbf{if}\;R\_m \leq 2.15 \cdot 10^{+110}:\\
\;\;\;\;R\_m \cdot \phi_2 - R\_m \cdot \phi_1\\
\mathbf{else}:\\
\;\;\;\;\phi_2 \cdot \left(R\_m - R\_m \cdot \frac{\phi_1}{\phi_2}\right)\\
\end{array}
\end{array}
if R < 2.15000000000000003e110Initial program 52.7%
hypot-define95.5%
Simplified95.5%
Taylor expanded in phi1 around -inf 27.0%
associate-*r*27.0%
mul-1-neg27.0%
mul-1-neg27.0%
unsub-neg27.0%
*-commutative27.0%
associate-/l*27.0%
Simplified27.0%
Taylor expanded in phi1 around 0 26.6%
+-commutative26.6%
mul-1-neg26.6%
unsub-neg26.6%
*-commutative26.6%
*-commutative26.6%
Simplified26.6%
if 2.15000000000000003e110 < R Initial program 92.5%
hypot-define99.2%
Simplified99.2%
add-log-exp99.2%
div-inv99.2%
metadata-eval99.2%
Applied egg-rr99.2%
add-sqr-sqrt99.0%
pow299.0%
rem-log-exp99.0%
*-commutative99.0%
+-commutative99.0%
Applied egg-rr99.0%
Taylor expanded in phi2 around inf 49.3%
mul-1-neg49.3%
unsub-neg49.3%
associate-/l*46.6%
Simplified46.6%
Final simplification29.4%
R\_m = (fabs.f64 R)
R\_s = (copysign.f64 #s(literal 1 binary64) R)
(FPCore (R_s R_m lambda1 lambda2 phi1 phi2)
:precision binary64
(*
R_s
(if (<= R_m 6e+96)
(- (* R_m phi2) (* R_m phi1))
(* R_m (* phi2 (- 1.0 (/ phi1 phi2)))))))R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (R_m <= 6e+96) {
tmp = (R_m * phi2) - (R_m * phi1);
} else {
tmp = R_m * (phi2 * (1.0 - (phi1 / phi2)));
}
return R_s * tmp;
}
R\_m = abs(r)
R\_s = copysign(1.0d0, r)
real(8) function code(r_s, r_m, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r_s
real(8), intent (in) :: r_m
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (r_m <= 6d+96) then
tmp = (r_m * phi2) - (r_m * phi1)
else
tmp = r_m * (phi2 * (1.0d0 - (phi1 / phi2)))
end if
code = r_s * tmp
end function
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (R_m <= 6e+96) {
tmp = (R_m * phi2) - (R_m * phi1);
} else {
tmp = R_m * (phi2 * (1.0 - (phi1 / phi2)));
}
return R_s * tmp;
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): tmp = 0 if R_m <= 6e+96: tmp = (R_m * phi2) - (R_m * phi1) else: tmp = R_m * (phi2 * (1.0 - (phi1 / phi2))) return R_s * tmp
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (R_m <= 6e+96) tmp = Float64(Float64(R_m * phi2) - Float64(R_m * phi1)); else tmp = Float64(R_m * Float64(phi2 * Float64(1.0 - Float64(phi1 / phi2)))); end return Float64(R_s * tmp) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp_2 = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0; if (R_m <= 6e+96) tmp = (R_m * phi2) - (R_m * phi1); else tmp = R_m * (phi2 * (1.0 - (phi1 / phi2))); end tmp_2 = R_s * tmp; end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * If[LessEqual[R$95$m, 6e+96], N[(N[(R$95$m * phi2), $MachinePrecision] - N[(R$95$m * phi1), $MachinePrecision]), $MachinePrecision], N[(R$95$m * N[(phi2 * N[(1.0 - N[(phi1 / phi2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \begin{array}{l}
\mathbf{if}\;R\_m \leq 6 \cdot 10^{+96}:\\
\;\;\;\;R\_m \cdot \phi_2 - R\_m \cdot \phi_1\\
\mathbf{else}:\\
\;\;\;\;R\_m \cdot \left(\phi_2 \cdot \left(1 - \frac{\phi_1}{\phi_2}\right)\right)\\
\end{array}
\end{array}
if R < 6.0000000000000001e96Initial program 51.8%
hypot-define95.4%
Simplified95.4%
Taylor expanded in phi1 around -inf 27.0%
associate-*r*27.0%
mul-1-neg27.0%
mul-1-neg27.0%
unsub-neg27.0%
*-commutative27.0%
associate-/l*27.0%
Simplified27.0%
Taylor expanded in phi1 around 0 26.6%
+-commutative26.6%
mul-1-neg26.6%
unsub-neg26.6%
*-commutative26.6%
*-commutative26.6%
Simplified26.6%
if 6.0000000000000001e96 < R Initial program 93.3%
hypot-define99.3%
Simplified99.3%
Taylor expanded in phi2 around inf 40.0%
mul-1-neg40.0%
unsub-neg40.0%
Simplified40.0%
Final simplification28.6%
R\_m = (fabs.f64 R) R\_s = (copysign.f64 #s(literal 1 binary64) R) (FPCore (R_s R_m lambda1 lambda2 phi1 phi2) :precision binary64 (* R_s (if (<= phi1 -4.3e+51) (* R_m (- phi1)) (* R_m phi2))))
R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -4.3e+51) {
tmp = R_m * -phi1;
} else {
tmp = R_m * phi2;
}
return R_s * tmp;
}
R\_m = abs(r)
R\_s = copysign(1.0d0, r)
real(8) function code(r_s, r_m, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r_s
real(8), intent (in) :: r_m
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (phi1 <= (-4.3d+51)) then
tmp = r_m * -phi1
else
tmp = r_m * phi2
end if
code = r_s * tmp
end function
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -4.3e+51) {
tmp = R_m * -phi1;
} else {
tmp = R_m * phi2;
}
return R_s * tmp;
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): tmp = 0 if phi1 <= -4.3e+51: tmp = R_m * -phi1 else: tmp = R_m * phi2 return R_s * tmp
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi1 <= -4.3e+51) tmp = Float64(R_m * Float64(-phi1)); else tmp = Float64(R_m * phi2); end return Float64(R_s * tmp) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp_2 = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = 0.0; if (phi1 <= -4.3e+51) tmp = R_m * -phi1; else tmp = R_m * phi2; end tmp_2 = R_s * tmp; end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * If[LessEqual[phi1, -4.3e+51], N[(R$95$m * (-phi1)), $MachinePrecision], N[(R$95$m * phi2), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \begin{array}{l}
\mathbf{if}\;\phi_1 \leq -4.3 \cdot 10^{+51}:\\
\;\;\;\;R\_m \cdot \left(-\phi_1\right)\\
\mathbf{else}:\\
\;\;\;\;R\_m \cdot \phi_2\\
\end{array}
\end{array}
if phi1 < -4.2999999999999997e51Initial program 49.3%
hypot-define93.9%
Simplified93.9%
Taylor expanded in phi1 around -inf 64.9%
mul-1-neg64.9%
Simplified64.9%
if -4.2999999999999997e51 < phi1 Initial program 60.6%
hypot-define96.6%
Simplified96.6%
Taylor expanded in phi2 around inf 18.1%
*-commutative18.1%
Simplified18.1%
Final simplification27.6%
R\_m = (fabs.f64 R) R\_s = (copysign.f64 #s(literal 1 binary64) R) (FPCore (R_s R_m lambda1 lambda2 phi1 phi2) :precision binary64 (* R_s (- (* R_m phi2) (* R_m phi1))))
R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
return R_s * ((R_m * phi2) - (R_m * phi1));
}
R\_m = abs(r)
R\_s = copysign(1.0d0, r)
real(8) function code(r_s, r_m, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r_s
real(8), intent (in) :: r_m
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
code = r_s * ((r_m * phi2) - (r_m * phi1))
end function
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
return R_s * ((R_m * phi2) - (R_m * phi1));
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): return R_s * ((R_m * phi2) - (R_m * phi1))
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) return Float64(R_s * Float64(Float64(R_m * phi2) - Float64(R_m * phi1))) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = R_s * ((R_m * phi2) - (R_m * phi1)); end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * N[(N[(R$95$m * phi2), $MachinePrecision] - N[(R$95$m * phi1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \left(R\_m \cdot \phi_2 - R\_m \cdot \phi_1\right)
\end{array}
Initial program 58.3%
hypot-define96.0%
Simplified96.0%
Taylor expanded in phi1 around -inf 28.6%
associate-*r*28.6%
mul-1-neg28.6%
mul-1-neg28.6%
unsub-neg28.6%
*-commutative28.6%
associate-/l*29.0%
Simplified29.0%
Taylor expanded in phi1 around 0 28.3%
+-commutative28.3%
mul-1-neg28.3%
unsub-neg28.3%
*-commutative28.3%
*-commutative28.3%
Simplified28.3%
Final simplification28.3%
R\_m = (fabs.f64 R) R\_s = (copysign.f64 #s(literal 1 binary64) R) (FPCore (R_s R_m lambda1 lambda2 phi1 phi2) :precision binary64 (* R_s (* R_m phi2)))
R\_m = fabs(R);
R\_s = copysign(1.0, R);
double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
return R_s * (R_m * phi2);
}
R\_m = abs(r)
R\_s = copysign(1.0d0, r)
real(8) function code(r_s, r_m, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r_s
real(8), intent (in) :: r_m
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
code = r_s * (r_m * phi2)
end function
R\_m = Math.abs(R);
R\_s = Math.copySign(1.0, R);
public static double code(double R_s, double R_m, double lambda1, double lambda2, double phi1, double phi2) {
return R_s * (R_m * phi2);
}
R\_m = math.fabs(R) R\_s = math.copysign(1.0, R) def code(R_s, R_m, lambda1, lambda2, phi1, phi2): return R_s * (R_m * phi2)
R\_m = abs(R) R\_s = copysign(1.0, R) function code(R_s, R_m, lambda1, lambda2, phi1, phi2) return Float64(R_s * Float64(R_m * phi2)) end
R\_m = abs(R); R\_s = sign(R) * abs(1.0); function tmp = code(R_s, R_m, lambda1, lambda2, phi1, phi2) tmp = R_s * (R_m * phi2); end
R\_m = N[Abs[R], $MachinePrecision]
R\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[R]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[R$95$s_, R$95$m_, lambda1_, lambda2_, phi1_, phi2_] := N[(R$95$s * N[(R$95$m * phi2), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
R\_m = \left|R\right|
\\
R\_s = \mathsf{copysign}\left(1, R\right)
\\
R\_s \cdot \left(R\_m \cdot \phi_2\right)
\end{array}
Initial program 58.3%
hypot-define96.0%
Simplified96.0%
Taylor expanded in phi2 around inf 15.7%
*-commutative15.7%
Simplified15.7%
Final simplification15.7%
herbie shell --seed 2024111
(FPCore (R lambda1 lambda2 phi1 phi2)
:name "Equirectangular approximation to distance on a great circle"
:precision binary64
(* R (sqrt (+ (* (* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0))) (* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0)))) (* (- phi1 phi2) (- phi1 phi2))))))