\left(\left(x \cdot y - y \cdot z\right) - y \cdot y\right) + y \cdot y
\mathsf{fma}\left(x, y, -z \cdot y\right) + y \cdot \left(z + \left(-z\right)\right)double f(double x, double y, double z) {
double r23645117 = x;
double r23645118 = y;
double r23645119 = r23645117 * r23645118;
double r23645120 = z;
double r23645121 = r23645118 * r23645120;
double r23645122 = r23645119 - r23645121;
double r23645123 = r23645118 * r23645118;
double r23645124 = r23645122 - r23645123;
double r23645125 = r23645124 + r23645123;
return r23645125;
}
double f(double x, double y, double z) {
double r23645126 = x;
double r23645127 = y;
double r23645128 = z;
double r23645129 = r23645128 * r23645127;
double r23645130 = -r23645129;
double r23645131 = fma(r23645126, r23645127, r23645130);
double r23645132 = -r23645128;
double r23645133 = r23645128 + r23645132;
double r23645134 = r23645127 * r23645133;
double r23645135 = r23645131 + r23645134;
return r23645135;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 16.8 |
|---|---|
| Target | 0.0 |
| Herbie | 0.0 |
Initial program 16.8
rmApplied prod-diff16.8
Applied associate--l+16.8
Applied associate-+l+7.6
Simplified0.0
Final simplification0.0
herbie shell --seed 2019164 +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)))