x + \frac{\left(y - x\right) \cdot z}{t}\begin{array}{l}
\mathbf{if}\;z \le -3.165968678679720807368432635267843482511 \cdot 10^{-173}:\\
\;\;\;\;\mathsf{fma}\left(y - x, \frac{z}{t}, x\right)\\
\mathbf{elif}\;z \le 2.133640105926503877026549421733062970497 \cdot 10^{-14}:\\
\;\;\;\;\frac{\left(y - x\right) \cdot z}{t} + x\\
\mathbf{else}:\\
\;\;\;\;x + \frac{z}{t} \cdot \left(y - x\right)\\
\end{array}double f(double x, double y, double z, double t) {
double r19480312 = x;
double r19480313 = y;
double r19480314 = r19480313 - r19480312;
double r19480315 = z;
double r19480316 = r19480314 * r19480315;
double r19480317 = t;
double r19480318 = r19480316 / r19480317;
double r19480319 = r19480312 + r19480318;
return r19480319;
}
double f(double x, double y, double z, double t) {
double r19480320 = z;
double r19480321 = -3.1659686786797208e-173;
bool r19480322 = r19480320 <= r19480321;
double r19480323 = y;
double r19480324 = x;
double r19480325 = r19480323 - r19480324;
double r19480326 = t;
double r19480327 = r19480320 / r19480326;
double r19480328 = fma(r19480325, r19480327, r19480324);
double r19480329 = 2.133640105926504e-14;
bool r19480330 = r19480320 <= r19480329;
double r19480331 = r19480325 * r19480320;
double r19480332 = r19480331 / r19480326;
double r19480333 = r19480332 + r19480324;
double r19480334 = r19480327 * r19480325;
double r19480335 = r19480324 + r19480334;
double r19480336 = r19480330 ? r19480333 : r19480335;
double r19480337 = r19480322 ? r19480328 : r19480336;
return r19480337;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
| Original | 6.7 |
|---|---|
| Target | 2.1 |
| Herbie | 1.9 |
if z < -3.1659686786797208e-173Initial program 8.2
Simplified2.0
if -3.1659686786797208e-173 < z < 2.133640105926504e-14Initial program 1.1
Simplified1.3
rmApplied fma-udef1.3
rmApplied associate-*r/1.1
if 2.133640105926504e-14 < z Initial program 15.5
Simplified3.3
rmApplied fma-udef3.4
Final simplification1.9
herbie shell --seed 2019174 +o rules:numerics
(FPCore (x y z t)
:name "Numeric.Histogram:binBounds from Chart-1.5.3"
:herbie-target
(if (< x -9.025511195533005e-135) (- x (* (/ z t) (- x y))) (if (< x 4.275032163700715e-250) (+ x (* (/ (- y x) t) z)) (+ x (/ (- y x) (/ t z)))))
(+ x (/ (* (- y x) z) t)))