Details

Time bar (total: 5.2s)

analyze479.0ms (9.1%)

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
0%0%99.9%0.1%0%0%0%5
0%0%99.9%0.1%0%0%0%6
12.5%12.5%87.4%0.1%0%0%0%7
18.8%18.7%81.1%0.1%0%0%0%8
25.8%25%71.8%0.1%3.1%0%0%9
36.4%34.3%60.1%0.1%5.5%0%0%10
44.5%41.3%51.5%0.1%7%0%0%11
51.5%46.8%44.1%0.1%9%0%0%12
Compiler

Compiled 11 to 7 computations (36.4% saved)

sample2.7s (51.5%)

Results
2.2s8256×body256valid
389.0ms1225×body256infinite
Bogosity

preprocess6.0ms (0.1%)

Algorithm
egg-herbie
Rules
12×rational_best.json-simplify-1
12×rational_best.json-simplify-2
rational_best.json-simplify-47
trig.json-simplify-13
swap-d2-d3
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01552
12952
23452
033
133
Stop Event
unsound
saturated
Calls
Call 1
Inputs
0
1
2
Outputs
0
1
2
1
Call 2
Inputs
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d2 d3))
(+.f64 (*.f64 d3 d2) (*.f64 d3 d1))
(+.f64 (*.f64 d1 d3) (*.f64 d1 d2))
Outputs
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d3 d2))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d2 d3))
(*.f64 d2 (+.f64 d3 d1))
(*.f64 d2 (+.f64 d1 d3))
(+.f64 (*.f64 d3 d2) (*.f64 d3 d1))
(*.f64 d3 (+.f64 d1 d2))
(+.f64 (*.f64 d1 d3) (*.f64 d1 d2))
(*.f64 d1 (+.f64 d3 d2))
(*.f64 d1 (+.f64 d2 d3))
Symmetry

(sort d2 d3)

Compiler

Compiled 13 to 9 computations (30.8% saved)

simplify21.0ms (0.4%)

Algorithm
egg-herbie
Rules
rational_best.json-simplify-2
rational_best.json-simplify-1
rational_best.json-simplify-47
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0813
11313
21513
Stop Event
saturated
Counts
1 → 3
Calls
Call 1
Inputs
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
Outputs
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d3 d2))
(*.f64 d1 (+.f64 d2 d3))

eval1.0ms (0%)

Compiler

Compiled 20 to 10 computations (50% saved)

prune1.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New123
Fresh011
Picked000
Done000
Total134
Error
0.0b
Counts
4 → 2
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
0.0b
(*.f64 d1 (+.f64 d3 d2))
Compiler

Compiled 18 to 11 computations (38.9% saved)

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(*.f64 d1 (+.f64 d3 d2))
Compiler

Compiled 14 to 5 computations (64.3% saved)

series138.0ms (2.6%)

Counts
1 → 36
Calls

9 calls:

TimeVariablePointExpression
135.0ms
d1
@0
(*.f64 d1 (+.f64 d3 d2))
0.0ms
d3
@-inf
(*.f64 d1 (+.f64 d3 d2))
0.0ms
d1
@inf
(*.f64 d1 (+.f64 d3 d2))
0.0ms
d1
@-inf
(*.f64 d1 (+.f64 d3 d2))
0.0ms
d3
@inf
(*.f64 d1 (+.f64 d3 d2))

rewrite72.0ms (1.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0713
16013
220613
385913
4377713
Stop Event
node limit
Counts
1 → 7
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 d3 d2))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 (+.f64 d3 d2)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 d1 (+.f64 d3 d2)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 d1 (+.f64 d3 d2)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 d3 d2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 d3 d2)) (/.f64 (*.f64 d1 (+.f64 d3 d2)) (*.f64 d1 (+.f64 d3 d2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d3 d2) (+.f64 d1 d1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 d3 d2)) 1)))))

simplify180.0ms (3.4%)

Algorithm
egg-herbie
Rules
1754×rational_best.json-simplify-80
1354×rational_best.json-simplify-78
1080×rational_best.json-simplify-44
1040×rational_best.json-simplify-132
876×rational_best.json-simplify-1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
025523
137523
271523
3200523
4843523
52639523
64681523
76912523
Stop Event
node limit
Counts
43 → 12
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d2 d1)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d2 d1)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d1 (+.f64 d3 d2)) 0)
(+.f64 0 (*.f64 d1 (+.f64 d3 d2)))
(-.f64 (*.f64 d1 (+.f64 d3 d2)) 0)
(/.f64 (*.f64 d1 (+.f64 d3 d2)) 1)
(/.f64 (*.f64 d1 (+.f64 d3 d2)) (/.f64 (*.f64 d1 (+.f64 d3 d2)) (*.f64 d1 (+.f64 d3 d2))))
(/.f64 (*.f64 (+.f64 d3 d2) (+.f64 d1 d1)) 2)
(pow.f64 (*.f64 d1 (+.f64 d3 d2)) 1)
Outputs
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d1 (+.f64 d3 d2)) 0)
(*.f64 d1 (+.f64 d2 d3))
(+.f64 0 (*.f64 d1 (+.f64 d3 d2)))
(*.f64 d1 (+.f64 d2 d3))
(-.f64 (*.f64 d1 (+.f64 d3 d2)) 0)
(*.f64 d1 (+.f64 d2 d3))
(/.f64 (*.f64 d1 (+.f64 d3 d2)) 1)
(*.f64 d1 (+.f64 d2 d3))
(/.f64 (*.f64 d1 (+.f64 d3 d2)) (/.f64 (*.f64 d1 (+.f64 d3 d2)) (*.f64 d1 (+.f64 d3 d2))))
(*.f64 d1 (+.f64 d2 d3))
(/.f64 (*.f64 (+.f64 d3 d2) (+.f64 d1 d1)) 2)
(*.f64 d1 (+.f64 d2 d3))
(pow.f64 (*.f64 d1 (+.f64 d3 d2)) 1)
(*.f64 d1 (+.f64 d2 d3))

localize8.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
Compiler

Compiled 19 to 6 computations (68.4% saved)

series3.0ms (0.1%)

Counts
1 → 36
Calls

9 calls:

TimeVariablePointExpression
1.0ms
d1
@inf
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
1.0ms
d1
@0
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
1.0ms
d1
@-inf
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
0.0ms
d2
@0
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
0.0ms
d2
@inf
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))

rewrite93.0ms (1.8%)

Algorithm
batch-egg-rewrite
Rules
896×rational_best.json-simplify-57
680×rational_best.json-simplify-80
628×rational_best.json-simplify-44
622×rational_best.json-simplify-43
484×rational_best.json-5
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0813
17113
224613
3102513
4466813
Stop Event
node limit
Counts
1 → 38
Calls
Call 1
Inputs
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 d1 (+.f64 d2 d3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (neg.f64 (*.f64 d1 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (+.f64 d2 d3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (*.f64 (+.f64 d2 d3) (/.f64 d1 d1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (*.f64 (+.f64 d2 d3) (*.f64 d1 (/.f64 1 d1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (*.f64 d1 (+.f64 d2 d3)) (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (+.f64 d2 d3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (+.f64 d2 d3)) (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (+.f64 d2 d3)) (/.f64 1 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d2 d3) d1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d2 d3) (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 d1) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 d1) (+.f64 (*.f64 d2 (*.f64 d1 d1)) (*.f64 d1 (*.f64 d1 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 d1) (*.f64 (+.f64 d2 d3) (/.f64 1 d1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (/.f64 1 (*.f64 d1 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) (/.f64 1 d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3)))) (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3)))) (*.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))) (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 d2 d3)) (*.f64 d1 (*.f64 (+.f64 d2 d3) (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))) (*.f64 (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 (*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) d1) d1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3)))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 d2 d3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 d2 d3)) (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d2 d3) (+.f64 d1 d1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 (+.f64 d2 d3) (+.f64 d1 d1))) -2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 d2 d3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (neg.f64 (*.f64 d1 (+.f64 d2 d3))))))))

simplify251.0ms (4.8%)

Algorithm
egg-herbie
Rules
1004×rational_best.json-simplify-2
894×rational_best.json-simplify-80
826×rational_best.json-simplify-49
810×rational_best.json-simplify-78
776×rational_best.json-simplify-129
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
097926
1227926
2536926
31770926
43346926
57018926
Stop Event
node limit
Counts
74 → 43
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2))))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2))))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2))))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2))))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d2 d1)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d2 d1)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d2 d1)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(-.f64 (*.f64 d1 (+.f64 d2 d3)) 0)
(-.f64 0 (neg.f64 (*.f64 d1 (+.f64 d2 d3))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (*.f64 (+.f64 d2 d3) (/.f64 d1 d1)))
(*.f64 d1 (*.f64 (+.f64 d2 d3) (*.f64 d1 (/.f64 1 d1))))
(*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (*.f64 d1 (+.f64 d2 d3)) (+.f64 d2 d3))))
(*.f64 (*.f64 d1 (+.f64 d2 d3)) 1)
(*.f64 (*.f64 d1 (+.f64 d2 d3)) (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))))
(*.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (+.f64 d2 d3))))
(*.f64 (*.f64 d1 (+.f64 d2 d3)) (/.f64 1 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3)))))
(*.f64 1 (*.f64 d1 (+.f64 d2 d3)))
(*.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3)))
(*.f64 (+.f64 d2 d3) d1)
(*.f64 (+.f64 d2 d3) (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))
(*.f64 (/.f64 1 d1) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))
(*.f64 (/.f64 1 d1) (+.f64 (*.f64 d2 (*.f64 d1 d1)) (*.f64 d1 (*.f64 d1 d3))))
(*.f64 (*.f64 d1 d1) (*.f64 (+.f64 d2 d3) (/.f64 1 d1)))
(*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))
(*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (/.f64 1 (*.f64 d1 (+.f64 d2 d3))))
(*.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) (/.f64 1 d1))
(*.f64 (*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3)))
(*.f64 (/.f64 1 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3)))) (*.f64 d1 (+.f64 d2 d3)))
(*.f64 (/.f64 1 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3)))) (*.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))) (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))))))
(*.f64 (/.f64 1 (+.f64 d2 d3)) (*.f64 d1 (*.f64 (+.f64 d2 d3) (+.f64 d2 d3))))
(*.f64 (/.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))))
(*.f64 (/.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))
(*.f64 (/.f64 (*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))
(*.f64 (/.f64 (/.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))) (*.f64 (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))))
(*.f64 (/.f64 (/.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))))
(*.f64 (/.f64 (/.f64 (*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))))
(*.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) d1) d1)
(*.f64 (/.f64 (/.f64 1 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3)))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))
(/.f64 (*.f64 d1 (+.f64 d2 d3)) 1)
(/.f64 (*.f64 d1 (+.f64 d2 d3)) (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))))
(/.f64 (*.f64 (+.f64 d2 d3) (+.f64 d1 d1)) 2)
(/.f64 (neg.f64 (*.f64 (+.f64 d2 d3) (+.f64 d1 d1))) -2)
(pow.f64 (*.f64 d1 (+.f64 d2 d3)) 1)
(neg.f64 (neg.f64 (*.f64 d1 (+.f64 d2 d3))))
Outputs
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 -1 (*.f64 d1 (+.f64 (*.f64 -1 d3) (*.f64 -1 d2))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(-.f64 (*.f64 d1 (+.f64 d2 d3)) 0)
(*.f64 d1 (+.f64 d2 d3))
(-.f64 0 (neg.f64 (*.f64 d1 (+.f64 d2 d3))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (*.f64 (+.f64 d2 d3) (/.f64 d1 d1)))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (*.f64 (+.f64 d2 d3) (*.f64 d1 (/.f64 1 d1))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (*.f64 d1 (+.f64 d2 d3)) (+.f64 d2 d3))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (*.f64 d1 (+.f64 d2 d3)) 1)
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (*.f64 d1 (+.f64 d2 d3)) (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (+.f64 d2 d3))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (*.f64 d1 (+.f64 d2 d3)) (/.f64 1 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3)))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 1 (*.f64 d1 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (+.f64 d2 d3) d1)
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (+.f64 d2 d3) (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 1 d1) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 1 d1) (+.f64 (*.f64 d2 (*.f64 d1 d1)) (*.f64 d1 (*.f64 d1 d3))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (*.f64 d1 d1) (*.f64 (+.f64 d2 d3) (/.f64 1 d1)))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (/.f64 1 (*.f64 d1 (+.f64 d2 d3))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) (/.f64 1 d1))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 1 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3)))) (*.f64 d1 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 1 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3)))) (*.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))) (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 1 (+.f64 d2 d3)) (*.f64 d1 (*.f64 (+.f64 d2 d3) (+.f64 d2 d3))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 (*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 (/.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))) (*.f64 (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 (/.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 (/.f64 (*.f64 d1 (*.f64 (/.f64 1 (*.f64 d1 (+.f64 d2 d3))) (+.f64 d2 d3))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))) (*.f64 (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 (*.f64 d1 (+.f64 d2 d3)) d1) d1)
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (/.f64 (/.f64 1 (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3)))) (*.f64 d1 (+.f64 d2 d3))) (*.f64 (+.f64 d2 d3) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))
(*.f64 d1 (+.f64 d2 d3))
(/.f64 (*.f64 d1 (+.f64 d2 d3)) 1)
(*.f64 d1 (+.f64 d2 d3))
(/.f64 (*.f64 d1 (+.f64 d2 d3)) (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))))
(*.f64 d1 (+.f64 d2 d3))
(/.f64 (*.f64 (+.f64 d2 d3) (+.f64 d1 d1)) 2)
(*.f64 d1 (+.f64 d2 d3))
(/.f64 (neg.f64 (*.f64 (+.f64 d2 d3) (+.f64 d1 d1))) -2)
(*.f64 d1 (+.f64 d2 d3))
(pow.f64 (*.f64 d1 (+.f64 d2 d3)) 1)
(*.f64 d1 (+.f64 d2 d3))
(neg.f64 (neg.f64 (*.f64 d1 (+.f64 d2 d3))))
(*.f64 d1 (+.f64 d2 d3))

eval56.0ms (1.1%)

Compiler

Compiled 862 to 162 computations (81.2% saved)

prune9.0ms (0.2%)

Pruning

5 alts after pruning (3 fresh and 2 done)

PrunedKeptTotal
New52355
Fresh000
Picked011
Done011
Total52557
Error
0b
Counts
57 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
28.8b
(*.f64 (/.f64 1 d1) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))
34.1b
(*.f64 d2 d1)
0.0b
(*.f64 d1 (+.f64 d3 d2))
27.6b
(*.f64 d1 d3)
Compiler

Compiled 44 to 28 computations (36.4% saved)

localize151.0ms (2.9%)

Compiler

Compiled 8 to 4 computations (50% saved)

localize3.0ms (0.1%)

Compiler

Compiled 8 to 4 computations (50% saved)

localize10.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
12.4b
(*.f64 (+.f64 d2 d3) (*.f64 d1 d1))
15.4b
(*.f64 (/.f64 1 d1) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))
Compiler

Compiled 34 to 12 computations (64.7% saved)

series3.0ms (0.1%)

Counts
2 → 72
Calls

18 calls:

TimeVariablePointExpression
0.0ms
d1
@0
(*.f64 (+.f64 d2 d3) (*.f64 d1 d1))
0.0ms
d2
@0
(*.f64 (+.f64 d2 d3) (*.f64 d1 d1))
0.0ms
d3
@0
(*.f64 (+.f64 d2 d3) (*.f64 d1 d1))
0.0ms
d1
@inf
(*.f64 (+.f64 d2 d3) (*.f64 d1 d1))
0.0ms
d2
@-inf
(*.f64 (+.f64 d2 d3) (*.f64 d1 d1))

rewrite221.0ms (4.2%)

Algorithm
batch-egg-rewrite
Rules
1040×rational_best.json-simplify-54
850×rational_best.json-simplify-47
730×rational_best.json-5
728×rational_best.json-2
728×rational_best.json-3
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01150
19632
233132
3144232
4788932
Stop Event
node limit
Counts
2 → 14
Calls
Call 1
Inputs
(*.f64 (/.f64 1 d1) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))
(*.f64 (+.f64 d2 d3) (*.f64 d1 d1))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 (+.f64 d2 d3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 d1 (+.f64 d2 d3)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 d2 d3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 d2 d3)) (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 (+.f64 d2 d3) 2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 d2 d3)) 1)))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) (/.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (*.f64 d1 (*.f64 (+.f64 d2 d3) 2))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) 1)))))

simplify189.0ms (3.6%)

Algorithm
egg-herbie
Rules
1498×rational_best.json-simplify-80
1384×rational_best.json-simplify-2
1132×rational_best.json-simplify-78
808×rational_best.json-simplify-47
782×rational_best.json-simplify-82
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0391664
1691304
21461304
34141304
421581304
551561304
676401304
Stop Event
node limit
Counts
86 → 27
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d2 d1)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d2 d1)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d2 d1)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 (pow.f64 d1 2) d3)
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(*.f64 d2 (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(*.f64 d2 (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(*.f64 d2 (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(*.f64 (pow.f64 d1 2) d3)
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(*.f64 (pow.f64 d1 2) d3)
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d1 (+.f64 d2 d3)) 0)
(+.f64 0 (*.f64 d1 (+.f64 d2 d3)))
(-.f64 (*.f64 d1 (+.f64 d2 d3)) 0)
(/.f64 (*.f64 d1 (+.f64 d2 d3)) 1)
(/.f64 (*.f64 d1 (+.f64 d2 d3)) (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))))
(/.f64 (*.f64 d1 (*.f64 (+.f64 d2 d3) 2)) 2)
(pow.f64 (*.f64 d1 (+.f64 d2 d3)) 1)
(+.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) 0)
(+.f64 0 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))
(-.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) 0)
(/.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) 1)
(/.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) (/.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))
(/.f64 (*.f64 d1 (*.f64 d1 (*.f64 (+.f64 d2 d3) 2))) 2)
(pow.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) 1)
Outputs
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 (pow.f64 d1 2) d3)
(*.f64 d3 (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 d2 (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 d2 (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 d2 (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) d3)
(*.f64 d3 (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) d3)
(*.f64 d3 (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d2 (pow.f64 d1 2)) (*.f64 (pow.f64 d1 2) d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(*.f64 (pow.f64 d1 2) (+.f64 d2 d3))
(+.f64 (*.f64 d3 (pow.f64 d1 2)) (*.f64 d2 (pow.f64 d1 2)))
(*.f64 (+.f64 d2 d3) (pow.f64 d1 2))
(+.f64 (*.f64 d1 (+.f64 d2 d3)) 0)
(*.f64 d1 (+.f64 d2 d3))
(+.f64 0 (*.f64 d1 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 d3))
(-.f64 (*.f64 d1 (+.f64 d2 d3)) 0)
(*.f64 d1 (+.f64 d2 d3))
(/.f64 (*.f64 d1 (+.f64 d2 d3)) 1)
(*.f64 d1 (+.f64 d2 d3))
(/.f64 (*.f64 d1 (+.f64 d2 d3)) (/.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 (+.f64 d2 d3))))
(*.f64 d1 (+.f64 d2 d3))
(/.f64 (*.f64 d1 (*.f64 (+.f64 d2 d3) 2)) 2)
(*.f64 d1 (+.f64 d2 d3))
(pow.f64 (*.f64 d1 (+.f64 d2 d3)) 1)
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) 0)
(*.f64 d1 (*.f64 d1 (+.f64 d2 d3)))
(+.f64 0 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))
(*.f64 d1 (*.f64 d1 (+.f64 d2 d3)))
(-.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) 0)
(*.f64 d1 (*.f64 d1 (+.f64 d2 d3)))
(/.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) 1)
(*.f64 d1 (*.f64 d1 (+.f64 d2 d3)))
(/.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) (/.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1))))
(*.f64 d1 (*.f64 d1 (+.f64 d2 d3)))
(/.f64 (*.f64 d1 (*.f64 d1 (*.f64 (+.f64 d2 d3) 2))) 2)
(*.f64 d1 (*.f64 d1 (+.f64 d2 d3)))
(pow.f64 (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)) 1)
(*.f64 d1 (*.f64 d1 (+.f64 d2 d3)))

eval68.0ms (1.3%)

Compiler

Compiled 282 to 121 computations (57.1% saved)

prune5.0ms (0.1%)

Pruning

5 alts after pruning (0 fresh and 5 done)

PrunedKeptTotal
New27027
Fresh000
Picked011
Done044
Total27532
Error
0b
Counts
32 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
28.8b
(*.f64 (/.f64 1 d1) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))
34.1b
(*.f64 d2 d1)
0.0b
(*.f64 d1 (+.f64 d3 d2))
27.6b
(*.f64 d1 d3)
Compiler

Compiled 44 to 28 computations (36.4% saved)

regimes79.0ms (1.5%)

Counts
5 → 1
Calls
Call 1
Inputs
(*.f64 d1 d3)
(*.f64 d2 d1)
(*.f64 d1 (+.f64 d3 d2))
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
(*.f64 (/.f64 1 d1) (*.f64 (+.f64 d2 d3) (*.f64 d1 d1)))
Outputs
(*.f64 d1 (+.f64 d3 d2))
Calls

4 calls:

65.0ms
d3
4.0ms
(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
4.0ms
d2
4.0ms
d1
Results
ErrorSegmentsBranch
0.0b1d1
0.0b1d2
0.0b1d3
0.0b1(+.f64 (*.f64 d1 d2) (*.f64 d1 d3))
Compiler

Compiled 54 to 30 computations (44.4% saved)

regimes288.0ms (5.5%)

Accuracy

Total -49.3b remaining (-469.3%)

Threshold costs -49.3b (-469.3%)

Counts
2 → 2
Calls
Call 1
Inputs
(*.f64 d1 d3)
(*.f64 d2 d1)
Outputs
(*.f64 d2 d1)
(*.f64 d1 d3)
Calls

3 calls:

128.0ms
d2
124.0ms
d3
36.0ms
d1
Results
ErrorSegmentsBranch
20.8b8d1
11.0b6d2
10.5b2d3
Compiler

Compiled 21 to 14 computations (33.3% saved)

bsearch84.0ms (1.6%)

Algorithm
binary-search
Steps
TimeLeftRight
84.0ms
2.4913431891873104e-85
5.137477452122068e-83
Results
83.0ms112×body256valid
Compiler

Compiled 114 to 81 computations (28.9% saved)

simplify2.0ms (0%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01543
Stop Event
done
saturated
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 d3 d2))
(if (<=.f64 d3 2734063405978765/68351585149469122636640694597425667667286544715412888638305331450311031224980497600734786781970432) (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
Outputs
(*.f64 d1 (+.f64 d3 d2))
(if (<=.f64 d3 2734063405978765/68351585149469122636640694597425667667286544715412888638305331450311031224980497600734786781970432) (*.f64 d2 d1) (*.f64 d1 d3))
(*.f64 d1 d3)
Compiler

Compiled 27 to 17 computations (37% saved)

soundness14.0ms (0.3%)

Algorithm
egg-herbie
Rules
rational_best.json-simplify-2
rational_best.json-simplify-1
rational_best.json-simplify-47
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0813
11313
21513
Stop Event
saturated
Compiler

Compiled 15 to 8 computations (46.7% saved)

end97.0ms (1.9%)

Remove

(sort d2 d3)

Compiler

Compiled 37 to 20 computations (45.9% saved)

Profiling

Loading profile data...