\frac{x \cdot y - z \cdot t}{a}\frac{\mathsf{fma}\left(x, y, -z \cdot t\right)}{a}double f(double x, double y, double z, double t, double a) {
double r974985 = x;
double r974986 = y;
double r974987 = r974985 * r974986;
double r974988 = z;
double r974989 = t;
double r974990 = r974988 * r974989;
double r974991 = r974987 - r974990;
double r974992 = a;
double r974993 = r974991 / r974992;
return r974993;
}
double f(double x, double y, double z, double t, double a) {
double r974994 = x;
double r974995 = y;
double r974996 = z;
double r974997 = t;
double r974998 = r974996 * r974997;
double r974999 = -r974998;
double r975000 = fma(r974994, r974995, r974999);
double r975001 = a;
double r975002 = r975000 / r975001;
return r975002;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
| Original | 7.9 |
|---|---|
| Target | 6.0 |
| Herbie | 7.9 |
Initial program 7.9
rmApplied fma-neg7.9
Final simplification7.9
herbie shell --seed 2020083 +o rules:numerics
(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))