Details

Time bar (total: 4.6s)

analyze6.0ms (0.1%)

Algorithm
search
Search
TrueOtherFalseIter
0%74.9%25.1%0
0%74.9%25.1%1
37.5%37.5%25.1%2
37.5%18.7%43.8%3
46.8%9.4%43.8%4
51.5%4.7%43.8%5
51.5%2.3%46.1%6
52.7%1.2%46.1%7
53.3%0.6%46.1%8
53.3%0.3%46.4%9
53.4%0.1%46.4%10
53.5%0.1%46.4%11
53.5%0%46.5%12
53.5%0%46.5%13
53.5%0%46.5%14
Compiler

Compiled 71 to 33 computations (53.5% saved)

sample1.7s (36.4%)

Results
1.6s8256×body128valid
0.0msbody128invalid
Compiler

Compiled 210 to 97 computations (53.8% saved)

simplify103.0ms (2.2%)

Algorithm
egg-herbie
Rules
1509×associate-/l*_binary64
766×distribute-rgt-out_binary64
744×distribute-lft-out_binary64
549×unswap-sqr_binary64
497×associate-/r*_binary64
Counts
1 → 2
Iterations

Useful iterations: 7 (0.0ms)

IterNodesCost
03275
17459
223941
392837
4154937
5319537
6353437
7369833
8228933
9277533
10282333
11480733
12532433

prune10.0ms (0.2%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.0b
Counts
3 → 2
Alt Table
StatusErrorProgram
0.6b
(fabs.f64 (/.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (sqrt.f64 (PI.f64))))
0.1b
(fabs.f64 (*.f64 (/.f64 1 (sqrt.f64 (PI.f64))) (+.f64 (+.f64 (+.f64 (*.f64 2 (fabs.f64 x)) (*.f64 (/.f64 2 3) (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)))) (*.f64 (/.f64 1 5) (*.f64 (*.f64 (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)))) (*.f64 (/.f64 1 21) (*.f64 (*.f64 (*.f64 (*.f64 (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))))))
Compiler

Compiled 272 to 147 computations (46% saved)

localize23.0ms (0.5%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (/.f64 1 5) (*.f64 (*.f64 (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)))
0.1b
(*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x))
0.2b
(*.f64 (/.f64 2 3) (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)))
1.0b
(sqrt.f64 (PI.f64))

series36.0ms (0.8%)

Counts
4 → 36
Calls

4 calls:

18.0ms
(*.f64 (/.f64 1 5) (*.f64 (*.f64 (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)))
11.0ms
(*.f64 (/.f64 2 3) (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)))
7.0ms
(*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x))
0.0ms
(sqrt.f64 (PI.f64))

rewrite60.0ms (1.3%)

Algorithm
rewrite-expression-head
Rules
115×add-exp-log_binary64
78×add-cbrt-cube_binary64
75×prod-exp_binary64
53×pow1_binary64
45×cbrt-unprod_binary64
Counts
4 → 153
Calls

4 calls:

26.0ms
(*.f64 (/.f64 1 5) (*.f64 (*.f64 (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)))
10.0ms
(*.f64 (/.f64 2 3) (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)))
7.0ms
(*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x))
1.0ms
(sqrt.f64 (PI.f64))

simplify145.0ms (3.1%)

Algorithm
egg-herbie
Rules
504×associate-/l*_binary64
471×fma-def_binary64
345×associate-/r*_binary64
331×unswap-sqr_binary64
310×associate-*r*_binary64
Counts
189 → 194
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
02172646
13962039
213721782
329771752
446191719
549961719
648911719

prune353.0ms (7.6%)

Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New2811282
Fresh011
Picked011
Done000
Total2813284
Error
0.0b
Counts
284 → 3
Alt Table
StatusErrorProgram
0.6b
(fabs.f64 (/.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (sqrt.f64 (PI.f64))))
0.1b
(fabs.f64 (*.f64 (/.f64 1 (sqrt.f64 (PI.f64))) (+.f64 (+.f64 (+.f64 (*.f64 2 (fabs.f64 x)) (*.f64 (/.f64 2 3) (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)))) (*.f64 (/.f64 1 5) (*.f64 (*.f64 (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)))) (*.f64 (/.f64 1 21) (*.f64 (*.f64 (*.f64 (*.f64 (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))))))
1.1b
(fabs.f64 (*.f64 (/.f64 1 (expm1.f64 (log1p.f64 (sqrt.f64 (PI.f64))))) (+.f64 (+.f64 (+.f64 (*.f64 2 (fabs.f64 x)) (*.f64 (/.f64 2 3) (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)))) (*.f64 (/.f64 1 5) (*.f64 (*.f64 (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)))) (*.f64 (/.f64 1 21) (*.f64 (*.f64 (*.f64 (*.f64 (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))))))
Compiler

Compiled 20381 to 7293 computations (64.2% saved)

localize14.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))
0.2b
(*.f64 2/3 (pow.f64 x 3))
0.3b
(/.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (sqrt.f64 (PI.f64)))
1.0b
(sqrt.f64 (PI.f64))

series18.0ms (0.4%)

Counts
3 → 24
Calls

3 calls:

11.0ms
(/.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (sqrt.f64 (PI.f64)))
4.0ms
(fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))
3.0ms
(*.f64 2/3 (pow.f64 x 3))

rewrite13.0ms (0.3%)

Algorithm
rewrite-expression-head
Rules
29×add-sqr-sqrt_binary64
22×*-un-lft-identity_binary64
22×add-cube-cbrt_binary64
18×times-frac_binary64
12×associate-*r*_binary64
Counts
3 → 84
Calls

3 calls:

5.0ms
(*.f64 2/3 (pow.f64 x 3))
3.0ms
(/.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (sqrt.f64 (PI.f64)))
0.0ms
(fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))

simplify131.0ms (2.8%)

Algorithm
egg-herbie
Rules
651×associate-*l*_binary64
610×associate-*r*_binary64
285×log-prod_binary64
262×fma-def_binary64
184×swap-sqr_binary64
Counts
108 → 115
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01613342
13053139
27963025
334383025
448513025
548763025

prune143.0ms (3.1%)

Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New1292131
Fresh101
Picked011
Done101
Total1313134
Error
0b
Counts
134 → 3
Alt Table
StatusErrorProgram
0.1b
(fabs.f64 (+.f64 (*.f64 1/5 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 5))) (+.f64 (*.f64 2/3 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 3))) (+.f64 (*.f64 2 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) x)) (*.f64 1/21 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 7)))))))
0.6b
(fabs.f64 (/.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (sqrt.f64 (PI.f64))))
0.1b
(fabs.f64 (*.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (/.f64 1 (sqrt.f64 (PI.f64)))))
Compiler

Compiled 4223 to 3118 computations (26.2% saved)

localize18.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))
0.1b
(*.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (/.f64 1 (sqrt.f64 (PI.f64))))
0.2b
(*.f64 2/3 (pow.f64 x 3))
1.0b
(sqrt.f64 (PI.f64))

series9.0ms (0.2%)

Counts
1 → 12
Calls

1 calls:

9.0ms
(*.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (/.f64 1 (sqrt.f64 (PI.f64))))

rewrite13.0ms (0.3%)

Algorithm
rewrite-expression-head
Rules
27×add-sqr-sqrt_binary64
22×associate-*r*_binary64
22×times-frac_binary64
17×*-un-lft-identity_binary64
15×add-cube-cbrt_binary64
Counts
1 → 49
Calls

1 calls:

8.0ms
(*.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (/.f64 1 (sqrt.f64 (PI.f64))))

simplify111.0ms (2.4%)

Algorithm
egg-herbie
Rules
919×fma-def_binary64
409×*-commutative_binary64
362×associate-*l/_binary64
324×exp-prod_binary64
289×associate-*r/_binary64
Counts
61 → 80
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0952486
12152267
25782133
317322022
432252022
548492022
649322022

prune181.0ms (3.9%)

Pruning

3 alts after pruning (1 fresh and 2 done)

PrunedKeptTotal
New1550155
Fresh011
Picked011
Done011
Total1553158
Error
0b
Counts
158 → 3
Alt Table
StatusErrorProgram
0.1b
(fabs.f64 (+.f64 (*.f64 1/5 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 5))) (+.f64 (*.f64 2/3 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 3))) (+.f64 (*.f64 2 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) x)) (*.f64 1/21 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 7)))))))
0.6b
(fabs.f64 (/.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (sqrt.f64 (PI.f64))))
0.1b
(fabs.f64 (*.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (/.f64 1 (sqrt.f64 (PI.f64)))))
Compiler

Compiled 4980 to 3721 computations (25.3% saved)

localize20.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 1/21 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 7)))
0.1b
(*.f64 1/5 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 5)))
0.1b
(*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 3))
0.2b
(*.f64 2/3 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 3)))

series55.0ms (1.2%)

Counts
4 → 0
Calls

4 calls:

16.0ms
(*.f64 1/21 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 7)))
14.0ms
(*.f64 2/3 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 3)))
13.0ms
(*.f64 1/5 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 5)))
12.0ms
(*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 3))

rewrite42.0ms (0.9%)

Algorithm
rewrite-expression-head
Rules
50×add-sqr-sqrt_binary64
39×add-exp-log_binary64
25×sqrt-prod_binary64
25×associate-*l*_binary64
24×prod-exp_binary64
Counts
4 → 125
Calls

4 calls:

10.0ms
(*.f64 1/21 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 7)))
9.0ms
(*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 3))
7.0ms
(*.f64 2/3 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 3)))
7.0ms
(*.f64 1/5 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 5)))

simplify136.0ms (2.9%)

Algorithm
egg-herbie
Rules
558×unswap-sqr_binary64
455×associate-/l*_binary64
389×log-prod_binary64
350×associate-*r*_binary64
307×fma-def_binary64
Counts
125 → 140
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01842432
13772267
213622231
321912231
443002231
548522231
649062231

prune221.0ms (4.8%)

Pruning

3 alts after pruning (0 fresh and 3 done)

PrunedKeptTotal
New1400140
Fresh000
Picked011
Done022
Total1403143
Error
0b
Counts
143 → 3
Alt Table
StatusErrorProgram
0.1b
(fabs.f64 (+.f64 (*.f64 1/5 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 5))) (+.f64 (*.f64 2/3 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 3))) (+.f64 (*.f64 2 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) x)) (*.f64 1/21 (*.f64 (sqrt.f64 (/.f64 1 (PI.f64))) (pow.f64 x 7)))))))
0.6b
(fabs.f64 (/.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (sqrt.f64 (PI.f64))))
0.1b
(fabs.f64 (*.f64 (fma.f64 1/21 (pow.f64 x 7) (fma.f64 1/5 (pow.f64 x 5) (fma.f64 2 x (*.f64 2/3 (pow.f64 x 3))))) (/.f64 1 (sqrt.f64 (PI.f64)))))
Compiler

Compiled 7014 to 5647 computations (19.5% saved)

regimes974.0ms (21%)

Accuracy

Total 0.1b remaining (59.6%)

Threshold costs 0.1b (59.6%)

Counts
117 → 1
Compiler

Compiled 32942 to 19496 computations (40.8% saved)

simplify3.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
fabs-mul_binary64
fabs-div_binary64
1-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02236
12936
23336
33136

end110.0ms (2.4%)

Compiler

Compiled 141 to 118 computations (16.3% saved)

Profiling

Loading profile data...