Details

Time bar (total: 2.3s)

analyze5.0ms (0.2%)

Algorithm
search
Search
TrueOtherFalseIter
0%100%0%0
0%100%0%1
0%100%0%2
50%50%0%3
50%25%25%4
62.5%12.5%25%5
62.5%6.2%31.3%6
65.6%3.1%31.3%7
65.6%1.6%32.8%8
66.4%0.8%32.8%9
66.4%0.4%33.2%10
66.6%0.2%33.2%11
66.6%0.1%33.3%12
66.6%0%33.3%13
66.6%0%33.3%14
Compiler

Compiled 13 to 9 computations (30.8% saved)

sample1.0s (44.4%)

Results
854.0ms8256×body128valid
Compiler

Compiled 38 to 26 computations (31.6% saved)

simplify147.0ms (6.4%)

Algorithm
egg-herbie
Rules
1355×fma-neg_binary64
877×fma-def_binary64
720×distribute-rgt-neg-in_binary64
564×cancel-sign-sub-inv_binary64
530×sqr-pow_binary64
Counts
1 → 2
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0916
12111
24911
310711
417011
529111
651611
7100211
8149211
9212811
10273411
11315411
12335811
13353511
14410611
15309911
16352811
17466811
18473211

prune3.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.2b
(*.f64 x (fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000))
0.5b
(-.f64 (*.f64 238732414637843/250000000000000 x) (*.f64 6450306886639899/50000000000000000 (*.f64 (*.f64 x x) x)))
Compiler

Compiled 62 to 40 computations (35.5% saved)

localize5.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000)
0.2b
(*.f64 x (fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000))

series6.0ms (0.3%)

Counts
2 → 24
Calls

2 calls:

3.0ms
(*.f64 x (fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000))
3.0ms
(fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000)

rewrite4.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
add-sqr-sqrt_binary64
*-un-lft-identity_binary64
add-cube-cbrt_binary64
add-cbrt-cube_binary64
add-exp-log_binary64
Counts
2 → 32
Calls

2 calls:

3.0ms
(*.f64 x (fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000))
0.0ms
(fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000)

simplify41.0ms (1.8%)

Algorithm
egg-herbie
Rules
907×distribute-rgt-in_binary64
906×distribute-lft-in_binary64
386×fma-def_binary64
240×associate-*l*_binary64
199×associate-*r*_binary64
Counts
56 → 64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
054716
1106613
2301613
31063613
45380613

prune46.0ms (2%)

Pruning

5 alts after pruning (5 fresh and 0 done)

PrunedKeptTotal
New59564
Fresh101
Picked101
Done000
Total61566
Error
0.0b
Counts
66 → 5
Alt Table
StatusErrorProgram
32.8b
(*.f64 (sqrt.f64 (*.f64 x (fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000))) (sqrt.f64 (*.f64 x (fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000))))
0.2b
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))
0.4b
(-.f64 (*.f64 238732414637843/250000000000000 x) (*.f64 6450306886639899/50000000000000000 (pow.f64 x 3)))
15.7b
(*.f64 x (log.f64 (exp.f64 (fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000))))
33.1b
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000)))
Compiler

Compiled 958 to 573 computations (40.2% saved)

localize5.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(-.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2)))
0.2b
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))
0.2b
(*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))

series9.0ms (0.4%)

Counts
3 → 15
Calls

3 calls:

4.0ms
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))
3.0ms
(*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))
3.0ms
(-.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2)))

rewrite15.0ms (0.6%)

Algorithm
rewrite-expression-head
Rules
20×add-sqr-sqrt_binary64
12×*-un-lft-identity_binary64
12×add-cube-cbrt_binary64
11×associate-*r*_binary64
10×add-exp-log_binary64
Counts
3 → 81
Calls

3 calls:

4.0ms
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))
4.0ms
(*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))
3.0ms
(-.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2)))

simplify62.0ms (2.7%)

Algorithm
egg-herbie
Rules
795×distribute-rgt-in_binary64
737×distribute-lft-in_binary64
584×fma-def_binary64
209×*-commutative_binary64
173×unswap-sqr_binary64
Counts
96 → 136
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01341460
12511152
27311029
316751002
452491002

prune123.0ms (5.3%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New1333136
Fresh224
Picked011
Done000
Total1356141
Error
0b
Counts
141 → 6
Alt Table
StatusErrorProgram
0.4b
(-.f64 (*.f64 238732414637843/250000000000000 x) (*.f64 6450306886639899/50000000000000000 (pow.f64 x 3)))
6.0b
(/.f64 (*.f64 x (fma.f64 (pow.f64 x 4) -41606458931834106848498498730201/2500000000000000000000000000000000 56993165798814994692847692649/62500000000000000000000000000)) (+.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))
8.8b
(/.f64 (*.f64 x (-.f64 (pow.f64 238732414637843/250000000000000 3) (pow.f64 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2)) 3))) (+.f64 (*.f64 238732414637843/250000000000000 238732414637843/250000000000000) (+.f64 (*.f64 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2)) (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))) (*.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))))
0.3b
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)) (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)))))
0.2b
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))
33.1b
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000)))
Compiler

Compiled 2287 to 1730 computations (24.4% saved)

localize7.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(-.f64 238732414637843/250000000000000 (*.f64 (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)) (*.f64 x (sqrt.f64 6450306886639899/50000000000000000))))
0.2b
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)) (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)))))
0.4b
(*.f64 (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)) (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)))
0.4b
(*.f64 x (sqrt.f64 6450306886639899/50000000000000000))

series34.0ms (1.5%)

Counts
4 → 48
Calls

4 calls:

13.0ms
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)) (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)))))
8.0ms
(*.f64 (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)) (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)))
8.0ms
(-.f64 238732414637843/250000000000000 (*.f64 (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)) (*.f64 x (sqrt.f64 6450306886639899/50000000000000000))))
4.0ms
(*.f64 x (sqrt.f64 6450306886639899/50000000000000000))

rewrite26.0ms (1.1%)

Algorithm
rewrite-expression-head
Rules
47×pow1_binary64
21×add-sqr-sqrt_binary64
20×add-cbrt-cube_binary64
20×add-exp-log_binary64
19×pow-prod-down_binary64
Counts
4 → 114
Calls

4 calls:

6.0ms
(*.f64 (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)) (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)))
5.0ms
(*.f64 x (sqrt.f64 6450306886639899/50000000000000000))
5.0ms
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)) (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)))))
3.0ms
(-.f64 238732414637843/250000000000000 (*.f64 (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)) (*.f64 x (sqrt.f64 6450306886639899/50000000000000000))))

simplify137.0ms (5.9%)

Algorithm
egg-herbie
Rules
939×fma-def_binary64
378×distribute-rgt-neg-in_binary64
335×unswap-sqr_binary64
288×*-commutative_binary64
276×fma-neg_binary64
Counts
162 → 168
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01431834
12901598
29741469
323631434
449031434
547101434

prune179.0ms (7.7%)

Pruning

6 alts after pruning (4 fresh and 2 done)

PrunedKeptTotal
New2001201
Fresh134
Picked011
Done011
Total2016207
Error
0b
Counts
207 → 6
Alt Table
StatusErrorProgram
6.0b
(/.f64 (*.f64 x (fma.f64 (pow.f64 x 4) -41606458931834106848498498730201/2500000000000000000000000000000000 56993165798814994692847692649/62500000000000000000000000000)) (+.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))
8.8b
(/.f64 (*.f64 x (-.f64 (pow.f64 238732414637843/250000000000000 3) (pow.f64 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2)) 3))) (+.f64 (*.f64 238732414637843/250000000000000 238732414637843/250000000000000) (+.f64 (*.f64 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2)) (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))) (*.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))))
0.3b
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)) (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)))))
0.2b
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))
33.1b
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000)))
0.4b
(fma.f64 (pow.f64 x 3) -6450306886639899/50000000000000000 (*.f64 x 238732414637843/250000000000000))
Compiler

Compiled 3933 to 3043 computations (22.6% saved)

localize5.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.1b
(*.f64 x 238732414637843/250000000000000)
0.3b
(fma.f64 (pow.f64 x 3) -6450306886639899/50000000000000000 (*.f64 x 238732414637843/250000000000000))

series6.0ms (0.3%)

Counts
2 → 24
Calls

2 calls:

4.0ms
(fma.f64 (pow.f64 x 3) -6450306886639899/50000000000000000 (*.f64 x 238732414637843/250000000000000))
1.0ms
(*.f64 x 238732414637843/250000000000000)

rewrite4.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
add-sqr-sqrt_binary64
*-un-lft-identity_binary64
add-cube-cbrt_binary64
add-cbrt-cube_binary64
add-exp-log_binary64
Counts
2 → 30
Calls

2 calls:

3.0ms
(*.f64 x 238732414637843/250000000000000)
0.0ms
(fma.f64 (pow.f64 x 3) -6450306886639899/50000000000000000 (*.f64 x 238732414637843/250000000000000))

simplify61.0ms (2.7%)

Algorithm
egg-herbie
Rules
714×fma-def_binary64
600×distribute-rgt-in_binary64
563×distribute-lft-in_binary64
228×times-frac_binary64
218×exp-prod_binary64
Counts
54 → 51
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
054488
192435
2229435
3580435
41300435
54704435
65233435

prune43.0ms (1.8%)

Pruning

6 alts after pruning (3 fresh and 3 done)

PrunedKeptTotal
New51051
Fresh033
Picked011
Done022
Total51657
Error
0b
Counts
57 → 6
Alt Table
StatusErrorProgram
6.0b
(/.f64 (*.f64 x (fma.f64 (pow.f64 x 4) -41606458931834106848498498730201/2500000000000000000000000000000000 56993165798814994692847692649/62500000000000000000000000000)) (+.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))
8.8b
(/.f64 (*.f64 x (-.f64 (pow.f64 238732414637843/250000000000000 3) (pow.f64 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2)) 3))) (+.f64 (*.f64 238732414637843/250000000000000 238732414637843/250000000000000) (+.f64 (*.f64 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2)) (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))) (*.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))))
0.3b
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)) (*.f64 x (sqrt.f64 6450306886639899/50000000000000000)))))
0.2b
(*.f64 x (-.f64 238732414637843/250000000000000 (*.f64 6450306886639899/50000000000000000 (pow.f64 x 2))))
33.1b
(*.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (fma.f64 (*.f64 x x) -6450306886639899/50000000000000000 238732414637843/250000000000000)))
0.4b
(fma.f64 (pow.f64 x 3) -6450306886639899/50000000000000000 (*.f64 x 238732414637843/250000000000000))
Compiler

Compiled 732 to 558 computations (23.8% saved)

regimes151.0ms (6.5%)

Accuracy

Total 0.2b remaining (92.2%)

Threshold costs 0.2b (92.2%)

Counts
73 → 1
Compiler

Compiled 2112 to 1580 computations (25.2% saved)

simplify3.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
0913
11713
22513
32913
43213
53313
63213

end159.0ms (6.9%)

Compiler

Compiled 121 to 97 computations (19.8% saved)

Profiling

Loading profile data...