\frac{x \cdot y - \left(z \cdot 9.0\right) \cdot t}{a \cdot 2.0}\begin{array}{l}
\mathbf{if}\;x \cdot y - \left(z \cdot 9.0\right) \cdot t \le -1.5506240475436017 \cdot 10^{+275}:\\
\;\;\;\;\frac{x}{2.0} \cdot \frac{y}{a} - \frac{z}{a} \cdot \frac{t \cdot 9.0}{2.0}\\
\mathbf{elif}\;x \cdot y - \left(z \cdot 9.0\right) \cdot t \le 1.242329322710186 \cdot 10^{+161}:\\
\;\;\;\;\frac{\frac{x \cdot y - \left(t \cdot 9.0\right) \cdot z}{a}}{2.0}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{2.0} \cdot \frac{y}{a} - \frac{z}{a} \cdot \frac{t \cdot 9.0}{2.0}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r34357360 = x;
double r34357361 = y;
double r34357362 = r34357360 * r34357361;
double r34357363 = z;
double r34357364 = 9.0;
double r34357365 = r34357363 * r34357364;
double r34357366 = t;
double r34357367 = r34357365 * r34357366;
double r34357368 = r34357362 - r34357367;
double r34357369 = a;
double r34357370 = 2.0;
double r34357371 = r34357369 * r34357370;
double r34357372 = r34357368 / r34357371;
return r34357372;
}
double f(double x, double y, double z, double t, double a) {
double r34357373 = x;
double r34357374 = y;
double r34357375 = r34357373 * r34357374;
double r34357376 = z;
double r34357377 = 9.0;
double r34357378 = r34357376 * r34357377;
double r34357379 = t;
double r34357380 = r34357378 * r34357379;
double r34357381 = r34357375 - r34357380;
double r34357382 = -1.5506240475436017e+275;
bool r34357383 = r34357381 <= r34357382;
double r34357384 = 2.0;
double r34357385 = r34357373 / r34357384;
double r34357386 = a;
double r34357387 = r34357374 / r34357386;
double r34357388 = r34357385 * r34357387;
double r34357389 = r34357376 / r34357386;
double r34357390 = r34357379 * r34357377;
double r34357391 = r34357390 / r34357384;
double r34357392 = r34357389 * r34357391;
double r34357393 = r34357388 - r34357392;
double r34357394 = 1.242329322710186e+161;
bool r34357395 = r34357381 <= r34357394;
double r34357396 = r34357390 * r34357376;
double r34357397 = r34357375 - r34357396;
double r34357398 = r34357397 / r34357386;
double r34357399 = r34357398 / r34357384;
double r34357400 = r34357395 ? r34357399 : r34357393;
double r34357401 = r34357383 ? r34357393 : r34357400;
return r34357401;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 8.0 |
|---|---|
| Target | 5.8 |
| Herbie | 1.1 |
if (- (* x y) (* (* z 9.0) t)) < -1.5506240475436017e+275 or 1.242329322710186e+161 < (- (* x y) (* (* z 9.0) t)) Initial program 32.0
rmApplied *-un-lft-identity32.0
Applied times-frac32.0
rmApplied add-sqr-sqrt32.4
Applied *-un-lft-identity32.4
Applied times-frac32.3
Applied associate-*r*32.3
Simplified32.2
Taylor expanded around inf 32.2
Simplified2.0
if -1.5506240475436017e+275 < (- (* x y) (* (* z 9.0) t)) < 1.242329322710186e+161Initial program 0.9
rmApplied *-un-lft-identity0.9
Applied times-frac1.0
rmApplied add-sqr-sqrt1.6
Applied *-un-lft-identity1.6
Applied times-frac1.5
Applied associate-*r*1.4
Simplified1.3
rmApplied frac-times1.7
Simplified1.7
Simplified0.9
Final simplification1.1
herbie shell --seed 2019165
(FPCore (x y z t a)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, I"
:herbie-target
(if (< a -2.090464557976709e+86) (- (* 0.5 (/ (* y x) a)) (* 4.5 (/ t (/ a z)))) (if (< a 2.144030707833976e+99) (/ (- (* x y) (* z (* 9.0 t))) (* a 2.0)) (- (* (/ y a) (* x 0.5)) (* (/ t a) (* z 4.5)))))
(/ (- (* x y) (* (* z 9.0) t)) (* a 2.0)))