\left(x + y\right) \cdot \left(1 - z\right)
\mathsf{fma}\left(1, x, 1 \cdot y\right) + \left(-z\right) \cdot \left(x + y\right)double f(double x, double y, double z) {
double r31444 = x;
double r31445 = y;
double r31446 = r31444 + r31445;
double r31447 = 1.0;
double r31448 = z;
double r31449 = r31447 - r31448;
double r31450 = r31446 * r31449;
return r31450;
}
double f(double x, double y, double z) {
double r31451 = 1.0;
double r31452 = x;
double r31453 = y;
double r31454 = r31451 * r31453;
double r31455 = fma(r31451, r31452, r31454);
double r31456 = z;
double r31457 = -r31456;
double r31458 = r31452 + r31453;
double r31459 = r31457 * r31458;
double r31460 = r31455 + r31459;
return r31460;
}



Bits error versus x



Bits error versus y



Bits error versus z
Initial program 0.0
rmApplied sub-neg0.0
Applied distribute-lft-in0.0
Simplified0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2020089 +o rules:numerics
(FPCore (x y z)
:name "Optimisation.CirclePacking:place from circle-packing-0.1.0.4, H"
:precision binary64
(* (+ x y) (- 1 z)))