x + \left(\tan \left(y + z\right) - \tan a\right)
\frac{\cos a \cdot \left(\tan y + \tan z\right) - \sin a \cdot \left(1 - \sqrt[3]{\tan z \cdot \tan y} \cdot \left(\sqrt[3]{\tan z \cdot \tan y} \cdot \sqrt[3]{\tan z \cdot \tan y}\right)\right)}{\cos a \cdot \left(1 - \tan z \cdot \tan y\right)} + xdouble f(double x, double y, double z, double a) {
double r5236562 = x;
double r5236563 = y;
double r5236564 = z;
double r5236565 = r5236563 + r5236564;
double r5236566 = tan(r5236565);
double r5236567 = a;
double r5236568 = tan(r5236567);
double r5236569 = r5236566 - r5236568;
double r5236570 = r5236562 + r5236569;
return r5236570;
}
double f(double x, double y, double z, double a) {
double r5236571 = a;
double r5236572 = cos(r5236571);
double r5236573 = y;
double r5236574 = tan(r5236573);
double r5236575 = z;
double r5236576 = tan(r5236575);
double r5236577 = r5236574 + r5236576;
double r5236578 = r5236572 * r5236577;
double r5236579 = sin(r5236571);
double r5236580 = 1.0;
double r5236581 = r5236576 * r5236574;
double r5236582 = cbrt(r5236581);
double r5236583 = r5236582 * r5236582;
double r5236584 = r5236582 * r5236583;
double r5236585 = r5236580 - r5236584;
double r5236586 = r5236579 * r5236585;
double r5236587 = r5236578 - r5236586;
double r5236588 = r5236580 - r5236581;
double r5236589 = r5236572 * r5236588;
double r5236590 = r5236587 / r5236589;
double r5236591 = x;
double r5236592 = r5236590 + r5236591;
return r5236592;
}



Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus a
Results
Initial program 12.8
rmApplied tan-quot12.8
Applied tan-sum0.2
Applied frac-sub0.2
rmApplied add-cube-cbrt0.2
Final simplification0.2
herbie shell --seed 2019192 +o rules:numerics
(FPCore (x y z a)
:name "(+ x (- (tan (+ y z)) (tan a)))"
:pre (and (or (== x 0.0) (<= 0.5884142 x 505.5909)) (or (<= -1.796658e+308 y -9.425585e-310) (<= 1.284938e-309 y 1.751224e+308)) (or (<= -1.776707e+308 z -8.599796e-310) (<= 3.293145e-311 z 1.725154e+308)) (or (<= -1.796658e+308 a -9.425585e-310) (<= 1.284938e-309 a 1.751224e+308)))
(+ x (- (tan (+ y z)) (tan a))))