\left(x - \frac{y}{z \cdot 3}\right) + \frac{t}{\left(z \cdot 3\right) \cdot y}\begin{array}{l}
\mathbf{if}\;t \le -9.4052837436924809 \cdot 10^{37}:\\
\;\;\;\;\left(x - \frac{y}{z \cdot 3}\right) + 0.333333333333333315 \cdot \frac{t}{z \cdot y}\\
\mathbf{else}:\\
\;\;\;\;\left(x - \frac{\frac{y}{3}}{z}\right) + \frac{\frac{1}{z}}{\frac{y}{\frac{t}{3}}}\\
\end{array}double f(double x, double y, double z, double t) {
double r778970 = x;
double r778971 = y;
double r778972 = z;
double r778973 = 3.0;
double r778974 = r778972 * r778973;
double r778975 = r778971 / r778974;
double r778976 = r778970 - r778975;
double r778977 = t;
double r778978 = r778974 * r778971;
double r778979 = r778977 / r778978;
double r778980 = r778976 + r778979;
return r778980;
}
double f(double x, double y, double z, double t) {
double r778981 = t;
double r778982 = -9.40528374369248e+37;
bool r778983 = r778981 <= r778982;
double r778984 = x;
double r778985 = y;
double r778986 = z;
double r778987 = 3.0;
double r778988 = r778986 * r778987;
double r778989 = r778985 / r778988;
double r778990 = r778984 - r778989;
double r778991 = 0.3333333333333333;
double r778992 = r778986 * r778985;
double r778993 = r778981 / r778992;
double r778994 = r778991 * r778993;
double r778995 = r778990 + r778994;
double r778996 = r778985 / r778987;
double r778997 = r778996 / r778986;
double r778998 = r778984 - r778997;
double r778999 = 1.0;
double r779000 = r778999 / r778986;
double r779001 = r778981 / r778987;
double r779002 = r778985 / r779001;
double r779003 = r779000 / r779002;
double r779004 = r778998 + r779003;
double r779005 = r778983 ? r778995 : r779004;
return r779005;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 3.3 |
|---|---|
| Target | 1.8 |
| Herbie | 2.0 |
if t < -9.40528374369248e+37Initial program 0.7
Taylor expanded around 0 0.8
if -9.40528374369248e+37 < t Initial program 3.9
rmApplied associate-/r*1.5
rmApplied *-un-lft-identity1.5
Applied times-frac1.5
Applied associate-/l*2.3
rmApplied *-un-lft-identity2.3
Applied times-frac2.3
rmApplied associate-*l/2.3
Simplified2.3
Final simplification2.0
herbie shell --seed 2020018
(FPCore (x y z t)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, H"
:precision binary64
:herbie-target
(+ (- x (/ y (* z 3))) (/ (/ t (* z 3)) y))
(+ (- x (/ y (* z 3))) (/ t (* (* z 3) y))))