double f(double F, double l) {
double r622944 = atan2(1.0, 0.0);
double r622945 = l;
double r622946 = r622944 * r622945;
double r622947 = 1.0;
double r622948 = F;
double r622949 = r622948 * r622948;
double r622950 = r622947 / r622949;
double r622951 = tan(r622946);
double r622952 = r622950 * r622951;
double r622953 = r622946 - r622952;
return r622953;
}
double f(double F, double l) {
double r622954 = atan2(1.0, 0.0);
double r622955 = l;
double r622956 = r622954 * r622955;
double r622957 = 1.0;
double r622958 = F;
double r622959 = tan(r622956);
double r622960 = r622958 / r622959;
double r622961 = r622957 / r622960;
double r622962 = r622961 / r622958;
double r622963 = r622956 - r622962;
return r622963;
}
\pi \cdot \ell - \frac{1}{F \cdot F} \cdot \tan \left(\pi \cdot \ell\right)\pi \cdot \ell - \frac{\frac{1}{\frac{F}{\tan \left(\pi \cdot \ell\right)}}}{F}


Bits error versus F



Bits error versus l
Initial program 8.3
Simplified7.9
rmApplied associate-/r*0.6
rmApplied *-un-lft-identity0.6
Applied associate-/l*0.6
Final simplification0.6
herbie shell --seed 2019102 +o rules:numerics
(FPCore (F l)
:name "VandenBroeck and Keller, Equation (6)"
(- (* PI l) (* (/ 1 (* F F)) (tan (* PI l)))))