\frac{x \cdot y - z \cdot t}{a}\begin{array}{l}
\mathbf{if}\;x \cdot y - z \cdot t \le -7.2102141575108931 \cdot 10^{307}:\\
\;\;\;\;x \cdot \frac{y}{a} - \left(z \cdot \left(\sqrt[3]{\frac{t}{a}} \cdot \sqrt[3]{\frac{t}{a}}\right)\right) \cdot \frac{\sqrt[3]{t}}{\sqrt[3]{a}}\\
\mathbf{elif}\;x \cdot y - z \cdot t \le 9.36885390071793325 \cdot 10^{299}:\\
\;\;\;\;\frac{x \cdot y - z \cdot t}{a}\\
\mathbf{else}:\\
\;\;\;\;x \cdot \frac{y}{a} - \left(\sqrt[3]{z} \cdot \sqrt[3]{z}\right) \cdot \left(\frac{t}{a} \cdot \sqrt[3]{z}\right)\\
\end{array}double code(double x, double y, double z, double t, double a) {
return ((double) (((double) (((double) (x * y)) - ((double) (z * t)))) / a));
}
double code(double x, double y, double z, double t, double a) {
double VAR;
if ((((double) (((double) (x * y)) - ((double) (z * t)))) <= -7.210214157510893e+307)) {
VAR = ((double) (((double) (x * ((double) (y / a)))) - ((double) (((double) (z * ((double) (((double) cbrt(((double) (t / a)))) * ((double) cbrt(((double) (t / a)))))))) * ((double) (((double) cbrt(t)) / ((double) cbrt(a))))))));
} else {
double VAR_1;
if ((((double) (((double) (x * y)) - ((double) (z * t)))) <= 9.368853900717933e+299)) {
VAR_1 = ((double) (((double) (((double) (x * y)) - ((double) (z * t)))) / a));
} else {
VAR_1 = ((double) (((double) (x * ((double) (y / a)))) - ((double) (((double) (((double) cbrt(z)) * ((double) cbrt(z)))) * ((double) (((double) (t / a)) * ((double) cbrt(z))))))));
}
VAR = VAR_1;
}
return VAR;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 7.8 |
|---|---|
| Target | 6.3 |
| Herbie | 0.7 |
if (- (* x y) (* z t)) < -7.2102141575108931e307Initial program 63.7
rmApplied div-sub63.7
Simplified33.2
Simplified0.3
rmApplied add-cube-cbrt0.9
Applied associate-*r*0.8
rmApplied cbrt-div0.8
if -7.2102141575108931e307 < (- (* x y) (* z t)) < 9.36885390071793325e299Initial program 0.7
if 9.36885390071793325e299 < (- (* x y) (* z t)) Initial program 59.8
rmApplied div-sub59.8
Simplified33.1
Simplified0.3
rmApplied add-cube-cbrt0.8
Applied associate-*l*0.8
Simplified0.8
Final simplification0.7
herbie shell --seed 2020184
(FPCore (x y z t a)
:name "Data.Colour.Matrix:inverse from colour-2.3.3, B"
:precision binary64
:herbie-target
(if (< z -2.468684968699548e+170) (- (* (/ y a) x) (* (/ t a) z)) (if (< z 6.309831121978371e-71) (/ (- (* x y) (* z t)) a) (- (* (/ y a) x) (* (/ t a) z))))
(/ (- (* x y) (* z t)) a))