Details

Time bar (total: 1.4s)

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.2s (92%)

Results
1.2s8256×body256valid
Bogosity

preprocess19.0ms (1.4%)

Algorithm
egg-herbie
Rules
192×fma-def
88×distribute-lft-in
80×+-commutative
50×*-commutative
38×distribute-rgt-in
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
026133
181133
2154133
3244133
4290133
044
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
2
3
Outputs
0
1
2
3
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 b (+.f64 a 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 b (+.f64 c d)))
(*.f64 a (+.f64 (+.f64 b c) d))
(*.f64 a (+.f64 (+.f64 d c) b))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 (+.f64 b c) d))
(*.f64 a (+.f64 (+.f64 b d) c))
(*.f64 a (+.f64 b (+.f64 c d)))
(*.f64 a (+.f64 (+.f64 b c) d))
Compiler

Compiled 15 to 11 computations (26.7% saved)

simplify12.0ms (0.9%)

Algorithm
egg-herbie
Rules
48×fma-def
24×+-commutative
18×distribute-lft-in
14×*-commutative
12×distribute-rgt-in
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0919
12019
24319
36819
48319
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 c (+.f64 b d)))

eval0.0ms (0%)

Compiler

Compiled 18 to 10 computations (44.4% saved)

prune1.0ms (0.1%)

Pruning

2 alts after pruning (2 fresh and 0 done)

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

Compiled 11 to 7 computations (36.4% saved)

localize7.0ms (0.5%)

Local error

Found 1 expressions with local error:

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

Compiled 23 to 7 computations (69.6% saved)

series4.0ms (0.3%)

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
@inf
(*.f64 a (+.f64 (+.f64 b c) d))
0.0ms
a
@0
(*.f64 a (+.f64 (+.f64 b c) d))
0.0ms
b
@inf
(*.f64 a (+.f64 (+.f64 b c) d))

rewrite66.0ms (4.9%)

Algorithm
batch-egg-rewrite
Rules
1230×associate-*r/
1100×*-commutative
1044×associate-*l/
1024×distribute-lft-in
278×associate-+l+
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0919
120519
2304119
Stop Event
node limit
Calls
Call 1
Inputs
(*.f64 a (+.f64 (+.f64 b c) d))
Outputs
((((x +.f64 (*.f64 a d) (*.f64 a (+.f64 b c))))) (((x +.f64 (*.f64 a (+.f64 b c)) (*.f64 a d)))) (((x +.f64 (*.f64 a (+.f64 c d)) (*.f64 a b)))) (((x +.f64 (*.f64 a b) (*.f64 a (+.f64 c d))))) (((x +.f64 (*.f64 a c) (+.f64 (*.f64 a b) (*.f64 a d))))) (((x +.f64 (*.f64 a c) (*.f64 a (+.f64 b d))))) (((x +.f64 (+.f64 (*.f64 a d) (*.f64 a b)) (*.f64 a c)))) (((x +.f64 (*.f64 a (+.f64 b d)) (*.f64 a c)))) (((x +.f64 (*.f64 1 (*.f64 a b)) (*.f64 1 (*.f64 a (+.f64 c d)))))) (((x -.f64 (exp.f64 (log1p.f64 (*.f64 a (+.f64 b (+.f64 c d))))) 1))) (((x /.f64 a (/.f64 1 (+.f64 b (+.f64 c d)))))) (((x /.f64 (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d)) (/.f64 (-.f64 (+.f64 b c) d) a)))) (((x /.f64 (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3)) (/.f64 (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c)))) a)))) (((x /.f64 (*.f64 a (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d))) (-.f64 (+.f64 b c) d)))) (((x /.f64 (*.f64 a (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3))) (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c))))))) (((x /.f64 (-.f64 (*.f64 (*.f64 a (+.f64 b c)) (*.f64 a (+.f64 b c))) (*.f64 (*.f64 a d) (*.f64 a d))) (-.f64 (*.f64 a (+.f64 b c)) (*.f64 a d))))) (((x /.f64 (+.f64 (pow.f64 (*.f64 a (+.f64 b c)) 3) (pow.f64 (*.f64 a d) 3)) (+.f64 (*.f64 (*.f64 a (+.f64 b c)) (*.f64 a (+.f64 b c))) (-.f64 (*.f64 (*.f64 a d) (*.f64 a d)) (*.f64 (*.f64 a d) (*.f64 a (+.f64 b c)))))))) (((x /.f64 (*.f64 a (-.f64 (*.f64 b b) (*.f64 (+.f64 c d) (+.f64 c d)))) (-.f64 b (+.f64 c d))))) (((x /.f64 (*.f64 a (-.f64 (*.f64 d d) (pow.f64 (+.f64 b c) 2))) (-.f64 d (+.f64 b c))))) (((x /.f64 (*.f64 a (+.f64 (pow.f64 b 3) (pow.f64 (+.f64 c d) 3))) (-.f64 (+.f64 (*.f64 b b) (*.f64 (+.f64 c d) (+.f64 c d))) (*.f64 b (+.f64 c d)))))) (((x /.f64 (*.f64 a (neg.f64 (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d)))) (neg.f64 (-.f64 (+.f64 b c) d))))) (((x /.f64 (*.f64 a (neg.f64 (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3)))) (neg.f64 (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c)))))))) (((x /.f64 (*.f64 1 (*.f64 a (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d)))) (-.f64 (+.f64 b c) d)))) (((x /.f64 (*.f64 1 (*.f64 a (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3)))) (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c))))))) (((x /.f64 (*.f64 1 (-.f64 (*.f64 (*.f64 a (+.f64 b c)) (*.f64 a (+.f64 b c))) (*.f64 (*.f64 a d) (*.f64 a d)))) (-.f64 (*.f64 a (+.f64 b c)) (*.f64 a d))))) (((x /.f64 (*.f64 1 (+.f64 (pow.f64 (*.f64 a (+.f64 b c)) 3) (pow.f64 (*.f64 a d) 3))) (+.f64 (*.f64 (*.f64 a (+.f64 b c)) (*.f64 a (+.f64 b c))) (-.f64 (*.f64 (*.f64 a d) (*.f64 a d)) (*.f64 (*.f64 a d) (*.f64 a (+.f64 b c)))))))) (((x /.f64 (*.f64 (*.f64 a (sqrt.f64 (+.f64 b (+.f64 c d)))) (sqrt.f64 (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3)))) (sqrt.f64 (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c)))))))) (((x /.f64 (*.f64 (*.f64 a (sqrt.f64 (+.f64 b (+.f64 c d)))) (sqrt.f64 (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d)))) (sqrt.f64 (-.f64 (+.f64 b c) d))))) (((x /.f64 (*.f64 (*.f64 a (pow.f64 (cbrt.f64 (+.f64 b (+.f64 c d))) 2)) (cbrt.f64 (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3)))) (cbrt.f64 (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c)))))))) (((x /.f64 (*.f64 (*.f64 a (pow.f64 (cbrt.f64 (+.f64 b (+.f64 c d))) 2)) (cbrt.f64 (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d)))) (cbrt.f64 (-.f64 (+.f64 b c) d))))) (((x /.f64 (*.f64 (-.f64 (*.f64 b b) (*.f64 (+.f64 c d) (+.f64 c d))) a) (-.f64 b (+.f64 c d))))) (((x /.f64 (*.f64 (-.f64 (*.f64 d d) (pow.f64 (+.f64 b c) 2)) a) (-.f64 d (+.f64 b c))))) (((x /.f64 (*.f64 (+.f64 (pow.f64 b 3) (pow.f64 (+.f64 c d) 3)) a) (-.f64 (+.f64 (*.f64 b b) (*.f64 (+.f64 c d) (+.f64 c d))) (*.f64 b (+.f64 c d)))))) (((x /.f64 (*.f64 (neg.f64 (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d))) a) (neg.f64 (-.f64 (+.f64 b c) d))))) (((x /.f64 (*.f64 (neg.f64 (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3))) a) (neg.f64 (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c)))))))) (((x /.f64 (*.f64 (*.f64 a (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d))) 1) (-.f64 (+.f64 b c) d)))) (((x /.f64 (*.f64 (*.f64 a (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3))) 1) (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c))))))) (((x /.f64 (*.f64 (-.f64 (*.f64 (*.f64 a (+.f64 b c)) (*.f64 a (+.f64 b c))) (*.f64 (*.f64 a d) (*.f64 a d))) 1) (-.f64 (*.f64 a (+.f64 b c)) (*.f64 a d))))) (((x /.f64 (*.f64 (+.f64 (pow.f64 (*.f64 a (+.f64 b c)) 3) (pow.f64 (*.f64 a d) 3)) 1) (+.f64 (*.f64 (*.f64 a (+.f64 b c)) (*.f64 a (+.f64 b c))) (-.f64 (*.f64 (*.f64 a d) (*.f64 a d)) (*.f64 (*.f64 a d) (*.f64 a (+.f64 b c)))))))) (((x /.f64 (*.f64 (sqrt.f64 (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3))) (*.f64 a (sqrt.f64 (+.f64 b (+.f64 c d))))) (sqrt.f64 (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c)))))))) (((x /.f64 (*.f64 (sqrt.f64 (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d))) (*.f64 a (sqrt.f64 (+.f64 b (+.f64 c d))))) (sqrt.f64 (-.f64 (+.f64 b c) d))))) (((x /.f64 (/.f64 (*.f64 a (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d))) 1) (-.f64 (+.f64 b c) d)))) (((x /.f64 (/.f64 (*.f64 a (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d))) (sqrt.f64 (-.f64 (+.f64 b c) d))) (sqrt.f64 (-.f64 (+.f64 b c) d))))) (((x /.f64 (/.f64 (*.f64 a (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d))) (*.f64 (cbrt.f64 (-.f64 (+.f64 b c) d)) (cbrt.f64 (-.f64 (+.f64 b c) d)))) (cbrt.f64 (-.f64 (+.f64 b c) d))))) (((x /.f64 (/.f64 (*.f64 a (-.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d d))) (+.f64 (sqrt.f64 (+.f64 b c)) (sqrt.f64 d))) (-.f64 (sqrt.f64 (+.f64 b c)) (sqrt.f64 d))))) (((x /.f64 (/.f64 (*.f64 a (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3))) 1) (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c))))))) (((x /.f64 (/.f64 (*.f64 a (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3))) (sqrt.f64 (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c)))))) (sqrt.f64 (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c)))))))) (((x /.f64 (/.f64 (*.f64 a (+.f64 (pow.f64 (+.f64 b c) 3) (pow.f64 d 3))) (*.f64 (cbrt.f64 (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c))))) (cbrt.f64 (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c))))))) (cbrt.f64 (+.f64 (pow.f64 (+.f64 b c) 2) (*.f64 d (-.f64 d (+.f64 b c)))))))) (((x pow.f64 (*.f64 a (+.f64 b (+.f64 c d))) 1))) (((x pow.f64 (sqrt.f64 (*.f64 a (+.f64 b (+.f64 c d)))) 2))) (((x pow.f64 (cbrt.f64 (*.f64 a (+.f64 b (+.f64 c d)))) 3))) (((x pow.f64 (pow.f64 (*.f64 a (+.f64 b (+.f64 c d))) 3) 1/3))) (((x sqrt.f64 (pow.f64 (*.f64 a (+.f64 b (+.f64 c d))) 2)))) (((x log.f64 (pow.f64 (exp.f64 a) (+.f64 b (+.f64 c d)))))) (((x log.f64 (+.f64 1 (expm1.f64 (*.f64 a (+.f64 b (+.f64 c d)))))))) (((x cbrt.f64 (pow.f64 (*.f64 a (+.f64 b (+.f64 c d))) 3)))) (((x cbrt.f64 (*.f64 (pow.f64 (+.f64 b (+.f64 c d)) 3) (pow.f64 a 3))))) (((x expm1.f64 (log1p.f64 (*.f64 a (+.f64 b (+.f64 c d))))))) (((x exp.f64 (log.f64 (*.f64 a (+.f64 b (+.f64 c d))))))) (((x log1p.f64 (expm1.f64 (*.f64 a (+.f64 b (+.f64 c d))))))) (((x fma.f64 a (+.f64 b c) (*.f64 a d)))) (((x fma.f64 (+.f64 b c) a (*.f64 a d)))))

end0.0ms (0%)

Profiling

Loading profile data...