\frac{x}{\left(y - z\right) \cdot \left(t - z\right)}\frac{\frac{\sqrt[3]{x}}{\sqrt[3]{t - z}} \cdot \frac{\sqrt[3]{x}}{\sqrt[3]{t - z}}}{y - z} \cdot \frac{\sqrt[3]{x}}{\sqrt[3]{t - z}}double f(double x, double y, double z, double t) {
double r40934942 = x;
double r40934943 = y;
double r40934944 = z;
double r40934945 = r40934943 - r40934944;
double r40934946 = t;
double r40934947 = r40934946 - r40934944;
double r40934948 = r40934945 * r40934947;
double r40934949 = r40934942 / r40934948;
return r40934949;
}
double f(double x, double y, double z, double t) {
double r40934950 = x;
double r40934951 = cbrt(r40934950);
double r40934952 = t;
double r40934953 = z;
double r40934954 = r40934952 - r40934953;
double r40934955 = cbrt(r40934954);
double r40934956 = r40934951 / r40934955;
double r40934957 = r40934956 * r40934956;
double r40934958 = y;
double r40934959 = r40934958 - r40934953;
double r40934960 = r40934957 / r40934959;
double r40934961 = r40934960 * r40934956;
return r40934961;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 7.3 |
|---|---|
| Target | 7.8 |
| Herbie | 1.1 |
Initial program 7.3
rmApplied *-un-lft-identity7.3
Applied times-frac2.2
rmApplied add-cube-cbrt2.7
Applied add-cube-cbrt2.9
Applied times-frac2.9
Applied associate-*r*1.1
Simplified1.1
Final simplification1.1
herbie shell --seed 2019179
(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))))