x + \frac{\left(y - x\right) \cdot z}{t}\begin{array}{l}
\mathbf{if}\;x + \frac{\left(y - x\right) \cdot z}{t} = -\infty:\\
\;\;\;\;x + \left(y - x\right) \cdot \frac{z}{t}\\
\mathbf{elif}\;x + \frac{\left(y - x\right) \cdot z}{t} \le 2.4829011027507563 \cdot 10^{+286}:\\
\;\;\;\;x + \frac{\left(y - x\right) \cdot z}{t}\\
\mathbf{else}:\\
\;\;\;\;\frac{y - x}{t} \cdot z + x\\
\end{array}double f(double x, double y, double z, double t) {
double r22919107 = x;
double r22919108 = y;
double r22919109 = r22919108 - r22919107;
double r22919110 = z;
double r22919111 = r22919109 * r22919110;
double r22919112 = t;
double r22919113 = r22919111 / r22919112;
double r22919114 = r22919107 + r22919113;
return r22919114;
}
double f(double x, double y, double z, double t) {
double r22919115 = x;
double r22919116 = y;
double r22919117 = r22919116 - r22919115;
double r22919118 = z;
double r22919119 = r22919117 * r22919118;
double r22919120 = t;
double r22919121 = r22919119 / r22919120;
double r22919122 = r22919115 + r22919121;
double r22919123 = -inf.0;
bool r22919124 = r22919122 <= r22919123;
double r22919125 = r22919118 / r22919120;
double r22919126 = r22919117 * r22919125;
double r22919127 = r22919115 + r22919126;
double r22919128 = 2.4829011027507563e+286;
bool r22919129 = r22919122 <= r22919128;
double r22919130 = r22919117 / r22919120;
double r22919131 = r22919130 * r22919118;
double r22919132 = r22919131 + r22919115;
double r22919133 = r22919129 ? r22919122 : r22919132;
double r22919134 = r22919124 ? r22919127 : r22919133;
return r22919134;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 6.2 |
|---|---|
| Target | 2.0 |
| Herbie | 1.1 |
if (+ x (/ (* (- y x) z) t)) < -inf.0Initial program 60.3
rmApplied *-un-lft-identity60.3
Applied times-frac0.2
Simplified0.2
if -inf.0 < (+ x (/ (* (- y x) z) t)) < 2.4829011027507563e+286Initial program 0.8
if 2.4829011027507563e+286 < (+ x (/ (* (- y x) z) t)) Initial program 42.6
rmApplied associate-/l*2.0
rmApplied associate-/r/6.1
Final simplification1.1
herbie shell --seed 2019158
(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)))