\frac{x}{\left(y - z\right) \cdot \left(t - z\right)}\frac{\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\sqrt[3]{y - z} \cdot \sqrt[3]{y - z}}}{\sqrt[3]{t - z} \cdot \sqrt[3]{t - z}} \cdot \frac{\frac{\sqrt[3]{x}}{\sqrt[3]{y - z}}}{\sqrt[3]{t - z}}double f(double x, double y, double z, double t) {
double r543941 = x;
double r543942 = y;
double r543943 = z;
double r543944 = r543942 - r543943;
double r543945 = t;
double r543946 = r543945 - r543943;
double r543947 = r543944 * r543946;
double r543948 = r543941 / r543947;
return r543948;
}
double f(double x, double y, double z, double t) {
double r543949 = x;
double r543950 = cbrt(r543949);
double r543951 = r543950 * r543950;
double r543952 = y;
double r543953 = z;
double r543954 = r543952 - r543953;
double r543955 = cbrt(r543954);
double r543956 = r543955 * r543955;
double r543957 = r543951 / r543956;
double r543958 = t;
double r543959 = r543958 - r543953;
double r543960 = cbrt(r543959);
double r543961 = r543960 * r543960;
double r543962 = r543957 / r543961;
double r543963 = r543950 / r543955;
double r543964 = r543963 / r543960;
double r543965 = r543962 * r543964;
return r543965;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 7.9 |
|---|---|
| Target | 8.6 |
| Herbie | 1.3 |
Initial program 7.9
rmApplied add-cube-cbrt8.4
Applied times-frac1.7
rmApplied add-cube-cbrt1.9
rmApplied associate-*r/2.9
Simplified2.1
rmApplied add-cube-cbrt2.7
Applied add-cube-cbrt2.9
Applied add-cube-cbrt3.0
Applied times-frac3.0
Applied times-frac1.3
Final simplification1.3
herbie shell --seed 2019208 +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))))