x + \left(\tan \left(y + z\right) - \tan a\right)
x + \left(\frac{\frac{1}{\cos y} \cdot \frac{\sin y \cdot \cos z + \cos y \cdot \sin z}{\cos z}}{1 - \tan y \cdot \tan z} - \tan a\right)double f(double x, double y, double z, double a) {
double r106928 = x;
double r106929 = y;
double r106930 = z;
double r106931 = r106929 + r106930;
double r106932 = tan(r106931);
double r106933 = a;
double r106934 = tan(r106933);
double r106935 = r106932 - r106934;
double r106936 = r106928 + r106935;
return r106936;
}
double f(double x, double y, double z, double a) {
double r106937 = x;
double r106938 = 1.0;
double r106939 = y;
double r106940 = cos(r106939);
double r106941 = r106938 / r106940;
double r106942 = sin(r106939);
double r106943 = z;
double r106944 = cos(r106943);
double r106945 = r106942 * r106944;
double r106946 = sin(r106943);
double r106947 = r106940 * r106946;
double r106948 = r106945 + r106947;
double r106949 = r106948 / r106944;
double r106950 = r106941 * r106949;
double r106951 = tan(r106939);
double r106952 = tan(r106943);
double r106953 = r106951 * r106952;
double r106954 = r106938 - r106953;
double r106955 = r106950 / r106954;
double r106956 = a;
double r106957 = tan(r106956);
double r106958 = r106955 - r106957;
double r106959 = r106937 + r106958;
return r106959;
}



Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus a
Results
Initial program 13.2
rmApplied tan-sum0.2
rmApplied tan-quot0.2
Applied tan-quot0.2
Applied frac-add0.2
rmApplied *-un-lft-identity0.2
Applied times-frac0.2
Final simplification0.2
herbie shell --seed 2019209
(FPCore (x y z a)
:name "(+ x (- (tan (+ y z)) (tan a)))"
:precision binary64
:pre (and (or (== x 0.0) (<= 0.588414199999999998 x 505.590899999999976)) (or (<= -1.79665800000000009e308 y -9.425585000000013e-310) (<= 1.284938e-309 y 1.75122399999999993e308)) (or (<= -1.776707e308 z -8.59979600000002e-310) (<= 3.29314499999998e-311 z 1.72515400000000009e308)) (or (<= -1.79665800000000009e308 a -9.425585000000013e-310) (<= 1.284938e-309 a 1.75122399999999993e308)))
(+ x (- (tan (+ y z)) (tan a))))