\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)}\begin{array}{l}
\mathbf{if}\;t \le -6.37136786365512784 \cdot 10^{131}:\\
\;\;\;\;\frac{2}{\left(\left({\left(\sqrt[3]{t} \cdot \sqrt[3]{t}\right)}^{\left(\frac{3}{2}\right)} \cdot \left(\frac{{\left(\sqrt[3]{t} \cdot \sqrt[3]{t}\right)}^{\left(\frac{3}{2}\right)}}{\ell} \cdot \left(\left(\sqrt[3]{\frac{{\left(\sqrt[3]{t}\right)}^{3}}{\ell} \cdot \sin k} \cdot \sqrt[3]{\frac{{\left(\sqrt[3]{t}\right)}^{3}}{\ell} \cdot \sin k}\right) \cdot \sqrt[3]{\frac{{\left(\sqrt[3]{t}\right)}^{3}}{\ell} \cdot \sin k}\right)\right)\right) \cdot \tan k\right) \cdot \left(\left(1 + {\left(\frac{k}{t}\right)}^{2}\right) + 1\right)}\\
\mathbf{elif}\;t \le -3.32261110546203778 \cdot 10^{-5}:\\
\;\;\;\;\frac{2}{\frac{\left(\left({\left(\sqrt[3]{t} \cdot \sqrt[3]{t}\right)}^{3} \cdot \left(\frac{{\left(\sqrt[3]{t}\right)}^{3}}{\ell} \cdot \sin k\right)\right) \cdot \tan k\right) \cdot \left(\left(1 + {\left(\frac{k}{t}\right)}^{2}\right) + 1\right)}{\ell}}\\
\mathbf{elif}\;t \le -3.2204260688869917 \cdot 10^{-213}:\\
\;\;\;\;\frac{2}{\left(\left({\left(\sqrt[3]{t} \cdot \sqrt[3]{t}\right)}^{\left(\frac{3}{2}\right)} \cdot \frac{{\left(\sqrt[3]{t} \cdot \sqrt[3]{t}\right)}^{\left(\frac{3}{2}\right)}}{\ell}\right) \cdot \left(\frac{{\left(\sqrt[3]{t}\right)}^{3}}{\ell} \cdot \sin k\right)\right) \cdot \left(\tan k \cdot \left(\left(1 + {\left(\frac{k}{t}\right)}^{2}\right) + 1\right)\right)}\\
\mathbf{elif}\;t \le 2.99331157222912718 \cdot 10^{-130}:\\
\;\;\;\;\frac{2}{\left(\left({\left(\sqrt[3]{t} \cdot \sqrt[3]{t}\right)}^{\left(\frac{3}{2}\right)} \cdot \left(\frac{{\left(\sqrt[3]{t} \cdot \sqrt[3]{t}\right)}^{\left(\frac{3}{2}\right)}}{\ell} \cdot \left(\frac{k \cdot t}{\ell} - \frac{1}{6} \cdot \frac{{k}^{3} \cdot t}{\ell}\right)\right)\right) \cdot \tan k\right) \cdot \left(\left(1 + {\left(\frac{k}{t}\right)}^{2}\right) + 1\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\left(\left(\left({\left(\sqrt[3]{t} \cdot \sqrt[3]{t}\right)}^{\left(\frac{3}{2}\right)} \cdot \left(\frac{{\left(\sqrt[3]{t} \cdot \sqrt[3]{t}\right)}^{\left(\frac{3}{2}\right)}}{\ell} \cdot \left(\frac{{\left(\sqrt[3]{t}\right)}^{3}}{\ell} \cdot \sin k\right)\right)\right) \cdot \tan k\right) \cdot \left(\sqrt[3]{\left(1 + {\left(\frac{k}{t}\right)}^{2}\right) + 1} \cdot \sqrt[3]{\left(1 + {\left(\frac{k}{t}\right)}^{2}\right) + 1}\right)\right) \cdot \sqrt[3]{\left(1 + {\left(\frac{k}{t}\right)}^{2}\right) + 1}}\\
\end{array}double code(double t, double l, double k) {
return ((double) (2.0 / ((double) (((double) (((double) (((double) (((double) pow(t, 3.0)) / ((double) (l * l)))) * ((double) sin(k)))) * ((double) tan(k)))) * ((double) (((double) (1.0 + ((double) pow(((double) (k / t)), 2.0)))) + 1.0))))));
}
double code(double t, double l, double k) {
double VAR;
if ((t <= -6.371367863655128e+131)) {
VAR = ((double) (2.0 / ((double) (((double) (((double) (((double) pow(((double) (((double) cbrt(t)) * ((double) cbrt(t)))), ((double) (3.0 / 2.0)))) * ((double) (((double) (((double) pow(((double) (((double) cbrt(t)) * ((double) cbrt(t)))), ((double) (3.0 / 2.0)))) / l)) * ((double) (((double) (((double) cbrt(((double) (((double) (((double) pow(((double) cbrt(t)), 3.0)) / l)) * ((double) sin(k)))))) * ((double) cbrt(((double) (((double) (((double) pow(((double) cbrt(t)), 3.0)) / l)) * ((double) sin(k)))))))) * ((double) cbrt(((double) (((double) (((double) pow(((double) cbrt(t)), 3.0)) / l)) * ((double) sin(k)))))))))))) * ((double) tan(k)))) * ((double) (((double) (1.0 + ((double) pow(((double) (k / t)), 2.0)))) + 1.0))))));
} else {
double VAR_1;
if ((t <= -3.322611105462038e-05)) {
VAR_1 = ((double) (2.0 / ((double) (((double) (((double) (((double) (((double) pow(((double) (((double) cbrt(t)) * ((double) cbrt(t)))), 3.0)) * ((double) (((double) (((double) pow(((double) cbrt(t)), 3.0)) / l)) * ((double) sin(k)))))) * ((double) tan(k)))) * ((double) (((double) (1.0 + ((double) pow(((double) (k / t)), 2.0)))) + 1.0)))) / l))));
} else {
double VAR_2;
if ((t <= -3.2204260688869917e-213)) {
VAR_2 = ((double) (2.0 / ((double) (((double) (((double) (((double) pow(((double) (((double) cbrt(t)) * ((double) cbrt(t)))), ((double) (3.0 / 2.0)))) * ((double) (((double) pow(((double) (((double) cbrt(t)) * ((double) cbrt(t)))), ((double) (3.0 / 2.0)))) / l)))) * ((double) (((double) (((double) pow(((double) cbrt(t)), 3.0)) / l)) * ((double) sin(k)))))) * ((double) (((double) tan(k)) * ((double) (((double) (1.0 + ((double) pow(((double) (k / t)), 2.0)))) + 1.0))))))));
} else {
double VAR_3;
if ((t <= 2.993311572229127e-130)) {
VAR_3 = ((double) (2.0 / ((double) (((double) (((double) (((double) pow(((double) (((double) cbrt(t)) * ((double) cbrt(t)))), ((double) (3.0 / 2.0)))) * ((double) (((double) (((double) pow(((double) (((double) cbrt(t)) * ((double) cbrt(t)))), ((double) (3.0 / 2.0)))) / l)) * ((double) (((double) (((double) (k * t)) / l)) - ((double) (0.16666666666666666 * ((double) (((double) (((double) pow(k, 3.0)) * t)) / l)))))))))) * ((double) tan(k)))) * ((double) (((double) (1.0 + ((double) pow(((double) (k / t)), 2.0)))) + 1.0))))));
} else {
VAR_3 = ((double) (2.0 / ((double) (((double) (((double) (((double) (((double) pow(((double) (((double) cbrt(t)) * ((double) cbrt(t)))), ((double) (3.0 / 2.0)))) * ((double) (((double) (((double) pow(((double) (((double) cbrt(t)) * ((double) cbrt(t)))), ((double) (3.0 / 2.0)))) / l)) * ((double) (((double) (((double) pow(((double) cbrt(t)), 3.0)) / l)) * ((double) sin(k)))))))) * ((double) tan(k)))) * ((double) (((double) cbrt(((double) (((double) (1.0 + ((double) pow(((double) (k / t)), 2.0)))) + 1.0)))) * ((double) cbrt(((double) (((double) (1.0 + ((double) pow(((double) (k / t)), 2.0)))) + 1.0)))))))) * ((double) cbrt(((double) (((double) (1.0 + ((double) pow(((double) (k / t)), 2.0)))) + 1.0))))))));
}
VAR_2 = VAR_3;
}
VAR_1 = VAR_2;
}
VAR = VAR_1;
}
return VAR;
}



Bits error versus t



Bits error versus l



Bits error versus k
Results
if t < -6.371367863655128e+131Initial program 23.5
rmApplied add-cube-cbrt23.5
Applied unpow-prod-down23.5
Applied times-frac17.8
Applied associate-*l*17.4
rmApplied *-un-lft-identity17.4
Applied sqr-pow17.4
Applied times-frac6.5
Simplified6.5
rmApplied associate-*l*4.3
rmApplied add-cube-cbrt4.3
if -6.371367863655128e+131 < t < -3.322611105462038e-05Initial program 21.6
rmApplied add-cube-cbrt21.9
Applied unpow-prod-down21.9
Applied times-frac14.4
Applied associate-*l*10.1
rmApplied associate-*l/9.9
Applied associate-*l/7.8
Applied associate-*l/7.8
if -3.322611105462038e-05 < t < -3.2204260688869917e-213Initial program 45.2
rmApplied add-cube-cbrt45.4
Applied unpow-prod-down45.4
Applied times-frac35.0
Applied associate-*l*32.6
rmApplied *-un-lft-identity32.6
Applied sqr-pow32.6
Applied times-frac28.0
Simplified28.0
rmApplied associate-*l*27.2
if -3.2204260688869917e-213 < t < 2.993311572229127e-130Initial program 64.0
rmApplied add-cube-cbrt64.0
Applied unpow-prod-down64.0
Applied times-frac59.7
Applied associate-*l*59.7
rmApplied *-un-lft-identity59.7
Applied sqr-pow59.7
Applied times-frac50.2
Simplified50.2
rmApplied associate-*l*50.2
Taylor expanded around 0 42.0
if 2.993311572229127e-130 < t Initial program 24.7
rmApplied add-cube-cbrt24.9
Applied unpow-prod-down24.9
Applied times-frac17.6
Applied associate-*l*15.6
rmApplied *-un-lft-identity15.6
Applied sqr-pow15.6
Applied times-frac11.2
Simplified11.2
rmApplied associate-*l*10.9
rmApplied add-cube-cbrt10.9
Applied associate-*r*11.0
Final simplification16.2
herbie shell --seed 2020124
(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))))