Details

Time bar (total: 6.0s)

analyze129.0ms (2.1%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.9%0.1%0
0%99.9%0.1%1
0%99.9%0.1%2
0%99.9%0.1%3
0%74.9%25.1%4
12.5%62.4%25.1%5
31.2%31.2%37.6%6
37.5%25%37.6%7
40.6%15.6%43.8%8
42.9%11.7%45.4%9
44.1%7.4%48.5%10
45.1%5.7%49.3%11
45.6%3.6%50.8%12
46%2.8%51.2%13
46.2%1.8%52%14
Compiler

Compiled 17 to 14 computations (17.6% saved)

sample1.9s (31.9%)

Results
1.7s8256×body128valid
44.0ms228×body128invalid
Compiler

Compiled 50 to 41 computations (18% saved)

simplify198.0ms (3.3%)

Algorithm
egg-herbie
Rules
1205×fma-neg_binary64
900×fma-def_binary64
326×associate-/l*_binary64
318×cancel-sign-sub-inv_binary64
290×distribute-rgt-neg-in_binary64
Counts
1 → 2
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01321
12818
26818
314516
425716
541116
686116
7137116
8238616
9249316
10267516
11260716
12258116
13258116
14353116
15336416
16336416
17336416
18336416
19317116

prune6.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.2b
Counts
3 → 2
Alt Table
StatusErrorProgram
0.4b
(*.f64 (sqrt.f64 x) (fma.f64 3 (+.f64 y (/.f64 1/9 x)) -3))
0.4b
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
Compiler

Compiled 85 to 66 computations (22.4% saved)

localize16.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(+.f64 y (/.f64 1 (*.f64 x 9)))
0.2b
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.3b
(/.f64 1 (*.f64 x 9))
0.3b
(*.f64 3 (sqrt.f64 x))

series66.0ms (1.1%)

Counts
4 → 48
Calls

4 calls:

42.0ms
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
14.0ms
(+.f64 y (/.f64 1 (*.f64 x 9)))
8.0ms
(*.f64 3 (sqrt.f64 x))
2.0ms
(/.f64 1 (*.f64 x 9))

rewrite56.0ms (0.9%)

Algorithm
rewrite-expression-head
Rules
58×*-un-lft-identity_binary64
37×add-sqr-sqrt_binary64
30×prod-diff_binary64
29×add-cube-cbrt_binary64
22×add-exp-log_binary64
Counts
4 → 140
Calls

4 calls:

21.0ms
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
6.0ms
(+.f64 y (/.f64 1 (*.f64 x 9)))
6.0ms
(*.f64 3 (sqrt.f64 x))
5.0ms
(/.f64 1 (*.f64 x 9))

simplify112.0ms (1.9%)

Algorithm
egg-herbie
Rules
625×times-frac_binary64
456×distribute-rgt-in_binary64
422×distribute-lft-in_binary64
305×fma-def_binary64
289×associate-/l*_binary64
Counts
188 → 171
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01742841
14122251
212412225
350982225

prune375.0ms (6.2%)

Pruning

10 alts after pruning (10 fresh and 0 done)

PrunedKeptTotal
New1629171
Fresh011
Picked101
Done000
Total16310173
Error
0.0b
Counts
173 → 10
Alt Table
StatusErrorProgram
0.4b
(*.f64 (sqrt.f64 x) (fma.f64 3 (+.f64 y (/.f64 1/9 x)) -3))
27.7b
(*.f64 (sqrt.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (+.f64 (-.f64 (/.f64 1/9 x) 1) y))) (sqrt.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (+.f64 (-.f64 (/.f64 1/9 x) 1) y))))
34.9b
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (cbrt.f64 (*.f64 (*.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) (+.f64 y (/.f64 1 (*.f64 x 9)))) (+.f64 y (/.f64 1 (*.f64 x 9))))) 1))
16.9b
(*.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (+.f64 1 (sqrt.f64 (+.f64 (/.f64 1/9 x) y)))) (-.f64 (sqrt.f64 (+.f64 y (/.f64 1 (*.f64 x 9)))) 1))
0.4b
(-.f64 (+.f64 (*.f64 3 (*.f64 y (sqrt.f64 x))) (*.f64 1/3 (sqrt.f64 (/.f64 1 x)))) (*.f64 3 (sqrt.f64 x)))
0.7b
(*.f64 (*.f64 (sqrt.f64 (*.f64 3 (sqrt.f64 x))) (sqrt.f64 (*.f64 3 (sqrt.f64 x)))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
1.3b
(*.f64 (*.f64 (cbrt.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (+.f64 (-.f64 (/.f64 1/9 x) 1) y))) (cbrt.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (+.f64 (-.f64 (/.f64 1/9 x) 1) y)))) (cbrt.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (+.f64 (-.f64 (/.f64 1/9 x) 1) y))))
1.4b
(*.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 3 (sqrt.f64 x))) (cbrt.f64 (*.f64 3 (sqrt.f64 x)))) (cbrt.f64 (*.f64 3 (sqrt.f64 x)))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
19.8b
(*.f64 (cbrt.f64 (*.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (*.f64 3 (sqrt.f64 x))) (*.f64 3 (sqrt.f64 x)))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.9b
(*.f64 (*.f64 (*.f64 3 (fabs.f64 (cbrt.f64 x))) (sqrt.f64 (cbrt.f64 x))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
Compiler

Compiled 4397 to 3310 computations (24.7% saved)

localize21.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 y (sqrt.f64 x))
0.3b
(*.f64 3 (*.f64 y (sqrt.f64 x)))
0.3b
(*.f64 3 (sqrt.f64 x))
0.4b
(*.f64 1/3 (sqrt.f64 (/.f64 1 x)))

series40.0ms (0.7%)

Counts
3 → 0
Calls

3 calls:

16.0ms
(*.f64 3 (*.f64 y (sqrt.f64 x)))
16.0ms
(*.f64 y (sqrt.f64 x))
8.0ms
(*.f64 1/3 (sqrt.f64 (/.f64 1 x)))

rewrite32.0ms (0.5%)

Algorithm
rewrite-expression-head
Rules
29×add-sqr-sqrt_binary64
23×associate-*r*_binary64
20×sqrt-prod_binary64
17×*-un-lft-identity_binary64
16×add-cube-cbrt_binary64
Counts
3 → 81
Calls

3 calls:

10.0ms
(*.f64 1/3 (sqrt.f64 (/.f64 1 x)))
7.0ms
(*.f64 3 (*.f64 y (sqrt.f64 x)))
6.0ms
(*.f64 y (sqrt.f64 x))

simplify149.0ms (2.5%)

Algorithm
egg-herbie
Rules
923×fma-def_binary64
458×unswap-sqr_binary64
457×associate-*l*_binary64
344×*-commutative_binary64
324×associate-/r*_binary64
Counts
81 → 114
Iterations

Useful iterations: 5 (0.0ms)

IterNodesCost
0112894
1200843
2485842
31076842
41485842
52218801
62929801
73312801
84823801
94913801

prune299.0ms (4.9%)

Pruning

11 alts after pruning (11 fresh and 0 done)

PrunedKeptTotal
New1354139
Fresh279
Picked101
Done000
Total13811149
Error
0.0b
Counts
149 → 11
Alt Table
StatusErrorProgram
0.3b
(-.f64 (+.f64 (*.f64 3 (*.f64 y (sqrt.f64 x))) (/.f64 1/3 (sqrt.f64 x))) (*.f64 3 (sqrt.f64 x)))
34.9b
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (cbrt.f64 (*.f64 (*.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) (+.f64 y (/.f64 1 (*.f64 x 9)))) (+.f64 y (/.f64 1 (*.f64 x 9))))) 1))
16.9b
(*.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (+.f64 1 (sqrt.f64 (+.f64 (/.f64 1/9 x) y)))) (-.f64 (sqrt.f64 (+.f64 y (/.f64 1 (*.f64 x 9)))) 1))
0.9b
(*.f64 (*.f64 (*.f64 3 (fabs.f64 (cbrt.f64 x))) (sqrt.f64 (cbrt.f64 x))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.5b
(-.f64 (+.f64 (*.f64 3 (*.f64 y (sqrt.f64 x))) (*.f64 (sqrt.f64 (/.f64 1/3 (sqrt.f64 x))) (sqrt.f64 (/.f64 1/3 (sqrt.f64 x))))) (*.f64 3 (sqrt.f64 x)))
0.4b
(*.f64 (sqrt.f64 x) (fma.f64 3 (+.f64 y (/.f64 1/9 x)) -3))
0.7b
(*.f64 (*.f64 (sqrt.f64 (*.f64 3 (sqrt.f64 x))) (sqrt.f64 (*.f64 3 (sqrt.f64 x)))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
1.4b
(*.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 3 (sqrt.f64 x))) (cbrt.f64 (*.f64 3 (sqrt.f64 x)))) (cbrt.f64 (*.f64 3 (sqrt.f64 x)))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
19.8b
(*.f64 (cbrt.f64 (*.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (*.f64 3 (sqrt.f64 x))) (*.f64 3 (sqrt.f64 x)))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.7b
(-.f64 (+.f64 (*.f64 3 (*.f64 (*.f64 (cbrt.f64 (*.f64 y (sqrt.f64 x))) (cbrt.f64 (*.f64 y (sqrt.f64 x)))) (cbrt.f64 (*.f64 y (sqrt.f64 x))))) (*.f64 1/3 (sqrt.f64 (/.f64 1 x)))) (*.f64 3 (sqrt.f64 x)))
0.4b
(-.f64 (+.f64 (*.f64 (*.f64 (cbrt.f64 3) (cbrt.f64 3)) (*.f64 (cbrt.f64 3) (*.f64 y (sqrt.f64 x)))) (*.f64 1/3 (sqrt.f64 (/.f64 1 x)))) (*.f64 3 (sqrt.f64 x)))
Compiler

Compiled 3807 to 2441 computations (35.9% saved)

localize17.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 y (sqrt.f64 x))
0.3b
(*.f64 3 (*.f64 y (sqrt.f64 x)))
0.3b
(*.f64 3 (sqrt.f64 x))
0.3b
(/.f64 1/3 (sqrt.f64 x))

series18.0ms (0.3%)

Counts
1 → 0
Calls

1 calls:

18.0ms
(/.f64 1/3 (sqrt.f64 x))

rewrite8.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
18×times-frac_binary64
16×*-un-lft-identity_binary64
16×add-sqr-sqrt_binary64
16×add-cube-cbrt_binary64
12×sqrt-prod_binary64
Counts
1 → 41
Calls

1 calls:

5.0ms
(/.f64 1/3 (sqrt.f64 x))

simplify118.0ms (2%)

Algorithm
egg-herbie
Rules
1051×fma-neg_binary64
416×unswap-sqr_binary64
375×associate-/l/_binary64
356×times-frac_binary64
325×associate-/l*_binary64
Counts
41 → 45
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
068540
1101514
2165514
3221514
4353514
5469514
6645514
71189514
82252514
92826514
103214514
114235514
124855514

prune282.0ms (4.7%)

Pruning

10 alts after pruning (10 fresh and 0 done)

PrunedKeptTotal
New1292131
Fresh2810
Picked101
Done000
Total13210142
Error
0.0b
Counts
142 → 10
Alt Table
StatusErrorProgram
0.4b
(-.f64 (+.f64 (*.f64 3 (*.f64 y (sqrt.f64 x))) (/.f64 1 (/.f64 (sqrt.f64 x) 1/3))) (*.f64 3 (sqrt.f64 x)))
34.9b
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (cbrt.f64 (*.f64 (*.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) (+.f64 y (/.f64 1 (*.f64 x 9)))) (+.f64 y (/.f64 1 (*.f64 x 9))))) 1))
16.9b
(*.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (+.f64 1 (sqrt.f64 (+.f64 (/.f64 1/9 x) y)))) (-.f64 (sqrt.f64 (+.f64 y (/.f64 1 (*.f64 x 9)))) 1))
0.4b
(-.f64 (+.f64 (*.f64 (*.f64 (cbrt.f64 3) (cbrt.f64 3)) (*.f64 (*.f64 (sqrt.f64 x) y) (cbrt.f64 3))) (/.f64 1/3 (sqrt.f64 x))) (*.f64 3 (sqrt.f64 x)))
0.4b
(*.f64 (sqrt.f64 x) (fma.f64 3 (+.f64 y (/.f64 1/9 x)) -3))
0.7b
(*.f64 (*.f64 (sqrt.f64 (*.f64 3 (sqrt.f64 x))) (sqrt.f64 (*.f64 3 (sqrt.f64 x)))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
1.4b
(*.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 3 (sqrt.f64 x))) (cbrt.f64 (*.f64 3 (sqrt.f64 x)))) (cbrt.f64 (*.f64 3 (sqrt.f64 x)))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
19.8b
(*.f64 (cbrt.f64 (*.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (*.f64 3 (sqrt.f64 x))) (*.f64 3 (sqrt.f64 x)))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.7b
(-.f64 (+.f64 (*.f64 3 (*.f64 (*.f64 (cbrt.f64 (*.f64 y (sqrt.f64 x))) (cbrt.f64 (*.f64 y (sqrt.f64 x)))) (cbrt.f64 (*.f64 y (sqrt.f64 x))))) (*.f64 1/3 (sqrt.f64 (/.f64 1 x)))) (*.f64 3 (sqrt.f64 x)))
0.9b
(*.f64 (*.f64 (*.f64 3 (fabs.f64 (cbrt.f64 x))) (sqrt.f64 (cbrt.f64 x))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
Compiler

Compiled 3324 to 1869 computations (43.8% saved)

localize24.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (sqrt.f64 x) y)
0.3b
(*.f64 3 (sqrt.f64 x))
0.3b
(/.f64 1/3 (sqrt.f64 x))
0.4b
(*.f64 (*.f64 (sqrt.f64 x) y) (cbrt.f64 3))

series50.0ms (0.8%)

Counts
2 → 24
Calls

2 calls:

26.0ms
(*.f64 (*.f64 (sqrt.f64 x) y) (cbrt.f64 3))
23.0ms
(*.f64 (sqrt.f64 x) y)

rewrite18.0ms (0.3%)

Algorithm
rewrite-expression-head
Rules
11×add-sqr-sqrt_binary64
associate-*r*_binary64
add-exp-log_binary64
pow1_binary64
associate-*l*_binary64
Counts
2 → 47
Calls

2 calls:

9.0ms
(*.f64 (*.f64 (sqrt.f64 x) y) (cbrt.f64 3))
6.0ms
(*.f64 (sqrt.f64 x) y)

simplify132.0ms (2.2%)

Algorithm
egg-herbie
Rules
610×associate-/l*_binary64
550×log-div_binary64
470×times-frac_binary64
369×*-commutative_binary64
314×associate-/r*_binary64
Counts
71 → 69
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
070769
1138709
2461709
3609703
4751703
5992703
61732703
73403703
84736703
95052703

prune329.0ms (5.5%)

Pruning

10 alts after pruning (9 fresh and 1 done)

PrunedKeptTotal
New1381139
Fresh189
Picked011
Done000
Total13910149
Error
0.0b
Counts
149 → 10
Alt Table
StatusErrorProgram
0.3b
(-.f64 (+.f64 (*.f64 (*.f64 (cbrt.f64 3) (cbrt.f64 3)) (*.f64 (*.f64 (*.f64 (sqrt.f64 x) y) (cbrt.f64 (sqrt.f64 3))) (cbrt.f64 (sqrt.f64 3)))) (/.f64 1/3 (sqrt.f64 x))) (*.f64 3 (sqrt.f64 x)))
0.4b
(*.f64 (sqrt.f64 x) (fma.f64 3 (+.f64 y (/.f64 1/9 x)) -3))
0.4b
(-.f64 (+.f64 (*.f64 3 (*.f64 y (sqrt.f64 x))) (/.f64 1 (/.f64 (sqrt.f64 x) 1/3))) (*.f64 3 (sqrt.f64 x)))
16.9b
(*.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (+.f64 1 (sqrt.f64 (+.f64 (/.f64 1/9 x) y)))) (-.f64 (sqrt.f64 (+.f64 y (/.f64 1 (*.f64 x 9)))) 1))
0.4b
(-.f64 (+.f64 (*.f64 (*.f64 (cbrt.f64 3) (cbrt.f64 3)) (*.f64 (*.f64 (sqrt.f64 x) y) (cbrt.f64 3))) (/.f64 1/3 (sqrt.f64 x))) (*.f64 3 (sqrt.f64 x)))
0.7b
(*.f64 (*.f64 (sqrt.f64 (*.f64 3 (sqrt.f64 x))) (sqrt.f64 (*.f64 3 (sqrt.f64 x)))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
1.4b
(*.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 3 (sqrt.f64 x))) (cbrt.f64 (*.f64 3 (sqrt.f64 x)))) (cbrt.f64 (*.f64 3 (sqrt.f64 x)))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
19.8b
(*.f64 (cbrt.f64 (*.f64 (*.f64 (*.f64 3 (sqrt.f64 x)) (*.f64 3 (sqrt.f64 x))) (*.f64 3 (sqrt.f64 x)))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.7b
(-.f64 (+.f64 (*.f64 3 (*.f64 (*.f64 (cbrt.f64 (*.f64 y (sqrt.f64 x))) (cbrt.f64 (*.f64 y (sqrt.f64 x)))) (cbrt.f64 (*.f64 y (sqrt.f64 x))))) (*.f64 1/3 (sqrt.f64 (/.f64 1 x)))) (*.f64 3 (sqrt.f64 x)))
0.9b
(*.f64 (*.f64 (*.f64 3 (fabs.f64 (cbrt.f64 x))) (sqrt.f64 (cbrt.f64 x))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
Compiler

Compiled 4213 to 2765 computations (34.4% saved)

regimes1.3s (21.1%)

Accuracy

Total 0.3b remaining (87.2%)

Threshold costs 0.3b (87.2%)

Counts
202 → 1
Compiler

Compiled 13478 to 10166 computations (24.6% saved)

simplify5.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
+-commutative_binary64
sub-neg_binary64
distribute-lft-neg-in_binary64
distribute-rgt-neg-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01225
12225
23025
33425
43725
53825
63725

end336.0ms (5.6%)

Compiler

Compiled 283 to 206 computations (27.2% saved)

Profiling

Loading profile data...