| Alternative 1 | |
|---|---|
| Accuracy | 99.9% |
| Cost | 448 |
\[x - x \cdot \left(x \cdot y\right)
\]

(FPCore (x y) :precision binary64 (* x (- 1.0 (* x y))))
(FPCore (x y) :precision binary64 (- x (* x (* x y))))
double code(double x, double y) {
return x * (1.0 - (x * y));
}
double code(double x, double y) {
return x - (x * (x * y));
}
real(8) function code(x, y)
real(8), intent (in) :: x
real(8), intent (in) :: y
code = x * (1.0d0 - (x * y))
end function
real(8) function code(x, y)
real(8), intent (in) :: x
real(8), intent (in) :: y
code = x - (x * (x * y))
end function
public static double code(double x, double y) {
return x * (1.0 - (x * y));
}
public static double code(double x, double y) {
return x - (x * (x * y));
}
def code(x, y): return x * (1.0 - (x * y))
def code(x, y): return x - (x * (x * y))
function code(x, y) return Float64(x * Float64(1.0 - Float64(x * y))) end
function code(x, y) return Float64(x - Float64(x * Float64(x * y))) end
function tmp = code(x, y) tmp = x * (1.0 - (x * y)); end
function tmp = code(x, y) tmp = x - (x * (x * y)); end
code[x_, y_] := N[(x * N[(1.0 - N[(x * y), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
code[x_, y_] := N[(x - N[(x * N[(x * y), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
x \cdot \left(1 - x \cdot y\right)
x - x \cdot \left(x \cdot y\right)
Herbie found 4 alternatives:
| Alternative | Accuracy | Speedup |
|---|
Results
Initial program 99.9%
Taylor expanded in x around 0 94.1%
Simplified99.9%
[Start]94.1% | \[ -1 \cdot \left(y \cdot {x}^{2}\right) + x
\] |
|---|---|
+-commutative [=>]94.1% | \[ \color{blue}{x + -1 \cdot \left(y \cdot {x}^{2}\right)}
\] |
mul-1-neg [=>]94.1% | \[ x + \color{blue}{\left(-y \cdot {x}^{2}\right)}
\] |
unpow2 [=>]94.1% | \[ x + \left(-y \cdot \color{blue}{\left(x \cdot x\right)}\right)
\] |
sub-neg [<=]94.1% | \[ \color{blue}{x - y \cdot \left(x \cdot x\right)}
\] |
*-commutative [=>]94.1% | \[ x - \color{blue}{\left(x \cdot x\right) \cdot y}
\] |
associate-*r* [<=]99.9% | \[ x - \color{blue}{x \cdot \left(x \cdot y\right)}
\] |
Final simplification99.9%
| Alternative 1 | |
|---|---|
| Accuracy | 99.9% |
| Cost | 448 |
| Alternative 2 | |
|---|---|
| Accuracy | 74.8% |
| Cost | 649 |
| Alternative 3 | |
|---|---|
| Accuracy | 99.9% |
| Cost | 448 |
| Alternative 4 | |
|---|---|
| Accuracy | 50.6% |
| Cost | 64 |
herbie shell --seed 2023245
(FPCore (x y)
:name "Numeric.SpecFunctions:log1p from math-functions-0.1.5.2, A"
:precision binary64
(* x (- 1.0 (* x y))))