x + \left(\tan \left(y + z\right) - \tan a\right)
\frac{\frac{\frac{\frac{\left(\left(\sin y \cdot \cos z + \cos y \cdot \sin z\right) \cdot \cos a\right) \cdot \left(1 + \tan y \cdot \tan z\right) - \left(\cos y \cdot \cos z\right) \cdot \left(\left(1 - \left(\tan y \cdot \tan z\right) \cdot \left(\tan y \cdot \tan z\right)\right) \cdot \sin a\right)}{1 - \tan y \cdot \tan z}}{\cos a}}{\cos y \cdot \cos z}}{1 + \frac{\tan y \cdot \sin z}{\cos z}} + xdouble f(double x, double y, double z, double a) {
double r148761 = x;
double r148762 = y;
double r148763 = z;
double r148764 = r148762 + r148763;
double r148765 = tan(r148764);
double r148766 = a;
double r148767 = tan(r148766);
double r148768 = r148765 - r148767;
double r148769 = r148761 + r148768;
return r148769;
}
double f(double x, double y, double z, double a) {
double r148770 = y;
double r148771 = sin(r148770);
double r148772 = z;
double r148773 = cos(r148772);
double r148774 = r148771 * r148773;
double r148775 = cos(r148770);
double r148776 = sin(r148772);
double r148777 = r148775 * r148776;
double r148778 = r148774 + r148777;
double r148779 = a;
double r148780 = cos(r148779);
double r148781 = r148778 * r148780;
double r148782 = 1.0;
double r148783 = tan(r148770);
double r148784 = tan(r148772);
double r148785 = r148783 * r148784;
double r148786 = r148782 + r148785;
double r148787 = r148781 * r148786;
double r148788 = r148775 * r148773;
double r148789 = r148785 * r148785;
double r148790 = r148782 - r148789;
double r148791 = sin(r148779);
double r148792 = r148790 * r148791;
double r148793 = r148788 * r148792;
double r148794 = r148787 - r148793;
double r148795 = r148782 - r148785;
double r148796 = r148794 / r148795;
double r148797 = r148796 / r148780;
double r148798 = r148797 / r148788;
double r148799 = r148783 * r148776;
double r148800 = r148799 / r148773;
double r148801 = r148782 + r148800;
double r148802 = r148798 / r148801;
double r148803 = x;
double r148804 = r148802 + r148803;
return r148804;
}



Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus a
Results
Initial program 13.3
rmApplied tan-quot13.3
Applied tan-sum0.2
Applied frac-sub0.2
rmApplied clear-num0.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.2
Applied associate-/r/0.3
Applied associate-/r*0.2
Simplified0.2
rmApplied tan-quot0.2
Applied associate-*r/0.2
Final simplification0.2
herbie shell --seed 2019298
(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))))