x \cdot x - 1
\mathsf{fma}\left(x, x, -1\right)double f(double x) {
double r220049 = x;
double r220050 = r220049 * r220049;
double r220051 = 1.0;
double r220052 = r220050 - r220051;
return r220052;
}
double f(double x) {
double r220053 = x;
double r220054 = 1.0;
double r220055 = -r220054;
double r220056 = fma(r220053, r220053, r220055);
return r220056;
}



Bits error versus x
Initial program 0.0
Simplified0
Final simplification0
herbie shell --seed 2019179 +o rules:numerics
(FPCore (x)
:name "Data.Random.Dice:roll from dice-0.1"
(- (* x x) 1.0))