| Alternative 1 | |
|---|---|
| Accuracy | 99.7% |
| Cost | 512 |
\[\left(a \cdot b\right) \cdot \left(a \cdot \left(-b\right)\right)
\]

(FPCore (a b) :precision binary64 (- (* (* (* a a) b) b)))
(FPCore (a b) :precision binary64 (- (pow (* a b) 2.0)))
double code(double a, double b) {
return -(((a * a) * b) * b);
}
double code(double a, double b) {
return -pow((a * b), 2.0);
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = -(((a * a) * b) * b)
end function
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = -((a * b) ** 2.0d0)
end function
public static double code(double a, double b) {
return -(((a * a) * b) * b);
}
public static double code(double a, double b) {
return -Math.pow((a * b), 2.0);
}
def code(a, b): return -(((a * a) * b) * b)
def code(a, b): return -math.pow((a * b), 2.0)
function code(a, b) return Float64(-Float64(Float64(Float64(a * a) * b) * b)) end
function code(a, b) return Float64(-(Float64(a * b) ^ 2.0)) end
function tmp = code(a, b) tmp = -(((a * a) * b) * b); end
function tmp = code(a, b) tmp = -((a * b) ^ 2.0); end
code[a_, b_] := (-N[(N[(N[(a * a), $MachinePrecision] * b), $MachinePrecision] * b), $MachinePrecision])
code[a_, b_] := (-N[Power[N[(a * b), $MachinePrecision], 2.0], $MachinePrecision])
-\left(\left(a \cdot a\right) \cdot b\right) \cdot b
-{\left(a \cdot b\right)}^{2}
Herbie found 3 alternatives:
| Alternative | Accuracy | Speedup |
|---|
Results
Initial program 77.6%
Taylor expanded in a around 0 70.3%
Simplified99.6%
[Start]70.3 | \[ -{a}^{2} \cdot {b}^{2}
\] |
|---|---|
unpow2 [=>]70.3 | \[ -\color{blue}{\left(a \cdot a\right)} \cdot {b}^{2}
\] |
unpow2 [=>]70.3 | \[ -\left(a \cdot a\right) \cdot \color{blue}{\left(b \cdot b\right)}
\] |
swap-sqr [<=]99.5 | \[ -\color{blue}{\left(a \cdot b\right) \cdot \left(a \cdot b\right)}
\] |
unpow2 [<=]99.6 | \[ -\color{blue}{{\left(a \cdot b\right)}^{2}}
\] |
Final simplification99.6%
| Alternative 1 | |
|---|---|
| Accuracy | 99.7% |
| Cost | 512 |
| Alternative 2 | |
|---|---|
| Accuracy | 29.1% |
| Cost | 448 |
herbie shell --seed 2023160
(FPCore (a b)
:name "ab-angle->ABCF D"
:precision binary64
(- (* (* (* a a) b) b)))