\mathsf{fma}\left(x, y, z\right) - \left(1 + \left(x \cdot y + z\right)\right)\left(\mathsf{fma}\left(x, y, z\right) - \left(1 + \frac{x \cdot y}{\frac{x \cdot y - z}{x \cdot y}}\right)\right) + \frac{z}{\frac{x \cdot y - z}{z}}double f(double x, double y, double z) {
double r70996 = x;
double r70997 = y;
double r70998 = z;
double r70999 = fma(r70996, r70997, r70998);
double r71000 = 1.0;
double r71001 = r70996 * r70997;
double r71002 = r71001 + r70998;
double r71003 = r71000 + r71002;
double r71004 = r70999 - r71003;
return r71004;
}
double f(double x, double y, double z) {
double r71005 = x;
double r71006 = y;
double r71007 = z;
double r71008 = fma(r71005, r71006, r71007);
double r71009 = 1.0;
double r71010 = r71005 * r71006;
double r71011 = r71010 - r71007;
double r71012 = r71011 / r71010;
double r71013 = r71010 / r71012;
double r71014 = r71009 + r71013;
double r71015 = r71008 - r71014;
double r71016 = r71011 / r71007;
double r71017 = r71007 / r71016;
double r71018 = r71015 + r71017;
return r71018;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 45.2 |
|---|---|
| Target | 0 |
| Herbie | 45.1 |
Initial program 45.2
rmApplied flip-+45.9
rmApplied div-sub45.9
Applied associate-+r-45.9
Applied associate--r-45.9
rmApplied associate-/l*45.6
rmApplied associate-/l*45.1
Final simplification45.1
herbie shell --seed 2020001
(FPCore (x y z)
:name "simple fma test"
:precision binary64
:herbie-target
-1
(- (fma x y z) (+ 1 (+ (* x y) z))))