\frac{x \cdot \left(\left(y - z\right) + 1\right)}{z}\begin{array}{l}
\mathbf{if}\;z \le -6.231177025534271 \cdot 10^{38} \lor \neg \left(z \le 1.30166855464399448 \cdot 10^{-27}\right):\\
\;\;\;\;x \cdot \frac{\left(y - z\right) + 1}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{z} \cdot \left(\left(y - z\right) + 1\right)\\
\end{array}double f(double x, double y, double z) {
double r824393 = x;
double r824394 = y;
double r824395 = z;
double r824396 = r824394 - r824395;
double r824397 = 1.0;
double r824398 = r824396 + r824397;
double r824399 = r824393 * r824398;
double r824400 = r824399 / r824395;
return r824400;
}
double f(double x, double y, double z) {
double r824401 = z;
double r824402 = -6.231177025534271e+38;
bool r824403 = r824401 <= r824402;
double r824404 = 1.3016685546439945e-27;
bool r824405 = r824401 <= r824404;
double r824406 = !r824405;
bool r824407 = r824403 || r824406;
double r824408 = x;
double r824409 = y;
double r824410 = r824409 - r824401;
double r824411 = 1.0;
double r824412 = r824410 + r824411;
double r824413 = r824412 / r824401;
double r824414 = r824408 * r824413;
double r824415 = r824408 / r824401;
double r824416 = r824415 * r824412;
double r824417 = r824407 ? r824414 : r824416;
return r824417;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 10.6 |
|---|---|
| Target | 0.4 |
| Herbie | 0.2 |
if z < -6.231177025534271e+38 or 1.3016685546439945e-27 < z Initial program 17.9
rmApplied *-un-lft-identity17.9
Applied times-frac0.1
Simplified0.1
if -6.231177025534271e+38 < z < 1.3016685546439945e-27Initial program 0.2
rmApplied associate-/l*7.2
rmApplied associate-/r/0.2
Final simplification0.2
herbie shell --seed 2020047
(FPCore (x y z)
:name "Diagrams.TwoD.Segment.Bernstein:evaluateBernstein from diagrams-lib-1.3.0.3"
:precision binary64
:herbie-target
(if (< x -2.71483106713436e-162) (- (* (+ 1 y) (/ x z)) x) (if (< x 3.874108816439546e-197) (* (* x (+ (- y z) 1)) (/ 1 z)) (- (* (+ 1 y) (/ x z)) x)))
(/ (* x (+ (- y z) 1)) z))