Details

Time bar (total: 10.9s)

analyze182.0ms (1.7%)

Algorithm
search
Search
TrueOtherFalseIter
0%24.7%75.3%0
0%24.7%75.3%1
0%24.7%75.3%2
12.4%12.4%75.3%3
12.4%12.4%75.3%4
18.5%6.2%75.3%5
18.5%6.2%75.3%6
21.6%3.1%75.3%7
21.6%3.1%75.3%8
23.2%1.5%75.3%9
23.2%1.5%75.3%10
23.9%0.8%75.3%11
23.9%0.8%75.3%12
24.3%0.4%75.3%13
24.3%0.4%75.3%14
Compiler

Compiled 18 to 14 computations (22.2% saved)

sample2.6s (23.9%)

Results
2.5s8256×body128valid
Compiler

Compiled 47 to 37 computations (21.3% saved)

simplify69.0ms (0.6%)

Algorithm
egg-herbie
Rules
944×fma-neg_binary32
518×unswap-sqr_binary32
432×exp-prod_binary32
340×times-frac_binary32
333×associate-*l*_binary32
Counts
1 → 1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0914
11714
22714
33614
45014
57914
614714
726114
852814
9167614
10316014
11412114
12485014

prune2.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New011
Fresh011
Picked000
Done000
Total022
Error
0.1b
Counts
2 → 1
Alt Table
StatusErrorProgram
0.1b
(/.f32 1 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s))))
Compiler

Compiled 33 to 27 computations (18.2% saved)

localize26.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))
0.0b
(/.f32 1 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s))))
0.1b
(exp.f32 (/.f32 (neg.f32 x) s))

series37.0ms (0.3%)

Counts
3 → 72
Calls

3 calls:

24.0ms
(/.f32 1 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s))))
6.0ms
(+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))
6.0ms
(exp.f32 (/.f32 (neg.f32 x) s))

rewrite24.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
43×*-un-lft-identity_binary32
42×times-frac_binary32
34×exp-prod_binary32
33×add-sqr-sqrt_binary32
33×add-cube-cbrt_binary32
Counts
3 → 102
Calls

3 calls:

6.0ms
(/.f32 1 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s))))
6.0ms
(+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))
5.0ms
(exp.f32 (/.f32 (neg.f32 x) s))

simplify143.0ms (1.3%)

Algorithm
egg-herbie
Rules
727×fma-neg_binary32
322×associate-/l/_binary32
269×associate-/r/_binary32
197×distribute-rgt-neg-in_binary32
190×distribute-lft-neg-in_binary32
Counts
174 → 161
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01702521
13462365
28062311
324142287
448502287
550892287

prune229.0ms (2.1%)

Pruning

5 alts after pruning (5 fresh and 0 done)

PrunedKeptTotal
New1565161
Fresh000
Picked101
Done000
Total1575162
Error
0.0b
Counts
162 → 5
Alt Table
StatusErrorProgram
0.1b
(/.f32 1 (+.f32 1 (*.f32 (*.f32 (cbrt.f32 (exp.f32 (/.f32 (neg.f32 x) s))) (cbrt.f32 (exp.f32 (/.f32 (neg.f32 x) s)))) (cbrt.f32 (exp.f32 (/.f32 (neg.f32 x) s))))))
0.3b
(/.f32 1 (*.f32 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2)) (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2))))
0.1b
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))))
0.1b
(/.f32 1 (+.f32 1 (pow.f32 (exp.f32 (*.f32 (cbrt.f32 (/.f32 (neg.f32 x) s)) (cbrt.f32 (/.f32 (neg.f32 x) s)))) (cbrt.f32 (/.f32 (neg.f32 x) s)))))
22.8b
(fma.f32 (/.f32 x s) 1/4 1/2)
Compiler

Compiled 2815 to 1499 computations (46.7% saved)

localize59.0ms (0.5%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))))
0.1b
(/.f32 1 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2)))
0.1b
(exp.f32 (/.f32 x s))
0.1b
(exp.f32 (/.f32 (neg.f32 x) s))

series1.1s (9.8%)

Counts
3 → 60
Calls

3 calls:

621.0ms
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))))
439.0ms
(/.f32 1 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2)))
7.0ms
(exp.f32 (/.f32 x s))

rewrite67.0ms (0.6%)

Algorithm
rewrite-expression-head
Rules
181×times-frac_binary32
130×*-un-lft-identity_binary32
102×add-sqr-sqrt_binary32
102×add-cube-cbrt_binary32
56×sqrt-prod_binary32
Counts
3 → 188
Calls

3 calls:

18.0ms
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))))
5.0ms
(exp.f32 (/.f32 x s))
5.0ms
(/.f32 1 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2)))

simplify433.0ms (4%)

Algorithm
egg-herbie
Rules
853×fma-def_binary32
437×associate-/l/_binary32
220×associate-/r*_binary32
217×times-frac_binary32
157×cancel-sign-sub-inv_binary32
Counts
248 → 244
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
031911137
179610804
2296810528
3490010522
4501310522

prune807.0ms (7.4%)

Pruning

6 alts after pruning (6 fresh and 0 done)

PrunedKeptTotal
New3083311
Fresh134
Picked101
Done000
Total3106316
Error
0.0b
Counts
316 → 6
Alt Table
StatusErrorProgram
0.2b
(/.f32 (/.f32 (/.f32 1 (hypot.f32 1 (exp.f32 (*.f32 (/.f32 x s) -1/2)))) (*.f32 (cbrt.f32 (sqrt.f32 (+.f32 1 (exp.f32 (neg.f32 (/.f32 x s)))))) (cbrt.f32 (sqrt.f32 (+.f32 1 (exp.f32 (neg.f32 (/.f32 x s)))))))) (cbrt.f32 (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s))))))
22.8b
(fma.f32 (/.f32 x s) 1/4 1/2)
0.3b
(/.f32 1 (*.f32 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2)) (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2))))
0.1b
(/.f32 1 (+.f32 1 (pow.f32 (exp.f32 (*.f32 (cbrt.f32 (/.f32 (neg.f32 x) s)) (cbrt.f32 (/.f32 (neg.f32 x) s)))) (cbrt.f32 (/.f32 (neg.f32 x) s)))))
15.4b
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (pow.f32 (exp.f32 (sqrt.f32 (neg.f32 (/.f32 x s)))) (sqrt.f32 (/.f32 (neg.f32 x) s))))))
0.1b
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (pow.f32 (E.f32) (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))))
Compiler

Compiled 11244 to 6931 computations (38.4% saved)

localize75.0ms (0.7%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (pow.f32 (E.f32) (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))))
0.1b
(/.f32 1 (hypot.f32 1 (pow.f32 (pow.f32 (E.f32) (/.f32 x s)) -1/2)))
0.1b
(exp.f32 (/.f32 (neg.f32 x) s))
0.1b
(pow.f32 (E.f32) (/.f32 x s))

series1.4s (12.8%)

Counts
3 → 72
Calls

3 calls:

833.0ms
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (pow.f32 (E.f32) (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))))
550.0ms
(/.f32 1 (hypot.f32 1 (pow.f32 (pow.f32 (E.f32) (/.f32 x s)) -1/2)))
7.0ms
(pow.f32 (E.f32) (/.f32 x s))

rewrite61.0ms (0.6%)

Algorithm
rewrite-expression-head
Rules
181×times-frac_binary32
131×*-un-lft-identity_binary32
103×add-sqr-sqrt_binary32
103×add-cube-cbrt_binary32
56×sqrt-prod_binary32
Counts
3 → 195
Calls

3 calls:

10.0ms
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (pow.f32 (E.f32) (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))))
6.0ms
(pow.f32 (E.f32) (/.f32 x s))
3.0ms
(/.f32 1 (hypot.f32 1 (pow.f32 (pow.f32 (E.f32) (/.f32 x s)) -1/2)))

simplify660.0ms (6.1%)

Algorithm
egg-herbie
Rules
887×fma-def_binary32
227×times-frac_binary32
221×associate-/r*_binary32
158×cancel-sign-sub-inv_binary32
156×associate-*r*_binary32
Counts
267 → 254
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
033311871
186010931
2318810647
347469856
448989841
549809841
649969841
749269841

prune762.0ms (7%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New3183321
Fresh325
Picked011
Done000
Total3216327
Error
0.0b
Counts
327 → 6
Alt Table
StatusErrorProgram
0.1b
(/.f32 1 (+.f32 1 (exp.f32 (neg.f32 (/.f32 x s)))))
15.4b
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (pow.f32 (exp.f32 (sqrt.f32 (neg.f32 (/.f32 x s)))) (sqrt.f32 (/.f32 (neg.f32 x) s))))))
0.1b
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (exp.f32 (*.f32 (log.f32 (E.f32)) (/.f32 x s))) -1/2))) (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))))
22.8b
(fma.f32 (/.f32 x s) 1/4 1/2)
0.1b
(sqrt.f32 (/.f32 1 (pow.f32 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2)) 4)))
0.1b
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (pow.f32 (E.f32) (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))))
Compiler

Compiled 11526 to 6832 computations (40.7% saved)

localize53.0ms (0.5%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(+.f32 1 (exp.f32 (neg.f32 (/.f32 x s))))
0.0b
(/.f32 1 (+.f32 1 (exp.f32 (neg.f32 (/.f32 x s)))))
0.1b
(exp.f32 (neg.f32 (/.f32 x s)))

series75.0ms (0.7%)

Counts
3 → 48
Calls

3 calls:

51.0ms
(/.f32 1 (+.f32 1 (exp.f32 (neg.f32 (/.f32 x s)))))
12.0ms
(+.f32 1 (exp.f32 (neg.f32 (/.f32 x s))))
11.0ms
(exp.f32 (neg.f32 (/.f32 x s)))

rewrite35.0ms (0.3%)

Algorithm
rewrite-expression-head
Rules
38×*-un-lft-identity_binary32
30×times-frac_binary32
30×exp-prod_binary32
28×add-sqr-sqrt_binary32
28×add-cube-cbrt_binary32
Counts
3 → 99
Calls

3 calls:

12.0ms
(/.f32 1 (+.f32 1 (exp.f32 (neg.f32 (/.f32 x s)))))
9.0ms
(+.f32 1 (exp.f32 (neg.f32 (/.f32 x s))))
9.0ms
(exp.f32 (neg.f32 (/.f32 x s)))

simplify128.0ms (1.2%)

Algorithm
egg-herbie
Rules
691×fma-neg_binary32
301×associate-/l/_binary32
210×distribute-neg-frac_binary32
203×distribute-rgt-neg-in_binary32
195×distribute-lft-neg-in_binary32
Counts
147 → 136
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01612180
13522024
28191970
324611946
447571946
549751946

prune176.0ms (1.6%)

Pruning

6 alts after pruning (4 fresh and 2 done)

PrunedKeptTotal
New1360136
Fresh044
Picked011
Done011
Total1366142
Error
0.0b
Counts
142 → 6
Alt Table
StatusErrorProgram
0.1b
(/.f32 1 (+.f32 1 (exp.f32 (neg.f32 (/.f32 x s)))))
15.4b
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (pow.f32 (exp.f32 (sqrt.f32 (neg.f32 (/.f32 x s)))) (sqrt.f32 (/.f32 (neg.f32 x) s))))))
0.1b
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (exp.f32 (*.f32 (log.f32 (E.f32)) (/.f32 x s))) -1/2))) (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))))
22.8b
(fma.f32 (/.f32 x s) 1/4 1/2)
0.1b
(sqrt.f32 (/.f32 1 (pow.f32 (hypot.f32 1 (pow.f32 (exp.f32 (/.f32 x s)) -1/2)) 4)))
0.1b
(/.f32 (/.f32 1 (hypot.f32 1 (pow.f32 (pow.f32 (E.f32) (/.f32 x s)) -1/2))) (sqrt.f32 (+.f32 1 (exp.f32 (/.f32 (neg.f32 x) s)))))
Compiler

Compiled 2290 to 1263 computations (44.8% saved)

regimes1.5s (14.2%)

Accuracy

Total 0.0b remaining (60.5%)

Threshold costs 0.0b (60.5%)

Counts
119 → 1
Compiler

Compiled 17782 to 13781 computations (22.5% saved)

simplify4.0ms (0%)

Algorithm
egg-herbie
Rules
+-commutative_binary32
1-exp_binary32
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01015
11315
21215

end173.0ms (1.6%)

Compiler

Compiled 132 to 107 computations (18.9% saved)

Profiling

Loading profile data...