\frac{x}{\left(y - z\right) \cdot \left(t - z\right)}\begin{array}{l}
\mathbf{if}\;\frac{x}{\left(y - z\right) \cdot \left(t - z\right)} \le 0.0:\\
\;\;\;\;\frac{\frac{1}{\frac{y - z}{x}}}{t - z}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{\left(y - z\right) \cdot \left(t - z\right)}\\
\end{array}double f(double x, double y, double z, double t) {
double r567298 = x;
double r567299 = y;
double r567300 = z;
double r567301 = r567299 - r567300;
double r567302 = t;
double r567303 = r567302 - r567300;
double r567304 = r567301 * r567303;
double r567305 = r567298 / r567304;
return r567305;
}
double f(double x, double y, double z, double t) {
double r567306 = x;
double r567307 = y;
double r567308 = z;
double r567309 = r567307 - r567308;
double r567310 = t;
double r567311 = r567310 - r567308;
double r567312 = r567309 * r567311;
double r567313 = r567306 / r567312;
double r567314 = 0.0;
bool r567315 = r567313 <= r567314;
double r567316 = 1.0;
double r567317 = r567309 / r567306;
double r567318 = r567316 / r567317;
double r567319 = r567318 / r567311;
double r567320 = r567315 ? r567319 : r567313;
return r567320;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 7.0 |
|---|---|
| Target | 7.8 |
| Herbie | 1.5 |
if (/ x (* (- y z) (- t z))) < 0.0Initial program 7.2
rmApplied associate-/r*2.1
rmApplied clear-num2.2
if 0.0 < (/ x (* (- y z) (- t z))) Initial program 6.8
Final simplification1.5
herbie shell --seed 2019323
(FPCore (x y z t)
:name "Data.Random.Distribution.Triangular:triangularCDF from random-fu-0.2.6.2, B"
:precision binary64
:herbie-target
(if (< (/ x (* (- y z) (- t z))) 0.0) (/ (/ x (- y z)) (- t z)) (* x (/ 1 (* (- y z) (- t z)))))
(/ x (* (- y z) (- t z))))