\frac{x}{\left(y - z\right) \cdot \left(t - z\right)}\begin{array}{l}
\mathbf{if}\;z \le -6.926678211265294330642012033135922586379 \cdot 10^{-112}:\\
\;\;\;\;\frac{\frac{1}{\frac{y - z}{x}}}{t - z}\\
\mathbf{elif}\;z \le 2.141565940867162526513329699771167619696 \cdot 10^{-142}:\\
\;\;\;\;\frac{\frac{1}{y - z}}{\frac{t - z}{x}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{1}{\frac{y - z}{x}}}{t - z}\\
\end{array}double f(double x, double y, double z, double t) {
double r29214748 = x;
double r29214749 = y;
double r29214750 = z;
double r29214751 = r29214749 - r29214750;
double r29214752 = t;
double r29214753 = r29214752 - r29214750;
double r29214754 = r29214751 * r29214753;
double r29214755 = r29214748 / r29214754;
return r29214755;
}
double f(double x, double y, double z, double t) {
double r29214756 = z;
double r29214757 = -6.926678211265294e-112;
bool r29214758 = r29214756 <= r29214757;
double r29214759 = 1.0;
double r29214760 = y;
double r29214761 = r29214760 - r29214756;
double r29214762 = x;
double r29214763 = r29214761 / r29214762;
double r29214764 = r29214759 / r29214763;
double r29214765 = t;
double r29214766 = r29214765 - r29214756;
double r29214767 = r29214764 / r29214766;
double r29214768 = 2.1415659408671625e-142;
bool r29214769 = r29214756 <= r29214768;
double r29214770 = r29214759 / r29214761;
double r29214771 = r29214766 / r29214762;
double r29214772 = r29214770 / r29214771;
double r29214773 = r29214769 ? r29214772 : r29214767;
double r29214774 = r29214758 ? r29214767 : r29214773;
return r29214774;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 7.4 |
|---|---|
| Target | 8.3 |
| Herbie | 2.3 |
if z < -6.926678211265294e-112 or 2.1415659408671625e-142 < z Initial program 8.0
rmApplied associate-/r*0.9
rmApplied clear-num1.0
if -6.926678211265294e-112 < z < 2.1415659408671625e-142Initial program 5.7
rmApplied associate-/r*5.6
rmApplied clear-num5.9
rmApplied div-inv5.9
Applied *-un-lft-identity5.9
Applied times-frac5.7
Applied associate-/l*5.9
Simplified5.8
Final simplification2.3
herbie shell --seed 2019200 +o rules:numerics
(FPCore (x y z t)
:name "Data.Random.Distribution.Triangular:triangularCDF from random-fu-0.2.6.2, B"
:herbie-target
(if (< (/ x (* (- y z) (- t z))) 0.0) (/ (/ x (- y z)) (- t z)) (* x (/ 1.0 (* (- y z) (- t z)))))
(/ x (* (- y z) (- t z))))