\pi \cdot \ell - \frac{1}{F \cdot F} \cdot \tan \left(\pi \cdot \ell\right)\begin{array}{l}
\mathbf{if}\;\pi \cdot \ell \le -4.88463047305792789 \cdot 10^{154}:\\
\;\;\;\;\pi \cdot \ell - \frac{1}{F \cdot F} \cdot \tan \left(\left(\sqrt[3]{\pi \cdot \ell} \cdot \sqrt[3]{\pi \cdot \ell}\right) \cdot \sqrt[3]{\pi \cdot \ell}\right)\\
\mathbf{elif}\;\pi \cdot \ell \le 9.0915089882537537 \cdot 10^{150}:\\
\;\;\;\;\pi \cdot \ell - \frac{\frac{1 \cdot \sin \left(\pi \cdot \ell\right)}{\left|F\right|}}{\left(\left(\frac{1}{24} \cdot \left({\pi}^{4} \cdot {\ell}^{4}\right) + 1\right) - \frac{1}{2} \cdot \left({\pi}^{2} \cdot {\ell}^{2}\right)\right) \cdot \left|F\right|}\\
\mathbf{else}:\\
\;\;\;\;\pi \cdot \ell - e^{\log \left(\frac{1}{F \cdot F}\right)} \cdot \tan \left(\pi \cdot \ell\right)\\
\end{array}double code(double F, double l) {
return ((double) (((double) (((double) M_PI) * l)) - ((double) (((double) (1.0 / ((double) (F * F)))) * ((double) tan(((double) (((double) M_PI) * l))))))));
}
double code(double F, double l) {
double VAR;
if ((((double) (((double) M_PI) * l)) <= -4.884630473057928e+154)) {
VAR = ((double) (((double) (((double) M_PI) * l)) - ((double) (((double) (1.0 / ((double) (F * F)))) * ((double) tan(((double) (((double) (((double) cbrt(((double) (((double) M_PI) * l)))) * ((double) cbrt(((double) (((double) M_PI) * l)))))) * ((double) cbrt(((double) (((double) M_PI) * l))))))))))));
} else {
double VAR_1;
if ((((double) (((double) M_PI) * l)) <= 9.091508988253754e+150)) {
VAR_1 = ((double) (((double) (((double) M_PI) * l)) - ((double) (((double) (((double) (1.0 * ((double) sin(((double) (((double) M_PI) * l)))))) / ((double) fabs(F)))) / ((double) (((double) (((double) (((double) (0.041666666666666664 * ((double) (((double) pow(((double) M_PI), 4.0)) * ((double) pow(l, 4.0)))))) + 1.0)) - ((double) (0.5 * ((double) (((double) pow(((double) M_PI), 2.0)) * ((double) pow(l, 2.0)))))))) * ((double) fabs(F))))))));
} else {
VAR_1 = ((double) (((double) (((double) M_PI) * l)) - ((double) (((double) exp(((double) log(((double) (1.0 / ((double) (F * F)))))))) * ((double) tan(((double) (((double) M_PI) * l))))))));
}
VAR = VAR_1;
}
return VAR;
}



Bits error versus F



Bits error versus l
Results
if (* PI l) < -4.884630473057928e+154Initial program 19.6
rmApplied add-cube-cbrt19.6
if -4.884630473057928e+154 < (* PI l) < 9.091508988253754e+150Initial program 15.3
rmApplied tan-quot15.3
Applied add-sqr-sqrt15.3
Applied associate-/r*15.3
Applied frac-times14.8
Simplified14.8
Simplified9.0
Taylor expanded around 0 3.7
if 9.091508988253754e+150 < (* PI l) Initial program 19.3
rmApplied add-exp-log41.2
Applied add-exp-log41.2
Applied prod-exp41.2
Applied add-exp-log41.2
Applied div-exp41.2
Simplified19.3
Final simplification8.0
herbie shell --seed 2020113
(FPCore (F l)
:name "VandenBroeck and Keller, Equation (6)"
:precision binary64
(- (* PI l) (* (/ 1 (* F F)) (tan (* PI l)))))