\left(-x \cdot \frac{1}{\tan B}\right) + \frac{F}{\sin B} \cdot {\left(\left(F \cdot F + 2\right) + 2 \cdot x\right)}^{\left(-\frac{1}{2}\right)}\begin{array}{l}
\mathbf{if}\;F \le -6436982318645.525390625:\\
\;\;\;\;\left(\frac{1}{\sin B \cdot {F}^{2}} - \frac{1}{\sin B}\right) - \frac{x \cdot 1}{\tan B}\\
\mathbf{elif}\;F \le 13740.11341628399168257601559162139892578:\\
\;\;\;\;\frac{\frac{F}{\sin B}}{{\left(\left(F \cdot F + 2\right) + 2 \cdot x\right)}^{\left(\frac{1}{2}\right)}} - \frac{x \cdot 1}{\tan B}\\
\mathbf{else}:\\
\;\;\;\;\left(\frac{1}{\sin B} - \frac{1}{\sin B \cdot {F}^{2}}\right) - \frac{x \cdot 1}{\tan B}\\
\end{array}double f(double F, double B, double x) {
double r43376 = x;
double r43377 = 1.0;
double r43378 = B;
double r43379 = tan(r43378);
double r43380 = r43377 / r43379;
double r43381 = r43376 * r43380;
double r43382 = -r43381;
double r43383 = F;
double r43384 = sin(r43378);
double r43385 = r43383 / r43384;
double r43386 = r43383 * r43383;
double r43387 = 2.0;
double r43388 = r43386 + r43387;
double r43389 = r43387 * r43376;
double r43390 = r43388 + r43389;
double r43391 = r43377 / r43387;
double r43392 = -r43391;
double r43393 = pow(r43390, r43392);
double r43394 = r43385 * r43393;
double r43395 = r43382 + r43394;
return r43395;
}
double f(double F, double B, double x) {
double r43396 = F;
double r43397 = -6436982318645.525;
bool r43398 = r43396 <= r43397;
double r43399 = 1.0;
double r43400 = B;
double r43401 = sin(r43400);
double r43402 = 2.0;
double r43403 = pow(r43396, r43402);
double r43404 = r43401 * r43403;
double r43405 = r43399 / r43404;
double r43406 = 1.0;
double r43407 = r43406 / r43401;
double r43408 = r43405 - r43407;
double r43409 = x;
double r43410 = r43409 * r43399;
double r43411 = tan(r43400);
double r43412 = r43410 / r43411;
double r43413 = r43408 - r43412;
double r43414 = 13740.113416283992;
bool r43415 = r43396 <= r43414;
double r43416 = r43396 / r43401;
double r43417 = r43396 * r43396;
double r43418 = 2.0;
double r43419 = r43417 + r43418;
double r43420 = r43418 * r43409;
double r43421 = r43419 + r43420;
double r43422 = r43399 / r43418;
double r43423 = pow(r43421, r43422);
double r43424 = r43416 / r43423;
double r43425 = r43424 - r43412;
double r43426 = r43407 - r43405;
double r43427 = r43426 - r43412;
double r43428 = r43415 ? r43425 : r43427;
double r43429 = r43398 ? r43413 : r43428;
return r43429;
}



Bits error versus F



Bits error versus B



Bits error versus x
Results
if F < -6436982318645.525Initial program 26.5
Simplified26.5
rmApplied associate-*r/26.4
Taylor expanded around -inf 0.1
Simplified0.1
if -6436982318645.525 < F < 13740.113416283992Initial program 0.4
Simplified0.4
rmApplied associate-*r/0.3
rmApplied pow-neg0.3
Applied un-div-inv0.3
if 13740.113416283992 < F Initial program 25.0
Simplified25.0
rmApplied associate-*r/24.9
Taylor expanded around inf 0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2019323
(FPCore (F B x)
:name "VandenBroeck and Keller, Equation (23)"
:precision binary64
(+ (- (* x (/ 1 (tan B)))) (* (/ F (sin B)) (pow (+ (+ (* F F) 2) (* 2 x)) (- (/ 1 2))))))