Details

Time bar (total: 21.5s)

analyze2.0s (9.2%)

Algorithm
search
Search
TrueOtherFalseIter
0%0%100%0
0%0%100%1
0%0%100%2
0%0%100%3
0%0%100%4
0%0%100%5
0%0%100%6
0%0%100%7
0%0%100%8
0%0%100%9
0%0%100%10
0%0%100%11
0%0%100%12
0%0%100%13
0%0%100%14
Compiler

Compiled 57 to 41 computations (28.1% saved)

sample2.6s (11.9%)

Results
2.5s8256×body128valid
Compiler

Compiled 136 to 97 computations (28.7% saved)

simplify27.0ms (0.1%)

Algorithm
egg-herbie
Rules
195×fma-neg_binary32
112×fma-def_binary32
65×cancel-sign-sub-inv_binary32
40×sub-neg_binary32
40×div-sub_binary32
Counts
1 → 2
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01626
13025
24225
35525
46725
58425
610525
713425
816025
918525
1022825
1125225
1235825
1340625
1444425
1545625
1646125
1742025

prune4.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.4b
Counts
3 → 2
Alt Table
StatusErrorProgram
0.4b
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))
12.7b
(/.f32 (neg.f32 (log.f32 (-.f32 1 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))
Compiler

Compiled 124 to 77 computations (37.9% saved)

localize51.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay)))
0.2b
(/.f32 cos2phi (*.f32 alphax alphax))
0.3b
(/.f32 sin2phi (*.f32 alphay alphay))
0.3b
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))

series287.0ms (1.3%)

Counts
4 → 156
Calls

4 calls:

139.0ms
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))
92.0ms
(+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay)))
28.0ms
(/.f32 cos2phi (*.f32 alphax alphax))
27.0ms
(/.f32 sin2phi (*.f32 alphay alphay))

rewrite66.0ms (0.3%)

Algorithm
rewrite-expression-head
Rules
60×*-un-lft-identity_binary32
49×times-frac_binary32
36×add-sqr-sqrt_binary32
36×add-cube-cbrt_binary32
16×associate-/l*_binary32
Counts
4 → 141
Calls

4 calls:

41.0ms
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))
9.0ms
(+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay)))
3.0ms
(/.f32 sin2phi (*.f32 alphay alphay))
3.0ms
(/.f32 cos2phi (*.f32 alphax alphax))

simplify223.0ms (1%)

Algorithm
egg-herbie
Rules
415×associate-/l/_binary32
350×fma-def_binary32
208×times-frac_binary32
185×associate-/l*_binary32
185×unswap-sqr_binary32
Counts
297 → 237
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
03138536
17908175
226128167
349938167
449828167

prune295.0ms (1.4%)

Pruning

11 alts after pruning (11 fresh and 0 done)

PrunedKeptTotal
New22611237
Fresh101
Picked101
Done000
Total22811239
Error
0b
Counts
239 → 11
Alt Table
StatusErrorProgram
0.6b
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (*.f32 (/.f32 (sqrt.f32 sin2phi) alphay) (/.f32 (sqrt.f32 sin2phi) alphay))))
0.8b
(*.f32 (*.f32 (cbrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (cbrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay)))))) (cbrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))))
0.6b
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (*.f32 (/.f32 (*.f32 (cbrt.f32 sin2phi) (cbrt.f32 sin2phi)) alphay) (/.f32 (cbrt.f32 sin2phi) alphay))))
0.6b
(/.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (sqrt.f32 (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (sqrt.f32 (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay)))))
0.9b
(*.f32 (*.f32 (/.f32 (neg.f32 (cbrt.f32 (log1p.f32 (neg.f32 u0)))) (sqrt.f32 (+.f32 (/.f32 sin2phi (*.f32 alphay alphay)) (/.f32 cos2phi (*.f32 alphax alphax))))) (cbrt.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (cbrt.f32 (log1p.f32 (neg.f32 u0))) (sqrt.f32 (+.f32 (/.f32 sin2phi (*.f32 alphay alphay)) (/.f32 cos2phi (*.f32 alphax alphax))))))
10.3b
(*.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (-.f32 (/.f32 (*.f32 cos2phi cos2phi) (pow.f32 alphax 4)) (/.f32 (*.f32 sin2phi sin2phi) (pow.f32 alphay 4)))) (-.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))
2.6b
(fma.f32 1/3 (/.f32 (pow.f32 u0 3) (+.f32 (/.f32 sin2phi (*.f32 alphay alphay)) (/.f32 cos2phi (*.f32 alphax alphax)))) (fma.f32 1/2 (/.f32 (*.f32 u0 u0) (+.f32 (/.f32 sin2phi (*.f32 alphay alphay)) (/.f32 cos2phi (*.f32 alphax alphax)))) (/.f32 u0 (+.f32 (/.f32 sin2phi (*.f32 alphay alphay)) (/.f32 cos2phi (*.f32 alphax alphax))))))
0.6b
(*.f32 (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))))
0.5b
(*.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))
1.1b
(/.f32 -1 (/.f32 (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))) (log1p.f32 (neg.f32 u0))))
0.6b
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 (*.f32 (cbrt.f32 sin2phi) (cbrt.f32 sin2phi)) (/.f32 alphay (/.f32 (cbrt.f32 sin2phi) alphay)))))
Compiler

Compiled 7831 to 1969 computations (74.9% saved)

localize55.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi))
0.3b
(*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay))
0.3b
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi)))
0.3b
(*.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))

series328.0ms (1.5%)

Counts
4 → 192
Calls

4 calls:

155.0ms
(*.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))
132.0ms
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi)))
28.0ms
(fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi))
12.0ms
(*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay))

rewrite48.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
60×times-frac_binary32
59×add-cbrt-cube_binary32
59×add-exp-log_binary32
50×pow1_binary32
47×*-un-lft-identity_binary32
Counts
4 → 172
Calls

4 calls:

12.0ms
(*.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))
8.0ms
(*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay))
3.0ms
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi)))
0.0ms
(fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi))

simplify289.0ms (1.3%)

Algorithm
egg-herbie
Rules
637×associate-*r*_binary32
476×associate-*l*_binary32
401×fma-def_binary32
322×times-frac_binary32
303×associate-/l*_binary32
Counts
364 → 349
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
039514713
1112113457
2483213438
3518113438

prune381.0ms (1.8%)

Pruning

9 alts after pruning (8 fresh and 1 done)

PrunedKeptTotal
New3481349
Fresh3710
Picked011
Done000
Total3519360
Error
0b
Counts
360 → 9
Alt Table
StatusErrorProgram
0.6b
(*.f32 (/.f32 (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (fma.f32 (*.f32 alphay alphay) cos2phi (*.f32 (*.f32 alphax alphax) sin2phi)) (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))
0.6b
(*.f32 (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))))
0.6b
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (*.f32 (/.f32 (*.f32 (cbrt.f32 sin2phi) (cbrt.f32 sin2phi)) alphay) (/.f32 (cbrt.f32 sin2phi) alphay))))
0.6b
(/.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (sqrt.f32 (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (sqrt.f32 (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay)))))
0.9b
(*.f32 (*.f32 (/.f32 (neg.f32 (cbrt.f32 (log1p.f32 (neg.f32 u0)))) (sqrt.f32 (+.f32 (/.f32 sin2phi (*.f32 alphay alphay)) (/.f32 cos2phi (*.f32 alphax alphax))))) (cbrt.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (cbrt.f32 (log1p.f32 (neg.f32 u0))) (sqrt.f32 (+.f32 (/.f32 sin2phi (*.f32 alphay alphay)) (/.f32 cos2phi (*.f32 alphax alphax))))))
10.3b
(*.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (-.f32 (/.f32 (*.f32 cos2phi cos2phi) (pow.f32 alphax 4)) (/.f32 (*.f32 sin2phi sin2phi) (pow.f32 alphay 4)))) (-.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))
0.5b
(*.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))
0.8b
(*.f32 (*.f32 (cbrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (cbrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay)))))) (cbrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))))
1.1b
(/.f32 -1 (/.f32 (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))) (log1p.f32 (neg.f32 u0))))
Compiler

Compiled 14617 to 3133 computations (78.6% saved)

localize68.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.3b
(/.f32 (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (fma.f32 (*.f32 alphay alphay) cos2phi (*.f32 (*.f32 alphax alphax) sin2phi)) (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0))))))
0.3b
(*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay))
0.3b
(*.f32 (/.f32 (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (fma.f32 (*.f32 alphay alphay) cos2phi (*.f32 (*.f32 alphax alphax) sin2phi)) (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))
0.3b
(/.f32 (fma.f32 (*.f32 alphay alphay) cos2phi (*.f32 (*.f32 alphax alphax) sin2phi)) (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))))

series800.0ms (3.7%)

Counts
3 → 168
Calls

3 calls:

442.0ms
(/.f32 (fma.f32 (*.f32 alphay alphay) cos2phi (*.f32 (*.f32 alphax alphax) sin2phi)) (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))))
206.0ms
(*.f32 (/.f32 (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (fma.f32 (*.f32 alphay alphay) cos2phi (*.f32 (*.f32 alphax alphax) sin2phi)) (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))
151.0ms
(/.f32 (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (fma.f32 (*.f32 alphay alphay) cos2phi (*.f32 (*.f32 alphax alphax) sin2phi)) (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0))))))

rewrite570.0ms (2.7%)

Algorithm
rewrite-expression-head
Rules
2210×times-frac_binary32
1720×sqrt-prod_binary32
1084×*-un-lft-identity_binary32
1084×add-sqr-sqrt_binary32
1084×add-cube-cbrt_binary32
Counts
3 → 1312
Calls

3 calls:

71.0ms
(*.f32 (/.f32 (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (fma.f32 (*.f32 alphay alphay) cos2phi (*.f32 (*.f32 alphax alphax) sin2phi)) (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))
16.0ms
(/.f32 (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (fma.f32 (*.f32 alphay alphay) cos2phi (*.f32 (*.f32 alphax alphax) sin2phi)) (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0))))))
4.0ms
(/.f32 (fma.f32 (*.f32 alphay alphay) cos2phi (*.f32 (*.f32 alphax alphax) sin2phi)) (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))))

simplify2.0s (9.2%)

Algorithm
egg-herbie
Rules
502×associate-/r/_binary32
439×times-frac_binary32
401×*-commutative_binary32
346×associate-*r*_binary32
312×fma-def_binary32
Counts
1480 → 1862
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0133191643
1391088077
2499888077
3501888077

prune1.1s (4.9%)

Pruning

9 alts after pruning (7 fresh and 2 done)

PrunedKeptTotal
New190011901
Fresh167
Picked011
Done011
Total190191910
Error
0b
Counts
1910 → 9
Alt Table
StatusErrorProgram
0.6b
(*.f32 (/.f32 (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (fma.f32 (*.f32 alphay alphay) cos2phi (*.f32 (*.f32 alphax alphax) sin2phi)) (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))
8.5b
(/.f32 (*.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (*.f32 alphay alphay)) sin2phi)
0.6b
(*.f32 (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))))
0.6b
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (*.f32 (/.f32 (*.f32 (cbrt.f32 sin2phi) (cbrt.f32 sin2phi)) alphay) (/.f32 (cbrt.f32 sin2phi) alphay))))
0.6b
(/.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (sqrt.f32 (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (sqrt.f32 (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay)))))
0.9b
(*.f32 (*.f32 (/.f32 (neg.f32 (cbrt.f32 (log1p.f32 (neg.f32 u0)))) (sqrt.f32 (+.f32 (/.f32 sin2phi (*.f32 alphay alphay)) (/.f32 cos2phi (*.f32 alphax alphax))))) (cbrt.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (cbrt.f32 (log1p.f32 (neg.f32 u0))) (sqrt.f32 (+.f32 (/.f32 sin2phi (*.f32 alphay alphay)) (/.f32 cos2phi (*.f32 alphax alphax))))))
10.3b
(*.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (-.f32 (/.f32 (*.f32 cos2phi cos2phi) (pow.f32 alphax 4)) (/.f32 (*.f32 sin2phi sin2phi) (pow.f32 alphay 4)))) (-.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))
0.5b
(*.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))
1.1b
(/.f32 -1 (/.f32 (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))) (log1p.f32 (neg.f32 u0))))
Compiler

Compiled 107872 to 12248 computations (88.6% saved)

localize48.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.3b
(/.f32 sin2phi (*.f32 alphay alphay))
0.3b
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))
0.4b
(*.f32 (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))))
1.6b
(sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay)))))

series877.0ms (4.1%)

Counts
2 → 80
Calls

2 calls:

542.0ms
(*.f32 (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))))
334.0ms
(sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay)))))

rewrite152.0ms (0.7%)

Algorithm
rewrite-expression-head
Rules
341×*-un-lft-identity_binary32
313×sqrt-prod_binary32
277×times-frac_binary32
186×add-sqr-sqrt_binary32
137×add-cube-cbrt_binary32
Counts
2 → 290
Calls

2 calls:

51.0ms
(*.f32 (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))))
10.0ms
(sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay)))))

simplify442.0ms (2.1%)

Algorithm
egg-herbie
Rules
876×times-frac_binary32
760×fma-def_binary32
298×*-commutative_binary32
130×unswap-sqr_binary32
103×cancel-sign-sub-inv_binary32
Counts
370 → 395
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
082924550
1226523149
2497723145
3535023145

prune846.0ms (3.9%)

Pruning

9 alts after pruning (6 fresh and 3 done)

PrunedKeptTotal
New8570857
Fresh066
Picked011
Done022
Total8579866
Error
0b
Counts
866 → 9
Alt Table
StatusErrorProgram
0.6b
(*.f32 (/.f32 (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (fma.f32 (*.f32 alphay alphay) cos2phi (*.f32 (*.f32 alphax alphax) sin2phi)) (sqrt.f32 (neg.f32 (log1p.f32 (neg.f32 u0)))))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))
8.5b
(/.f32 (*.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (*.f32 alphay alphay)) sin2phi)
0.6b
(*.f32 (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (sqrt.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))))
0.6b
(/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (*.f32 (/.f32 (*.f32 (cbrt.f32 sin2phi) (cbrt.f32 sin2phi)) alphay) (/.f32 (cbrt.f32 sin2phi) alphay))))
0.6b
(/.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (sqrt.f32 (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))) (sqrt.f32 (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay)))))
0.9b
(*.f32 (*.f32 (/.f32 (neg.f32 (cbrt.f32 (log1p.f32 (neg.f32 u0)))) (sqrt.f32 (+.f32 (/.f32 sin2phi (*.f32 alphay alphay)) (/.f32 cos2phi (*.f32 alphax alphax))))) (cbrt.f32 (log1p.f32 (neg.f32 u0)))) (/.f32 (cbrt.f32 (log1p.f32 (neg.f32 u0))) (sqrt.f32 (+.f32 (/.f32 sin2phi (*.f32 alphay alphay)) (/.f32 cos2phi (*.f32 alphax alphax))))))
10.3b
(*.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (-.f32 (/.f32 (*.f32 cos2phi cos2phi) (pow.f32 alphax 4)) (/.f32 (*.f32 sin2phi sin2phi) (pow.f32 alphay 4)))) (-.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))))
0.5b
(*.f32 (/.f32 (neg.f32 (log1p.f32 (neg.f32 u0))) (fma.f32 sin2phi (*.f32 alphax alphax) (*.f32 (*.f32 alphay alphay) cos2phi))) (*.f32 (*.f32 alphax alphax) (*.f32 alphay alphay)))
1.1b
(/.f32 -1 (/.f32 (+.f32 (/.f32 cos2phi (*.f32 alphax alphax)) (/.f32 sin2phi (*.f32 alphay alphay))) (log1p.f32 (neg.f32 u0))))
Compiler

Compiled 53824 to 13437 computations (75% saved)

regimes7.9s (36.9%)

Accuracy

Total 0.5b remaining (94.5%)

Threshold costs 0.5b (94.5%)

Counts
412 → 1
Compiler

Compiled 208175 to 114793 computations (44.9% saved)

simplify2.0ms (0%)

Algorithm
egg-herbie
Rules
+-commutative_binary32
*-commutative_binary32
sub-neg_binary32
neg-sub0_binary32
neg-mul-1_binary32
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01525
12425
23025
33425
43525
53525

end125.0ms (0.6%)

Compiler

Compiled 328 to 178 computations (45.7% saved)

Profiling

Loading profile data...