Details

Time bar (total: 3.6s)

analyze209.0ms (5.8%)

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.4%25%73.3%0.1%1.6%0%0%9
35.3%34.3%62.8%0.1%2.7%0%0%10
43.9%41.3%52.9%0.1%5.7%0%0%11
50.6%46.8%45.7%0.1%7.3%0%0%12
Compiler

Compiled 15 to 10 computations (33.3% saved)

sample1.3s (37%)

Results
1.0s7864×body256valid
165.0ms1376×body256infinite
46.0ms232×body512valid
44.0ms160×body1024valid
Bogosity

preprocess36.0ms (1%)

Algorithm
egg-herbie
Rules
75×fma-def_binary64
22×+-commutative_binary64
22×*-commutative_binary64
20×distribute-lft-out_binary64
17×associate-+l+_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02252
15840
214940
321340
422440
522640
033
133
Stop Event
unsound
saturated
Calls
Call 1
Inputs
0
1
2
Outputs
0
1
2
1
Call 2
Inputs
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
(+.f64 (+.f64 (*.f64 d2 3) (*.f64 d2 d1)) (*.f64 d2 d3))
(+.f64 (+.f64 (*.f64 d3 3) (*.f64 d3 d2)) (*.f64 d3 d1))
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d3)) (*.f64 d1 d2))
Outputs
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
(+.f64 (*.f64 d1 (+.f64 3 d2)) (*.f64 d1 d3))
(*.f64 d1 (+.f64 (+.f64 3 d3) d2))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (+.f64 (*.f64 d2 3) (*.f64 d2 d1)) (*.f64 d2 d3))
(+.f64 (*.f64 d2 (+.f64 3 d1)) (*.f64 d2 d3))
(*.f64 d2 (+.f64 (+.f64 d1 3) d3))
(*.f64 d2 (+.f64 3 (+.f64 d1 d3)))
(+.f64 (+.f64 (*.f64 d3 3) (*.f64 d3 d2)) (*.f64 d3 d1))
(+.f64 (*.f64 d1 d3) (*.f64 d3 (+.f64 3 d2)))
(*.f64 d3 (+.f64 d1 (+.f64 3 d2)))
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d3)) (*.f64 d1 d2))
(+.f64 (*.f64 d1 (+.f64 3 d2)) (*.f64 d1 d3))
(*.f64 d1 (+.f64 (+.f64 3 d3) d2))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
Symmetry

(sort d2 d3)

Compiler

Compiled 17 to 12 computations (29.4% saved)

simplify13.0ms (0.4%)

Algorithm
egg-herbie
Rules
25×fma-def_binary64
+-commutative_binary64
*-commutative_binary64
distribute-lft-out_binary64
associate-+r+_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01013
12010
24610
37410
48510
58610
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
Outputs
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
(+.f64 (*.f64 d1 (+.f64 3 d2)) (*.f64 d1 d3))
(*.f64 d1 (+.f64 (+.f64 3 d2) d3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))

eval1.0ms (0%)

Compiler

Compiled 21 to 13 computations (38.1% saved)

prune2.0ms (0%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New112
Fresh101
Picked000
Done000
Total213
Error
0.1b
Counts
3 → 1
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
Compiler

Compiled 10 to 7 computations (30% saved)

localize13.0ms (0.4%)

Local error

Found 1 expressions with local error:

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

Compiled 22 to 10 computations (54.5% saved)

series8.0ms (0.2%)

Counts
1 → 28
Calls

9 calls:

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

rewrite93.0ms (2.6%)

Algorithm
batch-egg-rewrite
Rules
680×prod-diff_binary64
614×unpow-prod-down_binary64
438×log-prod_binary64
301×fma-def_binary64
253×pow2_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0810
118610
2272910
Stop Event
node limit
Counts
1 → 56
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 3) (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (+.f64 3 d2) d1) (*.f64 d3 d1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 d1 3) 1) (*.f64 (*.f64 d1 (+.f64 d2 d3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 (+.f64 3 d2)) (*.f64 d1 d3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 d1) (+.f64 3 (+.f64 d2 d3)))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 d1) (+.f64 3 (+.f64 d2 d3))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 d1) (+.f64 3 (+.f64 d2 d3))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 d1) (+.f64 3 (+.f64 d2 d3))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 (pow.f64 d1 3) 27) (pow.f64 (*.f64 d1 (+.f64 d2 d3)) 3)) (+.f64 (pow.f64 (*.f64 d1 3) 2) (-.f64 (pow.f64 (*.f64 d1 (+.f64 d2 d3)) 2) (*.f64 (*.f64 d1 3) (*.f64 d1 (+.f64 d2 d3))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 d1 3) 2) (pow.f64 (*.f64 d1 (+.f64 d2 d3)) 2)) (-.f64 (*.f64 d1 3) (*.f64 d1 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 27 (pow.f64 (+.f64 d2 d3) 3)) d1) (fma.f64 (+.f64 d2 d3) (-.f64 (+.f64 d2 d3) 3) 9))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 9 (pow.f64 (+.f64 d2 d3) 2)) d1) (-.f64 3 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 27 (pow.f64 (+.f64 d2 d3) 3))) (fma.f64 (+.f64 d2 d3) (-.f64 (+.f64 d2 d3) 3) 9))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (-.f64 9 (pow.f64 (+.f64 d2 d3) 2))) (-.f64 3 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 d1) (+.f64 3 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (*.f64 d1 (+.f64 d2 d3))) (exp.f64 (*.f64 d1 3))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 d1 3 (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 d1 (+.f64 d2 d3) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 d1 (+.f64 3 d2) (*.f64 d1 d3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 3 d1 (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 d2 d3) d1 (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 d1 3) (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 d1) 2) (*.f64 (cbrt.f64 d1) (+.f64 d2 d3)) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 d1) 2) (*.f64 (cbrt.f64 d1) 3) (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 d2 d3)) 2) (*.f64 (cbrt.f64 (+.f64 d2 d3)) d1) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 d1) (*.f64 (sqrt.f64 d1) (+.f64 d2 d3)) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 d1) (*.f64 (sqrt.f64 d1) 3) (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 d2 d3)) (*.f64 (sqrt.f64 (+.f64 d2 d3)) d1) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 d1 3) 1 (*.f64 (*.f64 d1 (+.f64 d2 d3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 3 d2) d1 (*.f64 d3 d1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 d1 3)) 2) (cbrt.f64 (*.f64 d1 3)) (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 d1 (+.f64 d2 d3))) 2) (cbrt.f64 (*.f64 d1 (+.f64 d2 d3))) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 d1 3)) (sqrt.f64 (*.f64 d1 3)) (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 d1 (+.f64 d2 d3))) (sqrt.f64 (*.f64 d1 (+.f64 d2 d3))) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 d1) (sqrt.f64 (+.f64 d2 d3))) (*.f64 (sqrt.f64 d1) (sqrt.f64 (+.f64 d2 d3))) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 (+.f64 d2 d3)) (sqrt.f64 d1)) (*.f64 (sqrt.f64 (+.f64 d2 d3)) (sqrt.f64 d1)) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 d1 (pow.f64 (cbrt.f64 (+.f64 d2 d3)) 2)) (cbrt.f64 (+.f64 d2 d3)) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 d1 (sqrt.f64 (+.f64 d2 d3))) (sqrt.f64 (+.f64 d2 d3)) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (+.f64 d2 d3) (pow.f64 (cbrt.f64 d1) 2)) (cbrt.f64 d1) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (+.f64 d2 d3) (sqrt.f64 d1)) (sqrt.f64 d1) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 3 (pow.f64 (cbrt.f64 d1) 2)) (cbrt.f64 d1) (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 3 (sqrt.f64 d1)) (sqrt.f64 d1) (*.f64 d1 (+.f64 d2 d3)))))))

simplify23.0ms (0.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
015250
141250
267250
389250
493250
Stop Event
saturated
Counts
84 → 65
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 d3)
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 d3)
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
Outputs
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(+.f64 (*.f64 d1 (+.f64 3 d3)) (*.f64 d2 d1))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 d2 3))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))
(+.f64 (*.f64 d1 d3) (*.f64 d1 (+.f64 3 d2)))
(*.f64 d1 (+.f64 d2 (+.f64 3 d3)))

eval23.0ms (0.7%)

Compiler

Compiled 780 to 360 computations (53.8% saved)

prune28.0ms (0.8%)

Pruning

7 alts after pruning (6 fresh and 1 done)

PrunedKeptTotal
New59665
Fresh000
Picked011
Done000
Total59766
Error
0b
Counts
66 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
25.2b
(/.f64 (*.f64 (-.f64 9 (pow.f64 (+.f64 d2 d3) 2)) d1) (-.f64 3 (+.f64 d2 d3)))
42.4b
(*.f64 d1 d3)
19.8b
(*.f64 d1 (+.f64 d2 3))
40.3b
(*.f64 d2 d1)
23.1b
(*.f64 d1 (+.f64 3 d3))
0.1b
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
0.0b
(fma.f64 d1 3 (*.f64 d1 (+.f64 d2 d3)))
Compiler

Compiled 124 to 85 computations (31.5% saved)

localize14.0ms (0.4%)

Local error

Found 2 expressions with local error:

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

Compiled 23 to 8 computations (65.2% saved)

series12.0ms (0.3%)

Counts
2 → 60
Calls

18 calls:

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

rewrite92.0ms (2.6%)

Algorithm
batch-egg-rewrite
Rules
960×pow1_binary64
892×add-log-exp_binary64
892×log1p-expm1-u_binary64
892×expm1-log1p-u_binary64
92×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0818
117517
2241217
Stop Event
node limit
Counts
2 → 49
Calls
Call 1
Inputs
(fma.f64 d1 3 (*.f64 d1 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 d2 d3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 (+.f64 d2 d3)) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 3) (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 d1 3) 1) (*.f64 d1 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (+.f64 3 (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))) (pow.f64 (cbrt.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))) 2) (cbrt.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))) (sqrt.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 d1 3) 3) (pow.f64 (*.f64 d1 (+.f64 d2 d3)) 3)) (+.f64 (*.f64 (*.f64 d1 3) (*.f64 d1 3)) (-.f64 (pow.f64 (*.f64 d1 (+.f64 d2 d3)) 2) (*.f64 (*.f64 d1 3) (*.f64 d1 (+.f64 d2 d3))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 d1 3) (*.f64 d1 3)) (pow.f64 (*.f64 d1 (+.f64 d2 d3)) 2)) (-.f64 (*.f64 d1 3) (*.f64 d1 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 d1 (+.f64 3 (+.f64 d2 d3)))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 d2) (*.f64 d1 d3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 d3) (*.f64 d1 d2))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 d1 d2) 1) (*.f64 (*.f64 d1 d3) 1))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 d1 (+.f64 d2 d3)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 d1 d2) 3) (pow.f64 (*.f64 d1 d3) 3)) (+.f64 (*.f64 (*.f64 d1 d2) (*.f64 d1 d2)) (-.f64 (*.f64 (*.f64 d1 d3) (*.f64 d1 d3)) (*.f64 (*.f64 d1 d2) (*.f64 d1 d3)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 d1 d2) (*.f64 d1 d2)) (*.f64 (*.f64 d1 d3) (*.f64 d1 d3))) (-.f64 (*.f64 d1 d2) (*.f64 d1 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 d2 3) (pow.f64 d3 3)) d1) (fma.f64 d2 d2 (*.f64 d3 (-.f64 d3 d2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 (*.f64 d2 d2) (*.f64 d3 d3)) d1) (-.f64 d2 d3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 (pow.f64 d2 3) (pow.f64 d3 3))) (fma.f64 d2 d2 (*.f64 d3 (-.f64 d3 d2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (-.f64 (*.f64 d2 d2) (*.f64 d3 d3))) (-.f64 d2 d3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 d2 d3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 d1 (+.f64 d2 d3)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 d1 (+.f64 d2 d3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 d1 (+.f64 d2 d3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 d1 (+.f64 d2 d3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 d1) (+.f64 d2 d3)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 d1 (+.f64 d2 d3)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 d1 (+.f64 d2 d3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 d1 3) (pow.f64 (+.f64 d2 d3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (+.f64 d2 d3) 3) (pow.f64 d1 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 d1 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 d1 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 d1 (+.f64 d2 d3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 d1 d2 (*.f64 d1 d3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 d2 d1 (*.f64 d1 d3))))))

simplify91.0ms (2.5%)

Algorithm
egg-herbie
Rules
403×fma-def_binary64
362×fma-neg_binary64
90×distribute-rgt-in_binary64
80×unsub-neg_binary64
75×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
020499
160480
2134480
3273480
4608480
51184480
61712480
71913480
81921480
Stop Event
saturated
Counts
109 → 60
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 (+.f64 d2 d3)) 3)))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 (+.f64 d2 d3)) 3)))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 (+.f64 d2 d3)) 3)))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 (+.f64 d2 d3)) 3)))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(+.f64 (*.f64 3 d1) (+.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 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))
Outputs
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 (+.f64 d2 d3)) 3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 (+.f64 d2 d3)) 3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 (+.f64 d2 d3)) 3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 -1 (*.f64 d1 (-.f64 (*.f64 -1 (+.f64 d2 d3)) 3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (*.f64 d1 d3))
(fma.f64 3 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d3 3))
(*.f64 d1 (+.f64 3 d3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 d2 d1) (*.f64 d1 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(*.f64 d1 d3)
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))
(+.f64 (*.f64 d2 d1) (*.f64 d1 d3))
(fma.f64 d2 d1 (*.f64 d1 d3))
(*.f64 d1 (+.f64 d2 d3))

localize6.0ms (0.2%)

Compiler

Compiled 8 to 4 computations (50% saved)

localize6.0ms (0.2%)

Compiler

Compiled 8 to 4 computations (50% saved)

localize36.0ms (1%)

Compiler

Compiled 14 to 9 computations (35.7% saved)

localize10.0ms (0.3%)

Local error

Found 1 expressions with local error:

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

Compiled 14 to 9 computations (35.7% saved)

series6.0ms (0.2%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
2.0ms
d2
@inf
(*.f64 d1 (+.f64 d2 3))
1.0ms
d1
@0
(*.f64 d1 (+.f64 d2 3))
1.0ms
d1
@inf
(*.f64 d1 (+.f64 d2 3))
1.0ms
d1
@-inf
(*.f64 d1 (+.f64 d2 3))
1.0ms
d2
@-inf
(*.f64 d1 (+.f64 d2 3))

rewrite86.0ms (2.4%)

Algorithm
batch-egg-rewrite
Rules
718×pow1_binary64
670×add-log-exp_binary64
670×log1p-expm1-u_binary64
670×expm1-log1p-u_binary64
657×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
067
11357
218027
Stop Event
node limit
Counts
1 → 24
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 d2 3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 d2) (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 3) (*.f64 d1 d2))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 d1 d2) 1) (*.f64 (*.f64 d1 3) 1))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 d1 (+.f64 d2 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 d1 d2) 3) (pow.f64 (*.f64 d1 3) 3)) (+.f64 (*.f64 (*.f64 d1 d2) (*.f64 d1 d2)) (-.f64 (*.f64 (*.f64 d1 3) (*.f64 d1 3)) (*.f64 (*.f64 d1 d2) (*.f64 d1 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 d1 d2) (*.f64 d1 d2)) (*.f64 (*.f64 d1 3) (*.f64 d1 3))) (-.f64 (*.f64 d1 d2) (*.f64 d1 3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 27 (pow.f64 d2 3)) d1) (fma.f64 d2 d2 (-.f64 9 (*.f64 d2 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (+.f64 d2 -3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (+.f64 27 (pow.f64 d2 3))) (fma.f64 d2 d2 (-.f64 9 (*.f64 d2 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 d1 (fma.f64 d2 d2 -9)) (+.f64 d2 -3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 d1 (+.f64 d2 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 d1 (+.f64 d2 3)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 d1 (+.f64 d2 3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 d1 (+.f64 d2 3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 d1 (+.f64 d2 3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 d1) (+.f64 d2 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 d1 (+.f64 d2 3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 d1 3) (pow.f64 (+.f64 d2 3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (+.f64 d2 3) 3) (pow.f64 d1 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 d1 (+.f64 d2 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 d1 (+.f64 d2 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 d1 (+.f64 d2 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 d1 d2 (*.f64 d1 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 d2 d1 (*.f64 d1 3))))))

simplify18.0ms (0.5%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
011159
118159
221159
Stop Event
saturated
Counts
48 → 31
Calls
Call 1
Inputs
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 (+.f64 d2 3) d1)
(*.f64 (+.f64 d2 3) d1)
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 3 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
Outputs
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 (+.f64 d2 3) d1)
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 3 d2))
(*.f64 3 d1)
(*.f64 d1 3)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))

eval31.0ms (0.9%)

Compiler

Compiled 1005 to 511 computations (49.2% saved)

prune29.0ms (0.8%)

Pruning

8 alts after pruning (2 fresh and 6 done)

PrunedKeptTotal
New89291
Fresh101
Picked011
Done055
Total90898
Error
0b
Counts
98 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
19.8b
(*.f64 d1 (+.f64 d2 3))
42.5b
(*.f64 d1 3)
40.3b
(*.f64 d2 d1)
23.1b
(*.f64 d1 (+.f64 3 d3))
33.5b
(/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (+.f64 d2 -3))
0.1b
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
0.0b
(fma.f64 d1 3 (*.f64 d1 (+.f64 d2 d3)))
42.4b
(*.f64 d1 d3)
Compiler

Compiled 68 to 48 computations (29.4% saved)

localize6.0ms (0.2%)

Compiler

Compiled 8 to 6 computations (25% saved)

localize22.0ms (0.6%)

Local error

Found 2 expressions with local error:

NewErrorProgram
5.9b
(*.f64 (fma.f64 d2 d2 -9) d1)
9.3b
(/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (+.f64 d2 -3))
Compiler

Compiled 30 to 18 computations (40% saved)

series13.0ms (0.4%)

Counts
2 → 48
Calls

12 calls:

TimeVariablePointExpression
2.0ms
d2
@-inf
(*.f64 (fma.f64 d2 d2 -9) d1)
2.0ms
d1
@0
(/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (+.f64 d2 -3))
1.0ms
d2
@-inf
(/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (+.f64 d2 -3))
1.0ms
d2
@0
(/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (+.f64 d2 -3))
1.0ms
d1
@inf
(/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (+.f64 d2 -3))

rewrite90.0ms (2.5%)

Algorithm
batch-egg-rewrite
Rules
477×log-prod_binary64
374×exp-prod_binary64
342×prod-exp_binary64
297×pow-prod-down_binary64
256×pow2_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0922
119915
2267015
Stop Event
node limit
Counts
2 → 100
Calls
Call 1
Inputs
(/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (+.f64 d2 -3))
(*.f64 (fma.f64 d2 d2 -9) d1)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (+.f64 d2 3) d1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 d2 3)) d1)) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 d2 3)) d1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 d2 3)) d1))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 d2 3)) d1))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (+.f64 d2 3) d1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 d2 d2 -9) (/.f64 1 (/.f64 (+.f64 d2 -3) d1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 d2 d2 -9) (*.f64 d1 (/.f64 1 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (*.f64 (fma.f64 d2 d2 -9) (/.f64 1 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (/.f64 1 (+.f64 d2 -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 d2 3) d1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 (+.f64 d2 3) d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (+.f64 d2 3) d1)) (pow.f64 (cbrt.f64 (*.f64 (+.f64 d2 3) d1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 (+.f64 d2 3) d1)) 2) (cbrt.f64 (*.f64 (+.f64 d2 3) d1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 2) (*.f64 (cbrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) (/.f64 1 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 (+.f64 d2 3) d1)) (sqrt.f64 (*.f64 (+.f64 d2 3) d1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) (*.f64 (sqrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) (/.f64 1 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) (/.f64 1 (+.f64 3 (neg.f64 d2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 d2 -3)) (*.f64 (fma.f64 d2 d2 -9) d1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 d2 3) d1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 d2 d2 -9) 1) (/.f64 d1 (+.f64 d2 -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 d1 1) (+.f64 d2 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 2) 1) (/.f64 (cbrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) (+.f64 d2 -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 1) (/.f64 (sqrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) (+.f64 d2 -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 d2 d2 -9) (pow.f64 (cbrt.f64 (+.f64 d2 -3)) 2)) (/.f64 d1 (cbrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 d1 (pow.f64 (cbrt.f64 (+.f64 d2 -3)) 2)) (/.f64 (fma.f64 d2 d2 -9) (cbrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 d2 -3)) -2) (/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (cbrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 2) (pow.f64 (cbrt.f64 (+.f64 d2 -3)) 2)) (cbrt.f64 (*.f64 (+.f64 d2 3) d1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) (pow.f64 (cbrt.f64 (+.f64 d2 -3)) 2)) (/.f64 (sqrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) (cbrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 d2 d2 -9) (sqrt.f64 (+.f64 d2 -3))) (/.f64 d1 (sqrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 d1 (sqrt.f64 (+.f64 d2 -3))) (/.f64 (fma.f64 d2 d2 -9) (sqrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (+.f64 d2 -3) -1/2) (/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (sqrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 2) (sqrt.f64 (+.f64 d2 -3))) (/.f64 (cbrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) (sqrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (+.f64 -27 (pow.f64 d2 3))) (-.f64 (fma.f64 d2 d2 9) (*.f64 d2 -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (fma.f64 d2 d2 -9)) (+.f64 d2 3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (+.f64 d2 3) d1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (+.f64 d2 3) d1) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (+.f64 d2 3) d1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (+.f64 d2 3) d1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (+.f64 d2 3) d1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (*.f64 (+.f64 d2 3) d1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (*.f64 (+.f64 d2 3) d1)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 d2 d2 -9) d1) 3) (pow.f64 (+.f64 d2 -3) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 1 (*.f64 (+.f64 d2 3) d1)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (*.f64 (+.f64 d2 3) d1))) 2)) (cbrt.f64 (log.f64 (*.f64 (+.f64 d2 3) d1))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (*.f64 (+.f64 d2 3) d1)))) (sqrt.f64 (log.f64 (*.f64 (+.f64 d2 3) d1))))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (+.f64 3 (neg.f64 d2))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (+.f64 d2 3) d1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (+.f64 d2 3)) d1))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (+.f64 d2 3) d1))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (+.f64 d2 3) d1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 d2 d2 -9) d1) 3) (pow.f64 (+.f64 d2 -3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (+.f64 d2 3) d1)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (+.f64 d2 3) d1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (+.f64 d2 3) d1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (+.f64 d2 3) d1)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (*.f64 (+.f64 d2 3) d1))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 (+.f64 d2 3) d1))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 (+.f64 d2 3) d1))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (neg.f64 (log.f64 (*.f64 (+.f64 d2 3) d1))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 (+.f64 d2 3) d1)) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 (log.f64 (fma.f64 d2 d2 -9)) 1) (log.f64 (/.f64 (+.f64 d2 -3) d1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 1) (log.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) (*.f64 (log.f64 (+.f64 d2 -3)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 1) (*.f64 (log.f64 (+.f64 d2 -3)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 1) (neg.f64 (log.f64 (+.f64 d2 -3)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (neg.f64 (log.f64 (+.f64 d2 -3))) (*.f64 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (log.f64 (+.f64 d2 3)) (*.f64 (log.f64 d1) 1)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (fma.f64 d2 d2 -9) d1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 d2 d2) d1) (*.f64 -9 d1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 d1 (*.f64 d2 d2)) (*.f64 d1 -9))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 d1) (fma.f64 d2 d2 -9))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 d1) (fma.f64 d2 d2 -9)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 d1) (fma.f64 d2 d2 -9)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 d1) (fma.f64 d2 d2 -9)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (fma.f64 d2 d2 -9) d1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (fma.f64 d2 d2 -9) d1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (fma.f64 d2 d2 -9) d1) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (fma.f64 d2 d2 -9) d1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1))) 2)) (cbrt.f64 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1)))) (sqrt.f64 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (fma.f64 d2 d2 -9) d1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 d1) (fma.f64 d2 d2 -9)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (fma.f64 d2 d2 -9) d1))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (fma.f64 d2 d2 -9) d1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (fma.f64 d2 d2 -9) d1)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (fma.f64 d2 d2 -9) d1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 (fma.f64 d2 d2 -9) d1))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 (fma.f64 d2 d2 -9) d1)) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 (fma.f64 d2 d2 -9)) 1) (log.f64 d1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (log.f64 (fma.f64 d2 d2 -9)) (*.f64 (log.f64 d1) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 (fma.f64 d2 d2 -9)) 1) (*.f64 (log.f64 d1) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 d1) 1) (log.f64 (fma.f64 d2 d2 -9))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (log.f64 d1) (*.f64 (log.f64 (fma.f64 d2 d2 -9)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (+.f64 (*.f64 (log.f64 d1) 1) (*.f64 (log.f64 (fma.f64 d2 d2 -9)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 d1 (*.f64 d2 d2) (*.f64 d1 -9))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 d2 d2) d1 (*.f64 -9 d1))))))

simplify164.0ms (4.6%)

Algorithm
egg-herbie
Rules
804×fma-neg_binary64
715×associate-/r/_binary64
606×associate-*l*_binary64
469×associate-*l/_binary64
460×unswap-sqr_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
018495
143429
272429
3116429
4237429
5725429
63515429
77863429
Stop Event
node limit
Counts
148 → 114
Calls
Call 1
Inputs
(*.f64 3 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d2 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(*.f64 -9 d1)
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(*.f64 (pow.f64 d2 2) d1)
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(*.f64 (pow.f64 d2 2) d1)
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
Outputs
(*.f64 3 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d2 d1)
(*.f64 d1 d2)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 d1 (/.f64 (+.f64 d2 -3) (+.f64 (*.f64 d2 d2) -9)))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) (fma.f64 d2 d2 -9))
(*.f64 (fma.f64 d2 d2 -9) (/.f64 d1 (+.f64 d2 -3)))
(*.f64 d1 (/.f64 (fma.f64 d2 d2 -9) (+.f64 d2 -3)))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 d1 (/.f64 (+.f64 d2 -3) (+.f64 (*.f64 d2 d2) -9)))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) (fma.f64 d2 d2 -9))
(*.f64 (fma.f64 d2 d2 -9) (/.f64 d1 (+.f64 d2 -3)))
(*.f64 d1 (/.f64 (fma.f64 d2 d2 -9) (+.f64 d2 -3)))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 d1 (/.f64 (+.f64 d2 -3) (+.f64 (*.f64 d2 d2) -9)))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) (fma.f64 d2 d2 -9))
(*.f64 (fma.f64 d2 d2 -9) (/.f64 d1 (+.f64 d2 -3)))
(*.f64 d1 (/.f64 (fma.f64 d2 d2 -9) (+.f64 d2 -3)))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 d1 (/.f64 (+.f64 d2 -3) (+.f64 (*.f64 d2 d2) -9)))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) (fma.f64 d2 d2 -9))
(*.f64 (fma.f64 d2 d2 -9) (/.f64 d1 (+.f64 d2 -3)))
(*.f64 d1 (/.f64 (fma.f64 d2 d2 -9) (+.f64 d2 -3)))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 d1 (/.f64 (+.f64 d2 -3) (+.f64 (*.f64 d2 d2) -9)))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) (fma.f64 d2 d2 -9))
(*.f64 (fma.f64 d2 d2 -9) (/.f64 d1 (+.f64 d2 -3)))
(*.f64 d1 (/.f64 (fma.f64 d2 d2 -9) (+.f64 d2 -3)))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 d1 (/.f64 (+.f64 d2 -3) (+.f64 (*.f64 d2 d2) -9)))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) (fma.f64 d2 d2 -9))
(*.f64 (fma.f64 d2 d2 -9) (/.f64 d1 (+.f64 d2 -3)))
(*.f64 d1 (/.f64 (fma.f64 d2 d2 -9) (+.f64 d2 -3)))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 d1 (/.f64 (+.f64 d2 -3) (+.f64 (*.f64 d2 d2) -9)))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) (fma.f64 d2 d2 -9))
(*.f64 (fma.f64 d2 d2 -9) (/.f64 d1 (+.f64 d2 -3)))
(*.f64 d1 (/.f64 (fma.f64 d2 d2 -9) (+.f64 d2 -3)))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 d1 (/.f64 (+.f64 d2 -3) (+.f64 (*.f64 d2 d2) -9)))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) (fma.f64 d2 d2 -9))
(*.f64 (fma.f64 d2 d2 -9) (/.f64 d1 (+.f64 d2 -3)))
(*.f64 d1 (/.f64 (fma.f64 d2 d2 -9) (+.f64 d2 -3)))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 d1 (/.f64 (+.f64 d2 -3) (+.f64 (*.f64 d2 d2) -9)))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) (fma.f64 d2 d2 -9))
(*.f64 (fma.f64 d2 d2 -9) (/.f64 d1 (+.f64 d2 -3)))
(*.f64 d1 (/.f64 (fma.f64 d2 d2 -9) (+.f64 d2 -3)))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 d1 (/.f64 (+.f64 d2 -3) (+.f64 (*.f64 d2 d2) -9)))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) (fma.f64 d2 d2 -9))
(*.f64 (fma.f64 d2 d2 -9) (/.f64 d1 (+.f64 d2 -3)))
(*.f64 d1 (/.f64 (fma.f64 d2 d2 -9) (+.f64 d2 -3)))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 d1 (/.f64 (+.f64 d2 -3) (+.f64 (*.f64 d2 d2) -9)))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) (fma.f64 d2 d2 -9))
(*.f64 (fma.f64 d2 d2 -9) (/.f64 d1 (+.f64 d2 -3)))
(*.f64 d1 (/.f64 (fma.f64 d2 d2 -9) (+.f64 d2 -3)))
(/.f64 (*.f64 d1 (-.f64 (pow.f64 d2 2) 9)) (-.f64 d2 3))
(/.f64 d1 (/.f64 (+.f64 d2 -3) (+.f64 (*.f64 d2 d2) -9)))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) (fma.f64 d2 d2 -9))
(*.f64 (fma.f64 d2 d2 -9) (/.f64 d1 (+.f64 d2 -3)))
(*.f64 d1 (/.f64 (fma.f64 d2 d2 -9) (+.f64 d2 -3)))
(*.f64 -9 d1)
(*.f64 d1 -9)
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 (pow.f64 d2 2) d1)
(*.f64 d1 (*.f64 d2 d2))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 (pow.f64 d2 2) d1)
(*.f64 d1 (*.f64 d2 d2))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(+.f64 (*.f64 -9 d1) (*.f64 (pow.f64 d2 2) d1))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))
(*.f64 d1 (-.f64 (pow.f64 d2 2) 9))
(*.f64 d1 (+.f64 -9 (*.f64 d2 d2)))
(*.f64 d1 (fma.f64 d2 d2 -9))

eval34.0ms (1%)

Compiler

Compiled 1495 to 1046 computations (30% saved)

prune20.0ms (0.6%)

Pruning

8 alts after pruning (1 fresh and 7 done)

PrunedKeptTotal
New1131114
Fresh000
Picked101
Done077
Total1148122
Error
0b
Counts
122 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
42.4b
(/.f64 (*.f64 d1 -9) (+.f64 d2 -3))
19.8b
(*.f64 d1 (+.f64 d2 3))
42.5b
(*.f64 d1 3)
40.3b
(*.f64 d2 d1)
23.1b
(*.f64 d1 (+.f64 3 d3))
0.0b
(fma.f64 d1 3 (*.f64 d1 (+.f64 d2 d3)))
42.4b
(*.f64 d1 d3)
Compiler

Compiled 65 to 47 computations (27.7% saved)

localize9.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(/.f64 (*.f64 d1 -9) (+.f64 d2 -3))
Compiler

Compiled 20 to 14 computations (30% saved)

series4.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
1.0ms
d1
@0
(/.f64 (*.f64 d1 -9) (+.f64 d2 -3))
1.0ms
d2
@inf
(/.f64 (*.f64 d1 -9) (+.f64 d2 -3))
1.0ms
d2
@0
(/.f64 (*.f64 d1 -9) (+.f64 d2 -3))
1.0ms
d1
@inf
(/.f64 (*.f64 d1 -9) (+.f64 d2 -3))
1.0ms
d1
@-inf
(/.f64 (*.f64 d1 -9) (+.f64 d2 -3))

rewrite61.0ms (1.7%)

Algorithm
batch-egg-rewrite
Rules
977×pow1_binary64
915×add-log-exp_binary64
915×log1p-expm1-u_binary64
915×expm1-log1p-u_binary64
91×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0810
117910
2237410
Stop Event
node limit
Counts
1 → 44
Calls
Call 1
Inputs
(/.f64 (*.f64 d1 -9) (+.f64 d2 -3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (/.f64 1 (*.f64 (+.f64 d2 -3) -1/9)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 d1 (*.f64 -9 (/.f64 1 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -9 (/.f64 d1 (+.f64 d2 -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -9 (*.f64 d1 (/.f64 1 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 -9) (/.f64 1 (+.f64 d2 -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))) (pow.f64 (cbrt.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))) 2) (cbrt.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 d1 -9)) 2) (*.f64 (cbrt.f64 (*.f64 d1 -9)) (/.f64 1 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))) (sqrt.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 d1 -9)) (*.f64 (sqrt.f64 (*.f64 d1 -9)) (/.f64 1 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 d1 9) (/.f64 1 (+.f64 3 (neg.f64 d2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 d2 -3)) (*.f64 d1 -9))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 d1 1) (/.f64 -9 (+.f64 d2 -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 d1 (+.f64 d2 -3)) -9)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 d1 -9)) 2) 1) (/.f64 (cbrt.f64 (*.f64 d1 -9)) (+.f64 d2 -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (*.f64 d1 -9)) 1) (/.f64 (sqrt.f64 (*.f64 d1 -9)) (+.f64 d2 -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 d1 (pow.f64 (cbrt.f64 (+.f64 d2 -3)) 2)) (/.f64 -9 (cbrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 -9 (pow.f64 (cbrt.f64 (+.f64 d2 -3)) 2)) (/.f64 d1 (cbrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (+.f64 d2 -3)) 2)) (/.f64 (*.f64 d1 -9) (cbrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 d1 -9)) 2) (pow.f64 (cbrt.f64 (+.f64 d2 -3)) 2)) (cbrt.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (*.f64 d1 -9)) (pow.f64 (cbrt.f64 (+.f64 d2 -3)) 2)) (/.f64 (sqrt.f64 (*.f64 d1 -9)) (cbrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 d1 (sqrt.f64 (+.f64 d2 -3))) (/.f64 -9 (sqrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 -9 (sqrt.f64 (+.f64 d2 -3))) (/.f64 d1 (sqrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (+.f64 d2 -3))) (/.f64 (*.f64 d1 -9) (sqrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 d1 -9)) 2) (sqrt.f64 (+.f64 d2 -3))) (/.f64 (cbrt.f64 (*.f64 d1 -9)) (sqrt.f64 (+.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 d1 -9) (+.f64 -27 (pow.f64 d2 3))) (fma.f64 d2 d2 (-.f64 9 (*.f64 d2 -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 d1 -9) (fma.f64 d2 d2 -9)) (+.f64 d2 3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 d2 -3) (*.f64 d1 -9)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (*.f64 d1 -9) (+.f64 3 (neg.f64 d2))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (*.f64 d1 -9) 3) (pow.f64 (+.f64 d2 -3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))))))))

simplify107.0ms (3%)

Algorithm
egg-herbie
Rules
672×associate-/l*_binary64
666×fma-def_binary64
529×associate-/l/_binary64
501×associate-*l/_binary64
439×distribute-rgt-out_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
041353
1110351
2285318
3822304
43141304
57522304
67996304
Stop Event
node limit
Counts
68 → 62
Calls
Call 1
Inputs
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 3 d1)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 1/3 (*.f64 (pow.f64 d2 2) d1)) (*.f64 d2 d1)))
(+.f64 (*.f64 1/9 (*.f64 (pow.f64 d2 3) d1)) (+.f64 (*.f64 3 d1) (+.f64 (*.f64 1/3 (*.f64 (pow.f64 d2 2) d1)) (*.f64 d2 d1))))
(*.f64 -9 (/.f64 d1 d2))
(+.f64 (*.f64 -9 (/.f64 d1 d2)) (*.f64 -27 (/.f64 d1 (pow.f64 d2 2))))
(+.f64 (*.f64 -81 (/.f64 d1 (pow.f64 d2 3))) (+.f64 (*.f64 -9 (/.f64 d1 d2)) (*.f64 -27 (/.f64 d1 (pow.f64 d2 2)))))
(+.f64 (*.f64 -81 (/.f64 d1 (pow.f64 d2 3))) (+.f64 (*.f64 -9 (/.f64 d1 d2)) (+.f64 (*.f64 -27 (/.f64 d1 (pow.f64 d2 2))) (*.f64 -243 (/.f64 d1 (pow.f64 d2 4))))))
(*.f64 -9 (/.f64 d1 d2))
(+.f64 (*.f64 -9 (/.f64 d1 d2)) (*.f64 -27 (/.f64 d1 (pow.f64 d2 2))))
(+.f64 (*.f64 -81 (/.f64 d1 (pow.f64 d2 3))) (+.f64 (*.f64 -9 (/.f64 d1 d2)) (*.f64 -27 (/.f64 d1 (pow.f64 d2 2)))))
(+.f64 (*.f64 -81 (/.f64 d1 (pow.f64 d2 3))) (+.f64 (*.f64 -9 (/.f64 d1 d2)) (+.f64 (*.f64 -27 (/.f64 d1 (pow.f64 d2 2))) (*.f64 -243 (/.f64 d1 (pow.f64 d2 4))))))
Outputs
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))
(/.f64 d1 (-.f64 (/.f64 d2 -9) -1/3))
(/.f64 d1 (+.f64 (/.f64 d2 -9) 1/3))
(/.f64 d1 (+.f64 1/3 (/.f64 d2 -9)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))
(/.f64 d1 (-.f64 (/.f64 d2 -9) -1/3))
(/.f64 d1 (+.f64 (/.f64 d2 -9) 1/3))
(/.f64 d1 (+.f64 1/3 (/.f64 d2 -9)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))
(/.f64 d1 (-.f64 (/.f64 d2 -9) -1/3))
(/.f64 d1 (+.f64 (/.f64 d2 -9) 1/3))
(/.f64 d1 (+.f64 1/3 (/.f64 d2 -9)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))
(/.f64 d1 (-.f64 (/.f64 d2 -9) -1/3))
(/.f64 d1 (+.f64 (/.f64 d2 -9) 1/3))
(/.f64 d1 (+.f64 1/3 (/.f64 d2 -9)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))
(/.f64 d1 (-.f64 (/.f64 d2 -9) -1/3))
(/.f64 d1 (+.f64 (/.f64 d2 -9) 1/3))
(/.f64 d1 (+.f64 1/3 (/.f64 d2 -9)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))
(/.f64 d1 (-.f64 (/.f64 d2 -9) -1/3))
(/.f64 d1 (+.f64 (/.f64 d2 -9) 1/3))
(/.f64 d1 (+.f64 1/3 (/.f64 d2 -9)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))
(/.f64 d1 (-.f64 (/.f64 d2 -9) -1/3))
(/.f64 d1 (+.f64 (/.f64 d2 -9) 1/3))
(/.f64 d1 (+.f64 1/3 (/.f64 d2 -9)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))
(/.f64 d1 (-.f64 (/.f64 d2 -9) -1/3))
(/.f64 d1 (+.f64 (/.f64 d2 -9) 1/3))
(/.f64 d1 (+.f64 1/3 (/.f64 d2 -9)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))
(/.f64 d1 (-.f64 (/.f64 d2 -9) -1/3))
(/.f64 d1 (+.f64 (/.f64 d2 -9) 1/3))
(/.f64 d1 (+.f64 1/3 (/.f64 d2 -9)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))
(/.f64 d1 (-.f64 (/.f64 d2 -9) -1/3))
(/.f64 d1 (+.f64 (/.f64 d2 -9) 1/3))
(/.f64 d1 (+.f64 1/3 (/.f64 d2 -9)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))
(/.f64 d1 (-.f64 (/.f64 d2 -9) -1/3))
(/.f64 d1 (+.f64 (/.f64 d2 -9) 1/3))
(/.f64 d1 (+.f64 1/3 (/.f64 d2 -9)))
(*.f64 -9 (/.f64 d1 (-.f64 d2 3)))
(*.f64 -9 (/.f64 d1 (+.f64 d2 -3)))
(/.f64 d1 (-.f64 (/.f64 d2 -9) -1/3))
(/.f64 d1 (+.f64 (/.f64 d2 -9) 1/3))
(/.f64 d1 (+.f64 1/3 (/.f64 d2 -9)))
(*.f64 3 d1)
(*.f64 d1 3)
(+.f64 (*.f64 3 d1) (*.f64 d2 d1))
(*.f64 d1 (+.f64 3 d2))
(*.f64 d1 (+.f64 d2 3))
(+.f64 (*.f64 3 d1) (+.f64 (*.f64 1/3 (*.f64 (pow.f64 d2 2) d1)) (*.f64 d2 d1)))
(fma.f64 3 d1 (fma.f64 1/3 (*.f64 d1 (*.f64 d2 d2)) (*.f64 d1 d2)))
(fma.f64 d1 3 (*.f64 d1 (+.f64 d2 (*.f64 (*.f64 1/3 d2) d2))))
(*.f64 d1 (+.f64 3 (fma.f64 1/3 (*.f64 d2 d2) d2)))
(*.f64 d1 (fma.f64 (fma.f64 d2 1/3 1) d2 3))
(+.f64 (*.f64 1/9 (*.f64 (pow.f64 d2 3) d1)) (+.f64 (*.f64 3 d1) (+.f64 (*.f64 1/3 (*.f64 (pow.f64 d2 2) d1)) (*.f64 d2 d1))))
(fma.f64 1/9 (*.f64 d1 (pow.f64 d2 3)) (fma.f64 3 d1 (fma.f64 1/3 (*.f64 d1 (*.f64 d2 d2)) (*.f64 d1 d2))))
(fma.f64 1/9 (*.f64 d1 (pow.f64 d2 3)) (fma.f64 d1 3 (*.f64 d1 (+.f64 d2 (*.f64 (*.f64 1/3 d2) d2)))))
(*.f64 d1 (+.f64 (fma.f64 1/3 (*.f64 d2 d2) d2) (fma.f64 1/9 (pow.f64 d2 3) 3)))
(*.f64 d1 (fma.f64 (fma.f64 d2 1/3 1) d2 (fma.f64 1/9 (pow.f64 d2 3) 3)))
(*.f64 -9 (/.f64 d1 d2))
(/.f64 -9 (/.f64 d2 d1))
(+.f64 (*.f64 -9 (/.f64 d1 d2)) (*.f64 -27 (/.f64 d1 (pow.f64 d2 2))))
(fma.f64 -9 (/.f64 d1 d2) (*.f64 -27 (/.f64 d1 (*.f64 d2 d2))))
(fma.f64 -9 (/.f64 d1 d2) (*.f64 (/.f64 -27 d2) (/.f64 d1 d2)))
(*.f64 (/.f64 d1 d2) (+.f64 -9 (/.f64 -27 d2)))
(+.f64 (*.f64 -81 (/.f64 d1 (pow.f64 d2 3))) (+.f64 (*.f64 -9 (/.f64 d1 d2)) (*.f64 -27 (/.f64 d1 (pow.f64 d2 2)))))
(fma.f64 -81 (/.f64 d1 (pow.f64 d2 3)) (fma.f64 -9 (/.f64 d1 d2) (*.f64 -27 (/.f64 d1 (*.f64 d2 d2)))))
(fma.f64 -81 (/.f64 d1 (pow.f64 d2 3)) (fma.f64 -9 (/.f64 d1 d2) (*.f64 (/.f64 -27 d2) (/.f64 d1 d2))))
(fma.f64 -81 (/.f64 d1 (pow.f64 d2 3)) (*.f64 (/.f64 d1 d2) (+.f64 -9 (/.f64 -27 d2))))
(*.f64 (/.f64 d1 d2) (+.f64 -9 (+.f64 (/.f64 -27 d2) (/.f64 -81 (*.f64 d2 d2)))))
(*.f64 (/.f64 d1 d2) (+.f64 (/.f64 -81 (*.f64 d2 d2)) (+.f64 -9 (/.f64 -27 d2))))
(+.f64 (*.f64 -81 (/.f64 d1 (pow.f64 d2 3))) (+.f64 (*.f64 -9 (/.f64 d1 d2)) (+.f64 (*.f64 -27 (/.f64 d1 (pow.f64 d2 2))) (*.f64 -243 (/.f64 d1 (pow.f64 d2 4))))))
(fma.f64 -81 (/.f64 d1 (pow.f64 d2 3)) (fma.f64 -9 (/.f64 d1 d2) (fma.f64 -27 (/.f64 d1 (*.f64 d2 d2)) (*.f64 -243 (/.f64 d1 (pow.f64 d2 4))))))
(fma.f64 -81 (/.f64 d1 (pow.f64 d2 3)) (fma.f64 -9 (/.f64 d1 d2) (fma.f64 -243 (/.f64 d1 (pow.f64 d2 4)) (*.f64 (/.f64 -27 d2) (/.f64 d1 d2)))))
(fma.f64 -81 (/.f64 d1 (pow.f64 d2 3)) (fma.f64 -243 (/.f64 d1 (pow.f64 d2 4)) (*.f64 (/.f64 d1 d2) (+.f64 -9 (/.f64 -27 d2)))))
(fma.f64 (/.f64 d1 d2) (+.f64 -9 (/.f64 -27 d2)) (*.f64 (/.f64 d1 (pow.f64 d2 3)) (+.f64 -81 (/.f64 -243 d2))))
(*.f64 -9 (/.f64 d1 d2))
(/.f64 -9 (/.f64 d2 d1))
(+.f64 (*.f64 -9 (/.f64 d1 d2)) (*.f64 -27 (/.f64 d1 (pow.f64 d2 2))))
(fma.f64 -9 (/.f64 d1 d2) (*.f64 -27 (/.f64 d1 (*.f64 d2 d2))))
(fma.f64 -9 (/.f64 d1 d2) (*.f64 (/.f64 -27 d2) (/.f64 d1 d2)))
(*.f64 (/.f64 d1 d2) (+.f64 -9 (/.f64 -27 d2)))
(+.f64 (*.f64 -81 (/.f64 d1 (pow.f64 d2 3))) (+.f64 (*.f64 -9 (/.f64 d1 d2)) (*.f64 -27 (/.f64 d1 (pow.f64 d2 2)))))
(fma.f64 -81 (/.f64 d1 (pow.f64 d2 3)) (fma.f64 -9 (/.f64 d1 d2) (*.f64 -27 (/.f64 d1 (*.f64 d2 d2)))))
(fma.f64 -81 (/.f64 d1 (pow.f64 d2 3)) (fma.f64 -9 (/.f64 d1 d2) (*.f64 (/.f64 -27 d2) (/.f64 d1 d2))))
(fma.f64 -81 (/.f64 d1 (pow.f64 d2 3)) (*.f64 (/.f64 d1 d2) (+.f64 -9 (/.f64 -27 d2))))
(*.f64 (/.f64 d1 d2) (+.f64 -9 (+.f64 (/.f64 -27 d2) (/.f64 -81 (*.f64 d2 d2)))))
(*.f64 (/.f64 d1 d2) (+.f64 (/.f64 -81 (*.f64 d2 d2)) (+.f64 -9 (/.f64 -27 d2))))
(+.f64 (*.f64 -81 (/.f64 d1 (pow.f64 d2 3))) (+.f64 (*.f64 -9 (/.f64 d1 d2)) (+.f64 (*.f64 -27 (/.f64 d1 (pow.f64 d2 2))) (*.f64 -243 (/.f64 d1 (pow.f64 d2 4))))))
(fma.f64 -81 (/.f64 d1 (pow.f64 d2 3)) (fma.f64 -9 (/.f64 d1 d2) (fma.f64 -27 (/.f64 d1 (*.f64 d2 d2)) (*.f64 -243 (/.f64 d1 (pow.f64 d2 4))))))
(fma.f64 -81 (/.f64 d1 (pow.f64 d2 3)) (fma.f64 -9 (/.f64 d1 d2) (fma.f64 -243 (/.f64 d1 (pow.f64 d2 4)) (*.f64 (/.f64 -27 d2) (/.f64 d1 d2)))))
(fma.f64 -81 (/.f64 d1 (pow.f64 d2 3)) (fma.f64 -243 (/.f64 d1 (pow.f64 d2 4)) (*.f64 (/.f64 d1 d2) (+.f64 -9 (/.f64 -27 d2)))))
(fma.f64 (/.f64 d1 d2) (+.f64 -9 (/.f64 -27 d2)) (*.f64 (/.f64 d1 (pow.f64 d2 3)) (+.f64 -81 (/.f64 -243 d2))))

eval17.0ms (0.5%)

Compiler

Compiled 758 to 568 computations (25.1% saved)

prune25.0ms (0.7%)

Pruning

10 alts after pruning (2 fresh and 8 done)

PrunedKeptTotal
New60262
Fresh000
Picked011
Done077
Total601070
Error
0b
Counts
70 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
42.4b
(/.f64 (*.f64 d1 -9) (+.f64 d2 -3))
42.4b
(*.f64 -9 (*.f64 d1 (/.f64 1 (+.f64 d2 -3))))
0.0b
(fma.f64 d1 3 (*.f64 d1 (+.f64 d2 d3)))
42.4b
(*.f64 (/.f64 d1 (+.f64 d2 -3)) -9)
19.8b
(*.f64 d1 (+.f64 d2 3))
42.5b
(*.f64 d1 3)
40.3b
(*.f64 d2 d1)
23.1b
(*.f64 d1 (+.f64 3 d3))
42.4b
(*.f64 d1 d3)
Compiler

Compiled 87 to 65 computations (25.3% saved)

regimes79.0ms (2.2%)

Counts
13 → 1
Calls
Call 1
Inputs
(*.f64 d1 3)
(*.f64 d1 d3)
(*.f64 d2 d1)
(*.f64 d1 (+.f64 d2 3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) -9)
(/.f64 (*.f64 d1 -9) (+.f64 d2 -3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 -9 (*.f64 d1 (/.f64 1 (+.f64 d2 -3))))
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
(fma.f64 d1 3 (*.f64 d1 (+.f64 d2 d3)))
(/.f64 (*.f64 (fma.f64 d2 d2 -9) d1) (+.f64 d2 -3))
(/.f64 (*.f64 (-.f64 9 (pow.f64 (+.f64 d2 d3) 2)) d1) (-.f64 3 (+.f64 d2 d3)))
Outputs
(fma.f64 d1 3 (*.f64 d1 (+.f64 d2 d3)))
Calls

4 calls:

54.0ms
d3
8.0ms
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
7.0ms
d2
7.0ms
d1
Results
ErrorSegmentsBranch
0.0b1d1
0.0b1d2
0.0b1d3
0.0b1(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
Compiler

Compiled 122 to 74 computations (39.3% saved)

regimes62.0ms (1.7%)

Counts
10 → 1
Calls
Call 1
Inputs
(*.f64 d1 3)
(*.f64 d1 d3)
(*.f64 d2 d1)
(*.f64 d1 (+.f64 d2 3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) -9)
(/.f64 (*.f64 d1 -9) (+.f64 d2 -3))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(*.f64 -9 (*.f64 d1 (/.f64 1 (+.f64 d2 -3))))
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
Outputs
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
Calls

4 calls:

9.0ms
d1
6.0ms
(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
6.0ms
d2
6.0ms
d3
Results
ErrorSegmentsBranch
0.1b1d1
0.1b1d2
0.1b1d3
0.1b1(+.f64 (+.f64 (*.f64 d1 3) (*.f64 d1 d2)) (*.f64 d1 d3))
Compiler

Compiled 89 to 57 computations (36% saved)

regimes52.0ms (1.5%)

Counts
7 → 2
Calls
Call 1
Inputs
(*.f64 d1 3)
(*.f64 d1 d3)
(*.f64 d2 d1)
(*.f64 d1 (+.f64 d2 3))
(*.f64 d1 (+.f64 3 d3))
(*.f64 (/.f64 d1 (+.f64 d2 -3)) -9)
(/.f64 (*.f64 d1 -9) (+.f64 d2 -3))
Outputs
(*.f64 d1 (+.f64 d2 3))
(*.f64 d1 (+.f64 3 d3))
Calls

3 calls:

29.0ms
d1
13.0ms
d2
9.0ms
d3
Results
ErrorSegmentsBranch
16.1b6d1
2.6b2d2
4.0b2d3
Compiler

Compiled 48 to 32 computations (33.3% saved)

bsearch57.0ms (1.6%)

Algorithm
binary-search
Steps
TimeLeftRight
57.0ms
-9.976291868209454e-7
-1.4170929034552785e-23
Compiler

Compiled 20 to 14 computations (30% saved)

regimes40.0ms (1.1%)

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

3 calls:

20.0ms
d2
11.0ms
d1
7.0ms
d3
Results
ErrorSegmentsBranch
18.6b3d1
14.0b4d2
4.4b2d3
Compiler

Compiled 29 to 19 computations (34.5% saved)

bsearch63.0ms (1.8%)

Algorithm
binary-search
Steps
TimeLeftRight
63.0ms
7650465607696317.0
8320603275372889.0
Compiler

Compiled 20 to 14 computations (30% saved)

regimes104.0ms (2.9%)

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

3 calls:

70.0ms
d1
22.0ms
d2
10.0ms
d3
Results
ErrorSegmentsBranch
30.0b8d1
14.9b5d2
17.3b3d3
Compiler

Compiled 24 to 16 computations (33.3% saved)

bsearch85.0ms (2.4%)

Algorithm
binary-search
Steps
TimeLeftRight
21.0ms
-9.466003572685604e-262
-8.936305182845431e-274
25.0ms
-1.7715181316143138e-207
-4.659652235667299e-208
21.0ms
-1.5922016899375404e-155
-3.353104528657353e-157
18.0ms
-3.9054118664969426
-0.15283485140088868
Compiler

Compiled 20 to 14 computations (30% saved)

regimes73.0ms (2%)

Accuracy

Total -37.3b remaining (-155.3%)

Threshold costs -37.3b (-155.3%)

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

3 calls:

40.0ms
d3
17.0ms
d2
15.0ms
d1
Results
ErrorSegmentsBranch
36.0b3d1
34.4b5d2
24.0b2d3
Compiler

Compiled 21 to 15 computations (28.6% saved)

bsearch18.0ms (0.5%)

Algorithm
binary-search
Steps
TimeLeftRight
18.0ms
2.4186819745042525e-5
23.506740870337637
Compiler

Compiled 20 to 14 computations (30% saved)

simplify10.0ms (0.3%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
039120
150120
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(fma.f64 d1 3 (*.f64 d1 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(if (<=.f64 d2 -1177792658543933/1180591620717411303424) (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 (+.f64 3 d3)))
(if (<=.f64 d3 7650465607696317) (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 d3))
(if (<=.f64 d2 -2198551428335493/562949953421312) (*.f64 d2 d1) (if (<=.f64 d2 -3845701984359447/241533595188578646543459493183249209018682958106652187416077203215719946393097526533512110411370161122653976001968886073585317416315186728483931792091692546793561300926464) (*.f64 d1 3) (if (<=.f64 d2 -640357367268291/361473786714651839609485931802192366508973300717001923159475447150424810286233407987951861887389439612274926783780351561999781998832434041296198795326329101623141899709787663433296905279066051548640942013290819886814068736) (*.f64 d1 d3) (if (<=.f64 d2 -2097503448768645/2215827865120445285436604169234485268788427414982608644747394113713414456189281304992986194038624093815384393617798347846350945898212351959632084639523021319185153902243763020549247279516306127414463752183841820368271691660401046407456843466086176161485977628013706077372678144) (*.f64 d1 3) (*.f64 d1 d3)))))
(if (<=.f64 d3 3569344590349955/147573952589676412928) (*.f64 d1 3) (*.f64 d1 d3))
(*.f64 d1 3)
Outputs
(fma.f64 d1 3 (*.f64 d1 (+.f64 d2 d3)))
(*.f64 d1 (+.f64 3 (+.f64 d2 d3)))
(if (<=.f64 d2 -1177792658543933/1180591620717411303424) (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 (+.f64 3 d3)))
(if (<=.f64 d2 -1177792658543933/1180591620717411303424) (*.f64 d1 (+.f64 3 d2)) (*.f64 d1 (+.f64 3 d3)))
(if (<=.f64 d3 7650465607696317) (*.f64 d1 (+.f64 d2 3)) (*.f64 d1 d3))
(if (<=.f64 d3 7650465607696317) (*.f64 d1 (+.f64 3 d2)) (*.f64 d1 d3))
(if (<=.f64 d2 -2198551428335493/562949953421312) (*.f64 d2 d1) (if (<=.f64 d2 -3845701984359447/241533595188578646543459493183249209018682958106652187416077203215719946393097526533512110411370161122653976001968886073585317416315186728483931792091692546793561300926464) (*.f64 d1 3) (if (<=.f64 d2 -640357367268291/361473786714651839609485931802192366508973300717001923159475447150424810286233407987951861887389439612274926783780351561999781998832434041296198795326329101623141899709787663433296905279066051548640942013290819886814068736) (*.f64 d1 d3) (if (<=.f64 d2 -2097503448768645/2215827865120445285436604169234485268788427414982608644747394113713414456189281304992986194038624093815384393617798347846350945898212351959632084639523021319185153902243763020549247279516306127414463752183841820368271691660401046407456843466086176161485977628013706077372678144) (*.f64 d1 3) (*.f64 d1 d3)))))
(if (<=.f64 d2 -2198551428335493/562949953421312) (*.f64 d1 d2) (if (<=.f64 d2 -3845701984359447/241533595188578646543459493183249209018682958106652187416077203215719946393097526533512110411370161122653976001968886073585317416315186728483931792091692546793561300926464) (*.f64 d1 3) (if (<=.f64 d2 -640357367268291/361473786714651839609485931802192366508973300717001923159475447150424810286233407987951861887389439612274926783780351561999781998832434041296198795326329101623141899709787663433296905279066051548640942013290819886814068736) (*.f64 d1 d3) (if (<=.f64 d2 -2097503448768645/2215827865120445285436604169234485268788427414982608644747394113713414456189281304992986194038624093815384393617798347846350945898212351959632084639523021319185153902243763020549247279516306127414463752183841820368271691660401046407456843466086176161485977628013706077372678144) (*.f64 d1 3) (*.f64 d1 d3)))))
(if (<=.f64 d3 3569344590349955/147573952589676412928) (*.f64 d1 3) (*.f64 d1 d3))
(*.f64 d1 3)
Compiler

Compiled 106 to 71 computations (33% saved)

soundness10.0ms (0.3%)

Algorithm
egg-herbie
Rules
25×fma-def_binary64
+-commutative_binary64
*-commutative_binary64
distribute-lft-out_binary64
associate-+r+_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01013
12010
24610
37410
48510
58610
Stop Event
saturated
Compiler

Compiled 46 to 31 computations (32.6% saved)

end145.0ms (4%)

Remove

(sort d2 d3)

Compiler

Compiled 110 to 64 computations (41.8% saved)

Profiling

Loading profile data...