x \cdot \left(1 - x \cdot y\right)
x \cdot \left(1 - x \cdot y\right) + x \cdot \mathsf{fma}\left(-y, x, y \cdot x\right)double f(double x, double y) {
double r36867 = x;
double r36868 = 1.0;
double r36869 = y;
double r36870 = r36867 * r36869;
double r36871 = r36868 - r36870;
double r36872 = r36867 * r36871;
return r36872;
}
double f(double x, double y) {
double r36873 = x;
double r36874 = 1.0;
double r36875 = y;
double r36876 = r36873 * r36875;
double r36877 = r36874 - r36876;
double r36878 = r36873 * r36877;
double r36879 = -r36875;
double r36880 = r36875 * r36873;
double r36881 = fma(r36879, r36873, r36880);
double r36882 = r36873 * r36881;
double r36883 = r36878 + r36882;
return r36883;
}



Bits error versus x



Bits error versus y
Initial program 0.1
rmApplied add-cube-cbrt0.1
Applied prod-diff0.1
Applied distribute-lft-in0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2020056 +o rules:numerics
(FPCore (x y)
:name "Numeric.SpecFunctions:log1p from math-functions-0.1.5.2, A"
:precision binary64
(* x (- 1 (* x y))))