Details

Time bar (total: 3.8s)

analyze5.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.5s (38.6%)

Results
1.4s8256×body128valid
1.0msbody128invalid
Compiler

Compiled 210 to 97 computations (53.8% saved)

simplify21.0ms (0.5%)

Algorithm
egg-herbie
Rules
642×distribute-lft-out_binary64
588×associate-/l*_binary64
406×associate-/r*_binary64
400×*-commutative_binary64
244×distribute-rgt-out_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
03275
17459
225141
3120837
4239437
Stop Event
node limit
Counts
1 → 2

prune5.0ms (0.1%)

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.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))))))
0.6b
(fabs.f64 (*.f64 (/.f64 (fabs.f64 x) (sqrt.f64 (PI.f64))) (+.f64 (fma.f64 1/5 (pow.f64 x 4) (*.f64 1/21 (pow.f64 x 6))) (fma.f64 2/3 (*.f64 x x) 2))))
Compiler

Compiled 278 to 149 computations (46.4% saved)

localize23.0ms (0.6%)

Local error

Found 4 expressions with local error:

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

series20.0ms (0.5%)

Counts
4 → 36
Calls

4 calls:

8.0ms
(*.f64 (/.f64 2 3) (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)))
7.0ms
(*.f64 (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))
5.0ms
(*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x))
0.0ms
(sqrt.f64 (PI.f64))

rewrite44.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
815×log1p-expm1-u_binary64
815×expm1-log1p-u_binary64
106×add-sqr-sqrt_binary64
103×add-cbrt-cube_binary64
102×add-cube-cbrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01329
124519
2257919
Stop Event
node limit
Counts
4 → 69
Calls

4 calls:

43.0ms
(*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x))
43.0ms
(*.f64 (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))
43.0ms
(*.f64 (/.f64 2 3) (*.f64 (*.f64 (fabs.f64 x) (fabs.f64 x)) (fabs.f64 x)))
43.0ms
(sqrt.f64 (PI.f64))

simplify72.0ms (1.9%)

Algorithm
egg-herbie
Rules
776×sqr-pow_binary64
400×unswap-sqr_binary64
357×pow-sqr_binary64
321×*-commutative_binary64
270×cube-prod_binary64
Iterations

Useful iterations: 8 (0.0ms)

IterNodesCost
09252
121252
245252
398252
4242228
5796228
61635228
71738228
81880180
92074180
102314180
112631180
123034180
133530180
144161180
154971180
Stop Event
node limit
Counts
105 → 73

prune167.0ms (4.4%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New1242126
Fresh011
Picked101
Done000
Total1253128
Error
0.0b
Counts
128 → 3
Alt Table
StatusErrorProgram
0.6b
(fabs.f64 (*.f64 (/.f64 (fabs.f64 x) (sqrt.f64 (PI.f64))) (+.f64 (fma.f64 1/5 (pow.f64 x 4) (*.f64 1/21 (pow.f64 x 6))) (fma.f64 2/3 (*.f64 x x) 2))))
0.2b
(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 (pow.f64 (*.f64 x (cbrt.f64 x)) 3) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))))))
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 (pow.f64 x 4) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))))))
Compiler

Compiled 8426 to 3457 computations (59% saved)

localize26.0ms (0.7%)

Local error

Found 4 expressions with local error:

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

prune141.0ms (3.7%)

Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New91091
Fresh022
Picked011
Done000
Total91394
Error
0.0b
Counts
94 → 3
Alt Table
StatusErrorProgram
0.6b
(fabs.f64 (*.f64 (/.f64 (fabs.f64 x) (sqrt.f64 (PI.f64))) (+.f64 (fma.f64 1/5 (pow.f64 x 4) (*.f64 1/21 (pow.f64 x 6))) (fma.f64 2/3 (*.f64 x x) 2))))
0.2b
(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 (pow.f64 (*.f64 x (cbrt.f64 x)) 3) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))))))
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 (pow.f64 x 4) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))))))
Compiler

Compiled 5429 to 2885 computations (46.9% saved)

localize36.0ms (0.9%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 x (cbrt.f64 x))
0.2b
(pow.f64 (*.f64 x (cbrt.f64 x)) 3)
0.6b
(cbrt.f64 x)
1.0b
(sqrt.f64 (PI.f64))

series128.0ms (3.4%)

Counts
3 → 36
Calls

3 calls:

57.0ms
(pow.f64 (*.f64 x (cbrt.f64 x)) 3)
36.0ms
(*.f64 x (cbrt.f64 x))
35.0ms
(cbrt.f64 x)

rewrite37.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
476×unpow-prod-down_binary64
472×log1p-expm1-u_binary64
472×expm1-log1p-u_binary64
255×log-prod_binary64
133×pow2_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0618
112516
2142116
Stop Event
node limit
Counts
3 → 107
Calls

3 calls:

35.0ms
(*.f64 x (cbrt.f64 x))
35.0ms
(pow.f64 (*.f64 x (cbrt.f64 x)) 3)
35.0ms
(cbrt.f64 x)

simplify39.0ms (1%)

Algorithm
egg-herbie
Rules
886×fma-def_binary64
828×unswap-sqr_binary64
418×associate-*l*_binary64
241×associate-*r*_binary64
188×*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
014212
137212
276212
3163212
4440212
51437212
62421212
74465212
Stop Event
node limit
Counts
143 → 115

prune210.0ms (5.5%)

Pruning

3 alts after pruning (1 fresh and 2 done)

PrunedKeptTotal
New1380138
Fresh011
Picked011
Done011
Total1383141
Error
0.0b
Counts
141 → 3
Alt Table
StatusErrorProgram
0.6b
(fabs.f64 (*.f64 (/.f64 (fabs.f64 x) (sqrt.f64 (PI.f64))) (+.f64 (fma.f64 1/5 (pow.f64 x 4) (*.f64 1/21 (pow.f64 x 6))) (fma.f64 2/3 (*.f64 x x) 2))))
0.2b
(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 (pow.f64 (*.f64 x (cbrt.f64 x)) 3) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))))))
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 (pow.f64 x 4) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))))))
Compiler

Compiled 9440 to 4250 computations (55% saved)

localize16.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 1/21 (pow.f64 x 6))
0.1b
(fma.f64 1/5 (pow.f64 x 4) (*.f64 1/21 (pow.f64 x 6)))
0.2b
(/.f64 (fabs.f64 x) (sqrt.f64 (PI.f64)))
1.0b
(sqrt.f64 (PI.f64))

series15.0ms (0.4%)

Counts
3 → 24
Calls

3 calls:

8.0ms
(/.f64 (fabs.f64 x) (sqrt.f64 (PI.f64)))
4.0ms
(fma.f64 1/5 (pow.f64 x 4) (*.f64 1/21 (pow.f64 x 6)))
3.0ms
(*.f64 1/21 (pow.f64 x 6))

rewrite49.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
534×log-prod_binary64
220×expm1-udef_binary64
220×log1p-udef_binary64
195×log-pow_binary64
138×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01430
130028
2345828
Stop Event
node limit
Counts
3 → 81
Calls

3 calls:

48.0ms
(*.f64 1/21 (pow.f64 x 6))
48.0ms
(fma.f64 1/5 (pow.f64 x 4) (*.f64 1/21 (pow.f64 x 6)))
48.0ms
(/.f64 (fabs.f64 x) (sqrt.f64 (PI.f64)))

simplify66.0ms (1.7%)

Algorithm
egg-herbie
Rules
518×sqr-pow_binary64
487×associate-*l*_binary64
467×unswap-sqr_binary64
440×fma-def_binary64
300×associate-*r*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
017291
132291
256291
3123267
4399267
51478267
62937267
73286267
83570267
93854267
104219267
114698267
Stop Event
node limit
Counts
105 → 86

prune114.0ms (3%)

Pruning

4 alts after pruning (1 fresh and 3 done)

PrunedKeptTotal
New1081109
Fresh000
Picked011
Done022
Total1084112
Error
0.0b
Counts
112 → 4
Alt Table
StatusErrorProgram
0.6b
(fabs.f64 (*.f64 (/.f64 (fabs.f64 x) (sqrt.f64 (PI.f64))) (+.f64 (fma.f64 1/5 (pow.f64 x 4) (*.f64 1/21 (pow.f64 x 6))) (fma.f64 2/3 (*.f64 x x) 2))))
0.2b
(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 (pow.f64 (*.f64 x (cbrt.f64 x)) 3) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))))))
2.6b
(fabs.f64 (*.f64 (/.f64 (fabs.f64 x) (sqrt.f64 (PI.f64))) (+.f64 (fma.f64 1/5 (pow.f64 x 4) (sqrt.f64 (*.f64 (pow.f64 x 12) 1/441))) (fma.f64 2/3 (*.f64 x x) 2))))
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 (pow.f64 x 4) (fabs.f64 x)) (fabs.f64 x)) (fabs.f64 x))))))
Compiler

Compiled 3277 to 2102 computations (35.9% saved)

regimes979.0ms (25.7%)

Accuracy

Total 0.2b remaining (89%)

Threshold costs 0.2b (89%)

Counts
123 → 1
Compiler

Compiled 29742 to 20008 computations (32.7% saved)

simplify3.0ms (0.1%)

Algorithm
egg-herbie
Rules
11×*-commutative_binary64
+-commutative_binary64
fabs-mul_binary64
sqr-abs_binary64
fabs-div_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
03676
15676
26076
Stop Event
saturated

end126.0ms (3.3%)

Compiler

Compiled 270 to 171 computations (36.7% saved)

Profiling

Loading profile data...