x + \frac{\left(y - z\right) \cdot \left(t - x\right)}{a - z}\begin{array}{l}
\mathbf{if}\;a \le -6.143232131925929682871142551410290774749 \cdot 10^{-28} \lor \neg \left(a \le 5.347427363587527749751148009426342589484 \cdot 10^{-182}\right):\\
\;\;\;\;\left(\frac{y}{a - z} - \frac{z}{a - z}\right) \cdot t + \mathsf{fma}\left(-x, \frac{y}{a - z} - \frac{1}{\sqrt[3]{a - z} \cdot \sqrt[3]{a - z}} \cdot \frac{z}{\sqrt[3]{a - z}}, x\right)\\
\mathbf{else}:\\
\;\;\;\;t - \frac{y}{z} \cdot \left(t - x\right)\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r457934 = x;
double r457935 = y;
double r457936 = z;
double r457937 = r457935 - r457936;
double r457938 = t;
double r457939 = r457938 - r457934;
double r457940 = r457937 * r457939;
double r457941 = a;
double r457942 = r457941 - r457936;
double r457943 = r457940 / r457942;
double r457944 = r457934 + r457943;
return r457944;
}
double f(double x, double y, double z, double t, double a) {
double r457945 = a;
double r457946 = -6.14323213192593e-28;
bool r457947 = r457945 <= r457946;
double r457948 = 5.347427363587528e-182;
bool r457949 = r457945 <= r457948;
double r457950 = !r457949;
bool r457951 = r457947 || r457950;
double r457952 = y;
double r457953 = z;
double r457954 = r457945 - r457953;
double r457955 = r457952 / r457954;
double r457956 = r457953 / r457954;
double r457957 = r457955 - r457956;
double r457958 = t;
double r457959 = r457957 * r457958;
double r457960 = x;
double r457961 = -r457960;
double r457962 = 1.0;
double r457963 = cbrt(r457954);
double r457964 = r457963 * r457963;
double r457965 = r457962 / r457964;
double r457966 = r457953 / r457963;
double r457967 = r457965 * r457966;
double r457968 = r457955 - r457967;
double r457969 = fma(r457961, r457968, r457960);
double r457970 = r457959 + r457969;
double r457971 = r457952 / r457953;
double r457972 = r457958 - r457960;
double r457973 = r457971 * r457972;
double r457974 = r457958 - r457973;
double r457975 = r457951 ? r457970 : r457974;
return r457975;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
| Original | 24.3 |
|---|---|
| Target | 11.7 |
| Herbie | 9.5 |
if a < -6.14323213192593e-28 or 5.347427363587528e-182 < a Initial program 22.9
Simplified8.8
rmApplied fma-udef8.8
rmApplied div-sub8.8
rmApplied sub-neg8.8
Applied distribute-lft-in8.8
Applied associate-+l+6.0
Simplified6.0
rmApplied add-cube-cbrt8.3
Applied *-un-lft-identity8.3
Applied times-frac8.2
if -6.14323213192593e-28 < a < 5.347427363587528e-182Initial program 27.7
Simplified19.2
Taylor expanded around inf 16.4
Simplified12.4
Final simplification9.5
herbie shell --seed 2019325 +o rules:numerics
(FPCore (x y z t a)
:name "Graphics.Rendering.Chart.Axis.Types:invLinMap from Chart-1.5.3"
:precision binary64
:herbie-target
(if (< z -1.2536131056095036e+188) (- t (* (/ y z) (- t x))) (if (< z 4.446702369113811e+64) (+ x (/ (- y z) (/ (- a z) (- t x)))) (- t (* (/ y z) (- t x)))))
(+ x (/ (* (- y z) (- t x)) (- a z))))