Details

Time bar (total: 9.8s)

analyze383.0ms (3.9%)

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 37 to 28 computations (24.3% saved)

sample2.0s (20.3%)

Results
1.9s8256×body128valid
1.0msbody128invalid
Compiler

Compiled 88 to 67 computations (23.9% saved)

simplify9.0ms (0.1%)

Algorithm
egg-herbie
Rules
11×sub-neg_binary32
+-commutative_binary32
fma-def_binary32
*-commutative_binary32
div-sub_binary32
Counts
1 → 1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01117
11717
22117
32717
43417
54417
65417
76917
87617
97917
108017
116017

prune3.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New011
Fresh011
Picked000
Done000
Total022
Error
0.6b
Counts
2 → 1
Alt Table
StatusErrorProgram
0.6b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))
Compiler

Compiled 42 to 33 computations (21.4% saved)

localize28.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(sqrt.f32 (/.f32 u1 (-.f32 1 u1)))
0.2b
(sin.f32 (*.f32 314159265359/50000000000 u2))
0.3b
(*.f32 314159265359/50000000000 u2)
0.4b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))

series39.0ms (0.4%)

Counts
4 → 24
Calls

4 calls:

26.0ms
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))
10.0ms
(sqrt.f32 (/.f32 u1 (-.f32 1 u1)))
2.0ms
(sin.f32 (*.f32 314159265359/50000000000 u2))
1.0ms
(*.f32 314159265359/50000000000 u2)

rewrite27.0ms (0.3%)

Algorithm
rewrite-expression-head
Rules
58×add-sqr-sqrt_binary32
50×sqrt-prod_binary32
46×*-un-lft-identity_binary32
38×times-frac_binary32
30×associate-*l*_binary32
Counts
4 → 114
Calls

4 calls:

10.0ms
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))
6.0ms
(sqrt.f32 (/.f32 u1 (-.f32 1 u1)))
3.0ms
(*.f32 314159265359/50000000000 u2)
1.0ms
(sin.f32 (*.f32 314159265359/50000000000 u2))

simplify110.0ms (1.1%)

Algorithm
egg-herbie
Rules
545×associate-/r*_binary32
479×fma-def_binary32
434×associate-*l*_binary32
293×fma-neg_binary32
259×times-frac_binary32
Counts
138 → 175
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02592965
15692793
216002681
345042681
449352681

prune229.0ms (2.4%)

Pruning

13 alts after pruning (13 fresh and 0 done)

PrunedKeptTotal
New16213175
Fresh000
Picked101
Done000
Total16313176
Error
0.1b
Counts
176 → 13
Alt Table
StatusErrorProgram
1.5b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (exp.f32 (log.f32 (*.f32 314159265359/50000000000 u2)))))
0.7b
(*.f32 (sqrt.f32 (/.f32 (sqrt.f32 u1) (*.f32 (cbrt.f32 (-.f32 1 u1)) (cbrt.f32 (-.f32 1 u1))))) (*.f32 (sqrt.f32 (/.f32 (sqrt.f32 u1) (cbrt.f32 (-.f32 1 u1)))) (sin.f32 (*.f32 314159265359/50000000000 u2))))
0.6b
(cbrt.f32 (*.f32 (*.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sqrt.f32 (/.f32 u1 (-.f32 1 u1)))) (sqrt.f32 (/.f32 u1 (-.f32 1 u1)))) (*.f32 (*.f32 (sin.f32 (*.f32 314159265359/50000000000 u2)) (sin.f32 (*.f32 314159265359/50000000000 u2))) (sin.f32 (*.f32 314159265359/50000000000 u2)))))
0.7b
(*.f32 (sqrt.f32 (/.f32 (*.f32 (cbrt.f32 u1) (cbrt.f32 u1)) (+.f32 1 (sqrt.f32 u1)))) (*.f32 (sqrt.f32 (/.f32 (cbrt.f32 u1) (-.f32 1 (sqrt.f32 u1)))) (sin.f32 (*.f32 314159265359/50000000000 u2))))
0.9b
(*.f32 (*.f32 (cbrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))) (cbrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2))))) (cbrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))))
0.8b
(*.f32 (*.f32 (sqrt.f32 (/.f32 (sqrt.f32 u1) (sqrt.f32 (-.f32 1 u1)))) (sqrt.f32 (/.f32 (sqrt.f32 u1) (sqrt.f32 (-.f32 1 u1))))) (sin.f32 (*.f32 314159265359/50000000000 u2)))
20.1b
(log.f32 (exp.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))))
0.8b
(*.f32 (*.f32 (sqrt.f32 (*.f32 (/.f32 (cbrt.f32 u1) (sqrt.f32 (-.f32 1 u1))) (cbrt.f32 u1))) (sqrt.f32 (/.f32 (cbrt.f32 u1) (sqrt.f32 (-.f32 1 u1))))) (sin.f32 (*.f32 314159265359/50000000000 u2)))
0.6b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 (*.f32 1 1) (*.f32 u1 u1)))) (*.f32 (sqrt.f32 (+.f32 1 u1)) (sin.f32 (*.f32 314159265359/50000000000 u2))))
1.0b
(*.f32 (*.f32 (cbrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1)))) (cbrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))))) (*.f32 (cbrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1)))) (sin.f32 (*.f32 314159265359/50000000000 u2))))
1.7b
(*.f32 (sqrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))) (sqrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))))
0.6b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2))))
0.5b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))
Compiler

Compiled 4395 to 3275 computations (25.5% saved)

localize41.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(sqrt.f32 (/.f32 u1 (-.f32 1 u1)))
0.2b
(sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))
0.3b
(*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))
0.4b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))

series50.0ms (0.5%)

Counts
3 → 44
Calls

3 calls:

31.0ms
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))
14.0ms
(*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))
4.0ms
(sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))

rewrite28.0ms (0.3%)

Algorithm
rewrite-expression-head
Rules
31×add-sqr-sqrt_binary32
28×associate-*l*_binary32
26×sqrt-prod_binary32
24×*-un-lft-identity_binary32
19×times-frac_binary32
Counts
3 → 80
Calls

3 calls:

11.0ms
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))
8.0ms
(*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))
2.0ms
(sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))

simplify95.0ms (1%)

Algorithm
egg-herbie
Rules
586×fma-neg_binary32
426×fma-def_binary32
352×*-commutative_binary32
299×associate-/r*_binary32
265×sub-neg_binary32
Counts
124 → 146
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02092264
14632106
214041994
337431994
449681994

prune238.0ms (2.4%)

Pruning

13 alts after pruning (13 fresh and 0 done)

PrunedKeptTotal
New1896195
Fresh5712
Picked101
Done000
Total19513208
Error
0.0b
Counts
208 → 13
Alt Table
StatusErrorProgram
0.7b
(*.f32 (*.f32 (fabs.f32 (cbrt.f32 (/.f32 u1 (-.f32 1 u1)))) (sqrt.f32 (cbrt.f32 (/.f32 u1 (-.f32 1 u1))))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))
0.8b
(*.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (*.f32 (cbrt.f32 (sin.f32 (*.f32 314159265359/50000000000 u2))) (cbrt.f32 (sin.f32 (*.f32 314159265359/50000000000 u2))))) (cbrt.f32 (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))))
0.8b
(*.f32 (*.f32 (sqrt.f32 (*.f32 (/.f32 (cbrt.f32 u1) (sqrt.f32 (-.f32 1 u1))) (cbrt.f32 u1))) (sqrt.f32 (/.f32 (cbrt.f32 u1) (sqrt.f32 (-.f32 1 u1))))) (sin.f32 (*.f32 314159265359/50000000000 u2)))
0.6b
(*.f32 (sqrt.f32 u1) (*.f32 (sin.f32 (*.f32 314159265359/50000000000 u2)) (sqrt.f32 (/.f32 1 (-.f32 1 u1)))))
0.7b
(*.f32 (sqrt.f32 (/.f32 (*.f32 (cbrt.f32 u1) (cbrt.f32 u1)) (+.f32 1 (sqrt.f32 u1)))) (*.f32 (sqrt.f32 (/.f32 (cbrt.f32 u1) (-.f32 1 (sqrt.f32 u1)))) (sin.f32 (*.f32 314159265359/50000000000 u2))))
0.9b
(*.f32 (*.f32 (cbrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))) (cbrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2))))) (cbrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))))
0.6b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 (*.f32 1 1) (*.f32 u1 u1)))) (*.f32 (sqrt.f32 (+.f32 1 u1)) (sin.f32 (*.f32 314159265359/50000000000 u2))))
1.0b
(*.f32 (*.f32 (cbrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1)))) (cbrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))))) (*.f32 (cbrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1)))) (sin.f32 (*.f32 314159265359/50000000000 u2))))
0.5b
(*.f32 (/.f32 (sqrt.f32 u1) (sqrt.f32 (-.f32 1 u1))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))
1.7b
(*.f32 (sqrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))) (sqrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))))
0.7b
(*.f32 (sqrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1)))) (*.f32 (sqrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1)))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))))
0.6b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2))))
0.6b
(*.f32 (sqrt.f32 (/.f32 (sqrt.f32 u1) 1)) (*.f32 (sqrt.f32 (/.f32 (sqrt.f32 u1) (-.f32 1 u1))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))))
Compiler

Compiled 5754 to 4572 computations (20.5% saved)

localize47.0ms (0.5%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))
0.2b
(/.f32 (sqrt.f32 u1) (sqrt.f32 (-.f32 1 u1)))
0.3b
(*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))
0.4b
(*.f32 (/.f32 (sqrt.f32 u1) (sqrt.f32 (-.f32 1 u1))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))

series53.0ms (0.5%)

Counts
2 → 20
Calls

2 calls:

38.0ms
(*.f32 (/.f32 (sqrt.f32 u1) (sqrt.f32 (-.f32 1 u1))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))
15.0ms
(/.f32 (sqrt.f32 u1) (sqrt.f32 (-.f32 1 u1)))

rewrite44.0ms (0.4%)

Algorithm
rewrite-expression-head
Rules
139×sqrt-prod_binary32
123×add-sqr-sqrt_binary32
112×times-frac_binary32
107×*-un-lft-identity_binary32
68×add-cube-cbrt_binary32
Counts
2 → 171
Calls

2 calls:

17.0ms
(*.f32 (/.f32 (sqrt.f32 u1) (sqrt.f32 (-.f32 1 u1))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))
7.0ms
(/.f32 (sqrt.f32 u1) (sqrt.f32 (-.f32 1 u1)))

simplify122.0ms (1.2%)

Algorithm
egg-herbie
Rules
785×associate-/r*_binary32
732×times-frac_binary32
426×fma-def_binary32
371×associate-/l*_binary32
153×cancel-sign-sub-inv_binary32
Counts
191 → 220
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02535768
16024411
216984340
352304340

prune370.0ms (3.8%)

Pruning

13 alts after pruning (12 fresh and 1 done)

PrunedKeptTotal
New2703273
Fresh3912
Picked011
Done000
Total27313286
Error
0.0b
Counts
286 → 13
Alt Table
StatusErrorProgram
0.7b
(*.f32 (*.f32 (fabs.f32 (cbrt.f32 (/.f32 u1 (-.f32 1 u1)))) (sqrt.f32 (cbrt.f32 (/.f32 u1 (-.f32 1 u1))))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))
0.8b
(*.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (*.f32 (cbrt.f32 (sin.f32 (*.f32 314159265359/50000000000 u2))) (cbrt.f32 (sin.f32 (*.f32 314159265359/50000000000 u2))))) (cbrt.f32 (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))))
0.8b
(*.f32 (/.f32 1 (*.f32 (cbrt.f32 (sqrt.f32 (-.f32 1 u1))) (cbrt.f32 (sqrt.f32 (-.f32 1 u1))))) (*.f32 (sin.f32 (*.f32 314159265359/50000000000 u2)) (/.f32 (sqrt.f32 u1) (cbrt.f32 (sqrt.f32 (-.f32 1 u1))))))
0.5b
(*.f32 (/.f32 (sqrt.f32 u1) (sqrt.f32 (-.f32 1 u1))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))
0.7b
(*.f32 (sqrt.f32 (/.f32 (*.f32 (cbrt.f32 u1) (cbrt.f32 u1)) (+.f32 1 (sqrt.f32 u1)))) (*.f32 (sqrt.f32 (/.f32 (cbrt.f32 u1) (-.f32 1 (sqrt.f32 u1)))) (sin.f32 (*.f32 314159265359/50000000000 u2))))
0.9b
(*.f32 (*.f32 (cbrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))) (cbrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2))))) (cbrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))))
0.7b
(*.f32 (*.f32 (fabs.f32 (cbrt.f32 u1)) (/.f32 (sqrt.f32 (cbrt.f32 u1)) (sqrt.f32 (-.f32 1 u1)))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))
0.6b
(*.f32 (sqrt.f32 u1) (*.f32 (sin.f32 (*.f32 314159265359/50000000000 u2)) (sqrt.f32 (/.f32 1 (-.f32 1 u1)))))
1.0b
(*.f32 (*.f32 (cbrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1)))) (cbrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))))) (*.f32 (cbrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1)))) (sin.f32 (*.f32 314159265359/50000000000 u2))))
1.7b
(*.f32 (sqrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))) (sqrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))))
0.9b
(*.f32 (/.f32 (sqrt.f32 (sqrt.f32 u1)) (sqrt.f32 (sqrt.f32 (-.f32 1 u1)))) (*.f32 (/.f32 (sqrt.f32 (sqrt.f32 u1)) (sqrt.f32 (sqrt.f32 (-.f32 1 u1)))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))))
0.6b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2))))
0.6b
(*.f32 (sqrt.f32 (/.f32 (sqrt.f32 u1) 1)) (*.f32 (sqrt.f32 (/.f32 (sqrt.f32 u1) (-.f32 1 u1))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))))
Compiler

Compiled 8329 to 6217 computations (25.4% saved)

localize42.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(sqrt.f32 (/.f32 u1 (-.f32 1 u1)))
0.2b
(sin.f32 (*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2)))
0.2b
(*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2))
0.4b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2))))

series57.0ms (0.6%)

Counts
3 → 44
Calls

3 calls:

41.0ms
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2))))
10.0ms
(*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2))
6.0ms
(sin.f32 (*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2)))

rewrite26.0ms (0.3%)

Algorithm
rewrite-expression-head
Rules
33×associate-*l*_binary32
33×add-sqr-sqrt_binary32
29×sqrt-prod_binary32
26×*-un-lft-identity_binary32
19×times-frac_binary32
Counts
3 → 79
Calls

3 calls:

11.0ms
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2))))
7.0ms
(*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2))
2.0ms
(sin.f32 (*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2)))

simplify116.0ms (1.2%)

Algorithm
egg-herbie
Rules
677×fma-neg_binary32
421×fma-def_binary32
377×*-commutative_binary32
299×associate-/r*_binary32
235×sub-neg_binary32
Counts
123 → 154
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
02142355
14972167
214962057
339542049
448762049
549012049

prune272.0ms (2.8%)

Pruning

12 alts after pruning (11 fresh and 1 done)

PrunedKeptTotal
New2012203
Fresh2911
Picked011
Done101
Total20412216
Error
0.0b
Counts
216 → 12
Alt Table
StatusErrorProgram
0.7b
(*.f32 (*.f32 (fabs.f32 (cbrt.f32 (/.f32 u1 (-.f32 1 u1)))) (sqrt.f32 (cbrt.f32 (/.f32 u1 (-.f32 1 u1))))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2))))
0.6b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 (sqrt.f32 (sqrt.f32 314159265359/50000000000)) (*.f32 u2 (pow.f32 (sqrt.f32 314159265359/50000000000) 3/2)))))
1.6b
(*.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sqrt.f32 (sin.f32 (*.f32 u2 314159265359/50000000000)))) (sqrt.f32 (sin.f32 (*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2)))))
0.8b
(*.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (*.f32 (cbrt.f32 (sin.f32 (*.f32 314159265359/50000000000 u2))) (cbrt.f32 (sin.f32 (*.f32 314159265359/50000000000 u2))))) (cbrt.f32 (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))))
0.6b
(*.f32 (sqrt.f32 u1) (*.f32 (sin.f32 (*.f32 314159265359/50000000000 u2)) (sqrt.f32 (/.f32 1 (-.f32 1 u1)))))
1.0b
(*.f32 (*.f32 (cbrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1)))) (cbrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))))) (*.f32 (cbrt.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1)))) (sin.f32 (*.f32 314159265359/50000000000 u2))))
0.8b
(*.f32 (/.f32 1 (*.f32 (cbrt.f32 (sqrt.f32 (-.f32 1 u1))) (cbrt.f32 (sqrt.f32 (-.f32 1 u1))))) (*.f32 (sin.f32 (*.f32 314159265359/50000000000 u2)) (/.f32 (sqrt.f32 u1) (cbrt.f32 (sqrt.f32 (-.f32 1 u1))))))
1.7b
(*.f32 (sqrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))) (sqrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))))
0.9b
(*.f32 (*.f32 (cbrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))) (cbrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2))))) (cbrt.f32 (*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 314159265359/50000000000 u2)))))
0.9b
(*.f32 (/.f32 (sqrt.f32 (sqrt.f32 u1)) (sqrt.f32 (sqrt.f32 (-.f32 1 u1)))) (*.f32 (/.f32 (sqrt.f32 (sqrt.f32 u1)) (sqrt.f32 (sqrt.f32 (-.f32 1 u1)))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))))
0.6b
(*.f32 (sqrt.f32 (/.f32 u1 (-.f32 1 u1))) (sin.f32 (*.f32 (sqrt.f32 314159265359/50000000000) (*.f32 (sqrt.f32 314159265359/50000000000) u2))))
0.6b
(*.f32 (sqrt.f32 (/.f32 (sqrt.f32 u1) 1)) (*.f32 (sqrt.f32 (/.f32 (sqrt.f32 u1) (-.f32 1 u1))) (sin.f32 (*.f32 (*.f32 (cbrt.f32 314159265359/50000000000) (cbrt.f32 314159265359/50000000000)) (*.f32 (cbrt.f32 314159265359/50000000000) u2)))))
Compiler

Compiled 5217 to 4104 computations (21.3% saved)

regimes5.1s (52.5%)

Accuracy

Total 0.4b remaining (88.3%)

Threshold costs 0.4b (88.3%)

Counts
400 → 1
Compiler

Compiled 82572 to 66264 computations (19.8% saved)

simplify4.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
01955
12855
23255
33455
43555
53455

end224.0ms (2.3%)

Compiler

Compiled 411 to 339 computations (17.5% saved)

Profiling

Loading profile data...