x + \left(\tan \left(y + z\right) - \tan a\right)
\mathsf{fma}\left(\frac{\tan y + \tan z}{1 - \left(\tan z \cdot \tan y\right) \cdot \left(\tan z \cdot \tan y\right)}, \tan z \cdot \tan y + 1, -\tan a\right) + xdouble f(double x, double y, double z, double a) {
double r1903219 = x;
double r1903220 = y;
double r1903221 = z;
double r1903222 = r1903220 + r1903221;
double r1903223 = tan(r1903222);
double r1903224 = a;
double r1903225 = tan(r1903224);
double r1903226 = r1903223 - r1903225;
double r1903227 = r1903219 + r1903226;
return r1903227;
}
double f(double x, double y, double z, double a) {
double r1903228 = y;
double r1903229 = tan(r1903228);
double r1903230 = z;
double r1903231 = tan(r1903230);
double r1903232 = r1903229 + r1903231;
double r1903233 = 1.0;
double r1903234 = r1903231 * r1903229;
double r1903235 = r1903234 * r1903234;
double r1903236 = r1903233 - r1903235;
double r1903237 = r1903232 / r1903236;
double r1903238 = r1903234 + r1903233;
double r1903239 = a;
double r1903240 = tan(r1903239);
double r1903241 = -r1903240;
double r1903242 = fma(r1903237, r1903238, r1903241);
double r1903243 = x;
double r1903244 = r1903242 + r1903243;
return r1903244;
}



Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus a
Initial program 13.1
rmApplied tan-sum0.2
rmApplied flip--0.2
Applied associate-/r/0.2
Applied fma-neg0.2
Final simplification0.2
herbie shell --seed 2019153 +o rules:numerics
(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))))