Details

Time bar (total: 3.2s)

analyze74.0ms (2.3%)

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)

sample137.0ms (4.3%)

Algorithm
intervals
Results
14.0ms256×body128valid
0.0msbody128nan
0.0msbody128invalid
Compiler

Compiled 35 to 29 computations (17.1% saved)

simplify180.0ms (5.7%)

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

prune4.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

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

Compiled 85 to 66 computations (22.4% saved)

localize10.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))

series42.0ms (1.3%)

Counts
4 → 48
Calls

4 calls:

27.0ms
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
9.0ms
(*.f64 3 (sqrt.f64 x))
4.0ms
(+.f64 y (/.f64 1 (*.f64 x 9)))
1.0ms
(/.f64 1 (*.f64 x 9))

rewrite37.0ms (1.2%)

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:

11.0ms
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
7.0ms
(/.f64 1 (*.f64 x 9))
4.0ms
(+.f64 y (/.f64 1 (*.f64 x 9)))
3.0ms
(*.f64 3 (sqrt.f64 x))

simplify75.0ms (2.4%)

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

prune181.0ms (5.7%)

Pruning

8 alts after pruning (7 fresh and 1 done)

PrunedKeptTotal
New1647171
Fresh101
Picked011
Done000
Total1658173
Error
0.0b
Counts
173 → 8
Alt Table
StatusErrorProgram
18.2b
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (*.f64 (sqrt.f64 (+.f64 (/.f64 1/9 x) y)) (sqrt.f64 (+.f64 (/.f64 1/9 x) y))) 1))
0.8b
(*.f64 (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 3) (sqrt.f64 x))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.6b
(*.f64 (*.f64 (*.f64 3 (sqrt.f64 (sqrt.f64 x))) (sqrt.f64 (sqrt.f64 x))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.6b
(*.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))
0.4b
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
18.2b
(*.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.3b
(fma.f64 (sqrt.f64 x) (fma.f64 3 y -3) (*.f64 1/3 (sqrt.f64 (/.f64 1 x))))
0.4b
(*.f64 3 (*.f64 (sqrt.f64 x) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1)))
Compiler

Compiled 4171 to 3145 computations (24.6% saved)

localize10.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 3 y -3)
0.1b
(sqrt.f64 (/.f64 1 x))
0.2b
(fma.f64 (sqrt.f64 x) (fma.f64 3 y -3) (*.f64 1/3 (sqrt.f64 (/.f64 1 x))))
0.4b
(*.f64 1/3 (sqrt.f64 (/.f64 1 x)))

series41.0ms (1.3%)

Counts
4 → 24
Calls

4 calls:

26.0ms
(fma.f64 (sqrt.f64 x) (fma.f64 3 y -3) (*.f64 1/3 (sqrt.f64 (/.f64 1 x))))
7.0ms
(sqrt.f64 (/.f64 1 x))
7.0ms
(*.f64 1/3 (sqrt.f64 (/.f64 1 x)))
1.0ms
(fma.f64 3 y -3)

rewrite12.0ms (0.4%)

Algorithm
rewrite-expression-head
Rules
33×add-sqr-sqrt_binary64
29×sqrt-prod_binary64
22×times-frac_binary64
22×*-un-lft-identity_binary64
20×add-cube-cbrt_binary64
Counts
4 → 87
Calls

4 calls:

6.0ms
(*.f64 1/3 (sqrt.f64 (/.f64 1 x)))
2.0ms
(sqrt.f64 (/.f64 1 x))
0.0ms
(fma.f64 (sqrt.f64 x) (fma.f64 3 y -3) (*.f64 1/3 (sqrt.f64 (/.f64 1 x))))
0.0ms
(fma.f64 3 y -3)

simplify71.0ms (2.3%)

Algorithm
egg-herbie
Rules
853×associate-+l+_binary64
393×distribute-lft-in_binary64
393×distribute-rgt-in_binary64
288×associate-*l*_binary64
263×distribute-rgt-out_binary64
Counts
111 → 116
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01021378
11551248
22651247
35741247
421811247
553731247

prune126.0ms (4%)

Pruning

9 alts after pruning (8 fresh and 1 done)

PrunedKeptTotal
New1133116
Fresh156
Picked101
Done011
Total1159124
Error
0.0b
Counts
124 → 9
Alt Table
StatusErrorProgram
0.4b
(fma.f64 (sqrt.f64 x) (-.f64 (*.f64 3 y) 3) (*.f64 1/3 (sqrt.f64 (/.f64 1 x))))
0.4b
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.6b
(*.f64 (*.f64 (*.f64 3 (sqrt.f64 (sqrt.f64 x))) (sqrt.f64 (sqrt.f64 x))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.6b
(*.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))
0.8b
(*.f64 (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 3) (sqrt.f64 x))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.3b
(fma.f64 (sqrt.f64 x) (fma.f64 3 y -3) (*.f64 1/3 (pow.f64 x -1/2)))
18.2b
(*.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))
20.3b
(fma.f64 (sqrt.f64 x) (cbrt.f64 (pow.f64 (fma.f64 3 y -3) 3)) (*.f64 1/3 (sqrt.f64 (/.f64 1 x))))
0.4b
(*.f64 3 (*.f64 (sqrt.f64 x) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1)))
Compiler

Compiled 2484 to 1813 computations (27% saved)

localize13.0ms (0.4%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 3 y -3)
0.2b
(fma.f64 (sqrt.f64 x) (fma.f64 3 y -3) (*.f64 1/3 (pow.f64 x -1/2)))
0.4b
(*.f64 1/3 (pow.f64 x -1/2))

series36.0ms (1.2%)

Counts
2 → 12
Calls

2 calls:

26.0ms
(fma.f64 (sqrt.f64 x) (fma.f64 3 y -3) (*.f64 1/3 (pow.f64 x -1/2)))
10.0ms
(*.f64 1/3 (pow.f64 x -1/2))

rewrite5.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
10×add-sqr-sqrt_binary64
associate-*r*_binary64
add-exp-log_binary64
*-un-lft-identity_binary64
add-cube-cbrt_binary64
Counts
2 → 37
Calls

2 calls:

4.0ms
(*.f64 1/3 (pow.f64 x -1/2))
0.0ms
(fma.f64 (sqrt.f64 x) (fma.f64 3 y -3) (*.f64 1/3 (pow.f64 x -1/2)))

simplify68.0ms (2.1%)

Algorithm
egg-herbie
Rules
871×fma-def_binary64
415×*-commutative_binary64
378×associate-+l+_binary64
286×unswap-sqr_binary64
201×associate-*l*_binary64
Counts
49 → 58
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
082800
1148688
2304675
3884655
41985655
54977655
64974655

prune79.0ms (2.5%)

Pruning

8 alts after pruning (7 fresh and 1 done)

PrunedKeptTotal
New71273
Fresh257
Picked101
Done011
Total74882
Error
0.0b
Counts
82 → 8
Alt Table
StatusErrorProgram
0.4b
(fma.f64 (sqrt.f64 x) (-.f64 (*.f64 3 y) 3) (*.f64 1/3 (sqrt.f64 (/.f64 1 x))))
0.4b
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.8b
(*.f64 (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 3) (sqrt.f64 x))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.7b
(fma.f64 (sqrt.f64 x) (fma.f64 3 y -3) (*.f64 (*.f64 1/3 (*.f64 (cbrt.f64 (pow.f64 x -1/2)) (cbrt.f64 (pow.f64 x -1/2)))) (cbrt.f64 (pow.f64 x -1/2))))
18.2b
(*.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.6b
(*.f64 (*.f64 (*.f64 3 (sqrt.f64 (sqrt.f64 x))) (sqrt.f64 (sqrt.f64 x))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
20.3b
(fma.f64 (sqrt.f64 x) (cbrt.f64 (pow.f64 (fma.f64 3 y -3) 3)) (*.f64 1/3 (pow.f64 x -1/2)))
0.4b
(*.f64 3 (*.f64 (sqrt.f64 x) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1)))
Compiler

Compiled 1547 to 1131 computations (26.9% saved)

localize10.0ms (0.3%)

Local error

Found 4 expressions with local error:

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

series45.0ms (1.4%)

Counts
2 → 24
Calls

2 calls:

27.0ms
(*.f64 3 (*.f64 (sqrt.f64 x) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1)))
19.0ms
(*.f64 (sqrt.f64 x) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))

rewrite44.0ms (1.4%)

Algorithm
rewrite-expression-head
Rules
122×*-un-lft-identity_binary64
100×distribute-lft-in_binary64
100×distribute-rgt-in_binary64
90×prod-diff_binary64
68×add-sqr-sqrt_binary64
Counts
2 → 174
Calls

2 calls:

12.0ms
(*.f64 3 (*.f64 (sqrt.f64 x) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1)))
12.0ms
(*.f64 (sqrt.f64 x) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))

simplify156.0ms (5%)

Algorithm
egg-herbie
Rules
593×distribute-rgt-in_binary64
565×distribute-lft-in_binary64
312×fma-neg_binary64
302×times-frac_binary64
271×*-commutative_binary64
Counts
198 → 181
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01574787
13193611
29063392
333183385
447913385
550023385

prune260.0ms (8.2%)

Pruning

8 alts after pruning (6 fresh and 2 done)

PrunedKeptTotal
New2501251
Fresh156
Picked011
Done011
Total2518259
Error
0.0b
Counts
259 → 8
Alt Table
StatusErrorProgram
0.4b
(fma.f64 (sqrt.f64 x) (-.f64 (*.f64 3 y) 3) (*.f64 1/3 (sqrt.f64 (/.f64 1 x))))
0.4b
(*.f64 3 (*.f64 (sqrt.f64 x) (-.f64 (+.f64 y (/.f64 (/.f64 1 x) 9)) 1)))
0.4b
(*.f64 (*.f64 3 (sqrt.f64 x)) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
0.8b
(*.f64 (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 3) (sqrt.f64 x))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
18.2b
(*.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.6b
(*.f64 (*.f64 (*.f64 3 (sqrt.f64 (sqrt.f64 x))) (sqrt.f64 (sqrt.f64 x))) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1))
20.3b
(fma.f64 (sqrt.f64 x) (cbrt.f64 (pow.f64 (fma.f64 3 y -3) 3)) (*.f64 1/3 (pow.f64 x -1/2)))
0.4b
(*.f64 3 (*.f64 (sqrt.f64 x) (-.f64 (+.f64 y (/.f64 1 (*.f64 x 9))) 1)))
Compiler

Compiled 6588 to 5009 computations (24% saved)

regimes626.0ms (19.8%)

Accuracy

Total 0.3b remaining (88.9%)

Threshold costs 0.3b (88.9%)

Counts
184 → 1
Compiler

Compiled 10847 to 8632 computations (20.4% saved)

simplify2.0ms (0.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01323
11823
21823

end1.0ms (0%)

Compiler

Compiled 17 to 12 computations (29.4% saved)

sample812.0ms (25.7%)

Algorithm
intervals
Results
477.0ms8000×body128valid
7.0ms134×body128nan
3.0ms63×body128invalid
Compiler

Compiled 184 to 147 computations (20.1% saved)

Profiling

Loading profile data...