Details

Time bar (total: 3.4s)

analyze167.0ms (4.9%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
0%0%99.9%0.1%0%0%0%3
0%0%99.9%0.1%0%0%0%4
25%25%74.9%0.1%0%0%0%5
28.6%25%62.4%0.1%12.5%0%0%6
36.4%25%43.7%0.1%31.2%0%0%7
50%31.2%31.2%0.1%37.5%0%0%8
62.5%39%23.4%0.1%37.5%0%0%9
72.4%42.9%16.4%0.1%40.6%0%0%10
79.6%47.2%12.1%0.1%40.6%0%0%11
85.5%49.4%8.4%0.1%42.1%0%0%12
Compiler

Compiled 14 to 9 computations (35.7% saved)

sample1.6s (47.9%)

Results
1.6s8256×body256valid
18.0ms207×body256infinite
Bogosity

preprocess7.0ms (0.2%)

Algorithm
egg-herbie
Rules
26×rational_best.json-simplify-1
rational_best.json-simplify-2
rational_best.json-simplify-43
rational_best.json-simplify-74
rational_best.json-simplify-47
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01350
12650
23850
34650
022
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
(+.f64 (+.f64 (*.f64 y 2) (*.f64 y y)) (*.f64 x x))
Outputs
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
(+.f64 (+.f64 (*.f64 y 2) (*.f64 y y)) (*.f64 x x))
(+.f64 (*.f64 x x) (*.f64 y (+.f64 y 2)))
(+.f64 (*.f64 x x) (*.f64 y (+.f64 2 y)))
Compiler

Compiled 15 to 10 computations (33.3% saved)

simplify16.0ms (0.5%)

Algorithm
egg-herbie
Rules
14×rational_best.json-simplify-1
rational_best.json-simplify-74
rational_best.json-simplify-2
rational_best.json-simplify-43
rational_best.json-simplify-130
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01025
11825
22425
32925
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
Outputs
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))

eval1.0ms (0%)

Compiler

Compiled 22 to 12 computations (45.5% saved)

prune1.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.0b
Counts
3 → 2
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
0.0b
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
Compiler

Compiled 24 to 15 computations (37.5% saved)

localize9.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
0.0b
(*.f64 x (+.f64 x 2))
Compiler

Compiled 25 to 13 computations (48% saved)

series2.0ms (0.1%)

Counts
2 → 36
Calls

9 calls:

TimeVariablePointExpression
0.0ms
y
@0
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
0.0ms
x
@-inf
(*.f64 x (+.f64 x 2))
0.0ms
x
@inf
(*.f64 x (+.f64 x 2))
0.0ms
x
@0
(*.f64 x (+.f64 x 2))
0.0ms
y
@inf
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))

rewrite103.0ms (3%)

Algorithm
batch-egg-rewrite
Rules
942×rational_best.json-simplify-57
896×rational_best.json-simplify-80
712×rational_best.json-simplify-78
628×rational_best.json-simplify-43
546×rational_best.json-simplify-44
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0938
17838
225538
3104138
4489638
Stop Event
node limit
Counts
2 → 32
Calls
Call 1
Inputs
(*.f64 x (+.f64 x 2))
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (+.f64 x 2)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (+.f64 x 2)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 x (+.f64 x 2)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (*.f64 x (+.f64 x 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 x 2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 x 2)) (/.f64 (*.f64 x (+.f64 x 2)) (*.f64 x (+.f64 x 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 x (+.f64 x 4))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 x (+.f64 x (+.f64 x 4)))) -2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (+.f64 x 2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (*.f64 x (+.f64 x 2))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) 2) -2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))))

simplify183.0ms (5.4%)

Algorithm
egg-herbie
Rules
1242×rational_best.json-simplify-2
638×rational_best.json-simplify-80
614×rational_best.json-simplify-129
602×rational_best.json-simplify-49
570×rational_best.json-simplify-78
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0781388
11511388
25911388
324031388
457981388
Stop Event
node limit
Counts
68 → 44
Calls
Call 1
Inputs
(*.f64 2 x)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(*.f64 (+.f64 2 x) x)
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(pow.f64 y 2)
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(pow.f64 y 2)
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (*.f64 x (+.f64 x 2)) 0)
(+.f64 0 (*.f64 x (+.f64 x 2)))
(-.f64 (*.f64 x (+.f64 x 2)) 0)
(-.f64 0 (neg.f64 (*.f64 x (+.f64 x 2))))
(/.f64 (*.f64 x (+.f64 x 2)) 1)
(/.f64 (*.f64 x (+.f64 x 2)) (/.f64 (*.f64 x (+.f64 x 2)) (*.f64 x (+.f64 x 2))))
(/.f64 (*.f64 x (+.f64 x (+.f64 x 4))) 2)
(/.f64 (neg.f64 (*.f64 x (+.f64 x (+.f64 x 4)))) -2)
(pow.f64 (*.f64 x (+.f64 x 2)) 1)
(neg.f64 (neg.f64 (*.f64 x (+.f64 x 2))))
(-.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 0)
(-.f64 0 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))
(*.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))
(*.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))
(*.f64 (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(*.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(*.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))
(*.f64 (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))
(*.f64 (/.f64 (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))
(*.f64 (/.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(*.f64 (/.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(*.f64 (/.f64 (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)
(/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(/.f64 (*.f64 2 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) 2)
(/.f64 (*.f64 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) 2) -2)
(pow.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)
(neg.f64 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
Outputs
(*.f64 2 x)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 x 2) (pow.f64 y 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 x 2) (pow.f64 y 2)))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 x 2) (pow.f64 y 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 x 2) (pow.f64 y 2)))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 x 2) (pow.f64 y 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 x 2) (pow.f64 y 2)))
(*.f64 (+.f64 2 x) x)
(*.f64 x (+.f64 2 x))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 x (+.f64 2 x)))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 x (+.f64 2 x)))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 x (+.f64 2 x)))
(pow.f64 y 2)
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 x (+.f64 2 x)))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 x (+.f64 2 x)))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 x (+.f64 2 x)))
(pow.f64 y 2)
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 x (+.f64 2 x)))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 x (+.f64 2 x)))
(+.f64 (pow.f64 y 2) (*.f64 (+.f64 2 x) x))
(+.f64 (pow.f64 y 2) (*.f64 x (+.f64 2 x)))
(+.f64 (*.f64 x (+.f64 x 2)) 0)
(*.f64 x (+.f64 2 x))
(+.f64 0 (*.f64 x (+.f64 x 2)))
(*.f64 x (+.f64 2 x))
(-.f64 (*.f64 x (+.f64 x 2)) 0)
(*.f64 x (+.f64 2 x))
(-.f64 0 (neg.f64 (*.f64 x (+.f64 x 2))))
(*.f64 x (+.f64 2 x))
(/.f64 (*.f64 x (+.f64 x 2)) 1)
(*.f64 x (+.f64 2 x))
(/.f64 (*.f64 x (+.f64 x 2)) (/.f64 (*.f64 x (+.f64 x 2)) (*.f64 x (+.f64 x 2))))
(*.f64 x (+.f64 2 x))
(/.f64 (*.f64 x (+.f64 x (+.f64 x 4))) 2)
(*.f64 x (+.f64 2 x))
(/.f64 (neg.f64 (*.f64 x (+.f64 x (+.f64 x 4)))) -2)
(*.f64 x (+.f64 2 x))
(pow.f64 (*.f64 x (+.f64 x 2)) 1)
(*.f64 x (+.f64 2 x))
(neg.f64 (neg.f64 (*.f64 x (+.f64 x 2))))
(*.f64 x (+.f64 2 x))
(-.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 0)
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(-.f64 0 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(/.f64 (*.f64 2 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) 2)
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(/.f64 (*.f64 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) 2) -2)
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(pow.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(neg.f64 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))

localize11.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
Compiler

Compiled 32 to 14 computations (56.3% saved)

series1.0ms (0%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
0.0ms
y
@0
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
0.0ms
x
@0
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
0.0ms
x
@-inf
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
0.0ms
x
@inf
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
0.0ms
y
@inf
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))

rewrite114.0ms (3.3%)

Algorithm
batch-egg-rewrite
Rules
1150×rational_best.json-simplify-57
762×rational_best.json-simplify-44
572×rational_best.json-2
572×rational_best.json-3
572×rational_best.json-1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01025
18925
230525
3126225
4613325
Stop Event
node limit
Counts
1 → 21
Calls
Call 1
Inputs
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 2 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))))

simplify174.0ms (5.1%)

Algorithm
egg-herbie
Rules
1460×rational_best.json-simplify-132
1366×rational_best.json-simplify-80
1208×rational_best.json-simplify-78
624×rational_best.json-simplify-2
414×rational_best.json-simplify-1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0551101
11071101
24031101
39821101
421331101
551521101
Stop Event
node limit
Counts
45 → 29
Calls
Call 1
Inputs
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(-.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 0)
(-.f64 0 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))
(*.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))
(*.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))
(*.f64 (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(*.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(*.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))
(*.f64 (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))
(*.f64 (/.f64 (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))
(*.f64 (/.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(*.f64 (/.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(*.f64 (/.f64 (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)
(/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(/.f64 (*.f64 2 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) 2)
(pow.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)
(neg.f64 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
Outputs
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (+.f64 (pow.f64 y 2) (pow.f64 x 2)))
(+.f64 (pow.f64 y 2) (+.f64 (*.f64 2 x) (pow.f64 x 2)))
(-.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 0)
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(-.f64 0 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 1 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(*.f64 (/.f64 (/.f64 1 (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)))) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) (*.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (/.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(/.f64 (*.f64 2 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))) 2)
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(pow.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y)) 1)
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))
(neg.f64 (neg.f64 (+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))))
(+.f64 (*.f64 x (+.f64 2 x)) (*.f64 y y))

eval21.0ms (0.6%)

Compiler

Compiled 1546 to 820 computations (47% saved)

prune9.0ms (0.3%)

Pruning

4 alts after pruning (2 fresh and 2 done)

PrunedKeptTotal
New71273
Fresh000
Picked011
Done011
Total71475
Error
0.0b
Counts
75 → 4
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
0.0b
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
17.6b
(+.f64 (*.f64 2 x) (*.f64 y y))
26.8b
(*.f64 (+.f64 2 x) x)
Compiler

Compiled 40 to 26 computations (35% saved)

localize6.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(*.f64 (+.f64 2 x) x)
Compiler

Compiled 12 to 8 computations (33.3% saved)

series0.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
0.0ms
x
@inf
(*.f64 (+.f64 2 x) x)
0.0ms
x
@0
(*.f64 (+.f64 2 x) x)
0.0ms
x
@-inf
(*.f64 (+.f64 2 x) x)

rewrite67.0ms (2%)

Algorithm
batch-egg-rewrite
Rules
1406×rational_best.json-5
1404×rational_best.json-2
1404×rational_best.json-3
1404×rational_best.json-1
1404×exponential.json-1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0613
15113
216213
365313
4282813
Stop Event
node limit
Counts
1 → 9
Calls
Call 1
Inputs
(*.f64 (+.f64 2 x) x)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (+.f64 2 x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (+.f64 2 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 x (+.f64 2 x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (*.f64 x (+.f64 2 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 2 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 2 x)) (/.f64 (*.f64 x (+.f64 2 x)) (*.f64 x (+.f64 2 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 2 x) (+.f64 x x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (+.f64 2 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (*.f64 x (+.f64 2 x))))))))

simplify144.0ms (4.2%)

Algorithm
egg-herbie
Rules
1570×rational_best.json-simplify-132
1340×rational_best.json-simplify-80
1212×rational_best.json-simplify-78
998×rational_best.json-simplify-82
720×rational_best.json-simplify-2
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
025309
142309
281309
3215309
4987309
52692309
65560309
Stop Event
node limit
Counts
21 → 13
Calls
Call 1
Inputs
(*.f64 2 x)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 x (+.f64 2 x)) 0)
(+.f64 0 (*.f64 x (+.f64 2 x)))
(-.f64 (*.f64 x (+.f64 2 x)) 0)
(-.f64 0 (neg.f64 (*.f64 x (+.f64 2 x))))
(/.f64 (*.f64 x (+.f64 2 x)) 1)
(/.f64 (*.f64 x (+.f64 2 x)) (/.f64 (*.f64 x (+.f64 2 x)) (*.f64 x (+.f64 2 x))))
(/.f64 (*.f64 (+.f64 2 x) (+.f64 x x)) 2)
(pow.f64 (*.f64 x (+.f64 2 x)) 1)
(neg.f64 (neg.f64 (*.f64 x (+.f64 2 x))))
Outputs
(*.f64 2 x)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(pow.f64 x 2)
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 2 x) (pow.f64 x 2))
(+.f64 (*.f64 x (+.f64 2 x)) 0)
(*.f64 x (+.f64 2 x))
(+.f64 0 (*.f64 x (+.f64 2 x)))
(*.f64 x (+.f64 2 x))
(-.f64 (*.f64 x (+.f64 2 x)) 0)
(*.f64 x (+.f64 2 x))
(-.f64 0 (neg.f64 (*.f64 x (+.f64 2 x))))
(*.f64 x (+.f64 2 x))
(/.f64 (*.f64 x (+.f64 2 x)) 1)
(*.f64 x (+.f64 2 x))
(/.f64 (*.f64 x (+.f64 2 x)) (/.f64 (*.f64 x (+.f64 2 x)) (*.f64 x (+.f64 2 x))))
(*.f64 x (+.f64 2 x))
(/.f64 (*.f64 (+.f64 2 x) (+.f64 x x)) 2)
(*.f64 x (+.f64 2 x))
(pow.f64 (*.f64 x (+.f64 2 x)) 1)
(*.f64 x (+.f64 2 x))
(neg.f64 (neg.f64 (*.f64 x (+.f64 2 x))))
(*.f64 x (+.f64 2 x))

localize7.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 2 x) (*.f64 y y))
Compiler

Compiled 18 to 9 computations (50% saved)

series3.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
3.0ms
x
@0
(+.f64 (*.f64 2 x) (*.f64 y y))
0.0ms
x
@inf
(+.f64 (*.f64 2 x) (*.f64 y y))
0.0ms
x
@-inf
(+.f64 (*.f64 2 x) (*.f64 y y))
0.0ms
y
@inf
(+.f64 (*.f64 2 x) (*.f64 y y))
0.0ms
y
@0
(+.f64 (*.f64 2 x) (*.f64 y y))

rewrite90.0ms (2.6%)

Algorithm
batch-egg-rewrite
Rules
820×rational_best.json-simplify-57
792×rational_best.json-simplify-80
718×rational_best.json-simplify-82
646×rational_best.json-simplify-78
490×rational_best.json-simplify-43
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0819
16919
223219
393719
4426519
Stop Event
node limit
Counts
1 → 26
Calls
Call 1
Inputs
(+.f64 (*.f64 2 x) (*.f64 y y))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 x (+.f64 x (*.f64 y y))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (+.f64 x (+.f64 x (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x (+.f64 x (*.f64 y y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (+.f64 x (+.f64 x (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))))) (*.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 x (+.f64 x (*.f64 y y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 x 4) (*.f64 2 (*.f64 y y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (*.f64 x 4) (*.f64 2 (*.f64 y y)))) -2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 x (+.f64 x (*.f64 y y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (+.f64 x (+.f64 x (*.f64 y y)))))))))

simplify151.0ms (4.4%)

Algorithm
egg-herbie
Rules
1294×rational_best.json-simplify-2
1162×rational_best.json-simplify-80
1056×rational_best.json-simplify-78
706×rational_best.json-simplify-49
662×rational_best.json-simplify-43
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
064902
1133902
2538902
32308902
44674902
Stop Event
node limit
Counts
50 → 34
Calls
Call 1
Inputs
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(*.f64 2 x)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(*.f64 2 x)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(*.f64 2 x)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(-.f64 (+.f64 x (+.f64 x (*.f64 y y))) 0)
(-.f64 0 (neg.f64 (+.f64 x (+.f64 x (*.f64 y y)))))
(*.f64 (+.f64 x (+.f64 x (*.f64 y y))) 1)
(*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))
(*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))))
(*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))))
(*.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))
(*.f64 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (+.f64 x (+.f64 x (*.f64 y y))))
(*.f64 (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))
(*.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y)))))
(*.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y))))
(*.f64 (/.f64 1 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y))))
(*.f64 (/.f64 1 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))
(*.f64 (/.f64 (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))
(*.f64 (/.f64 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))
(*.f64 (/.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))
(*.f64 (/.f64 (/.f64 (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))))) (*.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))))))
(*.f64 (/.f64 (/.f64 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))
(*.f64 (/.f64 (/.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))
(*.f64 (/.f64 (/.f64 1 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))
(/.f64 (+.f64 x (+.f64 x (*.f64 y y))) 1)
(/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))
(/.f64 (+.f64 (*.f64 x 4) (*.f64 2 (*.f64 y y))) 2)
(/.f64 (neg.f64 (+.f64 (*.f64 x 4) (*.f64 2 (*.f64 y y)))) -2)
(pow.f64 (+.f64 x (+.f64 x (*.f64 y y))) 1)
(neg.f64 (neg.f64 (+.f64 x (+.f64 x (*.f64 y y)))))
Outputs
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(*.f64 2 x)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(*.f64 2 x)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(*.f64 2 x)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(pow.f64 y 2)
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(+.f64 (*.f64 2 x) (pow.f64 y 2))
(+.f64 (pow.f64 y 2) (*.f64 2 x))
(-.f64 (+.f64 x (+.f64 x (*.f64 y y))) 0)
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(-.f64 0 (neg.f64 (+.f64 x (+.f64 x (*.f64 y y)))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (+.f64 x (+.f64 x (*.f64 y y))) 1)
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (+.f64 x (+.f64 x (*.f64 y y))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y)))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (/.f64 1 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (/.f64 1 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (/.f64 (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (/.f64 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (/.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (/.f64 (/.f64 (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))))) (*.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (/.f64 (/.f64 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (/.f64 (/.f64 (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 1 (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(*.f64 (/.f64 (/.f64 1 (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y))))) (+.f64 x (+.f64 x (*.f64 y y)))) (*.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(/.f64 (+.f64 x (+.f64 x (*.f64 y y))) 1)
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (/.f64 (+.f64 x (+.f64 x (*.f64 y y))) (+.f64 x (+.f64 x (*.f64 y y)))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(/.f64 (+.f64 (*.f64 x 4) (*.f64 2 (*.f64 y y))) 2)
(/.f64 (+.f64 (*.f64 x 4) (*.f64 y (*.f64 2 y))) 2)
(/.f64 (+.f64 (*.f64 x 4) (*.f64 y (*.f64 y 2))) 2)
(/.f64 (neg.f64 (+.f64 (*.f64 x 4) (*.f64 2 (*.f64 y y)))) -2)
(/.f64 (+.f64 (*.f64 x 4) (*.f64 y (*.f64 2 y))) 2)
(/.f64 (+.f64 (*.f64 x 4) (*.f64 y (*.f64 y 2))) 2)
(pow.f64 (+.f64 x (+.f64 x (*.f64 y y))) 1)
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))
(neg.f64 (neg.f64 (+.f64 x (+.f64 x (*.f64 y y)))))
(+.f64 x (+.f64 x (*.f64 y y)))
(+.f64 (*.f64 y y) (+.f64 x x))

eval7.0ms (0.2%)

Compiler

Compiled 958 to 191 computations (80.1% saved)

prune8.0ms (0.2%)

Pruning

5 alts after pruning (1 fresh and 4 done)

PrunedKeptTotal
New46147
Fresh000
Picked011
Done033
Total46551
Error
0.0b
Counts
51 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
0.0b
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
17.6b
(+.f64 (*.f64 2 x) (*.f64 y y))
26.8b
(*.f64 (+.f64 2 x) x)
44.2b
(*.f64 2 x)
Compiler

Compiled 45 to 30 computations (33.3% saved)

localize3.0ms (0.1%)

Compiler

Compiled 7 to 5 computations (28.6% saved)

eval0.0ms (0%)

Compiler

Compiled 2 to 2 computations (0% saved)

prune2.0ms (0.1%)

Pruning

5 alts after pruning (0 fresh and 5 done)

PrunedKeptTotal
New000
Fresh000
Picked011
Done044
Total055
Error
0.0b
Counts
5 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
0.0b
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
17.6b
(+.f64 (*.f64 2 x) (*.f64 y y))
26.8b
(*.f64 (+.f64 2 x) x)
44.2b
(*.f64 2 x)
Compiler

Compiled 45 to 30 computations (33.3% saved)

regimes22.0ms (0.7%)

Counts
5 → 1
Calls
Call 1
Inputs
(*.f64 2 x)
(*.f64 (+.f64 2 x) x)
(+.f64 (*.f64 2 x) (*.f64 y y))
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
Outputs
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
Calls

5 calls:

5.0ms
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
4.0ms
(+.f64 (*.f64 x 2) (*.f64 x x))
4.0ms
x
4.0ms
y
3.0ms
(*.f64 y y)
Results
ErrorSegmentsBranch
0.0b1x
0.0b1y
0.0b1(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
0.0b1(+.f64 (*.f64 x 2) (*.f64 x x))
0.0b1(*.f64 y y)
Compiler

Compiled 70 to 41 computations (41.4% saved)

regimes12.0ms (0.4%)

Counts
4 → 1
Calls
Call 1
Inputs
(*.f64 2 x)
(*.f64 (+.f64 2 x) x)
(+.f64 (*.f64 2 x) (*.f64 y y))
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
Outputs
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
Calls

3 calls:

4.0ms
x
4.0ms
y
3.0ms
(*.f64 y y)
Results
ErrorSegmentsBranch
0.0b1x
0.0b1y
0.0b1(*.f64 y y)
Compiler

Compiled 37 to 22 computations (40.5% saved)

regimes100.0ms (2.9%)

Counts
3 → 3
Calls
Call 1
Inputs
(*.f64 2 x)
(*.f64 (+.f64 2 x) x)
(+.f64 (*.f64 2 x) (*.f64 y y))
Outputs
(*.f64 (+.f64 2 x) x)
(+.f64 (*.f64 2 x) (*.f64 y y))
(*.f64 (+.f64 2 x) x)
Calls

3 calls:

61.0ms
x
19.0ms
(*.f64 y y)
19.0ms
y
Results
ErrorSegmentsBranch
4.4b3x
8.4b5y
7.3b6(*.f64 y y)
Compiler

Compiled 28 to 18 computations (35.7% saved)

bsearch20.0ms (0.6%)

Algorithm
binary-search
Steps
TimeLeftRight
8.0ms
3368128605993.066
7109855710879.595
12.0ms
-7.140876156499341e-9
-3.7929543529233206e-11
Results
17.0ms192×body256valid
Compiler

Compiled 234 to 168 computations (28.2% saved)

regimes208.0ms (6.1%)

Accuracy

Total -17.5b remaining (-65.2%)

Threshold costs -17.5b (-65.2%)

Counts
2 → 1
Calls
Call 1
Inputs
(*.f64 2 x)
(*.f64 (+.f64 2 x) x)
Outputs
(*.f64 (+.f64 2 x) x)
Calls

2 calls:

204.0ms
y
3.0ms
x
Results
ErrorSegmentsBranch
26.8b1x
26.8b1y
Compiler

Compiled 16 to 11 computations (31.3% saved)

simplify3.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
026139
Stop Event
done
saturated
Calls
Call 1
Inputs
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
(if (<=.f64 x -279564095785883/151115727451828646838272) (*.f64 (+.f64 2 x) x) (if (<=.f64 x 3500000000000) (+.f64 (*.f64 2 x) (*.f64 y y)) (*.f64 (+.f64 2 x) x)))
(*.f64 (+.f64 2 x) x)
(*.f64 2 x)
Outputs
(+.f64 (+.f64 (*.f64 x 2) (*.f64 x x)) (*.f64 y y))
(+.f64 (*.f64 x (+.f64 x 2)) (*.f64 y y))
(if (<=.f64 x -279564095785883/151115727451828646838272) (*.f64 (+.f64 2 x) x) (if (<=.f64 x 3500000000000) (+.f64 (*.f64 2 x) (*.f64 y y)) (*.f64 (+.f64 2 x) x)))
(*.f64 (+.f64 2 x) x)
(*.f64 2 x)
Compiler

Compiled 63 to 42 computations (33.3% saved)

soundness0.0ms (0%)

end111.0ms (3.2%)

Compiler

Compiled 55 to 32 computations (41.8% saved)

Profiling

Loading profile data...