
(FPCore (t l k) :precision binary64 (/ 2.0 (* (* (* (/ (pow t 3.0) (* l l)) (sin k)) (tan k)) (+ (+ 1.0 (pow (/ k t) 2.0)) 1.0))))
double code(double t, double l, double k) {
return 2.0 / ((((pow(t, 3.0) / (l * l)) * sin(k)) * tan(k)) * ((1.0 + pow((k / t), 2.0)) + 1.0));
}
real(8) function code(t, l, k)
real(8), intent (in) :: t
real(8), intent (in) :: l
real(8), intent (in) :: k
code = 2.0d0 / (((((t ** 3.0d0) / (l * l)) * sin(k)) * tan(k)) * ((1.0d0 + ((k / t) ** 2.0d0)) + 1.0d0))
end function
public static double code(double t, double l, double k) {
return 2.0 / ((((Math.pow(t, 3.0) / (l * l)) * Math.sin(k)) * Math.tan(k)) * ((1.0 + Math.pow((k / t), 2.0)) + 1.0));
}
def code(t, l, k): return 2.0 / ((((math.pow(t, 3.0) / (l * l)) * math.sin(k)) * math.tan(k)) * ((1.0 + math.pow((k / t), 2.0)) + 1.0))
function code(t, l, k) return Float64(2.0 / Float64(Float64(Float64(Float64((t ^ 3.0) / Float64(l * l)) * sin(k)) * tan(k)) * Float64(Float64(1.0 + (Float64(k / t) ^ 2.0)) + 1.0))) end
function tmp = code(t, l, k) tmp = 2.0 / (((((t ^ 3.0) / (l * l)) * sin(k)) * tan(k)) * ((1.0 + ((k / t) ^ 2.0)) + 1.0)); end
code[t_, l_, k_] := N[(2.0 / N[(N[(N[(N[(N[Power[t, 3.0], $MachinePrecision] / N[(l * l), $MachinePrecision]), $MachinePrecision] * N[Sin[k], $MachinePrecision]), $MachinePrecision] * N[Tan[k], $MachinePrecision]), $MachinePrecision] * N[(N[(1.0 + N[Power[N[(k / t), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision] + 1.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{2}{\left(\left(\frac{{t}^{3}}{\ell \cdot \ell} \cdot \sin k\right) \cdot \tan k\right) \cdot \left(\left(1 + {\left(\frac{k}{t}\right)}^{2}\right) + 1\right)}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 17 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (t l k) :precision binary64 (/ 2.0 (* (* (* (/ (pow t 3.0) (* l l)) (sin k)) (tan k)) (+ (+ 1.0 (pow (/ k t) 2.0)) 1.0))))
double code(double t, double l, double k) {
return 2.0 / ((((pow(t, 3.0) / (l * l)) * sin(k)) * tan(k)) * ((1.0 + pow((k / t), 2.0)) + 1.0));
}
real(8) function code(t, l, k)
real(8), intent (in) :: t
real(8), intent (in) :: l
real(8), intent (in) :: k
code = 2.0d0 / (((((t ** 3.0d0) / (l * l)) * sin(k)) * tan(k)) * ((1.0d0 + ((k / t) ** 2.0d0)) + 1.0d0))
end function
public static double code(double t, double l, double k) {
return 2.0 / ((((Math.pow(t, 3.0) / (l * l)) * Math.sin(k)) * Math.tan(k)) * ((1.0 + Math.pow((k / t), 2.0)) + 1.0));
}
def code(t, l, k): return 2.0 / ((((math.pow(t, 3.0) / (l * l)) * math.sin(k)) * math.tan(k)) * ((1.0 + math.pow((k / t), 2.0)) + 1.0))
function code(t, l, k) return Float64(2.0 / Float64(Float64(Float64(Float64((t ^ 3.0) / Float64(l * l)) * sin(k)) * tan(k)) * Float64(Float64(1.0 + (Float64(k / t) ^ 2.0)) + 1.0))) end
function tmp = code(t, l, k) tmp = 2.0 / (((((t ^ 3.0) / (l * l)) * sin(k)) * tan(k)) * ((1.0 + ((k / t) ^ 2.0)) + 1.0)); end
code[t_, l_, k_] := N[(2.0 / N[(N[(N[(N[(N[Power[t, 3.0], $MachinePrecision] / N[(l * l), $MachinePrecision]), $MachinePrecision] * N[Sin[k], $MachinePrecision]), $MachinePrecision] * N[Tan[k], $MachinePrecision]), $MachinePrecision] * N[(N[(1.0 + N[Power[N[(k / t), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision] + 1.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{2}{\left(\left(\frac{{t}^{3}}{\ell \cdot \ell} \cdot \sin k\right) \cdot \tan k\right) \cdot \left(\left(1 + {\left(\frac{k}{t}\right)}^{2}\right) + 1\right)}
\end{array}
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(*
t_s
(if (<= t_m 5.2e-22)
(/ 2.0 (/ (/ k l) (* l (/ (/ 1.0 (* t_m (* (sin k) (tan k)))) k))))
(if (<= t_m 5e+153)
(*
(/ (/ l t_m) (* t_m (* t_m (sin k))))
(* 2.0 (/ (/ l (tan k)) (+ 2.0 (/ k (/ t_m (/ k t_m)))))))
(/
2.0
(*
(*
t_m
(* (* (sin k) (+ 2.0 (/ (/ k (/ t_m k)) t_m))) (* t_m (/ (tan k) l))))
(/ t_m l)))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double tmp;
if (t_m <= 5.2e-22) {
tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * (sin(k) * tan(k)))) / k)));
} else if (t_m <= 5e+153) {
tmp = ((l / t_m) / (t_m * (t_m * sin(k)))) * (2.0 * ((l / tan(k)) / (2.0 + (k / (t_m / (k / t_m))))));
} else {
tmp = 2.0 / ((t_m * ((sin(k) * (2.0 + ((k / (t_m / k)) / t_m))) * (t_m * (tan(k) / l)))) * (t_m / l));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: tmp
if (t_m <= 5.2d-22) then
tmp = 2.0d0 / ((k / l) / (l * ((1.0d0 / (t_m * (sin(k) * tan(k)))) / k)))
else if (t_m <= 5d+153) then
tmp = ((l / t_m) / (t_m * (t_m * sin(k)))) * (2.0d0 * ((l / tan(k)) / (2.0d0 + (k / (t_m / (k / t_m))))))
else
tmp = 2.0d0 / ((t_m * ((sin(k) * (2.0d0 + ((k / (t_m / k)) / t_m))) * (t_m * (tan(k) / l)))) * (t_m / l))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double tmp;
if (t_m <= 5.2e-22) {
tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * (Math.sin(k) * Math.tan(k)))) / k)));
} else if (t_m <= 5e+153) {
tmp = ((l / t_m) / (t_m * (t_m * Math.sin(k)))) * (2.0 * ((l / Math.tan(k)) / (2.0 + (k / (t_m / (k / t_m))))));
} else {
tmp = 2.0 / ((t_m * ((Math.sin(k) * (2.0 + ((k / (t_m / k)) / t_m))) * (t_m * (Math.tan(k) / l)))) * (t_m / l));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): tmp = 0 if t_m <= 5.2e-22: tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * (math.sin(k) * math.tan(k)))) / k))) elif t_m <= 5e+153: tmp = ((l / t_m) / (t_m * (t_m * math.sin(k)))) * (2.0 * ((l / math.tan(k)) / (2.0 + (k / (t_m / (k / t_m)))))) else: tmp = 2.0 / ((t_m * ((math.sin(k) * (2.0 + ((k / (t_m / k)) / t_m))) * (t_m * (math.tan(k) / l)))) * (t_m / l)) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) tmp = 0.0 if (t_m <= 5.2e-22) tmp = Float64(2.0 / Float64(Float64(k / l) / Float64(l * Float64(Float64(1.0 / Float64(t_m * Float64(sin(k) * tan(k)))) / k)))); elseif (t_m <= 5e+153) tmp = Float64(Float64(Float64(l / t_m) / Float64(t_m * Float64(t_m * sin(k)))) * Float64(2.0 * Float64(Float64(l / tan(k)) / Float64(2.0 + Float64(k / Float64(t_m / Float64(k / t_m))))))); else tmp = Float64(2.0 / Float64(Float64(t_m * Float64(Float64(sin(k) * Float64(2.0 + Float64(Float64(k / Float64(t_m / k)) / t_m))) * Float64(t_m * Float64(tan(k) / l)))) * Float64(t_m / l))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) tmp = 0.0; if (t_m <= 5.2e-22) tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * (sin(k) * tan(k)))) / k))); elseif (t_m <= 5e+153) tmp = ((l / t_m) / (t_m * (t_m * sin(k)))) * (2.0 * ((l / tan(k)) / (2.0 + (k / (t_m / (k / t_m)))))); else tmp = 2.0 / ((t_m * ((sin(k) * (2.0 + ((k / (t_m / k)) / t_m))) * (t_m * (tan(k) / l)))) * (t_m / l)); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * If[LessEqual[t$95$m, 5.2e-22], N[(2.0 / N[(N[(k / l), $MachinePrecision] / N[(l * N[(N[(1.0 / N[(t$95$m * N[(N[Sin[k], $MachinePrecision] * N[Tan[k], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$m, 5e+153], N[(N[(N[(l / t$95$m), $MachinePrecision] / N[(t$95$m * N[(t$95$m * N[Sin[k], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(2.0 * N[(N[(l / N[Tan[k], $MachinePrecision]), $MachinePrecision] / N[(2.0 + N[(k / N[(t$95$m / N[(k / t$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(t$95$m * N[(N[(N[Sin[k], $MachinePrecision] * N[(2.0 + N[(N[(k / N[(t$95$m / k), $MachinePrecision]), $MachinePrecision] / t$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(t$95$m * N[(N[Tan[k], $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(t$95$m / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;t\_m \leq 5.2 \cdot 10^{-22}:\\
\;\;\;\;\frac{2}{\frac{\frac{k}{\ell}}{\ell \cdot \frac{\frac{1}{t\_m \cdot \left(\sin k \cdot \tan k\right)}}{k}}}\\
\mathbf{elif}\;t\_m \leq 5 \cdot 10^{+153}:\\
\;\;\;\;\frac{\frac{\ell}{t\_m}}{t\_m \cdot \left(t\_m \cdot \sin k\right)} \cdot \left(2 \cdot \frac{\frac{\ell}{\tan k}}{2 + \frac{k}{\frac{t\_m}{\frac{k}{t\_m}}}}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\left(t\_m \cdot \left(\left(\sin k \cdot \left(2 + \frac{\frac{k}{\frac{t\_m}{k}}}{t\_m}\right)\right) \cdot \left(t\_m \cdot \frac{\tan k}{\ell}\right)\right)\right) \cdot \frac{t\_m}{\ell}}\\
\end{array}
\end{array}
if t < 5.2e-22Initial program 50.3%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified36.8%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6470.4%
Simplified70.4%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr69.5%
clear-numN/A
associate-/r*N/A
frac-timesN/A
*-lft-identityN/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
Applied egg-rr80.9%
if 5.2e-22 < t < 5.00000000000000018e153Initial program 60.6%
Applied egg-rr96.1%
if 5.00000000000000018e153 < t Initial program 74.6%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified42.1%
*-commutativeN/A
times-fracN/A
associate-*r*N/A
associate-/l*N/A
associate-*r*N/A
*-lowering-*.f64N/A
Applied egg-rr77.7%
associate-*r*N/A
*-lowering-*.f64N/A
Applied egg-rr93.6%
Final simplification84.0%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(let* ((t_2 (* (sin k) (tan k))))
(*
t_s
(if (<= k 4.4e-72)
(* (/ l t_m) (/ (/ l t_m) (* k (* t_m k))))
(if (<= k 1.3e+111)
(/ (/ 2.0 (/ t_m l)) (/ (* t_2 (+ (* 2.0 (* t_m t_m)) (* k k))) l))
(/ 2.0 (/ (/ k l) (* l (/ (/ 1.0 (* t_m t_2)) k)))))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double t_2 = sin(k) * tan(k);
double tmp;
if (k <= 4.4e-72) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else if (k <= 1.3e+111) {
tmp = (2.0 / (t_m / l)) / ((t_2 * ((2.0 * (t_m * t_m)) + (k * k))) / l);
} else {
tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * t_2)) / k)));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: t_2
real(8) :: tmp
t_2 = sin(k) * tan(k)
if (k <= 4.4d-72) then
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)))
else if (k <= 1.3d+111) then
tmp = (2.0d0 / (t_m / l)) / ((t_2 * ((2.0d0 * (t_m * t_m)) + (k * k))) / l)
else
tmp = 2.0d0 / ((k / l) / (l * ((1.0d0 / (t_m * t_2)) / k)))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double t_2 = Math.sin(k) * Math.tan(k);
double tmp;
if (k <= 4.4e-72) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else if (k <= 1.3e+111) {
tmp = (2.0 / (t_m / l)) / ((t_2 * ((2.0 * (t_m * t_m)) + (k * k))) / l);
} else {
tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * t_2)) / k)));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): t_2 = math.sin(k) * math.tan(k) tmp = 0 if k <= 4.4e-72: tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))) elif k <= 1.3e+111: tmp = (2.0 / (t_m / l)) / ((t_2 * ((2.0 * (t_m * t_m)) + (k * k))) / l) else: tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * t_2)) / k))) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) t_2 = Float64(sin(k) * tan(k)) tmp = 0.0 if (k <= 4.4e-72) tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(k * Float64(t_m * k)))); elseif (k <= 1.3e+111) tmp = Float64(Float64(2.0 / Float64(t_m / l)) / Float64(Float64(t_2 * Float64(Float64(2.0 * Float64(t_m * t_m)) + Float64(k * k))) / l)); else tmp = Float64(2.0 / Float64(Float64(k / l) / Float64(l * Float64(Float64(1.0 / Float64(t_m * t_2)) / k)))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) t_2 = sin(k) * tan(k); tmp = 0.0; if (k <= 4.4e-72) tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))); elseif (k <= 1.3e+111) tmp = (2.0 / (t_m / l)) / ((t_2 * ((2.0 * (t_m * t_m)) + (k * k))) / l); else tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * t_2)) / k))); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := Block[{t$95$2 = N[(N[Sin[k], $MachinePrecision] * N[Tan[k], $MachinePrecision]), $MachinePrecision]}, N[(t$95$s * If[LessEqual[k, 4.4e-72], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k, 1.3e+111], N[(N[(2.0 / N[(t$95$m / l), $MachinePrecision]), $MachinePrecision] / N[(N[(t$95$2 * N[(N[(2.0 * N[(t$95$m * t$95$m), $MachinePrecision]), $MachinePrecision] + N[(k * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(k / l), $MachinePrecision] / N[(l * N[(N[(1.0 / N[(t$95$m * t$95$2), $MachinePrecision]), $MachinePrecision] / k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
\begin{array}{l}
t_2 := \sin k \cdot \tan k\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k \leq 4.4 \cdot 10^{-72}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{k \cdot \left(t\_m \cdot k\right)}\\
\mathbf{elif}\;k \leq 1.3 \cdot 10^{+111}:\\
\;\;\;\;\frac{\frac{2}{\frac{t\_m}{\ell}}}{\frac{t\_2 \cdot \left(2 \cdot \left(t\_m \cdot t\_m\right) + k \cdot k\right)}{\ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{\frac{k}{\ell}}{\ell \cdot \frac{\frac{1}{t\_m \cdot t\_2}}{k}}}\\
\end{array}
\end{array}
\end{array}
if k < 4.40000000000000005e-72Initial program 59.7%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6456.9%
Simplified56.9%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6469.9%
Applied egg-rr69.9%
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f6474.6%
Applied egg-rr74.6%
if 4.40000000000000005e-72 < k < 1.2999999999999999e111Initial program 51.6%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified51.6%
Taylor expanded in t around 0
*-lowering-*.f64N/A
+-lowering-+.f64N/A
associate-*r/N/A
/-lowering-/.f64N/A
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f64N/A
/-lowering-/.f64N/A
Simplified83.7%
times-fracN/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
Applied egg-rr94.6%
if 1.2999999999999999e111 < k Initial program 37.5%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified21.0%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6459.3%
Simplified59.3%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr68.2%
clear-numN/A
associate-/r*N/A
frac-timesN/A
*-lft-identityN/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
Applied egg-rr92.6%
Final simplification80.9%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(*
t_s
(if (<= k 3.2e-72)
(* (/ l t_m) (/ (/ l t_m) (* k (* t_m k))))
(if (<= k 3.7e+148)
(/
l
(*
(* (sin k) (* (tan k) (+ (* 2.0 (* t_m t_m)) (* k k))))
(/ t_m (* 2.0 l))))
(/ 2.0 (/ (/ k l) (* l (/ (/ 1.0 (* t_m (* (sin k) (tan k)))) k))))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 3.2e-72) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else if (k <= 3.7e+148) {
tmp = l / ((sin(k) * (tan(k) * ((2.0 * (t_m * t_m)) + (k * k)))) * (t_m / (2.0 * l)));
} else {
tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * (sin(k) * tan(k)))) / k)));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: tmp
if (k <= 3.2d-72) then
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)))
else if (k <= 3.7d+148) then
tmp = l / ((sin(k) * (tan(k) * ((2.0d0 * (t_m * t_m)) + (k * k)))) * (t_m / (2.0d0 * l)))
else
tmp = 2.0d0 / ((k / l) / (l * ((1.0d0 / (t_m * (sin(k) * tan(k)))) / k)))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 3.2e-72) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else if (k <= 3.7e+148) {
tmp = l / ((Math.sin(k) * (Math.tan(k) * ((2.0 * (t_m * t_m)) + (k * k)))) * (t_m / (2.0 * l)));
} else {
tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * (Math.sin(k) * Math.tan(k)))) / k)));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): tmp = 0 if k <= 3.2e-72: tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))) elif k <= 3.7e+148: tmp = l / ((math.sin(k) * (math.tan(k) * ((2.0 * (t_m * t_m)) + (k * k)))) * (t_m / (2.0 * l))) else: tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * (math.sin(k) * math.tan(k)))) / k))) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) tmp = 0.0 if (k <= 3.2e-72) tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(k * Float64(t_m * k)))); elseif (k <= 3.7e+148) tmp = Float64(l / Float64(Float64(sin(k) * Float64(tan(k) * Float64(Float64(2.0 * Float64(t_m * t_m)) + Float64(k * k)))) * Float64(t_m / Float64(2.0 * l)))); else tmp = Float64(2.0 / Float64(Float64(k / l) / Float64(l * Float64(Float64(1.0 / Float64(t_m * Float64(sin(k) * tan(k)))) / k)))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) tmp = 0.0; if (k <= 3.2e-72) tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))); elseif (k <= 3.7e+148) tmp = l / ((sin(k) * (tan(k) * ((2.0 * (t_m * t_m)) + (k * k)))) * (t_m / (2.0 * l))); else tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * (sin(k) * tan(k)))) / k))); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * If[LessEqual[k, 3.2e-72], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k, 3.7e+148], N[(l / N[(N[(N[Sin[k], $MachinePrecision] * N[(N[Tan[k], $MachinePrecision] * N[(N[(2.0 * N[(t$95$m * t$95$m), $MachinePrecision]), $MachinePrecision] + N[(k * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(t$95$m / N[(2.0 * l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(k / l), $MachinePrecision] / N[(l * N[(N[(1.0 / N[(t$95$m * N[(N[Sin[k], $MachinePrecision] * N[Tan[k], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k \leq 3.2 \cdot 10^{-72}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{k \cdot \left(t\_m \cdot k\right)}\\
\mathbf{elif}\;k \leq 3.7 \cdot 10^{+148}:\\
\;\;\;\;\frac{\ell}{\left(\sin k \cdot \left(\tan k \cdot \left(2 \cdot \left(t\_m \cdot t\_m\right) + k \cdot k\right)\right)\right) \cdot \frac{t\_m}{2 \cdot \ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{\frac{k}{\ell}}{\ell \cdot \frac{\frac{1}{t\_m \cdot \left(\sin k \cdot \tan k\right)}}{k}}}\\
\end{array}
\end{array}
if k < 3.19999999999999999e-72Initial program 59.7%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6456.9%
Simplified56.9%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6469.9%
Applied egg-rr69.9%
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f6474.6%
Applied egg-rr74.6%
if 3.19999999999999999e-72 < k < 3.7000000000000002e148Initial program 44.1%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified46.0%
Taylor expanded in t around 0
*-lowering-*.f64N/A
+-lowering-+.f64N/A
associate-*r/N/A
/-lowering-/.f64N/A
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f64N/A
/-lowering-/.f64N/A
Simplified77.9%
times-fracN/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
Applied egg-rr93.6%
associate-/r/N/A
*-commutativeN/A
clear-numN/A
un-div-invN/A
/-lowering-/.f64N/A
div-invN/A
clear-numN/A
*-lowering-*.f64N/A
Applied egg-rr93.6%
if 3.7000000000000002e148 < k Initial program 43.1%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified17.6%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6460.6%
Simplified60.6%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr72.0%
clear-numN/A
associate-/r*N/A
frac-timesN/A
*-lft-identityN/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
Applied egg-rr93.1%
Final simplification80.9%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(let* ((t_2 (* (sin k) (tan k))))
(*
t_s
(if (<= k 2.7e-72)
(* (/ l t_m) (/ (/ l t_m) (* k (* t_m k))))
(if (<= k 3.5e+111)
(/ 2.0 (/ (/ (* t_2 (+ (* 2.0 (* t_m t_m)) (* k k))) (/ l t_m)) l))
(/ 2.0 (/ (/ k l) (* l (/ (/ 1.0 (* t_m t_2)) k)))))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double t_2 = sin(k) * tan(k);
double tmp;
if (k <= 2.7e-72) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else if (k <= 3.5e+111) {
tmp = 2.0 / (((t_2 * ((2.0 * (t_m * t_m)) + (k * k))) / (l / t_m)) / l);
} else {
tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * t_2)) / k)));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: t_2
real(8) :: tmp
t_2 = sin(k) * tan(k)
if (k <= 2.7d-72) then
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)))
else if (k <= 3.5d+111) then
tmp = 2.0d0 / (((t_2 * ((2.0d0 * (t_m * t_m)) + (k * k))) / (l / t_m)) / l)
else
tmp = 2.0d0 / ((k / l) / (l * ((1.0d0 / (t_m * t_2)) / k)))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double t_2 = Math.sin(k) * Math.tan(k);
double tmp;
if (k <= 2.7e-72) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else if (k <= 3.5e+111) {
tmp = 2.0 / (((t_2 * ((2.0 * (t_m * t_m)) + (k * k))) / (l / t_m)) / l);
} else {
tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * t_2)) / k)));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): t_2 = math.sin(k) * math.tan(k) tmp = 0 if k <= 2.7e-72: tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))) elif k <= 3.5e+111: tmp = 2.0 / (((t_2 * ((2.0 * (t_m * t_m)) + (k * k))) / (l / t_m)) / l) else: tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * t_2)) / k))) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) t_2 = Float64(sin(k) * tan(k)) tmp = 0.0 if (k <= 2.7e-72) tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(k * Float64(t_m * k)))); elseif (k <= 3.5e+111) tmp = Float64(2.0 / Float64(Float64(Float64(t_2 * Float64(Float64(2.0 * Float64(t_m * t_m)) + Float64(k * k))) / Float64(l / t_m)) / l)); else tmp = Float64(2.0 / Float64(Float64(k / l) / Float64(l * Float64(Float64(1.0 / Float64(t_m * t_2)) / k)))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) t_2 = sin(k) * tan(k); tmp = 0.0; if (k <= 2.7e-72) tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))); elseif (k <= 3.5e+111) tmp = 2.0 / (((t_2 * ((2.0 * (t_m * t_m)) + (k * k))) / (l / t_m)) / l); else tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * t_2)) / k))); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := Block[{t$95$2 = N[(N[Sin[k], $MachinePrecision] * N[Tan[k], $MachinePrecision]), $MachinePrecision]}, N[(t$95$s * If[LessEqual[k, 2.7e-72], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k, 3.5e+111], N[(2.0 / N[(N[(N[(t$95$2 * N[(N[(2.0 * N[(t$95$m * t$95$m), $MachinePrecision]), $MachinePrecision] + N[(k * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(l / t$95$m), $MachinePrecision]), $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(k / l), $MachinePrecision] / N[(l * N[(N[(1.0 / N[(t$95$m * t$95$2), $MachinePrecision]), $MachinePrecision] / k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
\begin{array}{l}
t_2 := \sin k \cdot \tan k\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k \leq 2.7 \cdot 10^{-72}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{k \cdot \left(t\_m \cdot k\right)}\\
\mathbf{elif}\;k \leq 3.5 \cdot 10^{+111}:\\
\;\;\;\;\frac{2}{\frac{\frac{t\_2 \cdot \left(2 \cdot \left(t\_m \cdot t\_m\right) + k \cdot k\right)}{\frac{\ell}{t\_m}}}{\ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{\frac{k}{\ell}}{\ell \cdot \frac{\frac{1}{t\_m \cdot t\_2}}{k}}}\\
\end{array}
\end{array}
\end{array}
if k < 2.7e-72Initial program 59.7%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6456.9%
Simplified56.9%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6469.9%
Applied egg-rr69.9%
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f6474.6%
Applied egg-rr74.6%
if 2.7e-72 < k < 3.5000000000000002e111Initial program 51.6%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified51.6%
Taylor expanded in t around 0
*-lowering-*.f64N/A
+-lowering-+.f64N/A
associate-*r/N/A
/-lowering-/.f64N/A
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f64N/A
/-lowering-/.f64N/A
Simplified83.7%
associate-/r*N/A
/-lowering-/.f64N/A
Applied egg-rr94.6%
if 3.5000000000000002e111 < k Initial program 37.5%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified21.0%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6459.3%
Simplified59.3%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr68.2%
clear-numN/A
associate-/r*N/A
frac-timesN/A
*-lft-identityN/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
Applied egg-rr92.6%
Final simplification80.9%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(let* ((t_2 (* t_m (* (sin k) (tan k)))))
(*
t_s
(if (<= k 3.5e-8)
(* (/ l t_m) (/ (/ l t_m) (* k (* t_m k))))
(if (<= k 7e+236)
(* l (/ (/ (/ 2.0 k) t_2) (/ k l)))
(/ 2.0 (* t_2 (/ k (/ l (/ k l))))))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double t_2 = t_m * (sin(k) * tan(k));
double tmp;
if (k <= 3.5e-8) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else if (k <= 7e+236) {
tmp = l * (((2.0 / k) / t_2) / (k / l));
} else {
tmp = 2.0 / (t_2 * (k / (l / (k / l))));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: t_2
real(8) :: tmp
t_2 = t_m * (sin(k) * tan(k))
if (k <= 3.5d-8) then
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)))
else if (k <= 7d+236) then
tmp = l * (((2.0d0 / k) / t_2) / (k / l))
else
tmp = 2.0d0 / (t_2 * (k / (l / (k / l))))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double t_2 = t_m * (Math.sin(k) * Math.tan(k));
double tmp;
if (k <= 3.5e-8) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else if (k <= 7e+236) {
tmp = l * (((2.0 / k) / t_2) / (k / l));
} else {
tmp = 2.0 / (t_2 * (k / (l / (k / l))));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): t_2 = t_m * (math.sin(k) * math.tan(k)) tmp = 0 if k <= 3.5e-8: tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))) elif k <= 7e+236: tmp = l * (((2.0 / k) / t_2) / (k / l)) else: tmp = 2.0 / (t_2 * (k / (l / (k / l)))) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) t_2 = Float64(t_m * Float64(sin(k) * tan(k))) tmp = 0.0 if (k <= 3.5e-8) tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(k * Float64(t_m * k)))); elseif (k <= 7e+236) tmp = Float64(l * Float64(Float64(Float64(2.0 / k) / t_2) / Float64(k / l))); else tmp = Float64(2.0 / Float64(t_2 * Float64(k / Float64(l / Float64(k / l))))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) t_2 = t_m * (sin(k) * tan(k)); tmp = 0.0; if (k <= 3.5e-8) tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))); elseif (k <= 7e+236) tmp = l * (((2.0 / k) / t_2) / (k / l)); else tmp = 2.0 / (t_2 * (k / (l / (k / l)))); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := Block[{t$95$2 = N[(t$95$m * N[(N[Sin[k], $MachinePrecision] * N[Tan[k], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, N[(t$95$s * If[LessEqual[k, 3.5e-8], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k, 7e+236], N[(l * N[(N[(N[(2.0 / k), $MachinePrecision] / t$95$2), $MachinePrecision] / N[(k / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(t$95$2 * N[(k / N[(l / N[(k / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
\begin{array}{l}
t_2 := t\_m \cdot \left(\sin k \cdot \tan k\right)\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k \leq 3.5 \cdot 10^{-8}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{k \cdot \left(t\_m \cdot k\right)}\\
\mathbf{elif}\;k \leq 7 \cdot 10^{+236}:\\
\;\;\;\;\ell \cdot \frac{\frac{\frac{2}{k}}{t\_2}}{\frac{k}{\ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{t\_2 \cdot \frac{k}{\frac{\ell}{\frac{k}{\ell}}}}\\
\end{array}
\end{array}
\end{array}
if k < 3.50000000000000024e-8Initial program 62.1%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6460.6%
Simplified60.6%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6472.4%
Applied egg-rr72.4%
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f6476.6%
Applied egg-rr76.6%
if 3.50000000000000024e-8 < k < 6.99999999999999958e236Initial program 30.2%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified20.3%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6461.1%
Simplified61.1%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr69.4%
associate-/r*N/A
associate-/r*N/A
associate-/r/N/A
*-lowering-*.f64N/A
Applied egg-rr89.0%
if 6.99999999999999958e236 < k Initial program 37.9%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified19.1%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6462.9%
Simplified62.9%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr69.3%
/-lowering-/.f64N/A
associate-*l/N/A
div-invN/A
clear-numN/A
*-lowering-*.f64N/A
clear-numN/A
un-div-invN/A
/-lowering-/.f64N/A
clear-numN/A
associate-/r*N/A
clear-numN/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
associate-/l*N/A
Applied egg-rr99.7%
Final simplification80.5%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(*
t_s
(if (<= k 6.5e-8)
(* (/ l t_m) (/ (/ l t_m) (* k (* t_m k))))
(/ 2.0 (/ (/ k l) (* l (/ (/ 1.0 (* t_m (* (sin k) (tan k)))) k)))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 6.5e-8) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else {
tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * (sin(k) * tan(k)))) / k)));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: tmp
if (k <= 6.5d-8) then
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)))
else
tmp = 2.0d0 / ((k / l) / (l * ((1.0d0 / (t_m * (sin(k) * tan(k)))) / k)))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 6.5e-8) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else {
tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * (Math.sin(k) * Math.tan(k)))) / k)));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): tmp = 0 if k <= 6.5e-8: tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))) else: tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * (math.sin(k) * math.tan(k)))) / k))) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) tmp = 0.0 if (k <= 6.5e-8) tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(k * Float64(t_m * k)))); else tmp = Float64(2.0 / Float64(Float64(k / l) / Float64(l * Float64(Float64(1.0 / Float64(t_m * Float64(sin(k) * tan(k)))) / k)))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) tmp = 0.0; if (k <= 6.5e-8) tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))); else tmp = 2.0 / ((k / l) / (l * ((1.0 / (t_m * (sin(k) * tan(k)))) / k))); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * If[LessEqual[k, 6.5e-8], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(k / l), $MachinePrecision] / N[(l * N[(N[(1.0 / N[(t$95$m * N[(N[Sin[k], $MachinePrecision] * N[Tan[k], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k \leq 6.5 \cdot 10^{-8}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{k \cdot \left(t\_m \cdot k\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{\frac{k}{\ell}}{\ell \cdot \frac{\frac{1}{t\_m \cdot \left(\sin k \cdot \tan k\right)}}{k}}}\\
\end{array}
\end{array}
if k < 6.49999999999999997e-8Initial program 62.1%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6460.6%
Simplified60.6%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6472.4%
Applied egg-rr72.4%
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f6476.6%
Applied egg-rr76.6%
if 6.49999999999999997e-8 < k Initial program 32.0%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified20.0%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6461.6%
Simplified61.6%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr69.4%
clear-numN/A
associate-/r*N/A
frac-timesN/A
*-lft-identityN/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
Applied egg-rr90.1%
Final simplification80.1%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(*
t_s
(if (<= k 1.6e-8)
(* (/ l t_m) (/ (/ l t_m) (* k (* t_m k))))
(/ 2.0 (* (/ k l) (/ (* k (* t_m (* (sin k) (tan k)))) l))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 1.6e-8) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else {
tmp = 2.0 / ((k / l) * ((k * (t_m * (sin(k) * tan(k)))) / l));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: tmp
if (k <= 1.6d-8) then
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)))
else
tmp = 2.0d0 / ((k / l) * ((k * (t_m * (sin(k) * tan(k)))) / l))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 1.6e-8) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else {
tmp = 2.0 / ((k / l) * ((k * (t_m * (Math.sin(k) * Math.tan(k)))) / l));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): tmp = 0 if k <= 1.6e-8: tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))) else: tmp = 2.0 / ((k / l) * ((k * (t_m * (math.sin(k) * math.tan(k)))) / l)) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) tmp = 0.0 if (k <= 1.6e-8) tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(k * Float64(t_m * k)))); else tmp = Float64(2.0 / Float64(Float64(k / l) * Float64(Float64(k * Float64(t_m * Float64(sin(k) * tan(k)))) / l))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) tmp = 0.0; if (k <= 1.6e-8) tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))); else tmp = 2.0 / ((k / l) * ((k * (t_m * (sin(k) * tan(k)))) / l)); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * If[LessEqual[k, 1.6e-8], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(k / l), $MachinePrecision] * N[(N[(k * N[(t$95$m * N[(N[Sin[k], $MachinePrecision] * N[Tan[k], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k \leq 1.6 \cdot 10^{-8}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{k \cdot \left(t\_m \cdot k\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{k}{\ell} \cdot \frac{k \cdot \left(t\_m \cdot \left(\sin k \cdot \tan k\right)\right)}{\ell}}\\
\end{array}
\end{array}
if k < 1.6000000000000001e-8Initial program 62.1%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6460.6%
Simplified60.6%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6472.4%
Applied egg-rr72.4%
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f6476.6%
Applied egg-rr76.6%
if 1.6000000000000001e-8 < k Initial program 32.0%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified20.0%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6461.6%
Simplified61.6%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr69.4%
associate-*r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr89.4%
Final simplification79.9%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(*
t_s
(if (<= k 2.6e-8)
(* (/ l t_m) (/ (/ l t_m) (* k (* t_m k))))
(* l (/ (/ (/ 2.0 k) (* t_m (* (sin k) (tan k)))) (/ k l))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 2.6e-8) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else {
tmp = l * (((2.0 / k) / (t_m * (sin(k) * tan(k)))) / (k / l));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: tmp
if (k <= 2.6d-8) then
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)))
else
tmp = l * (((2.0d0 / k) / (t_m * (sin(k) * tan(k)))) / (k / l))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 2.6e-8) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else {
tmp = l * (((2.0 / k) / (t_m * (Math.sin(k) * Math.tan(k)))) / (k / l));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): tmp = 0 if k <= 2.6e-8: tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))) else: tmp = l * (((2.0 / k) / (t_m * (math.sin(k) * math.tan(k)))) / (k / l)) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) tmp = 0.0 if (k <= 2.6e-8) tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(k * Float64(t_m * k)))); else tmp = Float64(l * Float64(Float64(Float64(2.0 / k) / Float64(t_m * Float64(sin(k) * tan(k)))) / Float64(k / l))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) tmp = 0.0; if (k <= 2.6e-8) tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))); else tmp = l * (((2.0 / k) / (t_m * (sin(k) * tan(k)))) / (k / l)); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * If[LessEqual[k, 2.6e-8], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(l * N[(N[(N[(2.0 / k), $MachinePrecision] / N[(t$95$m * N[(N[Sin[k], $MachinePrecision] * N[Tan[k], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(k / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k \leq 2.6 \cdot 10^{-8}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{k \cdot \left(t\_m \cdot k\right)}\\
\mathbf{else}:\\
\;\;\;\;\ell \cdot \frac{\frac{\frac{2}{k}}{t\_m \cdot \left(\sin k \cdot \tan k\right)}}{\frac{k}{\ell}}\\
\end{array}
\end{array}
if k < 2.6000000000000001e-8Initial program 62.1%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6460.6%
Simplified60.6%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6472.4%
Applied egg-rr72.4%
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f6476.6%
Applied egg-rr76.6%
if 2.6000000000000001e-8 < k Initial program 32.0%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified20.0%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6461.6%
Simplified61.6%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr69.4%
associate-/r*N/A
associate-/r*N/A
associate-/r/N/A
*-lowering-*.f64N/A
Applied egg-rr87.4%
Final simplification79.4%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(*
t_s
(if (<= k 1.9e-8)
(* (/ l t_m) (/ (/ l t_m) (* k (* t_m k))))
(* (/ (/ 2.0 k) (* t_m (* (sin k) (tan k)))) (/ l (/ k l))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 1.9e-8) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else {
tmp = ((2.0 / k) / (t_m * (sin(k) * tan(k)))) * (l / (k / l));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: tmp
if (k <= 1.9d-8) then
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)))
else
tmp = ((2.0d0 / k) / (t_m * (sin(k) * tan(k)))) * (l / (k / l))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 1.9e-8) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else {
tmp = ((2.0 / k) / (t_m * (Math.sin(k) * Math.tan(k)))) * (l / (k / l));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): tmp = 0 if k <= 1.9e-8: tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))) else: tmp = ((2.0 / k) / (t_m * (math.sin(k) * math.tan(k)))) * (l / (k / l)) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) tmp = 0.0 if (k <= 1.9e-8) tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(k * Float64(t_m * k)))); else tmp = Float64(Float64(Float64(2.0 / k) / Float64(t_m * Float64(sin(k) * tan(k)))) * Float64(l / Float64(k / l))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) tmp = 0.0; if (k <= 1.9e-8) tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))); else tmp = ((2.0 / k) / (t_m * (sin(k) * tan(k)))) * (l / (k / l)); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * If[LessEqual[k, 1.9e-8], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(2.0 / k), $MachinePrecision] / N[(t$95$m * N[(N[Sin[k], $MachinePrecision] * N[Tan[k], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(l / N[(k / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k \leq 1.9 \cdot 10^{-8}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{k \cdot \left(t\_m \cdot k\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{2}{k}}{t\_m \cdot \left(\sin k \cdot \tan k\right)} \cdot \frac{\ell}{\frac{k}{\ell}}\\
\end{array}
\end{array}
if k < 1.90000000000000014e-8Initial program 62.1%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6460.6%
Simplified60.6%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6472.4%
Applied egg-rr72.4%
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f6476.6%
Applied egg-rr76.6%
if 1.90000000000000014e-8 < k Initial program 32.0%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified20.0%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6461.6%
Simplified61.6%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr69.4%
associate-/r*N/A
div-invN/A
clear-numN/A
*-lowering-*.f64N/A
Applied egg-rr80.7%
Final simplification77.7%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(*
t_s
(if (<= (* l l) 5e-74)
(/
(/ (/ l k) (* (tan k) (+ (* 2.0 (* t_m t_m)) (* k k))))
(/ t_m (* 2.0 l)))
(* (/ l t_m) (/ (/ l t_m) (* k (* t_m k)))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double tmp;
if ((l * l) <= 5e-74) {
tmp = ((l / k) / (tan(k) * ((2.0 * (t_m * t_m)) + (k * k)))) / (t_m / (2.0 * l));
} else {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: tmp
if ((l * l) <= 5d-74) then
tmp = ((l / k) / (tan(k) * ((2.0d0 * (t_m * t_m)) + (k * k)))) / (t_m / (2.0d0 * l))
else
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double tmp;
if ((l * l) <= 5e-74) {
tmp = ((l / k) / (Math.tan(k) * ((2.0 * (t_m * t_m)) + (k * k)))) / (t_m / (2.0 * l));
} else {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): tmp = 0 if (l * l) <= 5e-74: tmp = ((l / k) / (math.tan(k) * ((2.0 * (t_m * t_m)) + (k * k)))) / (t_m / (2.0 * l)) else: tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) tmp = 0.0 if (Float64(l * l) <= 5e-74) tmp = Float64(Float64(Float64(l / k) / Float64(tan(k) * Float64(Float64(2.0 * Float64(t_m * t_m)) + Float64(k * k)))) / Float64(t_m / Float64(2.0 * l))); else tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(k * Float64(t_m * k)))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) tmp = 0.0; if ((l * l) <= 5e-74) tmp = ((l / k) / (tan(k) * ((2.0 * (t_m * t_m)) + (k * k)))) / (t_m / (2.0 * l)); else tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * If[LessEqual[N[(l * l), $MachinePrecision], 5e-74], N[(N[(N[(l / k), $MachinePrecision] / N[(N[Tan[k], $MachinePrecision] * N[(N[(2.0 * N[(t$95$m * t$95$m), $MachinePrecision]), $MachinePrecision] + N[(k * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$m / N[(2.0 * l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;\ell \cdot \ell \leq 5 \cdot 10^{-74}:\\
\;\;\;\;\frac{\frac{\frac{\ell}{k}}{\tan k \cdot \left(2 \cdot \left(t\_m \cdot t\_m\right) + k \cdot k\right)}}{\frac{t\_m}{2 \cdot \ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{k \cdot \left(t\_m \cdot k\right)}\\
\end{array}
\end{array}
if (*.f64 l l) < 4.99999999999999998e-74Initial program 62.6%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified40.1%
Taylor expanded in t around 0
*-lowering-*.f64N/A
+-lowering-+.f64N/A
associate-*r/N/A
/-lowering-/.f64N/A
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f64N/A
/-lowering-/.f64N/A
Simplified78.0%
times-fracN/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
Applied egg-rr87.0%
clear-numN/A
associate-/r/N/A
clear-numN/A
clear-numN/A
div-invN/A
/-lowering-/.f64N/A
Applied egg-rr97.9%
Taylor expanded in k around 0
/-lowering-/.f6492.5%
Simplified92.5%
if 4.99999999999999998e-74 < (*.f64 l l) Initial program 49.3%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6454.4%
Simplified54.4%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6464.4%
Applied egg-rr64.4%
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f6467.0%
Applied egg-rr67.0%
Final simplification76.7%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(*
t_s
(if (<= t_m 4.9e-62)
(/ 2.0 (* (* k k) (/ (/ (* t_m (* k k)) (* l l)) (cos k))))
(* (/ l t_m) (/ (/ l t_m) (* k (* t_m k)))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double tmp;
if (t_m <= 4.9e-62) {
tmp = 2.0 / ((k * k) * (((t_m * (k * k)) / (l * l)) / cos(k)));
} else {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: tmp
if (t_m <= 4.9d-62) then
tmp = 2.0d0 / ((k * k) * (((t_m * (k * k)) / (l * l)) / cos(k)))
else
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double tmp;
if (t_m <= 4.9e-62) {
tmp = 2.0 / ((k * k) * (((t_m * (k * k)) / (l * l)) / Math.cos(k)));
} else {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): tmp = 0 if t_m <= 4.9e-62: tmp = 2.0 / ((k * k) * (((t_m * (k * k)) / (l * l)) / math.cos(k))) else: tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) tmp = 0.0 if (t_m <= 4.9e-62) tmp = Float64(2.0 / Float64(Float64(k * k) * Float64(Float64(Float64(t_m * Float64(k * k)) / Float64(l * l)) / cos(k)))); else tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(k * Float64(t_m * k)))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) tmp = 0.0; if (t_m <= 4.9e-62) tmp = 2.0 / ((k * k) * (((t_m * (k * k)) / (l * l)) / cos(k))); else tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * If[LessEqual[t$95$m, 4.9e-62], N[(2.0 / N[(N[(k * k), $MachinePrecision] * N[(N[(N[(t$95$m * N[(k * k), $MachinePrecision]), $MachinePrecision] / N[(l * l), $MachinePrecision]), $MachinePrecision] / N[Cos[k], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;t\_m \leq 4.9 \cdot 10^{-62}:\\
\;\;\;\;\frac{2}{\left(k \cdot k\right) \cdot \frac{\frac{t\_m \cdot \left(k \cdot k\right)}{\ell \cdot \ell}}{\cos k}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{k \cdot \left(t\_m \cdot k\right)}\\
\end{array}
\end{array}
if t < 4.9000000000000004e-62Initial program 50.8%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified36.3%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6470.9%
Simplified70.9%
Taylor expanded in k around 0
/-lowering-/.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6461.2%
Simplified61.2%
if 4.9000000000000004e-62 < t Initial program 65.0%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6461.6%
Simplified61.6%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6477.4%
Applied egg-rr77.4%
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f6480.5%
Applied egg-rr80.5%
Final simplification66.1%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(*
t_s
(if (<= t_m 1.45e-66)
(/ (/ (/ 2.0 (* k k)) (/ k (/ l k))) (/ t_m l))
(* (/ l t_m) (/ (/ l t_m) (* k (* t_m k)))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double tmp;
if (t_m <= 1.45e-66) {
tmp = ((2.0 / (k * k)) / (k / (l / k))) / (t_m / l);
} else {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: tmp
if (t_m <= 1.45d-66) then
tmp = ((2.0d0 / (k * k)) / (k / (l / k))) / (t_m / l)
else
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double tmp;
if (t_m <= 1.45e-66) {
tmp = ((2.0 / (k * k)) / (k / (l / k))) / (t_m / l);
} else {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): tmp = 0 if t_m <= 1.45e-66: tmp = ((2.0 / (k * k)) / (k / (l / k))) / (t_m / l) else: tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) tmp = 0.0 if (t_m <= 1.45e-66) tmp = Float64(Float64(Float64(2.0 / Float64(k * k)) / Float64(k / Float64(l / k))) / Float64(t_m / l)); else tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(k * Float64(t_m * k)))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) tmp = 0.0; if (t_m <= 1.45e-66) tmp = ((2.0 / (k * k)) / (k / (l / k))) / (t_m / l); else tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * If[LessEqual[t$95$m, 1.45e-66], N[(N[(N[(2.0 / N[(k * k), $MachinePrecision]), $MachinePrecision] / N[(k / N[(l / k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(t$95$m / l), $MachinePrecision]), $MachinePrecision], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;t\_m \leq 1.45 \cdot 10^{-66}:\\
\;\;\;\;\frac{\frac{\frac{2}{k \cdot k}}{\frac{k}{\frac{\ell}{k}}}}{\frac{t\_m}{\ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{k \cdot \left(t\_m \cdot k\right)}\\
\end{array}
\end{array}
if t < 1.45000000000000006e-66Initial program 50.3%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified35.5%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6470.8%
Simplified70.8%
Taylor expanded in k around 0
/-lowering-/.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6458.7%
Simplified58.7%
associate-/r*N/A
times-fracN/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
associate-/l*N/A
clear-numN/A
un-div-invN/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f6460.1%
Applied egg-rr60.1%
if 1.45000000000000006e-66 < t Initial program 65.6%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6462.4%
Simplified62.4%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6477.3%
Applied egg-rr77.3%
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f6480.2%
Applied egg-rr80.2%
Final simplification65.4%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(*
t_s
(if (<= k 6.5e+64)
(* (/ l t_m) (/ (/ l t_m) (* k (* t_m k))))
(* (/ (* l -0.3333333333333333) k) (/ l (* t_m k))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 6.5e+64) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else {
tmp = ((l * -0.3333333333333333) / k) * (l / (t_m * k));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: tmp
if (k <= 6.5d+64) then
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)))
else
tmp = ((l * (-0.3333333333333333d0)) / k) * (l / (t_m * k))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 6.5e+64) {
tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k)));
} else {
tmp = ((l * -0.3333333333333333) / k) * (l / (t_m * k));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): tmp = 0 if k <= 6.5e+64: tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))) else: tmp = ((l * -0.3333333333333333) / k) * (l / (t_m * k)) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) tmp = 0.0 if (k <= 6.5e+64) tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(k * Float64(t_m * k)))); else tmp = Float64(Float64(Float64(l * -0.3333333333333333) / k) * Float64(l / Float64(t_m * k))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) tmp = 0.0; if (k <= 6.5e+64) tmp = (l / t_m) * ((l / t_m) / (k * (t_m * k))); else tmp = ((l * -0.3333333333333333) / k) * (l / (t_m * k)); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * If[LessEqual[k, 6.5e+64], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(l * -0.3333333333333333), $MachinePrecision] / k), $MachinePrecision] * N[(l / N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k \leq 6.5 \cdot 10^{+64}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{k \cdot \left(t\_m \cdot k\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{\ell \cdot -0.3333333333333333}{k} \cdot \frac{\ell}{t\_m \cdot k}\\
\end{array}
\end{array}
if k < 6.50000000000000007e64Initial program 59.5%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6459.2%
Simplified59.2%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6470.9%
Applied egg-rr70.9%
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f6475.0%
Applied egg-rr75.0%
if 6.50000000000000007e64 < k Initial program 35.8%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified21.7%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6461.6%
Simplified61.6%
Taylor expanded in k around 0
/-lowering-/.f64N/A
Simplified12.6%
Taylor expanded in k around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6453.6%
Simplified53.6%
associate-*r*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f6460.0%
Applied egg-rr60.0%
Final simplification71.7%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(*
t_s
(if (<= k 7.5e+64)
(* (/ l t_m) (/ (/ l t_m) (* t_m (* k k))))
(* (/ (* l -0.3333333333333333) k) (/ l (* t_m k))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 7.5e+64) {
tmp = (l / t_m) * ((l / t_m) / (t_m * (k * k)));
} else {
tmp = ((l * -0.3333333333333333) / k) * (l / (t_m * k));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: tmp
if (k <= 7.5d+64) then
tmp = (l / t_m) * ((l / t_m) / (t_m * (k * k)))
else
tmp = ((l * (-0.3333333333333333d0)) / k) * (l / (t_m * k))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 7.5e+64) {
tmp = (l / t_m) * ((l / t_m) / (t_m * (k * k)));
} else {
tmp = ((l * -0.3333333333333333) / k) * (l / (t_m * k));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): tmp = 0 if k <= 7.5e+64: tmp = (l / t_m) * ((l / t_m) / (t_m * (k * k))) else: tmp = ((l * -0.3333333333333333) / k) * (l / (t_m * k)) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) tmp = 0.0 if (k <= 7.5e+64) tmp = Float64(Float64(l / t_m) * Float64(Float64(l / t_m) / Float64(t_m * Float64(k * k)))); else tmp = Float64(Float64(Float64(l * -0.3333333333333333) / k) * Float64(l / Float64(t_m * k))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) tmp = 0.0; if (k <= 7.5e+64) tmp = (l / t_m) * ((l / t_m) / (t_m * (k * k))); else tmp = ((l * -0.3333333333333333) / k) * (l / (t_m * k)); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * If[LessEqual[k, 7.5e+64], N[(N[(l / t$95$m), $MachinePrecision] * N[(N[(l / t$95$m), $MachinePrecision] / N[(t$95$m * N[(k * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(l * -0.3333333333333333), $MachinePrecision] / k), $MachinePrecision] * N[(l / N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k \leq 7.5 \cdot 10^{+64}:\\
\;\;\;\;\frac{\ell}{t\_m} \cdot \frac{\frac{\ell}{t\_m}}{t\_m \cdot \left(k \cdot k\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{\ell \cdot -0.3333333333333333}{k} \cdot \frac{\ell}{t\_m \cdot k}\\
\end{array}
\end{array}
if k < 7.5000000000000005e64Initial program 59.5%
Taylor expanded in k around 0
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6459.2%
Simplified59.2%
associate-*l*N/A
associate-/r*N/A
associate-/l*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6470.9%
Applied egg-rr70.9%
if 7.5000000000000005e64 < k Initial program 35.8%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified21.7%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6461.6%
Simplified61.6%
Taylor expanded in k around 0
/-lowering-/.f64N/A
Simplified12.6%
Taylor expanded in k around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6453.6%
Simplified53.6%
associate-*r*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f6460.0%
Applied egg-rr60.0%
Final simplification68.5%
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k)
:precision binary64
(*
t_s
(if (<= k 32.0)
(/ 2.0 (* (/ t_m (* l l)) -17.142857142857142))
(* (* l -0.3333333333333333) (/ l (* k (* t_m k)))))))t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 32.0) {
tmp = 2.0 / ((t_m / (l * l)) * -17.142857142857142);
} else {
tmp = (l * -0.3333333333333333) * (l / (k * (t_m * k)));
}
return t_s * tmp;
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
real(8) :: tmp
if (k <= 32.0d0) then
tmp = 2.0d0 / ((t_m / (l * l)) * (-17.142857142857142d0))
else
tmp = (l * (-0.3333333333333333d0)) * (l / (k * (t_m * k)))
end if
code = t_s * tmp
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
double tmp;
if (k <= 32.0) {
tmp = 2.0 / ((t_m / (l * l)) * -17.142857142857142);
} else {
tmp = (l * -0.3333333333333333) * (l / (k * (t_m * k)));
}
return t_s * tmp;
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): tmp = 0 if k <= 32.0: tmp = 2.0 / ((t_m / (l * l)) * -17.142857142857142) else: tmp = (l * -0.3333333333333333) * (l / (k * (t_m * k))) return t_s * tmp
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) tmp = 0.0 if (k <= 32.0) tmp = Float64(2.0 / Float64(Float64(t_m / Float64(l * l)) * -17.142857142857142)); else tmp = Float64(Float64(l * -0.3333333333333333) * Float64(l / Float64(k * Float64(t_m * k)))); end return Float64(t_s * tmp) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k) tmp = 0.0; if (k <= 32.0) tmp = 2.0 / ((t_m / (l * l)) * -17.142857142857142); else tmp = (l * -0.3333333333333333) * (l / (k * (t_m * k))); end tmp_2 = t_s * tmp; end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * If[LessEqual[k, 32.0], N[(2.0 / N[(N[(t$95$m / N[(l * l), $MachinePrecision]), $MachinePrecision] * -17.142857142857142), $MachinePrecision]), $MachinePrecision], N[(N[(l * -0.3333333333333333), $MachinePrecision] * N[(l / N[(k * N[(t$95$m * k), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k \leq 32:\\
\;\;\;\;\frac{2}{\frac{t\_m}{\ell \cdot \ell} \cdot -17.142857142857142}\\
\mathbf{else}:\\
\;\;\;\;\left(\ell \cdot -0.3333333333333333\right) \cdot \frac{\ell}{k \cdot \left(t\_m \cdot k\right)}\\
\end{array}
\end{array}
if k < 32Initial program 61.8%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified46.6%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6467.8%
Simplified67.8%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr62.5%
Taylor expanded in k around 0
/-lowering-/.f64N/A
Simplified43.9%
Taylor expanded in k around inf
*-commutativeN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f6425.4%
Simplified25.4%
if 32 < k Initial program 32.5%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified20.3%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6461.0%
Simplified61.0%
Taylor expanded in k around 0
/-lowering-/.f64N/A
Simplified11.1%
Taylor expanded in k around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6446.5%
Simplified46.5%
associate-*r*N/A
associate-/l*N/A
*-commutativeN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6453.4%
Applied egg-rr53.4%
Final simplification32.5%
t\_m = (fabs.f64 t) t\_s = (copysign.f64 #s(literal 1 binary64) t) (FPCore (t_s t_m l k) :precision binary64 (* t_s (/ 2.0 (* (/ t_m (* l l)) -17.142857142857142))))
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
return t_s * (2.0 / ((t_m / (l * l)) * -17.142857142857142));
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
code = t_s * (2.0d0 / ((t_m / (l * l)) * (-17.142857142857142d0)))
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
return t_s * (2.0 / ((t_m / (l * l)) * -17.142857142857142));
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): return t_s * (2.0 / ((t_m / (l * l)) * -17.142857142857142))
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) return Float64(t_s * Float64(2.0 / Float64(Float64(t_m / Float64(l * l)) * -17.142857142857142))) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp = code(t_s, t_m, l, k) tmp = t_s * (2.0 / ((t_m / (l * l)) * -17.142857142857142)); end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * N[(2.0 / N[(N[(t$95$m / N[(l * l), $MachinePrecision]), $MachinePrecision] * -17.142857142857142), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \frac{2}{\frac{t\_m}{\ell \cdot \ell} \cdot -17.142857142857142}
\end{array}
Initial program 54.4%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified39.9%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6466.1%
Simplified66.1%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr64.2%
Taylor expanded in k around 0
/-lowering-/.f64N/A
Simplified33.4%
Taylor expanded in k around inf
*-commutativeN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f6426.1%
Simplified26.1%
t\_m = (fabs.f64 t) t\_s = (copysign.f64 #s(literal 1 binary64) t) (FPCore (t_s t_m l k) :precision binary64 (* t_s (* (/ (* l l) t_m) -0.11666666666666667)))
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k) {
return t_s * (((l * l) / t_m) * -0.11666666666666667);
}
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k
code = t_s * (((l * l) / t_m) * (-0.11666666666666667d0))
end function
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
public static double code(double t_s, double t_m, double l, double k) {
return t_s * (((l * l) / t_m) * -0.11666666666666667);
}
t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k): return t_s * (((l * l) / t_m) * -0.11666666666666667)
t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k) return Float64(t_s * Float64(Float64(Float64(l * l) / t_m) * -0.11666666666666667)) end
t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp = code(t_s, t_m, l, k) tmp = t_s * (((l * l) / t_m) * -0.11666666666666667); end
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[t$95$s_, t$95$m_, l_, k_] := N[(t$95$s * N[(N[(N[(l * l), $MachinePrecision] / t$95$m), $MachinePrecision] * -0.11666666666666667), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \left(\frac{\ell \cdot \ell}{t\_m} \cdot -0.11666666666666667\right)
\end{array}
Initial program 54.4%
/-lowering-/.f64N/A
associate-*l*N/A
associate-*l/N/A
associate-*l/N/A
/-lowering-/.f64N/A
Simplified39.9%
Taylor expanded in t around 0
associate-/l*N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
times-fracN/A
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f64N/A
pow-lowering-pow.f64N/A
sin-lowering-sin.f64N/A
cos-lowering-cos.f6466.1%
Simplified66.1%
clear-numN/A
un-div-invN/A
associate-*l/N/A
associate-/r/N/A
times-fracN/A
*-lowering-*.f64N/A
Applied egg-rr64.2%
Taylor expanded in k around 0
/-lowering-/.f64N/A
Simplified33.4%
Taylor expanded in k around inf
*-commutativeN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
unpow2N/A
*-lowering-*.f6425.6%
Simplified25.6%
herbie shell --seed 2024164
(FPCore (t l k)
:name "Toniolo and Linder, Equation (10+)"
:precision binary64
(/ 2.0 (* (* (* (/ (pow t 3.0) (* l l)) (sin k)) (tan k)) (+ (+ 1.0 (pow (/ k t) 2.0)) 1.0))))