Details

Time bar (total: 1.6s)

analyze0.0ms (0%)

Algorithm
search
Search
TrueOtherFalseIter
0%0%100%0
0%0%100%1
Compiler

Compiled 42 to 30 computations (28.6% saved)

sample1.1s (73%)

Results
1.1s8256×body128valid

preprocess22.0ms (1.4%)

Algorithm
egg-herbie
Rules
116×fma-def_binary64
43×distribute-rgt-in_binary64
39×distribute-lft-in_binary64
25×*-commutative_binary64
17×+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02570
18870
218470
328970
434370
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 a (+.f64 c d)))
(*.f64 c (+.f64 (+.f64 b a) d))
(*.f64 c (+.f64 d (+.f64 a b)))
(*.f64 d (+.f64 (+.f64 b c) a))
(*.f64 d (+.f64 a (+.f64 b c)))
(*.f64 a (+.f64 (+.f64 c b) d))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 (+.f64 d c) b))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 (+.f64 b d) c))
(*.f64 a (+.f64 b (+.f64 c d)))
Symmetry

(sort b c d)

Compiler

Compiled 11 to 7 computations (36.4% saved)

simplify7.0ms (0.4%)

Algorithm
egg-herbie
Rules
28×fma-def_binary64
10×distribute-lft-in_binary64
10×distribute-rgt-in_binary64
*-commutative_binary64
+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0810
11910
24510
38510
410310
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)))

prune4.0ms (0.2%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New112
Fresh011
Picked000
Done000
Total123
Error
0.0b
Counts
3 → 1
Alt Table
StatusErrorProgram
0.0b
(*.f64 a (+.f64 (+.f64 b c) d))
Compiler

Compiled 40 to 24 computations (40% saved)

localize5.0ms (0.3%)

Local error

Found 1 expressions with local error:

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

series7.0ms (0.4%)

Counts
1 → 48
Calls

12 calls:

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

rewrite47.0ms (3%)

Algorithm
batch-egg-rewrite
Rules
475×log-prod_binary64
462×fma-def_binary64
218×fma-neg_binary64
176×expm1-udef_binary64
176×log1p-udef_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0810
118510
2288510
Stop Event
node limit
Counts
1 → 63
Calls
Call 1
Inputs
(*.f64 a (+.f64 (+.f64 b c) d))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 a (+.f64 b c)) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 a d) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 a (+.f64 b (+.f64 c d))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 b a) (*.f64 (+.f64 c d) a))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 a (+.f64 b c)) 1) (*.f64 (*.f64 a d) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 a) (+.f64 b (+.f64 c d)))) (cbrt.f64 (pow.f64 (exp.f64 a) (+.f64 b (+.f64 c d)))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 a) (+.f64 b (+.f64 c d))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 a) (+.f64 b (+.f64 c d))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 a) (+.f64 b (+.f64 c d))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 a (+.f64 b (+.f64 c d))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 a (+.f64 b c)) 3) (pow.f64 (*.f64 a d) 3)) (fma.f64 (*.f64 a (+.f64 b c)) (*.f64 a (+.f64 b c)) (-.f64 (*.f64 (*.f64 a d) (*.f64 a d)) (*.f64 (*.f64 a (+.f64 b c)) (*.f64 a d)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 (*.f64 a (+.f64 b c)) (*.f64 a (+.f64 b c)) (neg.f64 (*.f64 (*.f64 a d) (*.f64 a d)))) (fma.f64 a (+.f64 b c) (neg.f64 (*.f64 a d))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3)) a) (fma.f64 d (-.f64 d (+.f64 b c)) (pow.f64 (+.f64 b c) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d)) a) (+.f64 b (-.f64 c d)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 a (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3))) (fma.f64 d (-.f64 d (+.f64 b c)) (pow.f64 (+.f64 b c) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 a (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d))) (+.f64 b (-.f64 c d)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 a (+.f64 b (+.f64 c d))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 a (+.f64 b (+.f64 c d))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 a (+.f64 b (+.f64 c d)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 a (+.f64 b (+.f64 c d)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 a (+.f64 b (+.f64 c d))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 a) (+.f64 b (+.f64 c d))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 a (+.f64 b (+.f64 c d))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (*.f64 a d)) (exp.f64 (*.f64 a (+.f64 b c)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 a (+.f64 b (+.f64 c d))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 a 3) (pow.f64 (+.f64 b (+.f64 c d)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (+.f64 b (+.f64 c d)) 3) (pow.f64 a 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 a (+.f64 b (+.f64 c d)))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 a (+.f64 b (+.f64 c d)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 a b (*.f64 a (+.f64 c d)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 a (+.f64 b c) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 a d (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 b a (*.f64 (+.f64 c d) a))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 b c) a (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 d a (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 a (+.f64 b c)) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 a d) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 b c)) 2) (*.f64 (cbrt.f64 (+.f64 b c)) a) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 a) 2) (*.f64 (cbrt.f64 a) (+.f64 b c)) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 a) 2) (*.f64 (cbrt.f64 a) d) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 d) 2) (*.f64 (cbrt.f64 d) a) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 b c)) (*.f64 (sqrt.f64 (+.f64 b c)) a) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 a) (*.f64 (sqrt.f64 a) (+.f64 b c)) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 a) (*.f64 (sqrt.f64 a) d) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 d) (*.f64 (sqrt.f64 d) a) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 a (+.f64 b c)) 1 (*.f64 (*.f64 a d) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (cbrt.f64 (*.f64 a (+.f64 b c))) (cbrt.f64 (*.f64 a (+.f64 b c)))) (cbrt.f64 (*.f64 a (+.f64 b c))) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (cbrt.f64 (*.f64 a d)) (cbrt.f64 (*.f64 a d))) (cbrt.f64 (*.f64 a d)) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 a (+.f64 b c))) (sqrt.f64 (*.f64 a (+.f64 b c))) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 a d)) (sqrt.f64 (*.f64 a d)) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 a) (sqrt.f64 (+.f64 b c))) (*.f64 (sqrt.f64 a) (sqrt.f64 (+.f64 b c))) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 (+.f64 b c)) (sqrt.f64 a)) (*.f64 (sqrt.f64 (+.f64 b c)) (sqrt.f64 a)) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 a) (sqrt.f64 d)) (*.f64 (sqrt.f64 a) (sqrt.f64 d)) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 d) (sqrt.f64 a)) (*.f64 (sqrt.f64 d) (sqrt.f64 a)) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 a (pow.f64 (cbrt.f64 (+.f64 b c)) 2)) (cbrt.f64 (+.f64 b c)) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 a (sqrt.f64 (+.f64 b c))) (sqrt.f64 (+.f64 b c)) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (+.f64 b c) (pow.f64 (cbrt.f64 a) 2)) (cbrt.f64 a) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (+.f64 b c) (sqrt.f64 a)) (sqrt.f64 a) (*.f64 a d))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 a (pow.f64 (cbrt.f64 d) 2)) (cbrt.f64 d) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 a (sqrt.f64 d)) (sqrt.f64 d) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 d (pow.f64 (cbrt.f64 a) 2)) (cbrt.f64 a) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 d (sqrt.f64 a)) (sqrt.f64 a) (*.f64 a (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 a (+.f64 b (+.f64 c d)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 a (+.f64 b (+.f64 c d)))) 1))))))

simplify24.0ms (1.6%)

Algorithm
egg-herbie
Rules
25×fma-def_binary64
+-commutative_binary64
*-commutative_binary64
distribute-rgt-in_binary64
associate-+l+_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
021435
150435
269435
377435
Stop Event
saturated
Counts
111 → 75
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))
Outputs
(*.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 c (+.f64 d b)) a)
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a b)
(*.f64 b a)
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a b) (*.f64 a (+.f64 c d)))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a b)
(*.f64 b a)
(+.f64 (*.f64 a b) (*.f64 (+.f64 c d) a))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a b) (*.f64 (+.f64 c d) a))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a b) (*.f64 (+.f64 c d) a))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 (+.f64 d b) a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 c a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 c a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 (+.f64 d b) a) (*.f64 c a))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a d)
(*.f64 d a)
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 (+.f64 c (+.f64 d b)) a)
(*.f64 a d)
(*.f64 d a)
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 (+.f64 c (+.f64 d b)) a)
(+.f64 (*.f64 a (+.f64 c b)) (*.f64 a d))
(*.f64 (+.f64 c (+.f64 d b)) a)

prune96.0ms (6.1%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New74175
Fresh000
Picked101
Done000
Total75176
Error
0b
Counts
76 → 1
Alt Table
StatusErrorProgram
0b
(fma.f64 a d (*.f64 a (+.f64 b c)))
Compiler

Compiled 956 to 245 computations (74.4% saved)

localize6.0ms (0.4%)

Local error

Found 1 expressions with local error:

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

series6.0ms (0.4%)

Counts
1 → 36
Calls

9 calls:

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

rewrite36.0ms (2.3%)

Algorithm
batch-egg-rewrite
Rules
779×pow1_binary64
725×log1p-expm1-u_binary64
725×expm1-log1p-u_binary64
73×add-sqr-sqrt_binary64
72×*-un-lft-identity_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
067
11347
219757
Stop Event
node limit
Counts
1 → 26
Calls
Call 1
Inputs
(*.f64 a (+.f64 b c))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 a b) (*.f64 a c))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 a c) (*.f64 a b))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 a b) 1) (*.f64 (*.f64 a c) 1))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 a (+.f64 b c)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 a b) 3) (pow.f64 (*.f64 a c) 3)) (+.f64 (*.f64 (*.f64 a b) (*.f64 a b)) (-.f64 (*.f64 (*.f64 a c) (*.f64 a c)) (*.f64 (*.f64 a b) (*.f64 a c)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 a b) (*.f64 a b)) (*.f64 (*.f64 a c) (*.f64 a c))) (-.f64 (*.f64 a b) (*.f64 a c)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 b 3) (pow.f64 c 3)) a) (fma.f64 b b (*.f64 c (-.f64 c b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 (*.f64 b b) (*.f64 c c)) a) (-.f64 b c))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 a (+.f64 (pow.f64 b 3) (pow.f64 c 3))) (fma.f64 b b (*.f64 c (-.f64 c b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 a (-.f64 (*.f64 b b) (*.f64 c c))) (-.f64 b c))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 a (+.f64 b c)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 a (+.f64 b c)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 a (+.f64 b c))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 a (+.f64 b c))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 a (+.f64 b c)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 a) (+.f64 b c)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 a (+.f64 b c)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 a (+.f64 b c)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 a 3) (pow.f64 (+.f64 b c) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 a 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 a (+.f64 b c))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 a (+.f64 b c))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 a b (*.f64 a c))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 b a (*.f64 a c))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 a (+.f64 b c))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 a (+.f64 b c))) 1))))))

simplify10.0ms (0.7%)

Algorithm
egg-herbie
Rules
fma-def_binary64
*-commutative_binary64
+-commutative_binary64
distribute-lft-in_binary64
distribute-rgt-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
09234
117234
220234
Stop Event
saturated
Counts
62 → 31
Calls
Call 1
Inputs
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 c a)
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 c a)
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 c a)
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 c a))
(+.f64 (*.f64 a b) (*.f64 c a))
Outputs
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 a (+.f64 c b))
(*.f64 c a)
(*.f64 a c)
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(*.f64 c a)
(*.f64 a c)
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(*.f64 c a)
(*.f64 a c)
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))
(+.f64 (*.f64 a b) (*.f64 c a))
(*.f64 a (+.f64 c b))

prune67.0ms (4.3%)

Pruning

1 alts after pruning (0 fresh and 1 done)

PrunedKeptTotal
New31031
Fresh000
Picked011
Done000
Total31132
Error
0b
Counts
32 → 1
Alt Table
StatusErrorProgram
0b
(fma.f64 a d (*.f64 a (+.f64 b c)))
Compiler

Compiled 410 to 146 computations (64.4% saved)

regimes43.0ms (2.7%)

Accuracy

Total 0.0b remaining (0%)

Threshold costs 0.0b (0%)

Counts
8 → 1
Compiler

Compiled 114 to 60 computations (47.4% saved)

simplify3.0ms (0.2%)

Algorithm
egg-herbie
Rules
+-commutative_binary64
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0811
11011
Stop Event
saturated
Calls
Call 1
Inputs
(fma.f64 a d (*.f64 a (+.f64 b c)))
Outputs
(fma.f64 a d (*.f64 a (+.f64 b c)))

end40.0ms (2.6%)

Stop Event
done
Compiler

Compiled 56 to 28 computations (50% saved)

Profiling

Loading profile data...