9 \cdot {x}^{4} - \left(y \cdot y\right) \cdot \left(y \cdot y - 2\right)\sqrt[3]{\left(9 \cdot {x}^{4} - {y}^{4}\right) \cdot \left(\left(9 \cdot {x}^{4} - {y}^{4}\right) \cdot \left(9 \cdot {x}^{4} - {y}^{4}\right)\right)} - -2 \cdot \left(y \cdot y\right)(FPCore (x y) :precision binary64 (- (* 9.0 (pow x 4.0)) (* (* y y) (- (* y y) 2.0))))
(FPCore (x y)
:precision binary64
(-
(cbrt
(*
(- (* 9.0 (pow x 4.0)) (pow y 4.0))
(*
(- (* 9.0 (pow x 4.0)) (pow y 4.0))
(- (* 9.0 (pow x 4.0)) (pow y 4.0)))))
(* -2.0 (* y y))))double code(double x, double y) {
return (9.0 * pow(x, 4.0)) - ((y * y) * ((y * y) - 2.0));
}
double code(double x, double y) {
return cbrt(((9.0 * pow(x, 4.0)) - pow(y, 4.0)) * (((9.0 * pow(x, 4.0)) - pow(y, 4.0)) * ((9.0 * pow(x, 4.0)) - pow(y, 4.0)))) - (-2.0 * (y * y));
}
Results
Initial program 62.0
rmApplied sub-neg_binary64_143562.0
Applied distribute-rgt-in_binary64_139262.0
Applied associate--r+_binary64_137852.0
Simplified52.0
rmApplied add-cbrt-cube_binary64_147852.0
Final simplification52.0
herbie shell --seed 2021094
(FPCore (x y)
:name "From Rump in a 1983 paper, rewritten"
:precision binary64
:pre (and (== x 10864.0) (== y 18817.0))
(- (* 9.0 (pow x 4.0)) (* (* y y) (- (* y y) 2.0))))