\left(\left(x \cdot y - y \cdot z\right) - y \cdot y\right) + y \cdot y
\mathsf{fma}\left(y, x, \left(-y\right) \cdot z\right)double f(double x, double y, double z) {
double r21407886 = x;
double r21407887 = y;
double r21407888 = r21407886 * r21407887;
double r21407889 = z;
double r21407890 = r21407887 * r21407889;
double r21407891 = r21407888 - r21407890;
double r21407892 = r21407887 * r21407887;
double r21407893 = r21407891 - r21407892;
double r21407894 = r21407893 + r21407892;
return r21407894;
}
double f(double x, double y, double z) {
double r21407895 = y;
double r21407896 = x;
double r21407897 = -r21407895;
double r21407898 = z;
double r21407899 = r21407897 * r21407898;
double r21407900 = fma(r21407895, r21407896, r21407899);
return r21407900;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 17.9 |
|---|---|
| Target | 0.0 |
| Herbie | 0.0 |
Initial program 17.9
Simplified0.0
rmApplied sub-neg0.0
Applied distribute-lft-in0.0
rmApplied fma-def0.0
Final simplification0.0
herbie shell --seed 2019200 +o rules:numerics
(FPCore (x y z)
:name "Linear.Quaternion:$c/ from linear-1.19.1.3, B"
:herbie-target
(* (- x z) y)
(+ (- (- (* x y) (* y z)) (* y y)) (* y y)))