
(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 24 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}
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(let* ((t_2 (pow (cbrt l) 2.0)) (t_3 (* (tan k_m) (sin k_m))))
(*
t_s
(if (<= k_m 1.3e-115)
(/
2.0
(*
(pow (* (/ (cbrt k_m) t_2) t_m) 3.0)
(* (tan k_m) (+ 1.0 (+ 1.0 (/ (/ k_m t_m) (/ t_m k_m)))))))
(if (<= k_m 1.6)
(/
2.0
(pow
(*
(/ (pow t_m 1.5) l)
(* (hypot 1.0 (hypot 1.0 (/ k_m t_m))) (sqrt t_3)))
2.0))
(if (<= k_m 1.2e+154)
(/
2.0
(/
(* (* t_m (pow k_m 2.0)) (- 0.5 (/ (cos (* k_m 2.0)) 2.0)))
(* (pow l 2.0) (cos k_m))))
(/
2.0
(pow
(* (/ t_m t_2) (cbrt (* t_3 (+ 2.0 (pow (/ k_m t_m) 2.0)))))
3.0))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double t_2 = pow(cbrt(l), 2.0);
double t_3 = tan(k_m) * sin(k_m);
double tmp;
if (k_m <= 1.3e-115) {
tmp = 2.0 / (pow(((cbrt(k_m) / t_2) * t_m), 3.0) * (tan(k_m) * (1.0 + (1.0 + ((k_m / t_m) / (t_m / k_m))))));
} else if (k_m <= 1.6) {
tmp = 2.0 / pow(((pow(t_m, 1.5) / l) * (hypot(1.0, hypot(1.0, (k_m / t_m))) * sqrt(t_3))), 2.0);
} else if (k_m <= 1.2e+154) {
tmp = 2.0 / (((t_m * pow(k_m, 2.0)) * (0.5 - (cos((k_m * 2.0)) / 2.0))) / (pow(l, 2.0) * cos(k_m)));
} else {
tmp = 2.0 / pow(((t_m / t_2) * cbrt((t_3 * (2.0 + pow((k_m / t_m), 2.0))))), 3.0);
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double t_2 = Math.pow(Math.cbrt(l), 2.0);
double t_3 = Math.tan(k_m) * Math.sin(k_m);
double tmp;
if (k_m <= 1.3e-115) {
tmp = 2.0 / (Math.pow(((Math.cbrt(k_m) / t_2) * t_m), 3.0) * (Math.tan(k_m) * (1.0 + (1.0 + ((k_m / t_m) / (t_m / k_m))))));
} else if (k_m <= 1.6) {
tmp = 2.0 / Math.pow(((Math.pow(t_m, 1.5) / l) * (Math.hypot(1.0, Math.hypot(1.0, (k_m / t_m))) * Math.sqrt(t_3))), 2.0);
} else if (k_m <= 1.2e+154) {
tmp = 2.0 / (((t_m * Math.pow(k_m, 2.0)) * (0.5 - (Math.cos((k_m * 2.0)) / 2.0))) / (Math.pow(l, 2.0) * Math.cos(k_m)));
} else {
tmp = 2.0 / Math.pow(((t_m / t_2) * Math.cbrt((t_3 * (2.0 + Math.pow((k_m / t_m), 2.0))))), 3.0);
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) t_2 = cbrt(l) ^ 2.0 t_3 = Float64(tan(k_m) * sin(k_m)) tmp = 0.0 if (k_m <= 1.3e-115) tmp = Float64(2.0 / Float64((Float64(Float64(cbrt(k_m) / t_2) * t_m) ^ 3.0) * Float64(tan(k_m) * Float64(1.0 + Float64(1.0 + Float64(Float64(k_m / t_m) / Float64(t_m / k_m))))))); elseif (k_m <= 1.6) tmp = Float64(2.0 / (Float64(Float64((t_m ^ 1.5) / l) * Float64(hypot(1.0, hypot(1.0, Float64(k_m / t_m))) * sqrt(t_3))) ^ 2.0)); elseif (k_m <= 1.2e+154) tmp = Float64(2.0 / Float64(Float64(Float64(t_m * (k_m ^ 2.0)) * Float64(0.5 - Float64(cos(Float64(k_m * 2.0)) / 2.0))) / Float64((l ^ 2.0) * cos(k_m)))); else tmp = Float64(2.0 / (Float64(Float64(t_m / t_2) * cbrt(Float64(t_3 * Float64(2.0 + (Float64(k_m / t_m) ^ 2.0))))) ^ 3.0)); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := Block[{t$95$2 = N[Power[N[Power[l, 1/3], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$3 = N[(N[Tan[k$95$m], $MachinePrecision] * N[Sin[k$95$m], $MachinePrecision]), $MachinePrecision]}, N[(t$95$s * If[LessEqual[k$95$m, 1.3e-115], N[(2.0 / N[(N[Power[N[(N[(N[Power[k$95$m, 1/3], $MachinePrecision] / t$95$2), $MachinePrecision] * t$95$m), $MachinePrecision], 3.0], $MachinePrecision] * N[(N[Tan[k$95$m], $MachinePrecision] * N[(1.0 + N[(1.0 + N[(N[(k$95$m / t$95$m), $MachinePrecision] / N[(t$95$m / k$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 1.6], N[(2.0 / N[Power[N[(N[(N[Power[t$95$m, 1.5], $MachinePrecision] / l), $MachinePrecision] * N[(N[Sqrt[1.0 ^ 2 + N[Sqrt[1.0 ^ 2 + N[(k$95$m / t$95$m), $MachinePrecision] ^ 2], $MachinePrecision] ^ 2], $MachinePrecision] * N[Sqrt[t$95$3], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 1.2e+154], N[(2.0 / N[(N[(N[(t$95$m * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(0.5 - N[(N[Cos[N[(k$95$m * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[Power[N[(N[(t$95$m / t$95$2), $MachinePrecision] * N[Power[N[(t$95$3 * N[(2.0 + N[Power[N[(k$95$m / t$95$m), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision]), $MachinePrecision]]]]), $MachinePrecision]]]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
\begin{array}{l}
t_2 := {\left(\sqrt[3]{\ell}\right)}^{2}\\
t_3 := \tan k\_m \cdot \sin k\_m\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 1.3 \cdot 10^{-115}:\\
\;\;\;\;\frac{2}{{\left(\frac{\sqrt[3]{k\_m}}{t\_2} \cdot t\_m\right)}^{3} \cdot \left(\tan k\_m \cdot \left(1 + \left(1 + \frac{\frac{k\_m}{t\_m}}{\frac{t\_m}{k\_m}}\right)\right)\right)}\\
\mathbf{elif}\;k\_m \leq 1.6:\\
\;\;\;\;\frac{2}{{\left(\frac{{t\_m}^{1.5}}{\ell} \cdot \left(\mathsf{hypot}\left(1, \mathsf{hypot}\left(1, \frac{k\_m}{t\_m}\right)\right) \cdot \sqrt{t\_3}\right)\right)}^{2}}\\
\mathbf{elif}\;k\_m \leq 1.2 \cdot 10^{+154}:\\
\;\;\;\;\frac{2}{\frac{\left(t\_m \cdot {k\_m}^{2}\right) \cdot \left(0.5 - \frac{\cos \left(k\_m \cdot 2\right)}{2}\right)}{{\ell}^{2} \cdot \cos k\_m}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{{\left(\frac{t\_m}{t\_2} \cdot \sqrt[3]{t\_3 \cdot \left(2 + {\left(\frac{k\_m}{t\_m}\right)}^{2}\right)}\right)}^{3}}\\
\end{array}
\end{array}
\end{array}
if k < 1.30000000000000002e-115Initial program 58.5%
Simplified58.5%
add-cube-cbrt58.5%
pow358.5%
*-commutative58.5%
cbrt-prod58.4%
cbrt-div59.0%
rem-cbrt-cube65.0%
cbrt-prod80.0%
pow280.0%
Applied egg-rr80.0%
*-commutative80.0%
Simplified80.0%
unpow280.0%
clear-num80.0%
un-div-inv80.0%
Applied egg-rr80.0%
Taylor expanded in k around 0 60.7%
cbrt-div62.3%
pow262.3%
cbrt-prod76.3%
unpow276.3%
Applied egg-rr76.3%
if 1.30000000000000002e-115 < k < 1.6000000000000001Initial program 65.6%
Applied egg-rr57.2%
if 1.6000000000000001 < k < 1.20000000000000007e154Initial program 68.2%
Taylor expanded in t around 0 86.2%
associate-*r*86.2%
Simplified86.2%
unpow286.2%
sin-mult86.2%
Applied egg-rr86.2%
div-sub86.2%
+-inverses86.2%
cos-086.2%
metadata-eval86.2%
count-286.2%
*-commutative86.2%
Simplified86.2%
if 1.20000000000000007e154 < k Initial program 34.9%
add-cube-cbrt34.9%
pow334.9%
Applied egg-rr73.2%
Final simplification75.2%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 1.9e-112)
(/
2.0
(*
(pow (* (/ (cbrt k_m) (pow (cbrt l) 2.0)) t_m) 3.0)
(* (tan k_m) (+ 1.0 (+ 1.0 (/ (/ k_m t_m) (/ t_m k_m)))))))
(if (<= k_m 1.6)
(/
2.0
(pow
(*
(/ (pow t_m 1.5) l)
(*
(hypot 1.0 (hypot 1.0 (/ k_m t_m)))
(sqrt (* (tan k_m) (sin k_m)))))
2.0))
(if (<= k_m 1.35e+154)
(/
2.0
(/
(* (* t_m (pow k_m 2.0)) (- 0.5 (/ (cos (* k_m 2.0)) 2.0)))
(* (pow l 2.0) (cos k_m))))
(/
2.0
(pow
(*
(* t_m (pow (cbrt l) -2.0))
(cbrt (* (sin k_m) (* (tan k_m) (+ 2.0 (pow (/ k_m t_m) 2.0))))))
3.0)))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 1.9e-112) {
tmp = 2.0 / (pow(((cbrt(k_m) / pow(cbrt(l), 2.0)) * t_m), 3.0) * (tan(k_m) * (1.0 + (1.0 + ((k_m / t_m) / (t_m / k_m))))));
} else if (k_m <= 1.6) {
tmp = 2.0 / pow(((pow(t_m, 1.5) / l) * (hypot(1.0, hypot(1.0, (k_m / t_m))) * sqrt((tan(k_m) * sin(k_m))))), 2.0);
} else if (k_m <= 1.35e+154) {
tmp = 2.0 / (((t_m * pow(k_m, 2.0)) * (0.5 - (cos((k_m * 2.0)) / 2.0))) / (pow(l, 2.0) * cos(k_m)));
} else {
tmp = 2.0 / pow(((t_m * pow(cbrt(l), -2.0)) * cbrt((sin(k_m) * (tan(k_m) * (2.0 + pow((k_m / t_m), 2.0)))))), 3.0);
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 1.9e-112) {
tmp = 2.0 / (Math.pow(((Math.cbrt(k_m) / Math.pow(Math.cbrt(l), 2.0)) * t_m), 3.0) * (Math.tan(k_m) * (1.0 + (1.0 + ((k_m / t_m) / (t_m / k_m))))));
} else if (k_m <= 1.6) {
tmp = 2.0 / Math.pow(((Math.pow(t_m, 1.5) / l) * (Math.hypot(1.0, Math.hypot(1.0, (k_m / t_m))) * Math.sqrt((Math.tan(k_m) * Math.sin(k_m))))), 2.0);
} else if (k_m <= 1.35e+154) {
tmp = 2.0 / (((t_m * Math.pow(k_m, 2.0)) * (0.5 - (Math.cos((k_m * 2.0)) / 2.0))) / (Math.pow(l, 2.0) * Math.cos(k_m)));
} else {
tmp = 2.0 / Math.pow(((t_m * Math.pow(Math.cbrt(l), -2.0)) * Math.cbrt((Math.sin(k_m) * (Math.tan(k_m) * (2.0 + Math.pow((k_m / t_m), 2.0)))))), 3.0);
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 1.9e-112) tmp = Float64(2.0 / Float64((Float64(Float64(cbrt(k_m) / (cbrt(l) ^ 2.0)) * t_m) ^ 3.0) * Float64(tan(k_m) * Float64(1.0 + Float64(1.0 + Float64(Float64(k_m / t_m) / Float64(t_m / k_m))))))); elseif (k_m <= 1.6) tmp = Float64(2.0 / (Float64(Float64((t_m ^ 1.5) / l) * Float64(hypot(1.0, hypot(1.0, Float64(k_m / t_m))) * sqrt(Float64(tan(k_m) * sin(k_m))))) ^ 2.0)); elseif (k_m <= 1.35e+154) tmp = Float64(2.0 / Float64(Float64(Float64(t_m * (k_m ^ 2.0)) * Float64(0.5 - Float64(cos(Float64(k_m * 2.0)) / 2.0))) / Float64((l ^ 2.0) * cos(k_m)))); else tmp = Float64(2.0 / (Float64(Float64(t_m * (cbrt(l) ^ -2.0)) * cbrt(Float64(sin(k_m) * Float64(tan(k_m) * Float64(2.0 + (Float64(k_m / t_m) ^ 2.0)))))) ^ 3.0)); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 1.9e-112], N[(2.0 / N[(N[Power[N[(N[(N[Power[k$95$m, 1/3], $MachinePrecision] / N[Power[N[Power[l, 1/3], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision] * t$95$m), $MachinePrecision], 3.0], $MachinePrecision] * N[(N[Tan[k$95$m], $MachinePrecision] * N[(1.0 + N[(1.0 + N[(N[(k$95$m / t$95$m), $MachinePrecision] / N[(t$95$m / k$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 1.6], N[(2.0 / N[Power[N[(N[(N[Power[t$95$m, 1.5], $MachinePrecision] / l), $MachinePrecision] * N[(N[Sqrt[1.0 ^ 2 + N[Sqrt[1.0 ^ 2 + N[(k$95$m / t$95$m), $MachinePrecision] ^ 2], $MachinePrecision] ^ 2], $MachinePrecision] * N[Sqrt[N[(N[Tan[k$95$m], $MachinePrecision] * N[Sin[k$95$m], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 1.35e+154], N[(2.0 / N[(N[(N[(t$95$m * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(0.5 - N[(N[Cos[N[(k$95$m * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[Power[N[(N[(t$95$m * N[Power[N[Power[l, 1/3], $MachinePrecision], -2.0], $MachinePrecision]), $MachinePrecision] * N[Power[N[(N[Sin[k$95$m], $MachinePrecision] * N[(N[Tan[k$95$m], $MachinePrecision] * N[(2.0 + N[Power[N[(k$95$m / t$95$m), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision]), $MachinePrecision]]]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 1.9 \cdot 10^{-112}:\\
\;\;\;\;\frac{2}{{\left(\frac{\sqrt[3]{k\_m}}{{\left(\sqrt[3]{\ell}\right)}^{2}} \cdot t\_m\right)}^{3} \cdot \left(\tan k\_m \cdot \left(1 + \left(1 + \frac{\frac{k\_m}{t\_m}}{\frac{t\_m}{k\_m}}\right)\right)\right)}\\
\mathbf{elif}\;k\_m \leq 1.6:\\
\;\;\;\;\frac{2}{{\left(\frac{{t\_m}^{1.5}}{\ell} \cdot \left(\mathsf{hypot}\left(1, \mathsf{hypot}\left(1, \frac{k\_m}{t\_m}\right)\right) \cdot \sqrt{\tan k\_m \cdot \sin k\_m}\right)\right)}^{2}}\\
\mathbf{elif}\;k\_m \leq 1.35 \cdot 10^{+154}:\\
\;\;\;\;\frac{2}{\frac{\left(t\_m \cdot {k\_m}^{2}\right) \cdot \left(0.5 - \frac{\cos \left(k\_m \cdot 2\right)}{2}\right)}{{\ell}^{2} \cdot \cos k\_m}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{{\left(\left(t\_m \cdot {\left(\sqrt[3]{\ell}\right)}^{-2}\right) \cdot \sqrt[3]{\sin k\_m \cdot \left(\tan k\_m \cdot \left(2 + {\left(\frac{k\_m}{t\_m}\right)}^{2}\right)\right)}\right)}^{3}}\\
\end{array}
\end{array}
if k < 1.89999999999999997e-112Initial program 58.5%
Simplified58.5%
add-cube-cbrt58.5%
pow358.5%
*-commutative58.5%
cbrt-prod58.4%
cbrt-div59.0%
rem-cbrt-cube65.0%
cbrt-prod80.0%
pow280.0%
Applied egg-rr80.0%
*-commutative80.0%
Simplified80.0%
unpow280.0%
clear-num80.0%
un-div-inv80.0%
Applied egg-rr80.0%
Taylor expanded in k around 0 60.7%
cbrt-div62.3%
pow262.3%
cbrt-prod76.3%
unpow276.3%
Applied egg-rr76.3%
if 1.89999999999999997e-112 < k < 1.6000000000000001Initial program 65.6%
Applied egg-rr57.2%
if 1.6000000000000001 < k < 1.35000000000000003e154Initial program 68.2%
Taylor expanded in t around 0 86.2%
associate-*r*86.2%
Simplified86.2%
unpow286.2%
sin-mult86.2%
Applied egg-rr86.2%
div-sub86.2%
+-inverses86.2%
cos-086.2%
metadata-eval86.2%
count-286.2%
*-commutative86.2%
Simplified86.2%
if 1.35000000000000003e154 < k Initial program 34.9%
Simplified35.0%
add-cube-cbrt34.9%
pow334.9%
*-commutative34.9%
cbrt-prod34.8%
cbrt-div34.9%
rem-cbrt-cube46.6%
cbrt-prod54.0%
pow254.0%
Applied egg-rr54.0%
*-commutative54.0%
Simplified54.0%
Applied egg-rr73.1%
Final simplification75.1%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 2e-115)
(/
2.0
(*
(pow (* (/ (cbrt k_m) (pow (cbrt l) 2.0)) t_m) 3.0)
(* (tan k_m) (+ 1.0 (+ 1.0 (/ (/ k_m t_m) (/ t_m k_m)))))))
(if (<= k_m 1.6)
(/
2.0
(pow
(*
(/ (pow t_m 1.5) l)
(*
(hypot 1.0 (hypot 1.0 (/ k_m t_m)))
(sqrt (* (tan k_m) (sin k_m)))))
2.0))
(/
2.0
(/
(* (* t_m (pow k_m 2.0)) (- 0.5 (/ (cos (* k_m 2.0)) 2.0)))
(* (pow l 2.0) (cos k_m))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 2e-115) {
tmp = 2.0 / (pow(((cbrt(k_m) / pow(cbrt(l), 2.0)) * t_m), 3.0) * (tan(k_m) * (1.0 + (1.0 + ((k_m / t_m) / (t_m / k_m))))));
} else if (k_m <= 1.6) {
tmp = 2.0 / pow(((pow(t_m, 1.5) / l) * (hypot(1.0, hypot(1.0, (k_m / t_m))) * sqrt((tan(k_m) * sin(k_m))))), 2.0);
} else {
tmp = 2.0 / (((t_m * pow(k_m, 2.0)) * (0.5 - (cos((k_m * 2.0)) / 2.0))) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 2e-115) {
tmp = 2.0 / (Math.pow(((Math.cbrt(k_m) / Math.pow(Math.cbrt(l), 2.0)) * t_m), 3.0) * (Math.tan(k_m) * (1.0 + (1.0 + ((k_m / t_m) / (t_m / k_m))))));
} else if (k_m <= 1.6) {
tmp = 2.0 / Math.pow(((Math.pow(t_m, 1.5) / l) * (Math.hypot(1.0, Math.hypot(1.0, (k_m / t_m))) * Math.sqrt((Math.tan(k_m) * Math.sin(k_m))))), 2.0);
} else {
tmp = 2.0 / (((t_m * Math.pow(k_m, 2.0)) * (0.5 - (Math.cos((k_m * 2.0)) / 2.0))) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 2e-115) tmp = Float64(2.0 / Float64((Float64(Float64(cbrt(k_m) / (cbrt(l) ^ 2.0)) * t_m) ^ 3.0) * Float64(tan(k_m) * Float64(1.0 + Float64(1.0 + Float64(Float64(k_m / t_m) / Float64(t_m / k_m))))))); elseif (k_m <= 1.6) tmp = Float64(2.0 / (Float64(Float64((t_m ^ 1.5) / l) * Float64(hypot(1.0, hypot(1.0, Float64(k_m / t_m))) * sqrt(Float64(tan(k_m) * sin(k_m))))) ^ 2.0)); else tmp = Float64(2.0 / Float64(Float64(Float64(t_m * (k_m ^ 2.0)) * Float64(0.5 - Float64(cos(Float64(k_m * 2.0)) / 2.0))) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 2e-115], N[(2.0 / N[(N[Power[N[(N[(N[Power[k$95$m, 1/3], $MachinePrecision] / N[Power[N[Power[l, 1/3], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision] * t$95$m), $MachinePrecision], 3.0], $MachinePrecision] * N[(N[Tan[k$95$m], $MachinePrecision] * N[(1.0 + N[(1.0 + N[(N[(k$95$m / t$95$m), $MachinePrecision] / N[(t$95$m / k$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 1.6], N[(2.0 / N[Power[N[(N[(N[Power[t$95$m, 1.5], $MachinePrecision] / l), $MachinePrecision] * N[(N[Sqrt[1.0 ^ 2 + N[Sqrt[1.0 ^ 2 + N[(k$95$m / t$95$m), $MachinePrecision] ^ 2], $MachinePrecision] ^ 2], $MachinePrecision] * N[Sqrt[N[(N[Tan[k$95$m], $MachinePrecision] * N[Sin[k$95$m], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(N[(t$95$m * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(0.5 - N[(N[Cos[N[(k$95$m * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 2 \cdot 10^{-115}:\\
\;\;\;\;\frac{2}{{\left(\frac{\sqrt[3]{k\_m}}{{\left(\sqrt[3]{\ell}\right)}^{2}} \cdot t\_m\right)}^{3} \cdot \left(\tan k\_m \cdot \left(1 + \left(1 + \frac{\frac{k\_m}{t\_m}}{\frac{t\_m}{k\_m}}\right)\right)\right)}\\
\mathbf{elif}\;k\_m \leq 1.6:\\
\;\;\;\;\frac{2}{{\left(\frac{{t\_m}^{1.5}}{\ell} \cdot \left(\mathsf{hypot}\left(1, \mathsf{hypot}\left(1, \frac{k\_m}{t\_m}\right)\right) \cdot \sqrt{\tan k\_m \cdot \sin k\_m}\right)\right)}^{2}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{\left(t\_m \cdot {k\_m}^{2}\right) \cdot \left(0.5 - \frac{\cos \left(k\_m \cdot 2\right)}{2}\right)}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
if k < 2.0000000000000001e-115Initial program 58.5%
Simplified58.5%
add-cube-cbrt58.5%
pow358.5%
*-commutative58.5%
cbrt-prod58.4%
cbrt-div59.0%
rem-cbrt-cube65.0%
cbrt-prod80.0%
pow280.0%
Applied egg-rr80.0%
*-commutative80.0%
Simplified80.0%
unpow280.0%
clear-num80.0%
un-div-inv80.0%
Applied egg-rr80.0%
Taylor expanded in k around 0 60.7%
cbrt-div62.3%
pow262.3%
cbrt-prod76.3%
unpow276.3%
Applied egg-rr76.3%
if 2.0000000000000001e-115 < k < 1.6000000000000001Initial program 65.6%
Applied egg-rr57.2%
if 1.6000000000000001 < k Initial program 52.2%
Taylor expanded in t around 0 71.0%
associate-*r*70.9%
Simplified70.9%
unpow270.9%
sin-mult71.0%
Applied egg-rr71.0%
div-sub71.0%
+-inverses71.0%
cos-071.0%
metadata-eval71.0%
count-271.0%
*-commutative71.0%
Simplified71.0%
Final simplification73.3%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 110000000000.0)
(/
2.0
(*
(pow (/ (* t_m (cbrt (sin k_m))) (pow (cbrt l) 2.0)) 3.0)
(/ (* 2.0 (sin k_m)) (cos k_m))))
(/
2.0
(/
(* (* t_m (pow k_m 2.0)) (- 0.5 (/ (cos (* k_m 2.0)) 2.0)))
(* (pow l 2.0) (cos k_m)))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 110000000000.0) {
tmp = 2.0 / (pow(((t_m * cbrt(sin(k_m))) / pow(cbrt(l), 2.0)), 3.0) * ((2.0 * sin(k_m)) / cos(k_m)));
} else {
tmp = 2.0 / (((t_m * pow(k_m, 2.0)) * (0.5 - (cos((k_m * 2.0)) / 2.0))) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 110000000000.0) {
tmp = 2.0 / (Math.pow(((t_m * Math.cbrt(Math.sin(k_m))) / Math.pow(Math.cbrt(l), 2.0)), 3.0) * ((2.0 * Math.sin(k_m)) / Math.cos(k_m)));
} else {
tmp = 2.0 / (((t_m * Math.pow(k_m, 2.0)) * (0.5 - (Math.cos((k_m * 2.0)) / 2.0))) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 110000000000.0) tmp = Float64(2.0 / Float64((Float64(Float64(t_m * cbrt(sin(k_m))) / (cbrt(l) ^ 2.0)) ^ 3.0) * Float64(Float64(2.0 * sin(k_m)) / cos(k_m)))); else tmp = Float64(2.0 / Float64(Float64(Float64(t_m * (k_m ^ 2.0)) * Float64(0.5 - Float64(cos(Float64(k_m * 2.0)) / 2.0))) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 110000000000.0], N[(2.0 / N[(N[Power[N[(N[(t$95$m * N[Power[N[Sin[k$95$m], $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision] / N[Power[N[Power[l, 1/3], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision] * N[(N[(2.0 * N[Sin[k$95$m], $MachinePrecision]), $MachinePrecision] / N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(N[(t$95$m * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(0.5 - N[(N[Cos[N[(k$95$m * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 110000000000:\\
\;\;\;\;\frac{2}{{\left(\frac{t\_m \cdot \sqrt[3]{\sin k\_m}}{{\left(\sqrt[3]{\ell}\right)}^{2}}\right)}^{3} \cdot \frac{2 \cdot \sin k\_m}{\cos k\_m}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{\left(t\_m \cdot {k\_m}^{2}\right) \cdot \left(0.5 - \frac{\cos \left(k\_m \cdot 2\right)}{2}\right)}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
if k < 1.1e11Initial program 59.2%
Simplified59.2%
add-cube-cbrt59.1%
pow359.1%
*-commutative59.1%
cbrt-prod59.0%
cbrt-div59.5%
rem-cbrt-cube65.2%
cbrt-prod79.6%
pow279.6%
Applied egg-rr79.6%
*-commutative79.6%
Simplified79.6%
unpow279.6%
clear-num79.6%
un-div-inv79.6%
Applied egg-rr79.6%
associate-*l/79.6%
Applied egg-rr79.6%
Taylor expanded in t around inf 77.1%
*-commutative77.1%
associate-*l/77.1%
Simplified77.1%
if 1.1e11 < k Initial program 53.1%
Taylor expanded in t around 0 72.2%
associate-*r*72.2%
Simplified72.2%
unpow272.2%
sin-mult72.2%
Applied egg-rr72.2%
div-sub72.2%
+-inverses72.2%
cos-072.2%
metadata-eval72.2%
count-272.2%
*-commutative72.2%
Simplified72.2%
Final simplification76.1%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(let* ((t_2 (pow (cbrt l) 2.0)))
(*
t_s
(if (<= k_m 2.5e-14)
(/ 2.0 (* (* k_m 2.0) (pow (/ (* t_m (cbrt (sin k_m))) t_2) 3.0)))
(if (<= k_m 180000000000.0)
(/
2.0
(*
(* (* (tan k_m) (sin k_m)) (+ 2.0 (pow (/ k_m t_m) 2.0)))
(pow (/ t_m t_2) 3.0)))
(/
2.0
(/
(* (* t_m (pow k_m 2.0)) (- 0.5 (/ (cos (* k_m 2.0)) 2.0)))
(* (pow l 2.0) (cos k_m)))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double t_2 = pow(cbrt(l), 2.0);
double tmp;
if (k_m <= 2.5e-14) {
tmp = 2.0 / ((k_m * 2.0) * pow(((t_m * cbrt(sin(k_m))) / t_2), 3.0));
} else if (k_m <= 180000000000.0) {
tmp = 2.0 / (((tan(k_m) * sin(k_m)) * (2.0 + pow((k_m / t_m), 2.0))) * pow((t_m / t_2), 3.0));
} else {
tmp = 2.0 / (((t_m * pow(k_m, 2.0)) * (0.5 - (cos((k_m * 2.0)) / 2.0))) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double t_2 = Math.pow(Math.cbrt(l), 2.0);
double tmp;
if (k_m <= 2.5e-14) {
tmp = 2.0 / ((k_m * 2.0) * Math.pow(((t_m * Math.cbrt(Math.sin(k_m))) / t_2), 3.0));
} else if (k_m <= 180000000000.0) {
tmp = 2.0 / (((Math.tan(k_m) * Math.sin(k_m)) * (2.0 + Math.pow((k_m / t_m), 2.0))) * Math.pow((t_m / t_2), 3.0));
} else {
tmp = 2.0 / (((t_m * Math.pow(k_m, 2.0)) * (0.5 - (Math.cos((k_m * 2.0)) / 2.0))) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) t_2 = cbrt(l) ^ 2.0 tmp = 0.0 if (k_m <= 2.5e-14) tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * (Float64(Float64(t_m * cbrt(sin(k_m))) / t_2) ^ 3.0))); elseif (k_m <= 180000000000.0) tmp = Float64(2.0 / Float64(Float64(Float64(tan(k_m) * sin(k_m)) * Float64(2.0 + (Float64(k_m / t_m) ^ 2.0))) * (Float64(t_m / t_2) ^ 3.0))); else tmp = Float64(2.0 / Float64(Float64(Float64(t_m * (k_m ^ 2.0)) * Float64(0.5 - Float64(cos(Float64(k_m * 2.0)) / 2.0))) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := Block[{t$95$2 = N[Power[N[Power[l, 1/3], $MachinePrecision], 2.0], $MachinePrecision]}, N[(t$95$s * If[LessEqual[k$95$m, 2.5e-14], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[Power[N[(N[(t$95$m * N[Power[N[Sin[k$95$m], $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision] / t$95$2), $MachinePrecision], 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 180000000000.0], N[(2.0 / N[(N[(N[(N[Tan[k$95$m], $MachinePrecision] * N[Sin[k$95$m], $MachinePrecision]), $MachinePrecision] * N[(2.0 + N[Power[N[(k$95$m / t$95$m), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Power[N[(t$95$m / t$95$2), $MachinePrecision], 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(N[(t$95$m * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(0.5 - N[(N[Cos[N[(k$95$m * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
\begin{array}{l}
t_2 := {\left(\sqrt[3]{\ell}\right)}^{2}\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 2.5 \cdot 10^{-14}:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot {\left(\frac{t\_m \cdot \sqrt[3]{\sin k\_m}}{t\_2}\right)}^{3}}\\
\mathbf{elif}\;k\_m \leq 180000000000:\\
\;\;\;\;\frac{2}{\left(\left(\tan k\_m \cdot \sin k\_m\right) \cdot \left(2 + {\left(\frac{k\_m}{t\_m}\right)}^{2}\right)\right) \cdot {\left(\frac{t\_m}{t\_2}\right)}^{3}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{\left(t\_m \cdot {k\_m}^{2}\right) \cdot \left(0.5 - \frac{\cos \left(k\_m \cdot 2\right)}{2}\right)}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
\end{array}
if k < 2.5000000000000001e-14Initial program 59.5%
Simplified59.5%
add-cube-cbrt59.4%
pow359.4%
*-commutative59.4%
cbrt-prod59.3%
cbrt-div59.8%
rem-cbrt-cube65.2%
cbrt-prod79.3%
pow279.3%
Applied egg-rr79.3%
*-commutative79.3%
Simplified79.3%
unpow279.3%
clear-num79.3%
un-div-inv79.3%
Applied egg-rr79.3%
associate-*l/79.3%
Applied egg-rr79.3%
Taylor expanded in k around 0 74.9%
*-commutative63.9%
Simplified74.9%
if 2.5000000000000001e-14 < k < 1.8e11Initial program 35.9%
add-cube-cbrt35.9%
pow335.9%
Applied egg-rr98.1%
cube-prod98.4%
rem-cube-cbrt99.0%
Simplified99.0%
if 1.8e11 < k Initial program 53.1%
Taylor expanded in t around 0 72.2%
associate-*r*72.2%
Simplified72.2%
unpow272.2%
sin-mult72.2%
Applied egg-rr72.2%
div-sub72.2%
+-inverses72.2%
cos-072.2%
metadata-eval72.2%
count-272.2%
*-commutative72.2%
Simplified72.2%
Final simplification74.6%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 66000000000.0)
(/
2.0
(*
(* (tan k_m) (+ 1.0 (+ 1.0 (/ (/ k_m t_m) (/ t_m k_m)))))
(pow (* (/ t_m (pow (cbrt l) 2.0)) (cbrt (sin k_m))) 3.0)))
(/
2.0
(/
(* (* t_m (pow k_m 2.0)) (- 0.5 (/ (cos (* k_m 2.0)) 2.0)))
(* (pow l 2.0) (cos k_m)))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 66000000000.0) {
tmp = 2.0 / ((tan(k_m) * (1.0 + (1.0 + ((k_m / t_m) / (t_m / k_m))))) * pow(((t_m / pow(cbrt(l), 2.0)) * cbrt(sin(k_m))), 3.0));
} else {
tmp = 2.0 / (((t_m * pow(k_m, 2.0)) * (0.5 - (cos((k_m * 2.0)) / 2.0))) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 66000000000.0) {
tmp = 2.0 / ((Math.tan(k_m) * (1.0 + (1.0 + ((k_m / t_m) / (t_m / k_m))))) * Math.pow(((t_m / Math.pow(Math.cbrt(l), 2.0)) * Math.cbrt(Math.sin(k_m))), 3.0));
} else {
tmp = 2.0 / (((t_m * Math.pow(k_m, 2.0)) * (0.5 - (Math.cos((k_m * 2.0)) / 2.0))) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 66000000000.0) tmp = Float64(2.0 / Float64(Float64(tan(k_m) * Float64(1.0 + Float64(1.0 + Float64(Float64(k_m / t_m) / Float64(t_m / k_m))))) * (Float64(Float64(t_m / (cbrt(l) ^ 2.0)) * cbrt(sin(k_m))) ^ 3.0))); else tmp = Float64(2.0 / Float64(Float64(Float64(t_m * (k_m ^ 2.0)) * Float64(0.5 - Float64(cos(Float64(k_m * 2.0)) / 2.0))) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 66000000000.0], N[(2.0 / N[(N[(N[Tan[k$95$m], $MachinePrecision] * N[(1.0 + N[(1.0 + N[(N[(k$95$m / t$95$m), $MachinePrecision] / N[(t$95$m / k$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Power[N[(N[(t$95$m / N[Power[N[Power[l, 1/3], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision] * N[Power[N[Sin[k$95$m], $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(N[(t$95$m * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(0.5 - N[(N[Cos[N[(k$95$m * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 66000000000:\\
\;\;\;\;\frac{2}{\left(\tan k\_m \cdot \left(1 + \left(1 + \frac{\frac{k\_m}{t\_m}}{\frac{t\_m}{k\_m}}\right)\right)\right) \cdot {\left(\frac{t\_m}{{\left(\sqrt[3]{\ell}\right)}^{2}} \cdot \sqrt[3]{\sin k\_m}\right)}^{3}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{\left(t\_m \cdot {k\_m}^{2}\right) \cdot \left(0.5 - \frac{\cos \left(k\_m \cdot 2\right)}{2}\right)}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
if k < 6.6e10Initial program 59.2%
Simplified59.2%
add-cube-cbrt59.1%
pow359.1%
*-commutative59.1%
cbrt-prod59.0%
cbrt-div59.5%
rem-cbrt-cube65.2%
cbrt-prod79.6%
pow279.6%
Applied egg-rr79.6%
*-commutative79.6%
Simplified79.6%
unpow279.6%
clear-num79.6%
un-div-inv79.6%
Applied egg-rr79.6%
if 6.6e10 < k Initial program 53.1%
Taylor expanded in t around 0 72.2%
associate-*r*72.2%
Simplified72.2%
unpow272.2%
sin-mult72.2%
Applied egg-rr72.2%
div-sub72.2%
+-inverses72.2%
cos-072.2%
metadata-eval72.2%
count-272.2%
*-commutative72.2%
Simplified72.2%
Final simplification78.1%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 8.5e-12)
(/
2.0
(* (* k_m 2.0) (pow (/ (* t_m (cbrt (sin k_m))) (pow (cbrt l) 2.0)) 3.0)))
(if (<= k_m 195000000000.0)
(/
2.0
(*
(pow (* t_m (pow (cbrt l) -2.0)) 3.0)
(* (* (tan k_m) (sin k_m)) (+ 2.0 (/ k_m (* t_m (/ t_m k_m)))))))
(/
2.0
(/
(* (* t_m (pow k_m 2.0)) (- 0.5 (/ (cos (* k_m 2.0)) 2.0)))
(* (pow l 2.0) (cos k_m))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 8.5e-12) {
tmp = 2.0 / ((k_m * 2.0) * pow(((t_m * cbrt(sin(k_m))) / pow(cbrt(l), 2.0)), 3.0));
} else if (k_m <= 195000000000.0) {
tmp = 2.0 / (pow((t_m * pow(cbrt(l), -2.0)), 3.0) * ((tan(k_m) * sin(k_m)) * (2.0 + (k_m / (t_m * (t_m / k_m))))));
} else {
tmp = 2.0 / (((t_m * pow(k_m, 2.0)) * (0.5 - (cos((k_m * 2.0)) / 2.0))) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 8.5e-12) {
tmp = 2.0 / ((k_m * 2.0) * Math.pow(((t_m * Math.cbrt(Math.sin(k_m))) / Math.pow(Math.cbrt(l), 2.0)), 3.0));
} else if (k_m <= 195000000000.0) {
tmp = 2.0 / (Math.pow((t_m * Math.pow(Math.cbrt(l), -2.0)), 3.0) * ((Math.tan(k_m) * Math.sin(k_m)) * (2.0 + (k_m / (t_m * (t_m / k_m))))));
} else {
tmp = 2.0 / (((t_m * Math.pow(k_m, 2.0)) * (0.5 - (Math.cos((k_m * 2.0)) / 2.0))) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 8.5e-12) tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * (Float64(Float64(t_m * cbrt(sin(k_m))) / (cbrt(l) ^ 2.0)) ^ 3.0))); elseif (k_m <= 195000000000.0) tmp = Float64(2.0 / Float64((Float64(t_m * (cbrt(l) ^ -2.0)) ^ 3.0) * Float64(Float64(tan(k_m) * sin(k_m)) * Float64(2.0 + Float64(k_m / Float64(t_m * Float64(t_m / k_m))))))); else tmp = Float64(2.0 / Float64(Float64(Float64(t_m * (k_m ^ 2.0)) * Float64(0.5 - Float64(cos(Float64(k_m * 2.0)) / 2.0))) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 8.5e-12], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[Power[N[(N[(t$95$m * N[Power[N[Sin[k$95$m], $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision] / N[Power[N[Power[l, 1/3], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 195000000000.0], N[(2.0 / N[(N[Power[N[(t$95$m * N[Power[N[Power[l, 1/3], $MachinePrecision], -2.0], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision] * N[(N[(N[Tan[k$95$m], $MachinePrecision] * N[Sin[k$95$m], $MachinePrecision]), $MachinePrecision] * N[(2.0 + N[(k$95$m / N[(t$95$m * N[(t$95$m / k$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(N[(t$95$m * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(0.5 - N[(N[Cos[N[(k$95$m * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 8.5 \cdot 10^{-12}:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot {\left(\frac{t\_m \cdot \sqrt[3]{\sin k\_m}}{{\left(\sqrt[3]{\ell}\right)}^{2}}\right)}^{3}}\\
\mathbf{elif}\;k\_m \leq 195000000000:\\
\;\;\;\;\frac{2}{{\left(t\_m \cdot {\left(\sqrt[3]{\ell}\right)}^{-2}\right)}^{3} \cdot \left(\left(\tan k\_m \cdot \sin k\_m\right) \cdot \left(2 + \frac{k\_m}{t\_m \cdot \frac{t\_m}{k\_m}}\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{\left(t\_m \cdot {k\_m}^{2}\right) \cdot \left(0.5 - \frac{\cos \left(k\_m \cdot 2\right)}{2}\right)}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
if k < 8.4999999999999997e-12Initial program 59.5%
Simplified59.5%
add-cube-cbrt59.4%
pow359.4%
*-commutative59.4%
cbrt-prod59.3%
cbrt-div59.8%
rem-cbrt-cube65.2%
cbrt-prod79.3%
pow279.3%
Applied egg-rr79.3%
*-commutative79.3%
Simplified79.3%
unpow279.3%
clear-num79.3%
un-div-inv79.3%
Applied egg-rr79.3%
associate-*l/79.3%
Applied egg-rr79.3%
Taylor expanded in k around 0 74.9%
*-commutative63.9%
Simplified74.9%
if 8.4999999999999997e-12 < k < 1.95e11Initial program 35.9%
Simplified67.9%
unpow267.9%
clear-num67.9%
frac-times67.9%
*-un-lft-identity67.9%
Applied egg-rr67.9%
add-cube-cbrt67.1%
pow367.1%
associate-/l/35.9%
cbrt-div35.9%
unpow335.9%
add-cbrt-cube66.9%
cbrt-prod98.4%
unpow298.4%
div-inv98.4%
unpow-prod-down35.9%
pow-flip35.9%
metadata-eval35.9%
Applied egg-rr35.9%
cube-prod97.5%
Simplified97.5%
if 1.95e11 < k Initial program 53.1%
Taylor expanded in t around 0 72.2%
associate-*r*72.2%
Simplified72.2%
unpow272.2%
sin-mult72.2%
Applied egg-rr72.2%
div-sub72.2%
+-inverses72.2%
cos-072.2%
metadata-eval72.2%
count-272.2%
*-commutative72.2%
Simplified72.2%
Final simplification74.6%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 1.9e-151)
(/ 2.0 (* (* k_m 2.0) (pow (* (/ (pow t_m 1.5) l) (sqrt (sin k_m))) 2.0)))
(if (<= k_m 31000000000.0)
(/
2.0
(pow (* (* t_m (pow (cbrt l) -2.0)) (cbrt (* 2.0 (pow k_m 2.0)))) 3.0))
(/
2.0
(/
(* (* t_m (pow k_m 2.0)) (- 0.5 (/ (cos (* k_m 2.0)) 2.0)))
(* (pow l 2.0) (cos k_m))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 1.9e-151) {
tmp = 2.0 / ((k_m * 2.0) * pow(((pow(t_m, 1.5) / l) * sqrt(sin(k_m))), 2.0));
} else if (k_m <= 31000000000.0) {
tmp = 2.0 / pow(((t_m * pow(cbrt(l), -2.0)) * cbrt((2.0 * pow(k_m, 2.0)))), 3.0);
} else {
tmp = 2.0 / (((t_m * pow(k_m, 2.0)) * (0.5 - (cos((k_m * 2.0)) / 2.0))) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 1.9e-151) {
tmp = 2.0 / ((k_m * 2.0) * Math.pow(((Math.pow(t_m, 1.5) / l) * Math.sqrt(Math.sin(k_m))), 2.0));
} else if (k_m <= 31000000000.0) {
tmp = 2.0 / Math.pow(((t_m * Math.pow(Math.cbrt(l), -2.0)) * Math.cbrt((2.0 * Math.pow(k_m, 2.0)))), 3.0);
} else {
tmp = 2.0 / (((t_m * Math.pow(k_m, 2.0)) * (0.5 - (Math.cos((k_m * 2.0)) / 2.0))) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 1.9e-151) tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * (Float64(Float64((t_m ^ 1.5) / l) * sqrt(sin(k_m))) ^ 2.0))); elseif (k_m <= 31000000000.0) tmp = Float64(2.0 / (Float64(Float64(t_m * (cbrt(l) ^ -2.0)) * cbrt(Float64(2.0 * (k_m ^ 2.0)))) ^ 3.0)); else tmp = Float64(2.0 / Float64(Float64(Float64(t_m * (k_m ^ 2.0)) * Float64(0.5 - Float64(cos(Float64(k_m * 2.0)) / 2.0))) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 1.9e-151], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[Power[N[(N[(N[Power[t$95$m, 1.5], $MachinePrecision] / l), $MachinePrecision] * N[Sqrt[N[Sin[k$95$m], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 31000000000.0], N[(2.0 / N[Power[N[(N[(t$95$m * N[Power[N[Power[l, 1/3], $MachinePrecision], -2.0], $MachinePrecision]), $MachinePrecision] * N[Power[N[(2.0 * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(N[(t$95$m * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(0.5 - N[(N[Cos[N[(k$95$m * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 1.9 \cdot 10^{-151}:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot {\left(\frac{{t\_m}^{1.5}}{\ell} \cdot \sqrt{\sin k\_m}\right)}^{2}}\\
\mathbf{elif}\;k\_m \leq 31000000000:\\
\;\;\;\;\frac{2}{{\left(\left(t\_m \cdot {\left(\sqrt[3]{\ell}\right)}^{-2}\right) \cdot \sqrt[3]{2 \cdot {k\_m}^{2}}\right)}^{3}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{\left(t\_m \cdot {k\_m}^{2}\right) \cdot \left(0.5 - \frac{\cos \left(k\_m \cdot 2\right)}{2}\right)}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
if k < 1.89999999999999985e-151Initial program 57.9%
Simplified57.9%
add-sqr-sqrt28.9%
pow228.9%
*-commutative28.9%
sqrt-prod12.2%
sqrt-div12.2%
sqrt-pow113.4%
metadata-eval13.4%
sqrt-prod7.3%
add-sqr-sqrt14.6%
Applied egg-rr14.6%
*-commutative14.6%
Simplified14.6%
Taylor expanded in k around 0 13.6%
if 1.89999999999999985e-151 < k < 3.1e10Initial program 64.6%
Simplified70.0%
Taylor expanded in k around 0 78.3%
add-cube-cbrt78.2%
pow378.3%
cbrt-prod78.0%
associate-/l/75.0%
cbrt-div75.1%
unpow375.1%
add-cbrt-cube77.7%
cbrt-prod84.9%
unpow284.9%
div-inv84.9%
pow-flip84.9%
metadata-eval84.9%
Applied egg-rr84.9%
if 3.1e10 < k Initial program 53.1%
Taylor expanded in t around 0 72.2%
associate-*r*72.2%
Simplified72.2%
unpow272.2%
sin-mult72.2%
Applied egg-rr72.2%
div-sub72.2%
+-inverses72.2%
cos-072.2%
metadata-eval72.2%
count-272.2%
*-commutative72.2%
Simplified72.2%
Final simplification36.6%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 35000000000.0)
(/
2.0
(* (* k_m 2.0) (pow (/ (* t_m (cbrt (sin k_m))) (pow (cbrt l) 2.0)) 3.0)))
(/
2.0
(/
(* (* t_m (pow k_m 2.0)) (- 0.5 (/ (cos (* k_m 2.0)) 2.0)))
(* (pow l 2.0) (cos k_m)))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 35000000000.0) {
tmp = 2.0 / ((k_m * 2.0) * pow(((t_m * cbrt(sin(k_m))) / pow(cbrt(l), 2.0)), 3.0));
} else {
tmp = 2.0 / (((t_m * pow(k_m, 2.0)) * (0.5 - (cos((k_m * 2.0)) / 2.0))) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 35000000000.0) {
tmp = 2.0 / ((k_m * 2.0) * Math.pow(((t_m * Math.cbrt(Math.sin(k_m))) / Math.pow(Math.cbrt(l), 2.0)), 3.0));
} else {
tmp = 2.0 / (((t_m * Math.pow(k_m, 2.0)) * (0.5 - (Math.cos((k_m * 2.0)) / 2.0))) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 35000000000.0) tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * (Float64(Float64(t_m * cbrt(sin(k_m))) / (cbrt(l) ^ 2.0)) ^ 3.0))); else tmp = Float64(2.0 / Float64(Float64(Float64(t_m * (k_m ^ 2.0)) * Float64(0.5 - Float64(cos(Float64(k_m * 2.0)) / 2.0))) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 35000000000.0], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[Power[N[(N[(t$95$m * N[Power[N[Sin[k$95$m], $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision] / N[Power[N[Power[l, 1/3], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(N[(t$95$m * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(0.5 - N[(N[Cos[N[(k$95$m * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 35000000000:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot {\left(\frac{t\_m \cdot \sqrt[3]{\sin k\_m}}{{\left(\sqrt[3]{\ell}\right)}^{2}}\right)}^{3}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{\left(t\_m \cdot {k\_m}^{2}\right) \cdot \left(0.5 - \frac{\cos \left(k\_m \cdot 2\right)}{2}\right)}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
if k < 3.5e10Initial program 59.2%
Simplified59.2%
add-cube-cbrt59.1%
pow359.1%
*-commutative59.1%
cbrt-prod59.0%
cbrt-div59.5%
rem-cbrt-cube65.2%
cbrt-prod79.6%
pow279.6%
Applied egg-rr79.6%
*-commutative79.6%
Simplified79.6%
unpow279.6%
clear-num79.6%
un-div-inv79.6%
Applied egg-rr79.6%
associate-*l/79.6%
Applied egg-rr79.6%
Taylor expanded in k around 0 74.3%
*-commutative63.5%
Simplified74.3%
if 3.5e10 < k Initial program 53.1%
Taylor expanded in t around 0 72.2%
associate-*r*72.2%
Simplified72.2%
unpow272.2%
sin-mult72.2%
Applied egg-rr72.2%
div-sub72.2%
+-inverses72.2%
cos-072.2%
metadata-eval72.2%
count-272.2%
*-commutative72.2%
Simplified72.2%
Final simplification73.9%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 2.35e-5)
(/ 2.0 (* (* k_m 2.0) (pow (* (/ (pow t_m 1.5) l) (sqrt (sin k_m))) 2.0)))
(if (<= k_m 9.5e+93)
(*
(* (/ (/ 2.0 (pow t_m 3.0)) (sin k_m)) (/ l (tan k_m)))
(/ l (+ 2.0 (/ (/ k_m t_m) (/ t_m k_m)))))
(/
2.0
(/
(* (pow k_m 2.0) (* t_m (pow k_m 2.0)))
(* (pow l 2.0) (cos k_m))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 2.35e-5) {
tmp = 2.0 / ((k_m * 2.0) * pow(((pow(t_m, 1.5) / l) * sqrt(sin(k_m))), 2.0));
} else if (k_m <= 9.5e+93) {
tmp = (((2.0 / pow(t_m, 3.0)) / sin(k_m)) * (l / tan(k_m))) * (l / (2.0 + ((k_m / t_m) / (t_m / k_m))));
} else {
tmp = 2.0 / ((pow(k_m, 2.0) * (t_m * pow(k_m, 2.0))) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k_m
real(8) :: tmp
if (k_m <= 2.35d-5) then
tmp = 2.0d0 / ((k_m * 2.0d0) * ((((t_m ** 1.5d0) / l) * sqrt(sin(k_m))) ** 2.0d0))
else if (k_m <= 9.5d+93) then
tmp = (((2.0d0 / (t_m ** 3.0d0)) / sin(k_m)) * (l / tan(k_m))) * (l / (2.0d0 + ((k_m / t_m) / (t_m / k_m))))
else
tmp = 2.0d0 / (((k_m ** 2.0d0) * (t_m * (k_m ** 2.0d0))) / ((l ** 2.0d0) * cos(k_m)))
end if
code = t_s * tmp
end function
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 2.35e-5) {
tmp = 2.0 / ((k_m * 2.0) * Math.pow(((Math.pow(t_m, 1.5) / l) * Math.sqrt(Math.sin(k_m))), 2.0));
} else if (k_m <= 9.5e+93) {
tmp = (((2.0 / Math.pow(t_m, 3.0)) / Math.sin(k_m)) * (l / Math.tan(k_m))) * (l / (2.0 + ((k_m / t_m) / (t_m / k_m))));
} else {
tmp = 2.0 / ((Math.pow(k_m, 2.0) * (t_m * Math.pow(k_m, 2.0))) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = math.fabs(k) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k_m): tmp = 0 if k_m <= 2.35e-5: tmp = 2.0 / ((k_m * 2.0) * math.pow(((math.pow(t_m, 1.5) / l) * math.sqrt(math.sin(k_m))), 2.0)) elif k_m <= 9.5e+93: tmp = (((2.0 / math.pow(t_m, 3.0)) / math.sin(k_m)) * (l / math.tan(k_m))) * (l / (2.0 + ((k_m / t_m) / (t_m / k_m)))) else: tmp = 2.0 / ((math.pow(k_m, 2.0) * (t_m * math.pow(k_m, 2.0))) / (math.pow(l, 2.0) * math.cos(k_m))) return t_s * tmp
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 2.35e-5) tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * (Float64(Float64((t_m ^ 1.5) / l) * sqrt(sin(k_m))) ^ 2.0))); elseif (k_m <= 9.5e+93) tmp = Float64(Float64(Float64(Float64(2.0 / (t_m ^ 3.0)) / sin(k_m)) * Float64(l / tan(k_m))) * Float64(l / Float64(2.0 + Float64(Float64(k_m / t_m) / Float64(t_m / k_m))))); else tmp = Float64(2.0 / Float64(Float64((k_m ^ 2.0) * Float64(t_m * (k_m ^ 2.0))) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = abs(k); t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k_m) tmp = 0.0; if (k_m <= 2.35e-5) tmp = 2.0 / ((k_m * 2.0) * ((((t_m ^ 1.5) / l) * sqrt(sin(k_m))) ^ 2.0)); elseif (k_m <= 9.5e+93) tmp = (((2.0 / (t_m ^ 3.0)) / sin(k_m)) * (l / tan(k_m))) * (l / (2.0 + ((k_m / t_m) / (t_m / k_m)))); else tmp = 2.0 / (((k_m ^ 2.0) * (t_m * (k_m ^ 2.0))) / ((l ^ 2.0) * cos(k_m))); end tmp_2 = t_s * tmp; end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 2.35e-5], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[Power[N[(N[(N[Power[t$95$m, 1.5], $MachinePrecision] / l), $MachinePrecision] * N[Sqrt[N[Sin[k$95$m], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 9.5e+93], N[(N[(N[(N[(2.0 / N[Power[t$95$m, 3.0], $MachinePrecision]), $MachinePrecision] / N[Sin[k$95$m], $MachinePrecision]), $MachinePrecision] * N[(l / N[Tan[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(l / N[(2.0 + N[(N[(k$95$m / t$95$m), $MachinePrecision] / N[(t$95$m / k$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(N[Power[k$95$m, 2.0], $MachinePrecision] * N[(t$95$m * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 2.35 \cdot 10^{-5}:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot {\left(\frac{{t\_m}^{1.5}}{\ell} \cdot \sqrt{\sin k\_m}\right)}^{2}}\\
\mathbf{elif}\;k\_m \leq 9.5 \cdot 10^{+93}:\\
\;\;\;\;\left(\frac{\frac{2}{{t\_m}^{3}}}{\sin k\_m} \cdot \frac{\ell}{\tan k\_m}\right) \cdot \frac{\ell}{2 + \frac{\frac{k\_m}{t\_m}}{\frac{t\_m}{k\_m}}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{{k\_m}^{2} \cdot \left(t\_m \cdot {k\_m}^{2}\right)}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
if k < 2.34999999999999986e-5Initial program 59.4%
Simplified59.5%
add-sqr-sqrt30.0%
pow230.0%
*-commutative30.0%
sqrt-prod16.4%
sqrt-div16.4%
sqrt-pow117.9%
metadata-eval17.9%
sqrt-prod10.8%
add-sqr-sqrt21.2%
Applied egg-rr21.2%
*-commutative21.2%
Simplified21.2%
Taylor expanded in k around 0 19.1%
if 2.34999999999999986e-5 < k < 9.4999999999999991e93Initial program 75.6%
Simplified75.7%
associate-*r*81.5%
*-un-lft-identity81.5%
times-frac87.4%
Applied egg-rr87.4%
/-rgt-identity87.4%
associate-*l/87.4%
associate-*r*87.4%
times-frac87.4%
associate-/r*87.3%
Simplified87.3%
unpow287.5%
clear-num87.5%
un-div-inv87.5%
Applied egg-rr87.3%
if 9.4999999999999991e93 < k Initial program 42.3%
Taylor expanded in t around 0 66.2%
associate-*r*66.2%
Simplified66.2%
Taylor expanded in k around 0 58.7%
Final simplification29.3%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 1.35)
(/ 2.0 (* (* k_m 2.0) (pow (* (/ (pow t_m 1.5) l) (sqrt (sin k_m))) 2.0)))
(/
2.0
(/
(* (* t_m (pow k_m 2.0)) (- 0.5 (/ (cos (* k_m 2.0)) 2.0)))
(* (pow l 2.0) (cos k_m)))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 1.35) {
tmp = 2.0 / ((k_m * 2.0) * pow(((pow(t_m, 1.5) / l) * sqrt(sin(k_m))), 2.0));
} else {
tmp = 2.0 / (((t_m * pow(k_m, 2.0)) * (0.5 - (cos((k_m * 2.0)) / 2.0))) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k_m
real(8) :: tmp
if (k_m <= 1.35d0) then
tmp = 2.0d0 / ((k_m * 2.0d0) * ((((t_m ** 1.5d0) / l) * sqrt(sin(k_m))) ** 2.0d0))
else
tmp = 2.0d0 / (((t_m * (k_m ** 2.0d0)) * (0.5d0 - (cos((k_m * 2.0d0)) / 2.0d0))) / ((l ** 2.0d0) * cos(k_m)))
end if
code = t_s * tmp
end function
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 1.35) {
tmp = 2.0 / ((k_m * 2.0) * Math.pow(((Math.pow(t_m, 1.5) / l) * Math.sqrt(Math.sin(k_m))), 2.0));
} else {
tmp = 2.0 / (((t_m * Math.pow(k_m, 2.0)) * (0.5 - (Math.cos((k_m * 2.0)) / 2.0))) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = math.fabs(k) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k_m): tmp = 0 if k_m <= 1.35: tmp = 2.0 / ((k_m * 2.0) * math.pow(((math.pow(t_m, 1.5) / l) * math.sqrt(math.sin(k_m))), 2.0)) else: tmp = 2.0 / (((t_m * math.pow(k_m, 2.0)) * (0.5 - (math.cos((k_m * 2.0)) / 2.0))) / (math.pow(l, 2.0) * math.cos(k_m))) return t_s * tmp
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 1.35) tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * (Float64(Float64((t_m ^ 1.5) / l) * sqrt(sin(k_m))) ^ 2.0))); else tmp = Float64(2.0 / Float64(Float64(Float64(t_m * (k_m ^ 2.0)) * Float64(0.5 - Float64(cos(Float64(k_m * 2.0)) / 2.0))) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = abs(k); t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k_m) tmp = 0.0; if (k_m <= 1.35) tmp = 2.0 / ((k_m * 2.0) * ((((t_m ^ 1.5) / l) * sqrt(sin(k_m))) ^ 2.0)); else tmp = 2.0 / (((t_m * (k_m ^ 2.0)) * (0.5 - (cos((k_m * 2.0)) / 2.0))) / ((l ^ 2.0) * cos(k_m))); end tmp_2 = t_s * tmp; end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 1.35], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[Power[N[(N[(N[Power[t$95$m, 1.5], $MachinePrecision] / l), $MachinePrecision] * N[Sqrt[N[Sin[k$95$m], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(N[(t$95$m * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(0.5 - N[(N[Cos[N[(k$95$m * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 1.35:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot {\left(\frac{{t\_m}^{1.5}}{\ell} \cdot \sqrt{\sin k\_m}\right)}^{2}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{\left(t\_m \cdot {k\_m}^{2}\right) \cdot \left(0.5 - \frac{\cos \left(k\_m \cdot 2\right)}{2}\right)}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
if k < 1.3500000000000001Initial program 59.4%
Simplified59.5%
add-sqr-sqrt30.0%
pow230.0%
*-commutative30.0%
sqrt-prod16.4%
sqrt-div16.4%
sqrt-pow117.9%
metadata-eval17.9%
sqrt-prod10.8%
add-sqr-sqrt21.2%
Applied egg-rr21.2%
*-commutative21.2%
Simplified21.2%
Taylor expanded in k around 0 19.1%
if 1.3500000000000001 < k Initial program 52.2%
Taylor expanded in t around 0 71.0%
associate-*r*70.9%
Simplified70.9%
unpow270.9%
sin-mult71.0%
Applied egg-rr71.0%
div-sub71.0%
+-inverses71.0%
cos-071.0%
metadata-eval71.0%
count-271.0%
*-commutative71.0%
Simplified71.0%
Final simplification30.1%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 1.9e-5)
(/ 2.0 (* (* k_m 2.0) (pow (* (/ (pow t_m 1.5) l) (sqrt (sin k_m))) 2.0)))
(if (<= k_m 3.15e+94)
(*
(* (/ (/ 2.0 (pow t_m 3.0)) (sin k_m)) (/ l (tan k_m)))
(/ l (+ 2.0 (/ (/ k_m t_m) (/ t_m k_m)))))
(/ 2.0 (* (* k_m 2.0) (pow (* t_m (cbrt (/ k_m (pow l 2.0)))) 3.0)))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 1.9e-5) {
tmp = 2.0 / ((k_m * 2.0) * pow(((pow(t_m, 1.5) / l) * sqrt(sin(k_m))), 2.0));
} else if (k_m <= 3.15e+94) {
tmp = (((2.0 / pow(t_m, 3.0)) / sin(k_m)) * (l / tan(k_m))) * (l / (2.0 + ((k_m / t_m) / (t_m / k_m))));
} else {
tmp = 2.0 / ((k_m * 2.0) * pow((t_m * cbrt((k_m / pow(l, 2.0)))), 3.0));
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 1.9e-5) {
tmp = 2.0 / ((k_m * 2.0) * Math.pow(((Math.pow(t_m, 1.5) / l) * Math.sqrt(Math.sin(k_m))), 2.0));
} else if (k_m <= 3.15e+94) {
tmp = (((2.0 / Math.pow(t_m, 3.0)) / Math.sin(k_m)) * (l / Math.tan(k_m))) * (l / (2.0 + ((k_m / t_m) / (t_m / k_m))));
} else {
tmp = 2.0 / ((k_m * 2.0) * Math.pow((t_m * Math.cbrt((k_m / Math.pow(l, 2.0)))), 3.0));
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 1.9e-5) tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * (Float64(Float64((t_m ^ 1.5) / l) * sqrt(sin(k_m))) ^ 2.0))); elseif (k_m <= 3.15e+94) tmp = Float64(Float64(Float64(Float64(2.0 / (t_m ^ 3.0)) / sin(k_m)) * Float64(l / tan(k_m))) * Float64(l / Float64(2.0 + Float64(Float64(k_m / t_m) / Float64(t_m / k_m))))); else tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * (Float64(t_m * cbrt(Float64(k_m / (l ^ 2.0)))) ^ 3.0))); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 1.9e-5], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[Power[N[(N[(N[Power[t$95$m, 1.5], $MachinePrecision] / l), $MachinePrecision] * N[Sqrt[N[Sin[k$95$m], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 3.15e+94], N[(N[(N[(N[(2.0 / N[Power[t$95$m, 3.0], $MachinePrecision]), $MachinePrecision] / N[Sin[k$95$m], $MachinePrecision]), $MachinePrecision] * N[(l / N[Tan[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(l / N[(2.0 + N[(N[(k$95$m / t$95$m), $MachinePrecision] / N[(t$95$m / k$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[Power[N[(t$95$m * N[Power[N[(k$95$m / N[Power[l, 2.0], $MachinePrecision]), $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 1.9 \cdot 10^{-5}:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot {\left(\frac{{t\_m}^{1.5}}{\ell} \cdot \sqrt{\sin k\_m}\right)}^{2}}\\
\mathbf{elif}\;k\_m \leq 3.15 \cdot 10^{+94}:\\
\;\;\;\;\left(\frac{\frac{2}{{t\_m}^{3}}}{\sin k\_m} \cdot \frac{\ell}{\tan k\_m}\right) \cdot \frac{\ell}{2 + \frac{\frac{k\_m}{t\_m}}{\frac{t\_m}{k\_m}}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot {\left(t\_m \cdot \sqrt[3]{\frac{k\_m}{{\ell}^{2}}}\right)}^{3}}\\
\end{array}
\end{array}
if k < 1.9000000000000001e-5Initial program 59.4%
Simplified59.5%
add-sqr-sqrt30.0%
pow230.0%
*-commutative30.0%
sqrt-prod16.4%
sqrt-div16.4%
sqrt-pow117.9%
metadata-eval17.9%
sqrt-prod10.8%
add-sqr-sqrt21.2%
Applied egg-rr21.2%
*-commutative21.2%
Simplified21.2%
Taylor expanded in k around 0 19.1%
if 1.9000000000000001e-5 < k < 3.15e94Initial program 75.6%
Simplified75.7%
associate-*r*81.5%
*-un-lft-identity81.5%
times-frac87.4%
Applied egg-rr87.4%
/-rgt-identity87.4%
associate-*l/87.4%
associate-*r*87.4%
times-frac87.4%
associate-/r*87.3%
Simplified87.3%
unpow287.5%
clear-num87.5%
un-div-inv87.5%
Applied egg-rr87.3%
if 3.15e94 < k Initial program 42.3%
Simplified42.4%
add-cube-cbrt42.3%
pow342.3%
*-commutative42.3%
cbrt-prod42.3%
cbrt-div42.3%
rem-cbrt-cube53.0%
cbrt-prod58.0%
pow258.0%
Applied egg-rr58.0%
*-commutative58.0%
Simplified58.0%
unpow258.0%
clear-num58.0%
un-div-inv58.0%
Applied egg-rr58.0%
Taylor expanded in k around 0 58.6%
Taylor expanded in k around 0 56.2%
*-commutative56.2%
Simplified56.2%
Final simplification28.9%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(let* ((t_2 (* (/ (/ 2.0 (pow t_m 3.0)) (sin k_m)) (/ l (tan k_m)))))
(*
t_s
(if (<= k_m 3.3e-167)
(* t_2 (* l 0.5))
(if (<= k_m 4.8e-6)
(/
2.0
(* (* 2.0 (pow k_m 2.0)) (/ (* (pow t_m 1.5) (/ (pow t_m 1.5) l)) l)))
(if (<= k_m 1.9e+94)
(* t_2 (/ l (+ 2.0 (/ (/ k_m t_m) (/ t_m k_m)))))
(/
2.0
(* (* k_m 2.0) (pow (* t_m (cbrt (/ k_m (pow l 2.0)))) 3.0)))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double t_2 = ((2.0 / pow(t_m, 3.0)) / sin(k_m)) * (l / tan(k_m));
double tmp;
if (k_m <= 3.3e-167) {
tmp = t_2 * (l * 0.5);
} else if (k_m <= 4.8e-6) {
tmp = 2.0 / ((2.0 * pow(k_m, 2.0)) * ((pow(t_m, 1.5) * (pow(t_m, 1.5) / l)) / l));
} else if (k_m <= 1.9e+94) {
tmp = t_2 * (l / (2.0 + ((k_m / t_m) / (t_m / k_m))));
} else {
tmp = 2.0 / ((k_m * 2.0) * pow((t_m * cbrt((k_m / pow(l, 2.0)))), 3.0));
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double t_2 = ((2.0 / Math.pow(t_m, 3.0)) / Math.sin(k_m)) * (l / Math.tan(k_m));
double tmp;
if (k_m <= 3.3e-167) {
tmp = t_2 * (l * 0.5);
} else if (k_m <= 4.8e-6) {
tmp = 2.0 / ((2.0 * Math.pow(k_m, 2.0)) * ((Math.pow(t_m, 1.5) * (Math.pow(t_m, 1.5) / l)) / l));
} else if (k_m <= 1.9e+94) {
tmp = t_2 * (l / (2.0 + ((k_m / t_m) / (t_m / k_m))));
} else {
tmp = 2.0 / ((k_m * 2.0) * Math.pow((t_m * Math.cbrt((k_m / Math.pow(l, 2.0)))), 3.0));
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) t_2 = Float64(Float64(Float64(2.0 / (t_m ^ 3.0)) / sin(k_m)) * Float64(l / tan(k_m))) tmp = 0.0 if (k_m <= 3.3e-167) tmp = Float64(t_2 * Float64(l * 0.5)); elseif (k_m <= 4.8e-6) tmp = Float64(2.0 / Float64(Float64(2.0 * (k_m ^ 2.0)) * Float64(Float64((t_m ^ 1.5) * Float64((t_m ^ 1.5) / l)) / l))); elseif (k_m <= 1.9e+94) tmp = Float64(t_2 * Float64(l / Float64(2.0 + Float64(Float64(k_m / t_m) / Float64(t_m / k_m))))); else tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * (Float64(t_m * cbrt(Float64(k_m / (l ^ 2.0)))) ^ 3.0))); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := Block[{t$95$2 = N[(N[(N[(2.0 / N[Power[t$95$m, 3.0], $MachinePrecision]), $MachinePrecision] / N[Sin[k$95$m], $MachinePrecision]), $MachinePrecision] * N[(l / N[Tan[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, N[(t$95$s * If[LessEqual[k$95$m, 3.3e-167], N[(t$95$2 * N[(l * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 4.8e-6], N[(2.0 / N[(N[(2.0 * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(N[(N[Power[t$95$m, 1.5], $MachinePrecision] * N[(N[Power[t$95$m, 1.5], $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 1.9e+94], N[(t$95$2 * N[(l / N[(2.0 + N[(N[(k$95$m / t$95$m), $MachinePrecision] / N[(t$95$m / k$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[Power[N[(t$95$m * N[Power[N[(k$95$m / N[Power[l, 2.0], $MachinePrecision]), $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]]), $MachinePrecision]]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
\begin{array}{l}
t_2 := \frac{\frac{2}{{t\_m}^{3}}}{\sin k\_m} \cdot \frac{\ell}{\tan k\_m}\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 3.3 \cdot 10^{-167}:\\
\;\;\;\;t\_2 \cdot \left(\ell \cdot 0.5\right)\\
\mathbf{elif}\;k\_m \leq 4.8 \cdot 10^{-6}:\\
\;\;\;\;\frac{2}{\left(2 \cdot {k\_m}^{2}\right) \cdot \frac{{t\_m}^{1.5} \cdot \frac{{t\_m}^{1.5}}{\ell}}{\ell}}\\
\mathbf{elif}\;k\_m \leq 1.9 \cdot 10^{+94}:\\
\;\;\;\;t\_2 \cdot \frac{\ell}{2 + \frac{\frac{k\_m}{t\_m}}{\frac{t\_m}{k\_m}}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot {\left(t\_m \cdot \sqrt[3]{\frac{k\_m}{{\ell}^{2}}}\right)}^{3}}\\
\end{array}
\end{array}
\end{array}
if k < 3.29999999999999995e-167Initial program 57.5%
Simplified52.1%
associate-*r*58.8%
*-un-lft-identity58.8%
times-frac59.2%
Applied egg-rr59.2%
/-rgt-identity59.2%
associate-*l/59.2%
associate-*r*62.9%
times-frac65.1%
associate-/r*65.2%
Simplified65.2%
Taylor expanded in k around 0 63.5%
*-commutative63.5%
Simplified63.5%
if 3.29999999999999995e-167 < k < 4.7999999999999998e-6Initial program 66.4%
Simplified69.0%
Taylor expanded in k around 0 78.5%
sqr-pow39.8%
*-un-lft-identity39.8%
times-frac44.3%
metadata-eval44.3%
metadata-eval44.3%
Applied egg-rr44.3%
if 4.7999999999999998e-6 < k < 1.8999999999999998e94Initial program 75.6%
Simplified75.7%
associate-*r*81.5%
*-un-lft-identity81.5%
times-frac87.4%
Applied egg-rr87.4%
/-rgt-identity87.4%
associate-*l/87.4%
associate-*r*87.4%
times-frac87.4%
associate-/r*87.3%
Simplified87.3%
unpow287.5%
clear-num87.5%
un-div-inv87.5%
Applied egg-rr87.3%
if 1.8999999999999998e94 < k Initial program 42.3%
Simplified42.4%
add-cube-cbrt42.3%
pow342.3%
*-commutative42.3%
cbrt-prod42.3%
cbrt-div42.3%
rem-cbrt-cube53.0%
cbrt-prod58.0%
pow258.0%
Applied egg-rr58.0%
*-commutative58.0%
Simplified58.0%
unpow258.0%
clear-num58.0%
un-div-inv58.0%
Applied egg-rr58.0%
Taylor expanded in k around 0 58.6%
Taylor expanded in k around 0 56.2%
*-commutative56.2%
Simplified56.2%
Final simplification60.6%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(let* ((t_2 (* 2.0 (pow k_m 2.0))))
(*
t_s
(if (<= k_m 6.6e-288)
(/ 2.0 (* t_2 (/ (/ (pow t_m 3.0) l) l)))
(if (<= k_m 3.3e-167)
(/ 2.0 (* (* k_m 2.0) (* (sin k_m) (/ (pow t_m 3.0) (* l l)))))
(if (<= k_m 1120000000000.0)
(/ 2.0 (* t_2 (/ (pow (/ t_m (cbrt l)) 3.0) l)))
(/ 2.0 (/ (* t_m (pow k_m 4.0)) (* (pow l 2.0) (cos k_m))))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double t_2 = 2.0 * pow(k_m, 2.0);
double tmp;
if (k_m <= 6.6e-288) {
tmp = 2.0 / (t_2 * ((pow(t_m, 3.0) / l) / l));
} else if (k_m <= 3.3e-167) {
tmp = 2.0 / ((k_m * 2.0) * (sin(k_m) * (pow(t_m, 3.0) / (l * l))));
} else if (k_m <= 1120000000000.0) {
tmp = 2.0 / (t_2 * (pow((t_m / cbrt(l)), 3.0) / l));
} else {
tmp = 2.0 / ((t_m * pow(k_m, 4.0)) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double t_2 = 2.0 * Math.pow(k_m, 2.0);
double tmp;
if (k_m <= 6.6e-288) {
tmp = 2.0 / (t_2 * ((Math.pow(t_m, 3.0) / l) / l));
} else if (k_m <= 3.3e-167) {
tmp = 2.0 / ((k_m * 2.0) * (Math.sin(k_m) * (Math.pow(t_m, 3.0) / (l * l))));
} else if (k_m <= 1120000000000.0) {
tmp = 2.0 / (t_2 * (Math.pow((t_m / Math.cbrt(l)), 3.0) / l));
} else {
tmp = 2.0 / ((t_m * Math.pow(k_m, 4.0)) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) t_2 = Float64(2.0 * (k_m ^ 2.0)) tmp = 0.0 if (k_m <= 6.6e-288) tmp = Float64(2.0 / Float64(t_2 * Float64(Float64((t_m ^ 3.0) / l) / l))); elseif (k_m <= 3.3e-167) tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * Float64(sin(k_m) * Float64((t_m ^ 3.0) / Float64(l * l))))); elseif (k_m <= 1120000000000.0) tmp = Float64(2.0 / Float64(t_2 * Float64((Float64(t_m / cbrt(l)) ^ 3.0) / l))); else tmp = Float64(2.0 / Float64(Float64(t_m * (k_m ^ 4.0)) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := Block[{t$95$2 = N[(2.0 * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision]}, N[(t$95$s * If[LessEqual[k$95$m, 6.6e-288], N[(2.0 / N[(t$95$2 * N[(N[(N[Power[t$95$m, 3.0], $MachinePrecision] / l), $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 3.3e-167], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[(N[Sin[k$95$m], $MachinePrecision] * N[(N[Power[t$95$m, 3.0], $MachinePrecision] / N[(l * l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 1120000000000.0], N[(2.0 / N[(t$95$2 * N[(N[Power[N[(t$95$m / N[Power[l, 1/3], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(t$95$m * N[Power[k$95$m, 4.0], $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]]), $MachinePrecision]]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
\begin{array}{l}
t_2 := 2 \cdot {k\_m}^{2}\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 6.6 \cdot 10^{-288}:\\
\;\;\;\;\frac{2}{t\_2 \cdot \frac{\frac{{t\_m}^{3}}{\ell}}{\ell}}\\
\mathbf{elif}\;k\_m \leq 3.3 \cdot 10^{-167}:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot \left(\sin k\_m \cdot \frac{{t\_m}^{3}}{\ell \cdot \ell}\right)}\\
\mathbf{elif}\;k\_m \leq 1120000000000:\\
\;\;\;\;\frac{2}{t\_2 \cdot \frac{{\left(\frac{t\_m}{\sqrt[3]{\ell}}\right)}^{3}}{\ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{t\_m \cdot {k\_m}^{4}}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
\end{array}
if k < 6.59999999999999976e-288Initial program 54.6%
Simplified59.6%
Taylor expanded in k around 0 53.7%
if 6.59999999999999976e-288 < k < 3.29999999999999995e-167Initial program 72.8%
Simplified72.8%
Taylor expanded in k around 0 72.8%
if 3.29999999999999995e-167 < k < 1.12e12Initial program 63.6%
Simplified68.1%
Taylor expanded in k around 0 75.2%
add-cube-cbrt75.1%
pow375.1%
cbrt-div75.0%
rem-cbrt-cube79.3%
Applied egg-rr79.3%
if 1.12e12 < k Initial program 54.1%
Taylor expanded in t around 0 71.7%
associate-*r*71.7%
Simplified71.7%
Taylor expanded in k around 0 66.1%
Final simplification62.7%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(let* ((t_2 (* 2.0 (pow k_m 2.0))))
(*
t_s
(if (<= k_m 1.22e-288)
(/ 2.0 (* t_2 (/ (/ (pow t_m 3.0) l) l)))
(if (<= k_m 2.9e-146)
(/ 2.0 (* (* k_m 2.0) (pow (* t_m (cbrt (/ k_m (pow l 2.0)))) 3.0)))
(if (<= k_m 6000000000000.0)
(/ 2.0 (* t_2 (/ (pow (/ t_m (cbrt l)) 3.0) l)))
(/ 2.0 (/ (* t_m (pow k_m 4.0)) (* (pow l 2.0) (cos k_m))))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double t_2 = 2.0 * pow(k_m, 2.0);
double tmp;
if (k_m <= 1.22e-288) {
tmp = 2.0 / (t_2 * ((pow(t_m, 3.0) / l) / l));
} else if (k_m <= 2.9e-146) {
tmp = 2.0 / ((k_m * 2.0) * pow((t_m * cbrt((k_m / pow(l, 2.0)))), 3.0));
} else if (k_m <= 6000000000000.0) {
tmp = 2.0 / (t_2 * (pow((t_m / cbrt(l)), 3.0) / l));
} else {
tmp = 2.0 / ((t_m * pow(k_m, 4.0)) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double t_2 = 2.0 * Math.pow(k_m, 2.0);
double tmp;
if (k_m <= 1.22e-288) {
tmp = 2.0 / (t_2 * ((Math.pow(t_m, 3.0) / l) / l));
} else if (k_m <= 2.9e-146) {
tmp = 2.0 / ((k_m * 2.0) * Math.pow((t_m * Math.cbrt((k_m / Math.pow(l, 2.0)))), 3.0));
} else if (k_m <= 6000000000000.0) {
tmp = 2.0 / (t_2 * (Math.pow((t_m / Math.cbrt(l)), 3.0) / l));
} else {
tmp = 2.0 / ((t_m * Math.pow(k_m, 4.0)) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) t_2 = Float64(2.0 * (k_m ^ 2.0)) tmp = 0.0 if (k_m <= 1.22e-288) tmp = Float64(2.0 / Float64(t_2 * Float64(Float64((t_m ^ 3.0) / l) / l))); elseif (k_m <= 2.9e-146) tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * (Float64(t_m * cbrt(Float64(k_m / (l ^ 2.0)))) ^ 3.0))); elseif (k_m <= 6000000000000.0) tmp = Float64(2.0 / Float64(t_2 * Float64((Float64(t_m / cbrt(l)) ^ 3.0) / l))); else tmp = Float64(2.0 / Float64(Float64(t_m * (k_m ^ 4.0)) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := Block[{t$95$2 = N[(2.0 * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision]}, N[(t$95$s * If[LessEqual[k$95$m, 1.22e-288], N[(2.0 / N[(t$95$2 * N[(N[(N[Power[t$95$m, 3.0], $MachinePrecision] / l), $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 2.9e-146], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[Power[N[(t$95$m * N[Power[N[(k$95$m / N[Power[l, 2.0], $MachinePrecision]), $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 6000000000000.0], N[(2.0 / N[(t$95$2 * N[(N[Power[N[(t$95$m / N[Power[l, 1/3], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(t$95$m * N[Power[k$95$m, 4.0], $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]]), $MachinePrecision]]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
\begin{array}{l}
t_2 := 2 \cdot {k\_m}^{2}\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 1.22 \cdot 10^{-288}:\\
\;\;\;\;\frac{2}{t\_2 \cdot \frac{\frac{{t\_m}^{3}}{\ell}}{\ell}}\\
\mathbf{elif}\;k\_m \leq 2.9 \cdot 10^{-146}:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot {\left(t\_m \cdot \sqrt[3]{\frac{k\_m}{{\ell}^{2}}}\right)}^{3}}\\
\mathbf{elif}\;k\_m \leq 6000000000000:\\
\;\;\;\;\frac{2}{t\_2 \cdot \frac{{\left(\frac{t\_m}{\sqrt[3]{\ell}}\right)}^{3}}{\ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{t\_m \cdot {k\_m}^{4}}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
\end{array}
if k < 1.22e-288Initial program 54.6%
Simplified59.6%
Taylor expanded in k around 0 53.7%
if 1.22e-288 < k < 2.90000000000000011e-146Initial program 71.7%
Simplified71.7%
add-cube-cbrt71.5%
pow371.5%
*-commutative71.5%
cbrt-prod71.4%
cbrt-div71.4%
rem-cbrt-cube81.2%
cbrt-prod90.3%
pow290.3%
Applied egg-rr90.3%
*-commutative90.3%
Simplified90.3%
unpow290.3%
clear-num90.3%
un-div-inv90.3%
Applied egg-rr90.3%
Taylor expanded in k around 0 75.2%
Taylor expanded in k around 0 75.2%
*-commutative75.2%
Simplified75.2%
if 2.90000000000000011e-146 < k < 6e12Initial program 63.0%
Simplified68.3%
Taylor expanded in k around 0 76.4%
add-cube-cbrt76.3%
pow376.3%
cbrt-div76.2%
rem-cbrt-cube78.7%
Applied egg-rr78.7%
if 6e12 < k Initial program 54.1%
Taylor expanded in t around 0 71.7%
associate-*r*71.7%
Simplified71.7%
Taylor expanded in k around 0 66.1%
Final simplification62.7%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(let* ((t_2 (* 2.0 (pow k_m 2.0))))
(*
t_s
(if (<= k_m 2.4e-288)
(/ 2.0 (* t_2 (/ (/ (pow t_m 3.0) l) l)))
(if (<= k_m 1.25e-167)
(/ 2.0 (* (* k_m 2.0) (* (sin k_m) (/ (pow t_m 3.0) (* l l)))))
(if (<= k_m 1120000000000.0)
(/ 2.0 (* t_2 (/ (* (pow t_m 2.0) (/ t_m l)) l)))
(/ 2.0 (/ (* t_m (pow k_m 4.0)) (* (pow l 2.0) (cos k_m))))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double t_2 = 2.0 * pow(k_m, 2.0);
double tmp;
if (k_m <= 2.4e-288) {
tmp = 2.0 / (t_2 * ((pow(t_m, 3.0) / l) / l));
} else if (k_m <= 1.25e-167) {
tmp = 2.0 / ((k_m * 2.0) * (sin(k_m) * (pow(t_m, 3.0) / (l * l))));
} else if (k_m <= 1120000000000.0) {
tmp = 2.0 / (t_2 * ((pow(t_m, 2.0) * (t_m / l)) / l));
} else {
tmp = 2.0 / ((t_m * pow(k_m, 4.0)) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k_m
real(8) :: t_2
real(8) :: tmp
t_2 = 2.0d0 * (k_m ** 2.0d0)
if (k_m <= 2.4d-288) then
tmp = 2.0d0 / (t_2 * (((t_m ** 3.0d0) / l) / l))
else if (k_m <= 1.25d-167) then
tmp = 2.0d0 / ((k_m * 2.0d0) * (sin(k_m) * ((t_m ** 3.0d0) / (l * l))))
else if (k_m <= 1120000000000.0d0) then
tmp = 2.0d0 / (t_2 * (((t_m ** 2.0d0) * (t_m / l)) / l))
else
tmp = 2.0d0 / ((t_m * (k_m ** 4.0d0)) / ((l ** 2.0d0) * cos(k_m)))
end if
code = t_s * tmp
end function
k_m = Math.abs(k);
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_m) {
double t_2 = 2.0 * Math.pow(k_m, 2.0);
double tmp;
if (k_m <= 2.4e-288) {
tmp = 2.0 / (t_2 * ((Math.pow(t_m, 3.0) / l) / l));
} else if (k_m <= 1.25e-167) {
tmp = 2.0 / ((k_m * 2.0) * (Math.sin(k_m) * (Math.pow(t_m, 3.0) / (l * l))));
} else if (k_m <= 1120000000000.0) {
tmp = 2.0 / (t_2 * ((Math.pow(t_m, 2.0) * (t_m / l)) / l));
} else {
tmp = 2.0 / ((t_m * Math.pow(k_m, 4.0)) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = math.fabs(k) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k_m): t_2 = 2.0 * math.pow(k_m, 2.0) tmp = 0 if k_m <= 2.4e-288: tmp = 2.0 / (t_2 * ((math.pow(t_m, 3.0) / l) / l)) elif k_m <= 1.25e-167: tmp = 2.0 / ((k_m * 2.0) * (math.sin(k_m) * (math.pow(t_m, 3.0) / (l * l)))) elif k_m <= 1120000000000.0: tmp = 2.0 / (t_2 * ((math.pow(t_m, 2.0) * (t_m / l)) / l)) else: tmp = 2.0 / ((t_m * math.pow(k_m, 4.0)) / (math.pow(l, 2.0) * math.cos(k_m))) return t_s * tmp
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) t_2 = Float64(2.0 * (k_m ^ 2.0)) tmp = 0.0 if (k_m <= 2.4e-288) tmp = Float64(2.0 / Float64(t_2 * Float64(Float64((t_m ^ 3.0) / l) / l))); elseif (k_m <= 1.25e-167) tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * Float64(sin(k_m) * Float64((t_m ^ 3.0) / Float64(l * l))))); elseif (k_m <= 1120000000000.0) tmp = Float64(2.0 / Float64(t_2 * Float64(Float64((t_m ^ 2.0) * Float64(t_m / l)) / l))); else tmp = Float64(2.0 / Float64(Float64(t_m * (k_m ^ 4.0)) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = abs(k); t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k_m) t_2 = 2.0 * (k_m ^ 2.0); tmp = 0.0; if (k_m <= 2.4e-288) tmp = 2.0 / (t_2 * (((t_m ^ 3.0) / l) / l)); elseif (k_m <= 1.25e-167) tmp = 2.0 / ((k_m * 2.0) * (sin(k_m) * ((t_m ^ 3.0) / (l * l)))); elseif (k_m <= 1120000000000.0) tmp = 2.0 / (t_2 * (((t_m ^ 2.0) * (t_m / l)) / l)); else tmp = 2.0 / ((t_m * (k_m ^ 4.0)) / ((l ^ 2.0) * cos(k_m))); end tmp_2 = t_s * tmp; end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := Block[{t$95$2 = N[(2.0 * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision]}, N[(t$95$s * If[LessEqual[k$95$m, 2.4e-288], N[(2.0 / N[(t$95$2 * N[(N[(N[Power[t$95$m, 3.0], $MachinePrecision] / l), $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 1.25e-167], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[(N[Sin[k$95$m], $MachinePrecision] * N[(N[Power[t$95$m, 3.0], $MachinePrecision] / N[(l * l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 1120000000000.0], N[(2.0 / N[(t$95$2 * N[(N[(N[Power[t$95$m, 2.0], $MachinePrecision] * N[(t$95$m / l), $MachinePrecision]), $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(t$95$m * N[Power[k$95$m, 4.0], $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]]), $MachinePrecision]]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
\begin{array}{l}
t_2 := 2 \cdot {k\_m}^{2}\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 2.4 \cdot 10^{-288}:\\
\;\;\;\;\frac{2}{t\_2 \cdot \frac{\frac{{t\_m}^{3}}{\ell}}{\ell}}\\
\mathbf{elif}\;k\_m \leq 1.25 \cdot 10^{-167}:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot \left(\sin k\_m \cdot \frac{{t\_m}^{3}}{\ell \cdot \ell}\right)}\\
\mathbf{elif}\;k\_m \leq 1120000000000:\\
\;\;\;\;\frac{2}{t\_2 \cdot \frac{{t\_m}^{2} \cdot \frac{t\_m}{\ell}}{\ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{t\_m \cdot {k\_m}^{4}}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
\end{array}
if k < 2.3999999999999998e-288Initial program 54.6%
Simplified59.6%
Taylor expanded in k around 0 53.7%
if 2.3999999999999998e-288 < k < 1.25000000000000005e-167Initial program 72.8%
Simplified72.8%
Taylor expanded in k around 0 72.8%
if 1.25000000000000005e-167 < k < 1.12e12Initial program 63.6%
Simplified68.1%
Taylor expanded in k around 0 75.2%
unpow375.2%
*-un-lft-identity75.2%
times-frac77.4%
pow277.4%
Applied egg-rr77.4%
if 1.12e12 < k Initial program 54.1%
Taylor expanded in t around 0 71.7%
associate-*r*71.7%
Simplified71.7%
Taylor expanded in k around 0 66.1%
Final simplification62.4%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 3.3e-167)
(* (* (/ (/ 2.0 (pow t_m 3.0)) (sin k_m)) (/ l (tan k_m))) (* l 0.5))
(if (<= k_m 1120000000000.0)
(/
2.0
(* (* 2.0 (pow k_m 2.0)) (/ (* (pow t_m 1.5) (/ (pow t_m 1.5) l)) l)))
(/ 2.0 (/ (* t_m (pow k_m 4.0)) (* (pow l 2.0) (cos k_m))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 3.3e-167) {
tmp = (((2.0 / pow(t_m, 3.0)) / sin(k_m)) * (l / tan(k_m))) * (l * 0.5);
} else if (k_m <= 1120000000000.0) {
tmp = 2.0 / ((2.0 * pow(k_m, 2.0)) * ((pow(t_m, 1.5) * (pow(t_m, 1.5) / l)) / l));
} else {
tmp = 2.0 / ((t_m * pow(k_m, 4.0)) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k_m
real(8) :: tmp
if (k_m <= 3.3d-167) then
tmp = (((2.0d0 / (t_m ** 3.0d0)) / sin(k_m)) * (l / tan(k_m))) * (l * 0.5d0)
else if (k_m <= 1120000000000.0d0) then
tmp = 2.0d0 / ((2.0d0 * (k_m ** 2.0d0)) * (((t_m ** 1.5d0) * ((t_m ** 1.5d0) / l)) / l))
else
tmp = 2.0d0 / ((t_m * (k_m ** 4.0d0)) / ((l ** 2.0d0) * cos(k_m)))
end if
code = t_s * tmp
end function
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 3.3e-167) {
tmp = (((2.0 / Math.pow(t_m, 3.0)) / Math.sin(k_m)) * (l / Math.tan(k_m))) * (l * 0.5);
} else if (k_m <= 1120000000000.0) {
tmp = 2.0 / ((2.0 * Math.pow(k_m, 2.0)) * ((Math.pow(t_m, 1.5) * (Math.pow(t_m, 1.5) / l)) / l));
} else {
tmp = 2.0 / ((t_m * Math.pow(k_m, 4.0)) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = math.fabs(k) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k_m): tmp = 0 if k_m <= 3.3e-167: tmp = (((2.0 / math.pow(t_m, 3.0)) / math.sin(k_m)) * (l / math.tan(k_m))) * (l * 0.5) elif k_m <= 1120000000000.0: tmp = 2.0 / ((2.0 * math.pow(k_m, 2.0)) * ((math.pow(t_m, 1.5) * (math.pow(t_m, 1.5) / l)) / l)) else: tmp = 2.0 / ((t_m * math.pow(k_m, 4.0)) / (math.pow(l, 2.0) * math.cos(k_m))) return t_s * tmp
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 3.3e-167) tmp = Float64(Float64(Float64(Float64(2.0 / (t_m ^ 3.0)) / sin(k_m)) * Float64(l / tan(k_m))) * Float64(l * 0.5)); elseif (k_m <= 1120000000000.0) tmp = Float64(2.0 / Float64(Float64(2.0 * (k_m ^ 2.0)) * Float64(Float64((t_m ^ 1.5) * Float64((t_m ^ 1.5) / l)) / l))); else tmp = Float64(2.0 / Float64(Float64(t_m * (k_m ^ 4.0)) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = abs(k); t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k_m) tmp = 0.0; if (k_m <= 3.3e-167) tmp = (((2.0 / (t_m ^ 3.0)) / sin(k_m)) * (l / tan(k_m))) * (l * 0.5); elseif (k_m <= 1120000000000.0) tmp = 2.0 / ((2.0 * (k_m ^ 2.0)) * (((t_m ^ 1.5) * ((t_m ^ 1.5) / l)) / l)); else tmp = 2.0 / ((t_m * (k_m ^ 4.0)) / ((l ^ 2.0) * cos(k_m))); end tmp_2 = t_s * tmp; end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 3.3e-167], N[(N[(N[(N[(2.0 / N[Power[t$95$m, 3.0], $MachinePrecision]), $MachinePrecision] / N[Sin[k$95$m], $MachinePrecision]), $MachinePrecision] * N[(l / N[Tan[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(l * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 1120000000000.0], N[(2.0 / N[(N[(2.0 * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(N[(N[Power[t$95$m, 1.5], $MachinePrecision] * N[(N[Power[t$95$m, 1.5], $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(t$95$m * N[Power[k$95$m, 4.0], $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 3.3 \cdot 10^{-167}:\\
\;\;\;\;\left(\frac{\frac{2}{{t\_m}^{3}}}{\sin k\_m} \cdot \frac{\ell}{\tan k\_m}\right) \cdot \left(\ell \cdot 0.5\right)\\
\mathbf{elif}\;k\_m \leq 1120000000000:\\
\;\;\;\;\frac{2}{\left(2 \cdot {k\_m}^{2}\right) \cdot \frac{{t\_m}^{1.5} \cdot \frac{{t\_m}^{1.5}}{\ell}}{\ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{t\_m \cdot {k\_m}^{4}}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
if k < 3.29999999999999995e-167Initial program 57.5%
Simplified52.1%
associate-*r*58.8%
*-un-lft-identity58.8%
times-frac59.2%
Applied egg-rr59.2%
/-rgt-identity59.2%
associate-*l/59.2%
associate-*r*62.9%
times-frac65.1%
associate-/r*65.2%
Simplified65.2%
Taylor expanded in k around 0 63.5%
*-commutative63.5%
Simplified63.5%
if 3.29999999999999995e-167 < k < 1.12e12Initial program 63.6%
Simplified68.1%
Taylor expanded in k around 0 75.2%
sqr-pow38.0%
*-un-lft-identity38.0%
times-frac42.4%
metadata-eval42.4%
metadata-eval42.4%
Applied egg-rr42.4%
if 1.12e12 < k Initial program 54.1%
Taylor expanded in t around 0 71.7%
associate-*r*71.7%
Simplified71.7%
Taylor expanded in k around 0 66.1%
Final simplification60.3%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 3.3e-167)
(* (* (/ (/ 2.0 (pow t_m 3.0)) (sin k_m)) (/ l (tan k_m))) (* l 0.5))
(if (<= k_m 1040000000000.0)
(/ 2.0 (* (* 2.0 (pow k_m 2.0)) (/ (pow (/ t_m (cbrt l)) 3.0) l)))
(/ 2.0 (/ (* t_m (pow k_m 4.0)) (* (pow l 2.0) (cos k_m))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 3.3e-167) {
tmp = (((2.0 / pow(t_m, 3.0)) / sin(k_m)) * (l / tan(k_m))) * (l * 0.5);
} else if (k_m <= 1040000000000.0) {
tmp = 2.0 / ((2.0 * pow(k_m, 2.0)) * (pow((t_m / cbrt(l)), 3.0) / l));
} else {
tmp = 2.0 / ((t_m * pow(k_m, 4.0)) / (pow(l, 2.0) * cos(k_m)));
}
return t_s * tmp;
}
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 3.3e-167) {
tmp = (((2.0 / Math.pow(t_m, 3.0)) / Math.sin(k_m)) * (l / Math.tan(k_m))) * (l * 0.5);
} else if (k_m <= 1040000000000.0) {
tmp = 2.0 / ((2.0 * Math.pow(k_m, 2.0)) * (Math.pow((t_m / Math.cbrt(l)), 3.0) / l));
} else {
tmp = 2.0 / ((t_m * Math.pow(k_m, 4.0)) / (Math.pow(l, 2.0) * Math.cos(k_m)));
}
return t_s * tmp;
}
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 3.3e-167) tmp = Float64(Float64(Float64(Float64(2.0 / (t_m ^ 3.0)) / sin(k_m)) * Float64(l / tan(k_m))) * Float64(l * 0.5)); elseif (k_m <= 1040000000000.0) tmp = Float64(2.0 / Float64(Float64(2.0 * (k_m ^ 2.0)) * Float64((Float64(t_m / cbrt(l)) ^ 3.0) / l))); else tmp = Float64(2.0 / Float64(Float64(t_m * (k_m ^ 4.0)) / Float64((l ^ 2.0) * cos(k_m)))); end return Float64(t_s * tmp) end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 3.3e-167], N[(N[(N[(N[(2.0 / N[Power[t$95$m, 3.0], $MachinePrecision]), $MachinePrecision] / N[Sin[k$95$m], $MachinePrecision]), $MachinePrecision] * N[(l / N[Tan[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(l * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[k$95$m, 1040000000000.0], N[(2.0 / N[(N[(2.0 * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(N[Power[N[(t$95$m / N[Power[l, 1/3], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(t$95$m * N[Power[k$95$m, 4.0], $MachinePrecision]), $MachinePrecision] / N[(N[Power[l, 2.0], $MachinePrecision] * N[Cos[k$95$m], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 3.3 \cdot 10^{-167}:\\
\;\;\;\;\left(\frac{\frac{2}{{t\_m}^{3}}}{\sin k\_m} \cdot \frac{\ell}{\tan k\_m}\right) \cdot \left(\ell \cdot 0.5\right)\\
\mathbf{elif}\;k\_m \leq 1040000000000:\\
\;\;\;\;\frac{2}{\left(2 \cdot {k\_m}^{2}\right) \cdot \frac{{\left(\frac{t\_m}{\sqrt[3]{\ell}}\right)}^{3}}{\ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{t\_m \cdot {k\_m}^{4}}{{\ell}^{2} \cdot \cos k\_m}}\\
\end{array}
\end{array}
if k < 3.29999999999999995e-167Initial program 57.5%
Simplified52.1%
associate-*r*58.8%
*-un-lft-identity58.8%
times-frac59.2%
Applied egg-rr59.2%
/-rgt-identity59.2%
associate-*l/59.2%
associate-*r*62.9%
times-frac65.1%
associate-/r*65.2%
Simplified65.2%
Taylor expanded in k around 0 63.5%
*-commutative63.5%
Simplified63.5%
if 3.29999999999999995e-167 < k < 1.04e12Initial program 63.6%
Simplified68.1%
Taylor expanded in k around 0 75.2%
add-cube-cbrt75.1%
pow375.1%
cbrt-div75.0%
rem-cbrt-cube79.3%
Applied egg-rr79.3%
if 1.04e12 < k Initial program 54.1%
Taylor expanded in t around 0 71.7%
associate-*r*71.7%
Simplified71.7%
Taylor expanded in k around 0 66.1%
Final simplification66.9%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= t_m 3e-91)
(/ 2.0 (* t_m (* (pow k_m 4.0) (pow l -2.0))))
(/ 2.0 (* (* k_m 2.0) (* (sin k_m) (/ (pow t_m 3.0) (* l l))))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (t_m <= 3e-91) {
tmp = 2.0 / (t_m * (pow(k_m, 4.0) * pow(l, -2.0)));
} else {
tmp = 2.0 / ((k_m * 2.0) * (sin(k_m) * (pow(t_m, 3.0) / (l * l))));
}
return t_s * tmp;
}
k_m = abs(k)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k_m
real(8) :: tmp
if (t_m <= 3d-91) then
tmp = 2.0d0 / (t_m * ((k_m ** 4.0d0) * (l ** (-2.0d0))))
else
tmp = 2.0d0 / ((k_m * 2.0d0) * (sin(k_m) * ((t_m ** 3.0d0) / (l * l))))
end if
code = t_s * tmp
end function
k_m = Math.abs(k);
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_m) {
double tmp;
if (t_m <= 3e-91) {
tmp = 2.0 / (t_m * (Math.pow(k_m, 4.0) * Math.pow(l, -2.0)));
} else {
tmp = 2.0 / ((k_m * 2.0) * (Math.sin(k_m) * (Math.pow(t_m, 3.0) / (l * l))));
}
return t_s * tmp;
}
k_m = math.fabs(k) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k_m): tmp = 0 if t_m <= 3e-91: tmp = 2.0 / (t_m * (math.pow(k_m, 4.0) * math.pow(l, -2.0))) else: tmp = 2.0 / ((k_m * 2.0) * (math.sin(k_m) * (math.pow(t_m, 3.0) / (l * l)))) return t_s * tmp
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (t_m <= 3e-91) tmp = Float64(2.0 / Float64(t_m * Float64((k_m ^ 4.0) * (l ^ -2.0)))); else tmp = Float64(2.0 / Float64(Float64(k_m * 2.0) * Float64(sin(k_m) * Float64((t_m ^ 3.0) / Float64(l * l))))); end return Float64(t_s * tmp) end
k_m = abs(k); t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k_m) tmp = 0.0; if (t_m <= 3e-91) tmp = 2.0 / (t_m * ((k_m ^ 4.0) * (l ^ -2.0))); else tmp = 2.0 / ((k_m * 2.0) * (sin(k_m) * ((t_m ^ 3.0) / (l * l)))); end tmp_2 = t_s * tmp; end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[t$95$m, 3e-91], N[(2.0 / N[(t$95$m * N[(N[Power[k$95$m, 4.0], $MachinePrecision] * N[Power[l, -2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(k$95$m * 2.0), $MachinePrecision] * N[(N[Sin[k$95$m], $MachinePrecision] * N[(N[Power[t$95$m, 3.0], $MachinePrecision] / N[(l * l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;t\_m \leq 3 \cdot 10^{-91}:\\
\;\;\;\;\frac{2}{t\_m \cdot \left({k\_m}^{4} \cdot {\ell}^{-2}\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\left(k\_m \cdot 2\right) \cdot \left(\sin k\_m \cdot \frac{{t\_m}^{3}}{\ell \cdot \ell}\right)}\\
\end{array}
\end{array}
if t < 3.0000000000000002e-91Initial program 51.5%
Taylor expanded in t around 0 62.1%
associate-*r*62.1%
Simplified62.1%
Taylor expanded in k around 0 52.1%
*-commutative52.1%
associate-/l*51.6%
Simplified51.6%
*-un-lft-identity51.6%
div-inv51.6%
pow-flip51.6%
metadata-eval51.6%
Applied egg-rr51.6%
*-lft-identity51.6%
Simplified51.6%
if 3.0000000000000002e-91 < t Initial program 71.5%
Simplified71.5%
Taylor expanded in k around 0 62.2%
Final simplification55.0%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 2.15e+14)
(/ 2.0 (* (* 2.0 (pow k_m 2.0)) (/ (/ (pow t_m 3.0) l) l)))
(/ 2.0 (/ (* t_m (pow k_m 4.0)) (pow l 2.0))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 2.15e+14) {
tmp = 2.0 / ((2.0 * pow(k_m, 2.0)) * ((pow(t_m, 3.0) / l) / l));
} else {
tmp = 2.0 / ((t_m * pow(k_m, 4.0)) / pow(l, 2.0));
}
return t_s * tmp;
}
k_m = abs(k)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k_m
real(8) :: tmp
if (k_m <= 2.15d+14) then
tmp = 2.0d0 / ((2.0d0 * (k_m ** 2.0d0)) * (((t_m ** 3.0d0) / l) / l))
else
tmp = 2.0d0 / ((t_m * (k_m ** 4.0d0)) / (l ** 2.0d0))
end if
code = t_s * tmp
end function
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 2.15e+14) {
tmp = 2.0 / ((2.0 * Math.pow(k_m, 2.0)) * ((Math.pow(t_m, 3.0) / l) / l));
} else {
tmp = 2.0 / ((t_m * Math.pow(k_m, 4.0)) / Math.pow(l, 2.0));
}
return t_s * tmp;
}
k_m = math.fabs(k) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k_m): tmp = 0 if k_m <= 2.15e+14: tmp = 2.0 / ((2.0 * math.pow(k_m, 2.0)) * ((math.pow(t_m, 3.0) / l) / l)) else: tmp = 2.0 / ((t_m * math.pow(k_m, 4.0)) / math.pow(l, 2.0)) return t_s * tmp
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 2.15e+14) tmp = Float64(2.0 / Float64(Float64(2.0 * (k_m ^ 2.0)) * Float64(Float64((t_m ^ 3.0) / l) / l))); else tmp = Float64(2.0 / Float64(Float64(t_m * (k_m ^ 4.0)) / (l ^ 2.0))); end return Float64(t_s * tmp) end
k_m = abs(k); t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k_m) tmp = 0.0; if (k_m <= 2.15e+14) tmp = 2.0 / ((2.0 * (k_m ^ 2.0)) * (((t_m ^ 3.0) / l) / l)); else tmp = 2.0 / ((t_m * (k_m ^ 4.0)) / (l ^ 2.0)); end tmp_2 = t_s * tmp; end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 2.15e+14], N[(2.0 / N[(N[(2.0 * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[(N[(N[Power[t$95$m, 3.0], $MachinePrecision] / l), $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(t$95$m * N[Power[k$95$m, 4.0], $MachinePrecision]), $MachinePrecision] / N[Power[l, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 2.15 \cdot 10^{+14}:\\
\;\;\;\;\frac{2}{\left(2 \cdot {k\_m}^{2}\right) \cdot \frac{\frac{{t\_m}^{3}}{\ell}}{\ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{t\_m \cdot {k\_m}^{4}}{{\ell}^{2}}}\\
\end{array}
\end{array}
if k < 2.15e14Initial program 58.9%
Simplified61.7%
Taylor expanded in k around 0 59.4%
if 2.15e14 < k Initial program 54.1%
Taylor expanded in t around 0 71.7%
associate-*r*71.7%
Simplified71.7%
Taylor expanded in k around 0 62.2%
Final simplification60.0%
k_m = (fabs.f64 k)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
(FPCore (t_s t_m l k_m)
:precision binary64
(*
t_s
(if (<= k_m 3.9e+15)
(/ 2.0 (* (/ (pow t_m 3.0) l) (/ (* 2.0 (pow k_m 2.0)) l)))
(/ 2.0 (/ (* t_m (pow k_m 4.0)) (pow l 2.0))))))k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
double tmp;
if (k_m <= 3.9e+15) {
tmp = 2.0 / ((pow(t_m, 3.0) / l) * ((2.0 * pow(k_m, 2.0)) / l));
} else {
tmp = 2.0 / ((t_m * pow(k_m, 4.0)) / pow(l, 2.0));
}
return t_s * tmp;
}
k_m = abs(k)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k_m
real(8) :: tmp
if (k_m <= 3.9d+15) then
tmp = 2.0d0 / (((t_m ** 3.0d0) / l) * ((2.0d0 * (k_m ** 2.0d0)) / l))
else
tmp = 2.0d0 / ((t_m * (k_m ** 4.0d0)) / (l ** 2.0d0))
end if
code = t_s * tmp
end function
k_m = Math.abs(k);
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_m) {
double tmp;
if (k_m <= 3.9e+15) {
tmp = 2.0 / ((Math.pow(t_m, 3.0) / l) * ((2.0 * Math.pow(k_m, 2.0)) / l));
} else {
tmp = 2.0 / ((t_m * Math.pow(k_m, 4.0)) / Math.pow(l, 2.0));
}
return t_s * tmp;
}
k_m = math.fabs(k) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k_m): tmp = 0 if k_m <= 3.9e+15: tmp = 2.0 / ((math.pow(t_m, 3.0) / l) * ((2.0 * math.pow(k_m, 2.0)) / l)) else: tmp = 2.0 / ((t_m * math.pow(k_m, 4.0)) / math.pow(l, 2.0)) return t_s * tmp
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) tmp = 0.0 if (k_m <= 3.9e+15) tmp = Float64(2.0 / Float64(Float64((t_m ^ 3.0) / l) * Float64(Float64(2.0 * (k_m ^ 2.0)) / l))); else tmp = Float64(2.0 / Float64(Float64(t_m * (k_m ^ 4.0)) / (l ^ 2.0))); end return Float64(t_s * tmp) end
k_m = abs(k); t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp_2 = code(t_s, t_m, l, k_m) tmp = 0.0; if (k_m <= 3.9e+15) tmp = 2.0 / (((t_m ^ 3.0) / l) * ((2.0 * (k_m ^ 2.0)) / l)); else tmp = 2.0 / ((t_m * (k_m ^ 4.0)) / (l ^ 2.0)); end tmp_2 = t_s * tmp; end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * If[LessEqual[k$95$m, 3.9e+15], N[(2.0 / N[(N[(N[Power[t$95$m, 3.0], $MachinePrecision] / l), $MachinePrecision] * N[(N[(2.0 * N[Power[k$95$m, 2.0], $MachinePrecision]), $MachinePrecision] / l), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(2.0 / N[(N[(t$95$m * N[Power[k$95$m, 4.0], $MachinePrecision]), $MachinePrecision] / N[Power[l, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \begin{array}{l}
\mathbf{if}\;k\_m \leq 3.9 \cdot 10^{+15}:\\
\;\;\;\;\frac{2}{\frac{{t\_m}^{3}}{\ell} \cdot \frac{2 \cdot {k\_m}^{2}}{\ell}}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\frac{t\_m \cdot {k\_m}^{4}}{{\ell}^{2}}}\\
\end{array}
\end{array}
if k < 3.9e15Initial program 58.9%
Simplified61.7%
Taylor expanded in k around 0 59.4%
associate-*l/59.1%
Applied egg-rr59.1%
associate-/l*60.2%
Simplified60.2%
if 3.9e15 < k Initial program 54.1%
Taylor expanded in t around 0 71.7%
associate-*r*71.7%
Simplified71.7%
Taylor expanded in k around 0 62.2%
Final simplification60.6%
k_m = (fabs.f64 k) t\_m = (fabs.f64 t) t\_s = (copysign.f64 #s(literal 1 binary64) t) (FPCore (t_s t_m l k_m) :precision binary64 (* t_s (/ 2.0 (* t_m (* (pow k_m 4.0) (pow l -2.0))))))
k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
return t_s * (2.0 / (t_m * (pow(k_m, 4.0) * pow(l, -2.0))));
}
k_m = abs(k)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k_m
code = t_s * (2.0d0 / (t_m * ((k_m ** 4.0d0) * (l ** (-2.0d0)))))
end function
k_m = Math.abs(k);
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_m) {
return t_s * (2.0 / (t_m * (Math.pow(k_m, 4.0) * Math.pow(l, -2.0))));
}
k_m = math.fabs(k) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k_m): return t_s * (2.0 / (t_m * (math.pow(k_m, 4.0) * math.pow(l, -2.0))))
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) return Float64(t_s * Float64(2.0 / Float64(t_m * Float64((k_m ^ 4.0) * (l ^ -2.0))))) end
k_m = abs(k); t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp = code(t_s, t_m, l, k_m) tmp = t_s * (2.0 / (t_m * ((k_m ^ 4.0) * (l ^ -2.0)))); end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * N[(2.0 / N[(t$95$m * N[(N[Power[k$95$m, 4.0], $MachinePrecision] * N[Power[l, -2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \frac{2}{t\_m \cdot \left({k\_m}^{4} \cdot {\ell}^{-2}\right)}
\end{array}
Initial program 57.9%
Taylor expanded in t around 0 60.5%
associate-*r*60.5%
Simplified60.5%
Taylor expanded in k around 0 51.0%
*-commutative51.0%
associate-/l*50.7%
Simplified50.7%
*-un-lft-identity50.7%
div-inv50.7%
pow-flip50.7%
metadata-eval50.7%
Applied egg-rr50.7%
*-lft-identity50.7%
Simplified50.7%
Final simplification50.7%
k_m = (fabs.f64 k) t\_m = (fabs.f64 t) t\_s = (copysign.f64 #s(literal 1 binary64) t) (FPCore (t_s t_m l k_m) :precision binary64 (* t_s (/ 2.0 (* t_m (/ (pow k_m 4.0) (pow l 2.0))))))
k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
return t_s * (2.0 / (t_m * (pow(k_m, 4.0) / pow(l, 2.0))));
}
k_m = abs(k)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k_m
code = t_s * (2.0d0 / (t_m * ((k_m ** 4.0d0) / (l ** 2.0d0))))
end function
k_m = Math.abs(k);
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_m) {
return t_s * (2.0 / (t_m * (Math.pow(k_m, 4.0) / Math.pow(l, 2.0))));
}
k_m = math.fabs(k) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k_m): return t_s * (2.0 / (t_m * (math.pow(k_m, 4.0) / math.pow(l, 2.0))))
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) return Float64(t_s * Float64(2.0 / Float64(t_m * Float64((k_m ^ 4.0) / (l ^ 2.0))))) end
k_m = abs(k); t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp = code(t_s, t_m, l, k_m) tmp = t_s * (2.0 / (t_m * ((k_m ^ 4.0) / (l ^ 2.0)))); end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * N[(2.0 / N[(t$95$m * N[(N[Power[k$95$m, 4.0], $MachinePrecision] / N[Power[l, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \frac{2}{t\_m \cdot \frac{{k\_m}^{4}}{{\ell}^{2}}}
\end{array}
Initial program 57.9%
Taylor expanded in t around 0 60.5%
associate-*r*60.5%
Simplified60.5%
Taylor expanded in k around 0 51.0%
*-commutative51.0%
associate-/l*50.7%
Simplified50.7%
Final simplification50.7%
k_m = (fabs.f64 k) t\_m = (fabs.f64 t) t\_s = (copysign.f64 #s(literal 1 binary64) t) (FPCore (t_s t_m l k_m) :precision binary64 (* t_s (/ 2.0 (* (pow k_m 4.0) (/ t_m (pow l 2.0))))))
k_m = fabs(k);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
double code(double t_s, double t_m, double l, double k_m) {
return t_s * (2.0 / (pow(k_m, 4.0) * (t_m / pow(l, 2.0))));
}
k_m = abs(k)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
real(8) function code(t_s, t_m, l, k_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: t_m
real(8), intent (in) :: l
real(8), intent (in) :: k_m
code = t_s * (2.0d0 / ((k_m ** 4.0d0) * (t_m / (l ** 2.0d0))))
end function
k_m = Math.abs(k);
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_m) {
return t_s * (2.0 / (Math.pow(k_m, 4.0) * (t_m / Math.pow(l, 2.0))));
}
k_m = math.fabs(k) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) def code(t_s, t_m, l, k_m): return t_s * (2.0 / (math.pow(k_m, 4.0) * (t_m / math.pow(l, 2.0))))
k_m = abs(k) t\_m = abs(t) t\_s = copysign(1.0, t) function code(t_s, t_m, l, k_m) return Float64(t_s * Float64(2.0 / Float64((k_m ^ 4.0) * Float64(t_m / (l ^ 2.0))))) end
k_m = abs(k); t\_m = abs(t); t\_s = sign(t) * abs(1.0); function tmp = code(t_s, t_m, l, k_m) tmp = t_s * (2.0 / ((k_m ^ 4.0) * (t_m / (l ^ 2.0)))); end
k_m = N[Abs[k], $MachinePrecision]
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$95$m_] := N[(t$95$s * N[(2.0 / N[(N[Power[k$95$m, 4.0], $MachinePrecision] * N[(t$95$m / N[Power[l, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
k_m = \left|k\right|
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
t\_s \cdot \frac{2}{{k\_m}^{4} \cdot \frac{t\_m}{{\ell}^{2}}}
\end{array}
Initial program 57.9%
Taylor expanded in t around 0 60.5%
associate-*r*60.5%
Simplified60.5%
Taylor expanded in k around 0 51.0%
associate-/l*51.3%
Simplified51.3%
Final simplification51.3%
herbie shell --seed 2024071
(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))))