x + \left(\tan \left(y + z\right) - \tan a\right)
\left(\frac{\sin z}{\left(1 - \frac{\sin z \cdot \frac{\sin y}{\cos y}}{\cos z}\right) \cdot \cos z} + \left(\frac{\frac{\sin y}{\cos y}}{1 - \frac{\sin z \cdot \sin y}{\cos y \cdot \cos z}} - \frac{\sin a}{\cos a}\right)\right) + xdouble f(double x, double y, double z, double a) {
double r8254990 = x;
double r8254991 = y;
double r8254992 = z;
double r8254993 = r8254991 + r8254992;
double r8254994 = tan(r8254993);
double r8254995 = a;
double r8254996 = tan(r8254995);
double r8254997 = r8254994 - r8254996;
double r8254998 = r8254990 + r8254997;
return r8254998;
}
double f(double x, double y, double z, double a) {
double r8254999 = z;
double r8255000 = sin(r8254999);
double r8255001 = 1.0;
double r8255002 = y;
double r8255003 = sin(r8255002);
double r8255004 = cos(r8255002);
double r8255005 = r8255003 / r8255004;
double r8255006 = r8255000 * r8255005;
double r8255007 = cos(r8254999);
double r8255008 = r8255006 / r8255007;
double r8255009 = r8255001 - r8255008;
double r8255010 = r8255009 * r8255007;
double r8255011 = r8255000 / r8255010;
double r8255012 = r8255000 * r8255003;
double r8255013 = r8255004 * r8255007;
double r8255014 = r8255012 / r8255013;
double r8255015 = r8255001 - r8255014;
double r8255016 = r8255005 / r8255015;
double r8255017 = a;
double r8255018 = sin(r8255017);
double r8255019 = cos(r8255017);
double r8255020 = r8255018 / r8255019;
double r8255021 = r8255016 - r8255020;
double r8255022 = r8255011 + r8255021;
double r8255023 = x;
double r8255024 = r8255022 + r8255023;
return r8255024;
}



Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus a
Results
Initial program 12.9
rmApplied tan-sum0.2
Taylor expanded around inf 0.2
Simplified0.2
Taylor expanded around inf 0.2
Final simplification0.2
herbie shell --seed 2019172
(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))))