| Alternative 1 | |
|---|---|
| Error | 0.3 |
| Cost | 512 |
\[\left(b \cdot a\right) \cdot \left(b \cdot \left(-a\right)\right)
\]
(FPCore (a b) :precision binary64 (- (* (* (* a a) b) b)))
(FPCore (a b) :precision binary64 (* (* b a) (/ (- b) (pow a -1.0))))
double code(double a, double b) {
return -(((a * a) * b) * b);
}
double code(double a, double b) {
return (b * a) * (-b / pow(a, -1.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 = (b * a) * (-b / (a ** (-1.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 (b * a) * (-b / Math.pow(a, -1.0));
}
def code(a, b): return -(((a * a) * b) * b)
def code(a, b): return (b * a) * (-b / math.pow(a, -1.0))
function code(a, b) return Float64(-Float64(Float64(Float64(a * a) * b) * b)) end
function code(a, b) return Float64(Float64(b * a) * Float64(Float64(-b) / (a ^ -1.0))) end
function tmp = code(a, b) tmp = -(((a * a) * b) * b); end
function tmp = code(a, b) tmp = (b * a) * (-b / (a ^ -1.0)); end
code[a_, b_] := (-N[(N[(N[(a * a), $MachinePrecision] * b), $MachinePrecision] * b), $MachinePrecision])
code[a_, b_] := N[(N[(b * a), $MachinePrecision] * N[((-b) / N[Power[a, -1.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
-\left(\left(a \cdot a\right) \cdot b\right) \cdot b
\left(b \cdot a\right) \cdot \frac{-b}{{a}^{-1}}
Results
Initial program 15.6
Applied egg-rr21.0
Applied egg-rr5.6
Applied egg-rr0.3
Final simplification0.3
| Alternative 1 | |
|---|---|
| Error | 0.3 |
| Cost | 512 |
| Alternative 2 | |
|---|---|
| Error | 38.0 |
| Cost | 448 |
| Alternative 3 | |
|---|---|
| Error | 38.0 |
| Cost | 448 |
herbie shell --seed 2023057
(FPCore (a b)
:name "ab-angle->ABCF D"
:precision binary64
(- (* (* (* a a) b) b)))