Details

Time bar (total: 1.9s)

analyze0.0ms (0%)

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

Compiled 42 to 30 computations (28.6% saved)

sample1.5s (79.7%)

Results
1.5s8256×body256valid
Bogosity

preprocess8.0ms (0.4%)

Algorithm
egg-herbie
Rules
36×rational_best-simplify-1
16×rational_best-simplify-43
14×rational_best-simplify-2
swap-b-d
swap-b-c
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
026133
143133
250133
357133
044
144
Stop Event
unsound
saturated
Calls
Call 1
Inputs
0
1
2
3
Outputs
0
1
2
1
3
1
Call 2
Inputs
(*.f64 a (+.f64 (+.f64 b c) d))
(*.f64 b (+.f64 (+.f64 a c) d))
(*.f64 c (+.f64 (+.f64 b a) d))
(*.f64 d (+.f64 (+.f64 b c) a))
(*.f64 a (+.f64 (+.f64 c b) d))
(*.f64 a (+.f64 (+.f64 d c) b))
(*.f64 a (+.f64 (+.f64 b d) c))
Outputs
(*.f64 a (+.f64 (+.f64 b c) d))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 b (+.f64 (+.f64 a c) d))
(*.f64 b (+.f64 d (+.f64 a c)))
(*.f64 b (+.f64 a (+.f64 c d)))
(*.f64 c (+.f64 (+.f64 b a) d))
(*.f64 c (+.f64 d (+.f64 a b)))
(*.f64 c (+.f64 a (+.f64 b d)))
(*.f64 d (+.f64 (+.f64 b c) a))
(*.f64 d (+.f64 a (+.f64 b c)))
(*.f64 a (+.f64 (+.f64 c b) d))
(*.f64 a (+.f64 (+.f64 b c) d))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 (+.f64 d c) b))
(*.f64 a (+.f64 (+.f64 b c) d))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 (+.f64 b d) c))
(*.f64 a (+.f64 (+.f64 b c) d))
(*.f64 a (+.f64 b (+.f64 c d)))
Symmetry

(sort b c d)

Compiler

Compiled 15 to 11 computations (26.7% saved)

simplify10.0ms (0.6%)

Algorithm
egg-herbie
Rules
12×rational_best-simplify-1
rational_best-simplify-43
rational_best-simplify-2
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0919
11219
21619
32019
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(*.f64 a (+.f64 (+.f64 b c) d))
Outputs
(*.f64 a (+.f64 (+.f64 b c) d))
(*.f64 a (+.f64 b (+.f64 c d)))

eval0.0ms (0%)

Compiler

Compiled 18 to 10 computations (44.4% saved)

prune1.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New112
Fresh011
Picked000
Done000
Total123
Error
0.1b
Counts
3 → 1
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(*.f64 a (+.f64 (+.f64 b c) d))
Compiler

Compiled 11 to 7 computations (36.4% saved)

localize7.0ms (0.4%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(*.f64 a (+.f64 (+.f64 b c) d))
Compiler

Compiled 23 to 7 computations (69.6% saved)

series4.0ms (0.2%)

Counts
1 → 48
Calls

12 calls:

TimeVariablePointExpression
0.0ms
b
@-inf
(*.f64 a (+.f64 (+.f64 b c) d))
0.0ms
a
@-inf
(*.f64 a (+.f64 (+.f64 b c) d))
0.0ms
a
@0
(*.f64 a (+.f64 (+.f64 b c) d))
0.0ms
a
@inf
(*.f64 a (+.f64 (+.f64 b c) d))
0.0ms
b
@inf
(*.f64 a (+.f64 (+.f64 b c) d))

rewrite14.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
30×rational_best-simplify-1
24×rational_best-simplify-2
22×rational_best-4
22×rational_best-2
22×rational_best-3
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0919
15919
29119
310719
410919
Stop Event
saturated
Counts
1 → 5
Calls
Call 1
Inputs
(*.f64 a (+.f64 (+.f64 b c) d))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 a (+.f64 c (+.f64 b d))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 a (+.f64 c (+.f64 b d))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 a (+.f64 c (+.f64 b d))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 a (+.f64 c (+.f64 b d))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 a (+.f64 c (+.f64 b d))) 1)))))

simplify22.0ms (1.2%)

Algorithm
egg-herbie
Rules
48×rational_best-simplify-1
30×rational_best-simplify-7
24×rational_best-simplify-2
24×rational_best-simplify-54
16×rational_best-simplify-43
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
032917
153917
268917
3103917
4113917
Stop Event
saturated
Counts
53 → 19
Calls
Call 1
Inputs
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 c d))
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 (+.f64 c d) a))
(+.f64 (*.f64 a b) (*.f64 (+.f64 c d) a))
(+.f64 (*.f64 a b) (*.f64 (+.f64 c d) a))
(*.f64 (+.f64 d b) a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 c a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 c a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 a d)
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 a d)
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(+.f64 (*.f64 a (+.f64 c (+.f64 b d))) 0)
(+.f64 0 (*.f64 a (+.f64 c (+.f64 b d))))
(-.f64 (*.f64 a (+.f64 c (+.f64 b d))) 0)
(/.f64 (*.f64 a (+.f64 c (+.f64 b d))) 1)
(pow.f64 (*.f64 a (+.f64 c (+.f64 b d))) 1)
Outputs
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 a (+.f64 c d))
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 a b)
(*.f64 b a)
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 a b)
(*.f64 b a)
(+.f64 (*.f64 a b) (*.f64 (+.f64 c d) a))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a b) (*.f64 (+.f64 c d) a))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a b) (*.f64 (+.f64 c d) a))
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 (+.f64 d b) a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 c a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 c a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 a d)
(*.f64 d a)
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 a (+.f64 d (+.f64 c b)))
(*.f64 a d)
(*.f64 d a)
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 (*.f64 a (+.f64 c (+.f64 b d))) 0)
(*.f64 a (+.f64 d (+.f64 c b)))
(+.f64 0 (*.f64 a (+.f64 c (+.f64 b d))))
(*.f64 a (+.f64 d (+.f64 c b)))
(-.f64 (*.f64 a (+.f64 c (+.f64 b d))) 0)
(*.f64 a (+.f64 d (+.f64 c b)))
(/.f64 (*.f64 a (+.f64 c (+.f64 b d))) 1)
(*.f64 a (+.f64 d (+.f64 c b)))
(pow.f64 (*.f64 a (+.f64 c (+.f64 b d))) 1)
(*.f64 a (+.f64 d (+.f64 c b)))

eval2.0ms (0.1%)

Compiler

Compiled 129 to 37 computations (71.3% saved)

prune4.0ms (0.2%)

Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New16319
Fresh000
Picked011
Done000
Total16420
Error
0.0b
Counts
20 → 4
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
4.1b
(*.f64 d a)
0.1b
(*.f64 a (+.f64 (+.f64 b c) d))
0.2b
(*.f64 a (+.f64 c d))
Compiler

Compiled 40 to 26 computations (35% saved)

localize6.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(*.f64 a (+.f64 c d))
Compiler

Compiled 15 to 6 computations (60% saved)

series2.0ms (0.1%)

Counts
1 → 36
Calls

9 calls:

TimeVariablePointExpression
1.0ms
a
@inf
(*.f64 a (+.f64 c d))
0.0ms
a
@0
(*.f64 a (+.f64 c d))
0.0ms
a
@-inf
(*.f64 a (+.f64 c d))
0.0ms
c
@inf
(*.f64 a (+.f64 c d))
0.0ms
c
@-inf
(*.f64 a (+.f64 c d))

rewrite12.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
16×rational_best-simplify-2
16×rational_best-simplify-1
14×rational_best-4
14×rational_best-2
14×rational_best-3
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0713
14613
27013
Stop Event
saturated
Counts
1 → 5
Calls
Call 1
Inputs
(*.f64 a (+.f64 c d))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 a (+.f64 c d)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 a (+.f64 c d)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 a (+.f64 c d)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 a (+.f64 c d)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 a (+.f64 c d)) 1)))))

simplify17.0ms (0.9%)

Algorithm
egg-herbie
Rules
14×rational_best-simplify-1
14×rational_best-simplify-7
10×rational_best-simplify-2
rational_best-simplify-54
rational_best-simplify-4
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
019497
124497
230497
343497
447497
Stop Event
saturated
Counts
41 → 11
Calls
Call 1
Inputs
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 a d)
(+.f64 (*.f64 c a) (*.f64 a d))
(+.f64 (*.f64 c a) (*.f64 a d))
(+.f64 (*.f64 c a) (*.f64 a d))
(*.f64 c a)
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 c a)
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 c a)
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 a d)
(+.f64 (*.f64 c a) (*.f64 a d))
(+.f64 (*.f64 c a) (*.f64 a d))
(+.f64 (*.f64 c a) (*.f64 a d))
(*.f64 a d)
(+.f64 (*.f64 c a) (*.f64 a d))
(+.f64 (*.f64 c a) (*.f64 a d))
(+.f64 (*.f64 c a) (*.f64 a d))
(+.f64 (*.f64 a (+.f64 c d)) 0)
(+.f64 0 (*.f64 a (+.f64 c d)))
(-.f64 (*.f64 a (+.f64 c d)) 0)
(/.f64 (*.f64 a (+.f64 c d)) 1)
(pow.f64 (*.f64 a (+.f64 c d)) 1)
Outputs
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 a d)
(*.f64 d a)
(+.f64 (*.f64 c a) (*.f64 a d))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 c a) (*.f64 a d))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 c a) (*.f64 a d))
(*.f64 (+.f64 c d) a)
(*.f64 c a)
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 (+.f64 c d) a)
(*.f64 c a)
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 (+.f64 c d) a)
(*.f64 c a)
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 (+.f64 c d) a)
(*.f64 a d)
(*.f64 d a)
(+.f64 (*.f64 c a) (*.f64 a d))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 c a) (*.f64 a d))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 c a) (*.f64 a d))
(*.f64 (+.f64 c d) a)
(*.f64 a d)
(*.f64 d a)
(+.f64 (*.f64 c a) (*.f64 a d))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 c a) (*.f64 a d))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 c a) (*.f64 a d))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a (+.f64 c d)) 0)
(*.f64 (+.f64 c d) a)
(+.f64 0 (*.f64 a (+.f64 c d)))
(*.f64 (+.f64 c d) a)
(-.f64 (*.f64 a (+.f64 c d)) 0)
(*.f64 (+.f64 c d) a)
(/.f64 (*.f64 a (+.f64 c d)) 1)
(*.f64 (+.f64 c d) a)
(pow.f64 (*.f64 a (+.f64 c d)) 1)
(*.f64 (+.f64 c d) a)

localize3.0ms (0.2%)

Compiler

Compiled 9 to 5 computations (44.4% saved)

localize8.0ms (0.5%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(*.f64 (+.f64 d b) a)
0.0b
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
Compiler

Compiled 28 to 8 computations (71.4% saved)

series6.0ms (0.3%)

Counts
2 → 63
Calls

21 calls:

TimeVariablePointExpression
1.0ms
a
@-inf
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
1.0ms
c
@inf
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
1.0ms
a
@inf
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
0.0ms
a
@0
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
0.0ms
d
@0
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))

rewrite14.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
34×rational_best-simplify-1
32×rational_best-simplify-2
28×rational_best-4
28×rational_best-2
28×rational_best-3
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01038
16632
210032
311632
413332
513532
Stop Event
saturated
Counts
2 → 12
Calls
Call 1
Inputs
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 (+.f64 d b) a)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 a (+.f64 d (+.f64 b c))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 a (+.f64 d (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 a (+.f64 d (+.f64 b c))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 a (+.f64 d (+.f64 b c))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d (+.f64 b c)) a)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 a (+.f64 d (+.f64 b c))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 a (+.f64 d (+.f64 b c))) 1)))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (+.f64 d b) a) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (+.f64 d b) a))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (+.f64 d b) a) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 d b) a) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (+.f64 d b) a) 1)))))

simplify53.0ms (2.8%)

Algorithm
egg-herbie
Rules
246×rational_best-simplify-2
164×rational_best-simplify-46
136×rational_best-simplify-54
130×rational_best-simplify-1
102×rational_best-simplify-49
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0411359
1761125
21241125
31821125
42601125
53961125
66491125
77441125
87641125
97741125
Stop Event
saturated
Counts
75 → 31
Calls
Call 1
Inputs
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (+.f64 (*.f64 a d) (*.f64 c a)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 a d) (*.f64 c a)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 a d) (*.f64 c a)))
(*.f64 a d)
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(*.f64 a d)
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(*.f64 a b)
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(*.f64 a b)
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 -1 (*.f64 a (+.f64 (*.f64 -1 c) (*.f64 -1 (+.f64 d b)))))
(*.f64 -1 (*.f64 a (+.f64 (*.f64 -1 c) (*.f64 -1 (+.f64 d b)))))
(*.f64 -1 (*.f64 a (+.f64 (*.f64 -1 c) (*.f64 -1 (+.f64 d b)))))
(*.f64 -1 (*.f64 a (+.f64 (*.f64 -1 c) (*.f64 -1 (+.f64 d b)))))
(*.f64 (+.f64 d b) a)
(*.f64 c a)
(*.f64 c a)
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 a d))
(+.f64 (*.f64 a b) (*.f64 a d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a d)
(+.f64 (*.f64 a b) (*.f64 a d))
(+.f64 (*.f64 a b) (*.f64 a d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a d)
(+.f64 (*.f64 a b) (*.f64 a d))
(+.f64 (*.f64 a b) (*.f64 a d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a d)
(+.f64 (*.f64 a b) (*.f64 a d))
(+.f64 (*.f64 a b) (*.f64 a d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 a d))
(+.f64 (*.f64 a b) (*.f64 a d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 a d))
(+.f64 (*.f64 a b) (*.f64 a d))
(+.f64 (*.f64 a b) (*.f64 a d))
(-.f64 (*.f64 a (+.f64 d (+.f64 b c))) 0)
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 (*.f64 a (+.f64 d (+.f64 b c))) 1)
(*.f64 1 (*.f64 a (+.f64 d (+.f64 b c))))
(*.f64 (+.f64 d (+.f64 b c)) a)
(/.f64 (*.f64 a (+.f64 d (+.f64 b c))) 1)
(pow.f64 (*.f64 a (+.f64 d (+.f64 b c))) 1)
(+.f64 (*.f64 (+.f64 d b) a) 0)
(+.f64 0 (*.f64 (+.f64 d b) a))
(-.f64 (*.f64 (+.f64 d b) a) 0)
(/.f64 (*.f64 (+.f64 d b) a) 1)
(pow.f64 (*.f64 (+.f64 d b) a) 1)
Outputs
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 a c))
(*.f64 a (+.f64 b c))
(+.f64 (*.f64 a b) (+.f64 (*.f64 a d) (*.f64 c a)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 a d) (*.f64 c a)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 a d) (*.f64 c a)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 a d)
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 a d)
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a c) (*.f64 a d))
(*.f64 a (+.f64 c d))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 a b)
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 a b)
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 c a) (*.f64 a d)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 -1 (*.f64 a (+.f64 (*.f64 -1 c) (*.f64 -1 (+.f64 d b)))))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 -1 (*.f64 a (+.f64 (*.f64 -1 c) (*.f64 -1 (+.f64 d b)))))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 -1 (*.f64 a (+.f64 (*.f64 -1 c) (*.f64 -1 (+.f64 d b)))))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 -1 (*.f64 a (+.f64 (*.f64 -1 c) (*.f64 -1 (+.f64 d b)))))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 (+.f64 d b) a)
(*.f64 a (+.f64 b d))
(*.f64 c a)
(*.f64 a c)
(*.f64 c a)
(*.f64 a c)
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(*.f64 a d)
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(*.f64 a d)
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(*.f64 a d)
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(+.f64 (*.f64 a b) (*.f64 a d))
(*.f64 a (+.f64 b d))
(-.f64 (*.f64 a (+.f64 d (+.f64 b c))) 0)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 (*.f64 a (+.f64 d (+.f64 b c))) 1)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 1 (*.f64 a (+.f64 d (+.f64 b c))))
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(*.f64 (+.f64 d (+.f64 b c)) a)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(/.f64 (*.f64 a (+.f64 d (+.f64 b c))) 1)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(pow.f64 (*.f64 a (+.f64 d (+.f64 b c))) 1)
(+.f64 (*.f64 a c) (*.f64 a (+.f64 b d)))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 d (+.f64 b c)))
(+.f64 (*.f64 (+.f64 d b) a) 0)
(*.f64 a (+.f64 b d))
(+.f64 0 (*.f64 (+.f64 d b) a))
(*.f64 a (+.f64 b d))
(-.f64 (*.f64 (+.f64 d b) a) 0)
(*.f64 a (+.f64 b d))
(/.f64 (*.f64 (+.f64 d b) a) 1)
(*.f64 a (+.f64 b d))
(pow.f64 (*.f64 (+.f64 d b) a) 1)
(*.f64 a (+.f64 b d))

eval5.0ms (0.2%)

Compiler

Compiled 310 to 78 computations (74.8% saved)

prune6.0ms (0.3%)

Pruning

4 alts after pruning (1 fresh and 3 done)

PrunedKeptTotal
New41142
Fresh000
Picked101
Done033
Total42446
Error
0.0b
Counts
46 → 4
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(+.f64 (*.f64 c a) (*.f64 a d))
4.1b
(*.f64 d a)
0.1b
(*.f64 a (+.f64 (+.f64 b c) d))
0.2b
(*.f64 a (+.f64 c d))
Compiler

Compiled 38 to 25 computations (34.2% saved)

localize7.0ms (0.4%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(+.f64 (*.f64 c a) (*.f64 a d))
Compiler

Compiled 20 to 7 computations (65% saved)

series2.0ms (0.1%)

Counts
1 → 27
Calls

9 calls:

TimeVariablePointExpression
0.0ms
a
@0
(+.f64 (*.f64 c a) (*.f64 a d))
0.0ms
a
@-inf
(+.f64 (*.f64 c a) (*.f64 a d))
0.0ms
c
@0
(+.f64 (*.f64 c a) (*.f64 a d))
0.0ms
d
@0
(+.f64 (*.f64 c a) (*.f64 a d))
0.0ms
d
@inf
(+.f64 (*.f64 c a) (*.f64 a d))

rewrite13.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
24×rational_best-simplify-2
20×rational_best-4
20×rational_best-2
20×rational_best-3
20×rational_best-1
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0819
15313
28313
39513
49613
Stop Event
saturated
Counts
1 → 7
Calls
Call 1
Inputs
(+.f64 (*.f64 c a) (*.f64 a d))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 a (+.f64 c d)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 a (+.f64 c d))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 a (+.f64 c d)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 a (+.f64 c d)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 c d) a)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 a (+.f64 c d)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 a (+.f64 c d)) 1)))))

simplify28.0ms (1.5%)

Algorithm
egg-herbie
Rules
110×rational_best-simplify-2
70×rational_best-simplify-46
42×rational_best-simplify-49
40×rational_best-simplify-1
26×rational_best-simplify-44
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
024574
144406
268406
3100406
4138406
5183406
6232406
7264406
8272406
9276406
Stop Event
saturated
Counts
34 → 14
Calls
Call 1
Inputs
(*.f64 a d)
(*.f64 c a)
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 c a)
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 (+.f64 c d) a)
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 c) (*.f64 -1 d)) a))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 c) (*.f64 -1 d)) a))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 c) (*.f64 -1 d)) a))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 c) (*.f64 -1 d)) a))
(*.f64 c a)
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 c a))
(*.f64 a d)
(*.f64 a d)
(-.f64 (*.f64 a (+.f64 c d)) 0)
(*.f64 a (+.f64 c d))
(*.f64 (*.f64 a (+.f64 c d)) 1)
(*.f64 1 (*.f64 a (+.f64 c d)))
(*.f64 (+.f64 c d) a)
(/.f64 (*.f64 a (+.f64 c d)) 1)
(pow.f64 (*.f64 a (+.f64 c d)) 1)
Outputs
(*.f64 a d)
(*.f64 c a)
(*.f64 a c)
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 c a)
(*.f64 a c)
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 c) (*.f64 -1 d)) a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 c) (*.f64 -1 d)) a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 c) (*.f64 -1 d)) a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 -1 (*.f64 (+.f64 (*.f64 -1 c) (*.f64 -1 d)) a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 c a)
(*.f64 a c)
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(+.f64 (*.f64 a d) (*.f64 c a))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 a d)
(*.f64 a d)
(-.f64 (*.f64 a (+.f64 c d)) 0)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 a (+.f64 c d))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 (*.f64 a (+.f64 c d)) 1)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 1 (*.f64 a (+.f64 c d)))
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(*.f64 (+.f64 c d) a)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(/.f64 (*.f64 a (+.f64 c d)) 1)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))
(pow.f64 (*.f64 a (+.f64 c d)) 1)
(+.f64 (*.f64 a d) (*.f64 a c))
(*.f64 a (+.f64 d c))

eval2.0ms (0.1%)

Compiler

Compiled 88 to 32 computations (63.6% saved)

prune3.0ms (0.2%)

Pruning

4 alts after pruning (0 fresh and 4 done)

PrunedKeptTotal
New14014
Fresh000
Picked011
Done033
Total14418
Error
0.0b
Counts
18 → 4
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(+.f64 (*.f64 c a) (*.f64 a d))
4.1b
(*.f64 d a)
0.1b
(*.f64 a (+.f64 (+.f64 b c) d))
0.2b
(*.f64 a (+.f64 c d))
Compiler

Compiled 38 to 25 computations (34.2% saved)

regimes34.0ms (1.8%)

Counts
5 → 1
Calls
Call 1
Inputs
(*.f64 d a)
(*.f64 a (+.f64 c d))
(*.f64 a (+.f64 (+.f64 b c) d))
(+.f64 (*.f64 c a) (*.f64 a d))
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
Outputs
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
Calls

7 calls:

6.0ms
(+.f64 (+.f64 b c) d)
5.0ms
b
5.0ms
d
4.0ms
(*.f64 a (+.f64 (+.f64 b c) d))
4.0ms
(+.f64 b c)
Results
ErrorSegmentsBranch
0.1b1a
0.1b1b
0.1b1c
0.1b1d
0.1b1(*.f64 a (+.f64 (+.f64 b c) d))
0.1b1(+.f64 (+.f64 b c) d)
0.1b1(+.f64 b c)
Compiler

Compiled 82 to 50 computations (39% saved)

regimes30.0ms (1.6%)

Counts
4 → 1
Calls
Call 1
Inputs
(*.f64 d a)
(*.f64 a (+.f64 c d))
(*.f64 a (+.f64 (+.f64 b c) d))
(+.f64 (*.f64 c a) (*.f64 a d))
Outputs
(*.f64 a (+.f64 (+.f64 b c) d))
Calls

7 calls:

5.0ms
(+.f64 b c)
4.0ms
a
4.0ms
(*.f64 a (+.f64 (+.f64 b c) d))
4.0ms
c
4.0ms
(+.f64 (+.f64 b c) d)
Results
ErrorSegmentsBranch
0.1b1a
0.1b1b
0.1b1c
0.1b1d
0.1b1(*.f64 a (+.f64 (+.f64 b c) d))
0.1b1(+.f64 (+.f64 b c) d)
0.1b1(+.f64 b c)
Compiler

Compiled 73 to 47 computations (35.6% saved)

regimes13.0ms (0.7%)

Accuracy

Total -3.9b remaining (-2339.2%)

Threshold costs -3.9b (-2339.2%)

Counts
2 → 1
Calls
Call 1
Inputs
(*.f64 d a)
(*.f64 a (+.f64 c d))
Outputs
(*.f64 a (+.f64 c d))
Calls

4 calls:

4.0ms
b
3.0ms
c
3.0ms
a
3.0ms
d
Results
ErrorSegmentsBranch
0.2b1a
0.2b1b
0.2b1c
0.2b1d
Compiler

Compiled 32 to 23 computations (28.1% saved)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01664
Stop Event
done
saturated
Calls
Call 1
Inputs
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 a (+.f64 (+.f64 b c) d))
(*.f64 a (+.f64 c d))
(*.f64 d a)
Outputs
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 a (+.f64 (+.f64 b c) d))
(*.f64 a (+.f64 c d))
(*.f64 d a)
Compiler

Compiled 40 to 26 computations (35% saved)

soundness0.0ms (0%)

end41.0ms (2.2%)

Compiler

Compiled 54 to 30 computations (44.4% saved)

Profiling

Loading profile data...