x + \left(\tan \left(y + z\right) - \tan a\right)
\log \left(e^{x} \cdot \frac{e^{\frac{\tan y + \tan z}{1 - \frac{\sin y \cdot \tan z}{\cos y}}}}{e^{\tan a}}\right)double f(double x, double y, double z, double a) {
double r5547425 = x;
double r5547426 = y;
double r5547427 = z;
double r5547428 = r5547426 + r5547427;
double r5547429 = tan(r5547428);
double r5547430 = a;
double r5547431 = tan(r5547430);
double r5547432 = r5547429 - r5547431;
double r5547433 = r5547425 + r5547432;
return r5547433;
}
double f(double x, double y, double z, double a) {
double r5547434 = x;
double r5547435 = exp(r5547434);
double r5547436 = y;
double r5547437 = tan(r5547436);
double r5547438 = z;
double r5547439 = tan(r5547438);
double r5547440 = r5547437 + r5547439;
double r5547441 = 1.0;
double r5547442 = sin(r5547436);
double r5547443 = r5547442 * r5547439;
double r5547444 = cos(r5547436);
double r5547445 = r5547443 / r5547444;
double r5547446 = r5547441 - r5547445;
double r5547447 = r5547440 / r5547446;
double r5547448 = exp(r5547447);
double r5547449 = a;
double r5547450 = tan(r5547449);
double r5547451 = exp(r5547450);
double r5547452 = r5547448 / r5547451;
double r5547453 = r5547435 * r5547452;
double r5547454 = log(r5547453);
return r5547454;
}



Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus a
Results
Initial program 12.8
rmApplied tan-sum0.2
rmApplied add-log-exp0.3
rmApplied tan-quot0.3
Applied associate-*l/0.3
rmApplied add-log-exp0.3
Applied add-log-exp0.3
Applied diff-log0.3
Applied add-log-exp0.3
Applied sum-log0.3
Applied rem-exp-log0.3
Final simplification0.3
herbie shell --seed 2019168
(FPCore (x y z a)
:name "(+ x (- (tan (+ y z)) (tan a)))"
:pre (and (or (== x 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))))