\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 -4.54809909365855772791856768185597692522 \cdot 10^{-9} \lor \neg \left(\frac{x \cdot \left(\left(y - z\right) + 1\right)}{z} \le 1.231384797345861064411732315459653816138 \cdot 10^{161}\right):\\
\;\;\;\;\left(\left(y - z\right) + 1\right) \cdot \frac{x}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{\frac{z}{\left(y - z\right) + 1}}\\
\end{array}double f(double x, double y, double z) {
double r680125 = x;
double r680126 = y;
double r680127 = z;
double r680128 = r680126 - r680127;
double r680129 = 1.0;
double r680130 = r680128 + r680129;
double r680131 = r680125 * r680130;
double r680132 = r680131 / r680127;
return r680132;
}
double f(double x, double y, double z) {
double r680133 = x;
double r680134 = y;
double r680135 = z;
double r680136 = r680134 - r680135;
double r680137 = 1.0;
double r680138 = r680136 + r680137;
double r680139 = r680133 * r680138;
double r680140 = r680139 / r680135;
double r680141 = -4.548099093658558e-09;
bool r680142 = r680140 <= r680141;
double r680143 = 1.231384797345861e+161;
bool r680144 = r680140 <= r680143;
double r680145 = !r680144;
bool r680146 = r680142 || r680145;
double r680147 = r680133 / r680135;
double r680148 = r680138 * r680147;
double r680149 = r680135 / r680138;
double r680150 = r680133 / r680149;
double r680151 = r680146 ? r680148 : r680150;
return r680151;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 10.5 |
|---|---|
| Target | 0.4 |
| Herbie | 0.7 |
if (/ (* x (+ (- y z) 1.0)) z) < -4.548099093658558e-09 or 1.231384797345861e+161 < (/ (* x (+ (- y z) 1.0)) z) Initial program 21.5
rmApplied associate-/l*5.6
rmApplied clear-num6.2
rmApplied div-inv6.3
Applied add-sqr-sqrt6.3
Applied times-frac5.7
Applied *-un-lft-identity5.7
Applied times-frac0.3
Simplified0.3
Simplified0.2
if -4.548099093658558e-09 < (/ (* x (+ (- y z) 1.0)) z) < 1.231384797345861e+161Initial program 0.1
rmApplied associate-/l*1.2
Final simplification0.7
herbie shell --seed 2019353
(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))