\left(x + 1\right) \cdot \left(x + 1\right) - 1
\left(x + x\right) + x \cdot x
(FPCore (x) :precision binary64 (- (* (+ x 1.0) (+ x 1.0)) 1.0))
(FPCore (x) :precision binary64 (+ (+ x x) (* x x)))
double code(double x) {
return ((x + 1.0) * (x + 1.0)) - 1.0;
}
double code(double x) {
return (x + x) + (x * x);
}







Bits error versus x
Results
| Alternative 1 | |
|---|---|
| Error | 0.0 |
| Cost | 320 |
| Alternative 2 | |
|---|---|
| Error | 1.8 |
| Cost | 520 |
| Alternative 3 | |
|---|---|
| Error | 21.9 |
| Cost | 192 |
| Alternative 4 | |
|---|---|
| Error | 61.2 |
| Cost | 64 |

Initial program 38.6
Simplified0.0
rmApplied distribute-rgt-in_binary640.0
Simplified0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2021044
(FPCore (x)
:name "Expanding a square"
:precision binary64
(- (* (+ x 1.0) (+ x 1.0)) 1.0))