x + \left(\tan \left(y + z\right) - \tan a\right)
\frac{\left(\cos a \cdot \left(\cos z \cdot \sin y + \sin z \cdot \cos y\right)\right) \cdot \left(1 + \tan z \cdot \tan y\right) - \left(\sin a \cdot \left(1 - \left(\tan z \cdot \tan y\right) \cdot \left(\tan z \cdot \tan y\right)\right)\right) \cdot \left(\cos y \cdot \cos z\right)}{\left(\left(1 + \tan z \cdot \tan y\right) \cdot \left(\cos y \cdot \cos z\right)\right) \cdot \left(\left(1 - \tan z \cdot \tan y\right) \cdot \cos a\right)} + xdouble f(double x, double y, double z, double a) {
double r4723948 = x;
double r4723949 = y;
double r4723950 = z;
double r4723951 = r4723949 + r4723950;
double r4723952 = tan(r4723951);
double r4723953 = a;
double r4723954 = tan(r4723953);
double r4723955 = r4723952 - r4723954;
double r4723956 = r4723948 + r4723955;
return r4723956;
}
double f(double x, double y, double z, double a) {
double r4723957 = a;
double r4723958 = cos(r4723957);
double r4723959 = z;
double r4723960 = cos(r4723959);
double r4723961 = y;
double r4723962 = sin(r4723961);
double r4723963 = r4723960 * r4723962;
double r4723964 = sin(r4723959);
double r4723965 = cos(r4723961);
double r4723966 = r4723964 * r4723965;
double r4723967 = r4723963 + r4723966;
double r4723968 = r4723958 * r4723967;
double r4723969 = 1.0;
double r4723970 = tan(r4723959);
double r4723971 = tan(r4723961);
double r4723972 = r4723970 * r4723971;
double r4723973 = r4723969 + r4723972;
double r4723974 = r4723968 * r4723973;
double r4723975 = sin(r4723957);
double r4723976 = r4723972 * r4723972;
double r4723977 = r4723969 - r4723976;
double r4723978 = r4723975 * r4723977;
double r4723979 = r4723965 * r4723960;
double r4723980 = r4723978 * r4723979;
double r4723981 = r4723974 - r4723980;
double r4723982 = r4723973 * r4723979;
double r4723983 = r4723969 - r4723972;
double r4723984 = r4723983 * r4723958;
double r4723985 = r4723982 * r4723984;
double r4723986 = r4723981 / r4723985;
double r4723987 = x;
double r4723988 = r4723986 + r4723987;
return r4723988;
}



Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus a
Results
Initial program 13.2
rmApplied tan-quot13.2
Applied tan-sum0.2
Applied frac-sub0.2
rmApplied flip--0.2
Applied associate-*l/0.2
Applied tan-quot0.2
Applied tan-quot0.2
Applied frac-add0.2
Applied associate-*l/0.2
Applied frac-sub0.3
Applied associate-/l/0.2
Final simplification0.2
herbie shell --seed 2019143
(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))))