\left(-x \cdot \frac{1}{\tan B}\right) + \frac{1}{\sin B}\frac{\sqrt[3]{1} \cdot \mathsf{fma}\left(\cos B, -x, 1\right)}{\sin B} \cdot \left(\sqrt[3]{1} \cdot \sqrt[3]{1}\right)double f(double B, double x) {
double r9664 = x;
double r9665 = 1.0;
double r9666 = B;
double r9667 = tan(r9666);
double r9668 = r9665 / r9667;
double r9669 = r9664 * r9668;
double r9670 = -r9669;
double r9671 = sin(r9666);
double r9672 = r9665 / r9671;
double r9673 = r9670 + r9672;
return r9673;
}
double f(double B, double x) {
double r9674 = 1.0;
double r9675 = cbrt(r9674);
double r9676 = B;
double r9677 = cos(r9676);
double r9678 = x;
double r9679 = -r9678;
double r9680 = 1.0;
double r9681 = fma(r9677, r9679, r9680);
double r9682 = r9675 * r9681;
double r9683 = sin(r9676);
double r9684 = r9682 / r9683;
double r9685 = r9675 * r9675;
double r9686 = r9684 * r9685;
return r9686;
}



Bits error versus B



Bits error versus x
Initial program 0.2
Simplified0.2
rmApplied tan-quot0.2
Applied associate-/r/0.2
Taylor expanded around inf 0.2
Simplified0.2
rmApplied *-un-lft-identity0.2
Applied add-cube-cbrt0.2
Applied times-frac0.2
Applied associate-*l*0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2020035 +o rules:numerics
(FPCore (B x)
:name "VandenBroeck and Keller, Equation (24)"
:precision binary64
(+ (- (* x (/ 1 (tan B)))) (/ 1 (sin B))))