\frac{x \cdot \left(\left(y - z\right) + 1\right)}{z}\begin{array}{l}
\mathbf{if}\;\frac{x \cdot \left(\left(y - z\right) + 1\right)}{z} \le -6.579027488067199411550511935864463917316 \cdot 10^{210} \lor \neg \left(\frac{x \cdot \left(\left(y - z\right) + 1\right)}{z} \le 3.530201563568855701403158383753448655305 \cdot 10^{90}\right):\\
\;\;\;\;\frac{x}{z} \cdot \left(y + 1\right) - x\\
\mathbf{else}:\\
\;\;\;\;\frac{x \cdot \left(y + 1\right)}{z} - x\\
\end{array}double f(double x, double y, double z) {
double r475381 = x;
double r475382 = y;
double r475383 = z;
double r475384 = r475382 - r475383;
double r475385 = 1.0;
double r475386 = r475384 + r475385;
double r475387 = r475381 * r475386;
double r475388 = r475387 / r475383;
return r475388;
}
double f(double x, double y, double z) {
double r475389 = x;
double r475390 = y;
double r475391 = z;
double r475392 = r475390 - r475391;
double r475393 = 1.0;
double r475394 = r475392 + r475393;
double r475395 = r475389 * r475394;
double r475396 = r475395 / r475391;
double r475397 = -6.579027488067199e+210;
bool r475398 = r475396 <= r475397;
double r475399 = 3.5302015635688557e+90;
bool r475400 = r475396 <= r475399;
double r475401 = !r475400;
bool r475402 = r475398 || r475401;
double r475403 = r475389 / r475391;
double r475404 = r475390 + r475393;
double r475405 = r475403 * r475404;
double r475406 = r475405 - r475389;
double r475407 = r475389 * r475404;
double r475408 = r475407 / r475391;
double r475409 = r475408 - r475389;
double r475410 = r475402 ? r475406 : r475409;
return r475410;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 10.1 |
|---|---|
| Target | 0.5 |
| Herbie | 0.1 |
if (/ (* x (+ (- y z) 1.0)) z) < -6.579027488067199e+210 or 3.5302015635688557e+90 < (/ (* x (+ (- y z) 1.0)) z) Initial program 27.9
Taylor expanded around 0 10.4
Simplified0.1
if -6.579027488067199e+210 < (/ (* x (+ (- y z) 1.0)) z) < 3.5302015635688557e+90Initial program 0.1
Taylor expanded around 0 0.1
Simplified2.7
Taylor expanded around 0 0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2019326 +o rules:numerics
(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))