From Rump in a 1983 paper

Time bar (total: 4.4s)

analyze1.0ms (0%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%0%100%0%0%0%0
100%0%0%100%0%0%0%1
Compiler

Compiled 24 to 17 computations (29.2% saved)

sample4.1s (94.1%)

Results
1.7s8256×0valid-rival
262.0ms8254×0valid-sollya
10.0ms0exit-sollya
Bogosity

preprocess202.0ms (4.6%)

Algorithm
egg-herbie
Rules
844×fma-neg
430×fma-define
154×cancel-sign-sub-inv
145×sub-neg
96×associate-+l-
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
036409
194381
2266373
3641365
41392365
52312365
62684365
72971365
83045365
93052365
103052365
Stop Event
saturated
Calls
Call 1
Inputs
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 y y)))
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 y y)))
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 (neg.f64 x) #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 y y)))
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 (neg.f64 y) #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 (neg.f64 y) (neg.f64 y))))
(neg.f64 (+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 (neg.f64 x) #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 y y))))
(neg.f64 (+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 (neg.f64 y) #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 (neg.f64 y) (neg.f64 y)))))
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 y #s(literal 4 binary64))) (pow.f64 x #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 x x)))
Outputs
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 y y)))
(fma.f64 #s(literal 2 binary64) (*.f64 y y) (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))))
(-.f64 (fma.f64 y (*.f64 y #s(literal 2 binary64)) (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64)))) (pow.f64 y #s(literal 4 binary64)))
(-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (fma.f64 (*.f64 y y) #s(literal -2 binary64) (pow.f64 y #s(literal 4 binary64))))
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 y y)))
(fma.f64 #s(literal 2 binary64) (*.f64 y y) (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))))
(-.f64 (fma.f64 y (*.f64 y #s(literal 2 binary64)) (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64)))) (pow.f64 y #s(literal 4 binary64)))
(-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (fma.f64 (*.f64 y y) #s(literal -2 binary64) (pow.f64 y #s(literal 4 binary64))))
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 (neg.f64 x) #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 y y)))
(+.f64 (*.f64 #s(literal 2 binary64) (*.f64 y y)) (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 (neg.f64 x) #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))))
(fma.f64 #s(literal 2 binary64) (*.f64 y y) (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 (neg.f64 x) #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))))
(fma.f64 y (*.f64 y #s(literal 2 binary64)) (fma.f64 #s(literal 9 binary64) (pow.f64 (neg.f64 x) #s(literal 4 binary64)) (neg.f64 (pow.f64 y #s(literal 4 binary64)))))
(-.f64 (*.f64 y (*.f64 y #s(literal 2 binary64))) (fma.f64 (pow.f64 (neg.f64 x) #s(literal 4 binary64)) #s(literal -9 binary64) (pow.f64 y #s(literal 4 binary64))))
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 (neg.f64 y) #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 (neg.f64 y) (neg.f64 y))))
(+.f64 (*.f64 #s(literal 2 binary64) (*.f64 y y)) (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 (neg.f64 y) #s(literal 4 binary64))))
(fma.f64 #s(literal 2 binary64) (*.f64 y y) (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 (neg.f64 y) #s(literal 4 binary64))))
(-.f64 (fma.f64 y (*.f64 y #s(literal 2 binary64)) (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64)))) (pow.f64 (neg.f64 y) #s(literal 4 binary64)))
(-.f64 (fma.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64)) (*.f64 y (*.f64 y #s(literal 2 binary64)))) (pow.f64 (neg.f64 y) #s(literal 4 binary64)))
(neg.f64 (+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 (neg.f64 x) #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 y y))))
(neg.f64 (+.f64 (*.f64 #s(literal 2 binary64) (*.f64 y y)) (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 (neg.f64 x) #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64)))))
(-.f64 (*.f64 (*.f64 y y) #s(literal -2 binary64)) (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 (neg.f64 x) #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))))
(fma.f64 (*.f64 y y) #s(literal -2 binary64) (+.f64 (pow.f64 y #s(literal 4 binary64)) (*.f64 (pow.f64 (neg.f64 x) #s(literal 4 binary64)) #s(literal -9 binary64))))
(fma.f64 y (*.f64 y #s(literal -2 binary64)) (fma.f64 (pow.f64 (neg.f64 x) #s(literal 4 binary64)) #s(literal -9 binary64) (pow.f64 y #s(literal 4 binary64))))
(neg.f64 (+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 (neg.f64 y) #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 (neg.f64 y) (neg.f64 y)))))
(neg.f64 (+.f64 (*.f64 #s(literal 2 binary64) (*.f64 y y)) (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 (neg.f64 y) #s(literal 4 binary64)))))
(-.f64 (*.f64 (*.f64 y y) #s(literal -2 binary64)) (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 (neg.f64 y) #s(literal 4 binary64))))
(fma.f64 (*.f64 y y) #s(literal -2 binary64) (+.f64 (pow.f64 (neg.f64 y) #s(literal 4 binary64)) (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -9 binary64))))
(fma.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -9 binary64) (fma.f64 y (*.f64 y #s(literal -2 binary64)) (pow.f64 (neg.f64 y) #s(literal 4 binary64))))
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 y #s(literal 4 binary64))) (pow.f64 x #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 x x)))
(fma.f64 #s(literal 2 binary64) (*.f64 x x) (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 y #s(literal 4 binary64))) (pow.f64 x #s(literal 4 binary64))))
(fma.f64 x (*.f64 x #s(literal 2 binary64)) (fma.f64 #s(literal 9 binary64) (pow.f64 y #s(literal 4 binary64)) (neg.f64 (pow.f64 x #s(literal 4 binary64)))))
(-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 y #s(literal 4 binary64))) (fma.f64 x (*.f64 x #s(literal -2 binary64)) (pow.f64 x #s(literal 4 binary64))))
Compiler

Compiled 17 to 12 computations (29.4% saved)

eval0.0ms (0%)

Compiler

Compiled 2 to 2 computations (0% saved)

prune2.0ms (0%)

Alt Table
Click to see full alt table
StatusAccuracyProgram
18.8%
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 y y)))
Compiler

Compiled 34 to 24 computations (29.4% saved)

simplify4.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative
+-commutative
sub-neg
neg-sub0
neg-mul-1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01755
12355
22855
33055
43155
Stop Event
saturated
Calls
Call 1
Inputs
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 y y)))
Outputs
(+.f64 (-.f64 (*.f64 #s(literal 9 binary64) (pow.f64 x #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))) (*.f64 #s(literal 2 binary64) (*.f64 y y)))

soundness1.0ms (0%)

Stop Event
fuel
Compiler

Compiled 17 to 12 computations (29.4% saved)

preprocess50.0ms (1.1%)

Compiler

Compiled 68 to 48 computations (29.4% saved)

end0.0ms (0%)

Profiling

Loading profile data...