\frac{x \cdot \left(\left(y - z\right) + 1\right)}{z}\begin{array}{l}
\mathbf{if}\;x \le -4.665185119660453336993150082260987152155 \cdot 10^{-188}:\\
\;\;\;\;\mathsf{fma}\left(\frac{x}{z}, 1, \frac{y}{\frac{z}{x}}\right) - x\\
\mathbf{elif}\;x \le 1.213611178447867364643526562912545374463 \cdot 10^{-194}:\\
\;\;\;\;\frac{1}{z} \cdot \left(x \cdot \left(\left(y - z\right) + 1\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{x}{z}, 1, \frac{y}{\frac{z}{x}}\right) - x\\
\end{array}double f(double x, double y, double z) {
double r24897518 = x;
double r24897519 = y;
double r24897520 = z;
double r24897521 = r24897519 - r24897520;
double r24897522 = 1.0;
double r24897523 = r24897521 + r24897522;
double r24897524 = r24897518 * r24897523;
double r24897525 = r24897524 / r24897520;
return r24897525;
}
double f(double x, double y, double z) {
double r24897526 = x;
double r24897527 = -4.6651851196604533e-188;
bool r24897528 = r24897526 <= r24897527;
double r24897529 = z;
double r24897530 = r24897526 / r24897529;
double r24897531 = 1.0;
double r24897532 = y;
double r24897533 = r24897529 / r24897526;
double r24897534 = r24897532 / r24897533;
double r24897535 = fma(r24897530, r24897531, r24897534);
double r24897536 = r24897535 - r24897526;
double r24897537 = 1.2136111784478674e-194;
bool r24897538 = r24897526 <= r24897537;
double r24897539 = 1.0;
double r24897540 = r24897539 / r24897529;
double r24897541 = r24897532 - r24897529;
double r24897542 = r24897541 + r24897531;
double r24897543 = r24897526 * r24897542;
double r24897544 = r24897540 * r24897543;
double r24897545 = r24897538 ? r24897544 : r24897536;
double r24897546 = r24897528 ? r24897536 : r24897545;
return r24897546;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 10.7 |
|---|---|
| Target | 0.4 |
| Herbie | 0.6 |
if x < -4.6651851196604533e-188 or 1.2136111784478674e-194 < x Initial program 14.0
rmApplied associate-/l*1.9
rmApplied clear-num2.1
Taylor expanded around 0 4.6
Simplified0.6
if -4.6651851196604533e-188 < x < 1.2136111784478674e-194Initial program 0.2
rmApplied associate-/l*7.0
rmApplied clear-num7.1
rmApplied *-un-lft-identity7.1
Applied div-inv7.2
Applied times-frac0.4
Applied add-cube-cbrt0.4
Applied times-frac0.4
Simplified0.4
Simplified0.3
Final simplification0.6
herbie shell --seed 2019171 +o rules:numerics
(FPCore (x y z)
:name "Diagrams.TwoD.Segment.Bernstein:evaluateBernstein from diagrams-lib-1.3.0.3"
:herbie-target
(if (< x -2.71483106713436e-162) (- (* (+ 1.0 y) (/ x z)) x) (if (< x 3.874108816439546e-197) (* (* x (+ (- y z) 1.0)) (/ 1.0 z)) (- (* (+ 1.0 y) (/ x z)) x)))
(/ (* x (+ (- y z) 1.0)) z))