x + \left(\tan \left(y + z\right) - \tan a\right)
x + \frac{\left(\cos a \cdot \left(\tan y \cdot \tan y - \tan z \cdot \tan z\right)\right) \cdot \left(1 + \left(\left(\tan y \cdot \tan z\right) \cdot \left(\tan y \cdot \tan z\right) + \tan y \cdot \tan z\right)\right) - \left(\tan y - \tan z\right) \cdot \left(\sin a \cdot \left(1 - {\left(\tan y \cdot \tan z\right)}^{3}\right)\right)}{\left(\left(1 + \left(\left(\tan y \cdot \tan z\right) \cdot \left(\tan y \cdot \tan z\right) + \tan y \cdot \tan z\right)\right) \cdot \left(\tan y - \tan z\right)\right) \cdot \left(\left(1 - \tan y \cdot \tan z\right) \cdot \cos a\right)}double f(double x, double y, double z, double a) {
double r7005770 = x;
double r7005771 = y;
double r7005772 = z;
double r7005773 = r7005771 + r7005772;
double r7005774 = tan(r7005773);
double r7005775 = a;
double r7005776 = tan(r7005775);
double r7005777 = r7005774 - r7005776;
double r7005778 = r7005770 + r7005777;
return r7005778;
}
double f(double x, double y, double z, double a) {
double r7005779 = x;
double r7005780 = a;
double r7005781 = cos(r7005780);
double r7005782 = y;
double r7005783 = tan(r7005782);
double r7005784 = r7005783 * r7005783;
double r7005785 = z;
double r7005786 = tan(r7005785);
double r7005787 = r7005786 * r7005786;
double r7005788 = r7005784 - r7005787;
double r7005789 = r7005781 * r7005788;
double r7005790 = 1.0;
double r7005791 = r7005783 * r7005786;
double r7005792 = r7005791 * r7005791;
double r7005793 = r7005792 + r7005791;
double r7005794 = r7005790 + r7005793;
double r7005795 = r7005789 * r7005794;
double r7005796 = r7005783 - r7005786;
double r7005797 = sin(r7005780);
double r7005798 = 3.0;
double r7005799 = pow(r7005791, r7005798);
double r7005800 = r7005790 - r7005799;
double r7005801 = r7005797 * r7005800;
double r7005802 = r7005796 * r7005801;
double r7005803 = r7005795 - r7005802;
double r7005804 = r7005794 * r7005796;
double r7005805 = r7005790 - r7005791;
double r7005806 = r7005805 * r7005781;
double r7005807 = r7005804 * r7005806;
double r7005808 = r7005803 / r7005807;
double r7005809 = r7005779 + r7005808;
return r7005809;
}



Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus a
Results
Initial program 13.5
rmApplied tan-quot13.5
Applied tan-sum0.2
Applied frac-sub0.2
rmApplied flip3--0.2
Applied associate-*l/0.2
Applied flip-+0.2
Applied associate-*l/0.2
Applied frac-sub0.2
Applied associate-/l/0.2
Final simplification0.2
herbie shell --seed 2019170
(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))))