\frac{x}{\left(y - z\right) \cdot \left(t - z\right)}\begin{array}{l}
\mathbf{if}\;\left(y - z\right) \cdot \left(t - z\right) \le -2.89579810626969026095077558126418128097 \cdot 10^{70}:\\
\;\;\;\;\frac{\frac{1}{y - z}}{\frac{t - z}{x}}\\
\mathbf{elif}\;\left(y - z\right) \cdot \left(t - z\right) \le 3.319695875271514127355230850513732805532 \cdot 10^{169}:\\
\;\;\;\;\frac{x}{\left(y - z\right) \cdot \left(t - z\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{x}{y - z}}{t - z}\\
\end{array}double f(double x, double y, double z, double t) {
double r782067 = x;
double r782068 = y;
double r782069 = z;
double r782070 = r782068 - r782069;
double r782071 = t;
double r782072 = r782071 - r782069;
double r782073 = r782070 * r782072;
double r782074 = r782067 / r782073;
return r782074;
}
double f(double x, double y, double z, double t) {
double r782075 = y;
double r782076 = z;
double r782077 = r782075 - r782076;
double r782078 = t;
double r782079 = r782078 - r782076;
double r782080 = r782077 * r782079;
double r782081 = -2.89579810626969e+70;
bool r782082 = r782080 <= r782081;
double r782083 = 1.0;
double r782084 = r782083 / r782077;
double r782085 = x;
double r782086 = r782079 / r782085;
double r782087 = r782084 / r782086;
double r782088 = 3.319695875271514e+169;
bool r782089 = r782080 <= r782088;
double r782090 = r782085 / r782080;
double r782091 = r782085 / r782077;
double r782092 = r782091 / r782079;
double r782093 = r782089 ? r782090 : r782092;
double r782094 = r782082 ? r782087 : r782093;
return r782094;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 7.7 |
|---|---|
| Target | 8.5 |
| Herbie | 1.2 |
if (* (- y z) (- t z)) < -2.89579810626969e+70Initial program 8.1
rmApplied associate-/r*2.1
rmApplied clear-num2.3
rmApplied div-inv2.3
Applied *-un-lft-identity2.3
Applied times-frac2.2
Applied associate-/l*1.7
Simplified1.6
if -2.89579810626969e+70 < (* (- y z) (- t z)) < 3.319695875271514e+169Initial program 2.2
if 3.319695875271514e+169 < (* (- y z) (- t z)) Initial program 11.6
rmApplied associate-/r*0.3
Final simplification1.2
herbie shell --seed 2019354 +o rules:numerics
(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))))