\frac{x \cdot \left(\left(y - z\right) + 1\right)}{z}\begin{array}{l}
\mathbf{if}\;z \le -1.03093838410670302 \cdot 10^{-10}:\\
\;\;\;\;\frac{x}{\frac{z}{\left(y - z\right) + 1}}\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(1, \frac{x}{z}, \frac{x \cdot y}{z}\right) - x\\
\end{array}double f(double x, double y, double z) {
double r649184 = x;
double r649185 = y;
double r649186 = z;
double r649187 = r649185 - r649186;
double r649188 = 1.0;
double r649189 = r649187 + r649188;
double r649190 = r649184 * r649189;
double r649191 = r649190 / r649186;
return r649191;
}
double f(double x, double y, double z) {
double r649192 = z;
double r649193 = -1.030938384106703e-10;
bool r649194 = r649192 <= r649193;
double r649195 = x;
double r649196 = y;
double r649197 = r649196 - r649192;
double r649198 = 1.0;
double r649199 = r649197 + r649198;
double r649200 = r649192 / r649199;
double r649201 = r649195 / r649200;
double r649202 = r649195 / r649192;
double r649203 = r649195 * r649196;
double r649204 = r649203 / r649192;
double r649205 = fma(r649198, r649202, r649204);
double r649206 = r649205 - r649195;
double r649207 = r649194 ? r649201 : r649206;
return r649207;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 10.4 |
|---|---|
| Target | 0.4 |
| Herbie | 1.9 |
if z < -1.030938384106703e-10Initial program 16.6
rmApplied associate-/l*0.1
if -1.030938384106703e-10 < z Initial program 7.5
rmApplied *-un-lft-identity7.5
Applied times-frac5.0
Simplified5.0
Taylor expanded around 0 2.7
Simplified2.7
Final simplification1.9
herbie shell --seed 2020036 +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))