Details

Time bar (total: 3.5s)

analyze5.0ms (0.1%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.9%0.1%0
0%99.9%0.1%1
0%99.9%0.1%2
74.9%25%0.1%3
87.4%12.5%0.1%4
93.7%6.2%0.1%5
96.8%3.1%0.1%6
98.3%1.6%0.1%7
99.1%0.8%0.1%8
99.5%0.4%0.1%9
99.7%0.2%0.1%10
99.8%0.1%0.1%11
99.9%0%0.1%12
99.9%0%0.1%13
99.9%0%0.1%14
Compiler

Compiled 15 to 11 computations (26.7% saved)

sample1.1s (31.7%)

Results
1.1s8256×body128valid
Compiler

Compiled 30 to 22 computations (26.7% saved)

preprocess16.0ms (0.5%)

Algorithm
egg-herbie
Rules
hypot-def_binary64
fma-def_binary64
swap-re-im
+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01522
11922
022
122
Stop Event
unsound
saturated
Symmetry

(sort re im)

Compiler

Compiled 14 to 10 computations (28.6% saved)

simplify9.0ms (0.3%)

Algorithm
egg-herbie
Rules
hypot-def_binary64
fma-def_binary64
+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01111
11411
21611
Stop Event
saturated
Counts
1 → 2

prune3.0ms (0.1%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New112
Fresh101
Picked000
Done000
Total213
Error
0.6b
Counts
3 → 1
Alt Table
StatusErrorProgram
0.6b
(/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))
Compiler

Compiled 39 to 29 computations (25.6% saved)

localize6.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.6b
(/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))

series26.0ms (0.7%)

Counts
1 → 24
Calls

6 calls:

5.0ms
(/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))
im
-inf
4.0ms
(/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))
im
0
4.0ms
(/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))
re
0
4.0ms
(/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))
re
-inf
4.0ms
(/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))
re
inf

rewrite35.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
759×pow1_binary64
703×log1p-expm1-u_binary64
703×expm1-log1p-u_binary64
80×add-sqr-sqrt_binary64
77×*-un-lft-identity_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0811
116011
2191311
Stop Event
node limit
Counts
1 → 33

simplify37.0ms (1.1%)

Algorithm
egg-herbie
Rules
428×associate-/l/_binary64
349×associate-/r/_binary64
292×times-frac_binary64
222×sub-neg_binary64
220×fma-def_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
084936
1247924
2725880
32992860
Stop Event
node limit
Counts
57 → 72

prune58.0ms (1.7%)

Pruning

10 alts after pruning (9 fresh and 1 done)

PrunedKeptTotal
New63972
Fresh000
Picked011
Done000
Total631073
Error
0.0b
Counts
73 → 10
Alt Table
StatusErrorProgram
0.6b
(/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))
12.8b
(*.f64 (/.f64 (sqrt.f64 (log.f64 (hypot.f64 re im))) 1) (/.f64 (sqrt.f64 (log.f64 (hypot.f64 re im))) (log.f64 10)))
0.7b
(neg.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 1/10)))
0.6b
(pow.f64 (/.f64 (log.f64 10) (log.f64 (hypot.f64 re im))) -1)
12.9b
(pow.f64 (sqrt.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))) 2)
1.3b
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (log.f64 (hypot.f64 re im))) 2) (sqrt.f64 (log.f64 10))) (/.f64 (cbrt.f64 (log.f64 (hypot.f64 re im))) (sqrt.f64 (log.f64 10))))
0.5b
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (/.f64 (log.f64 (hypot.f64 re im)) (sqrt.f64 (log.f64 10))))
13.2b
(exp.f64 (log.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))))
1.3b
(*.f64 (cbrt.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))) (pow.f64 (cbrt.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))) 2))
0.8b
(cbrt.f64 (/.f64 (pow.f64 (log.f64 (hypot.f64 re im)) 3) (pow.f64 (log.f64 10) 3)))
Compiler

Compiled 1709 to 1221 computations (28.6% saved)

localize10.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (/.f64 (log.f64 (hypot.f64 re im)) (sqrt.f64 (log.f64 10))))
0.5b
(/.f64 (log.f64 (hypot.f64 re im)) (sqrt.f64 (log.f64 10)))

series59.0ms (1.7%)

Counts
2 → 48
Calls

12 calls:

7.0ms
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (/.f64 (log.f64 (hypot.f64 re im)) (sqrt.f64 (log.f64 10))))
im
0
6.0ms
(/.f64 (log.f64 (hypot.f64 re im)) (sqrt.f64 (log.f64 10)))
re
-inf
5.0ms
(/.f64 (log.f64 (hypot.f64 re im)) (sqrt.f64 (log.f64 10)))
re
0
5.0ms
(/.f64 (log.f64 (hypot.f64 re im)) (sqrt.f64 (log.f64 10)))
im
-inf
5.0ms
(/.f64 (log.f64 (hypot.f64 re im)) (sqrt.f64 (log.f64 10)))
re
inf

rewrite64.0ms (1.8%)

Algorithm
batch-egg-rewrite
Rules
541×log-prod_binary64
195×expm1-udef_binary64
194×log1p-udef_binary64
177×log-pow_binary64
115×log-div_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01224
124124
2293124
Stop Event
node limit
Counts
2 → 96

simplify46.0ms (1.3%)

Algorithm
egg-herbie
Rules
577×fma-def_binary64
422×times-frac_binary64
304×associate-/r*_binary64
280×associate-/l*_binary64
214×associate-*r*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01422156
14522108
213941872
Stop Event
node limit
Counts
144 → 174

prune157.0ms (4.6%)

Pruning

7 alts after pruning (6 fresh and 1 done)

PrunedKeptTotal
New1704174
Fresh628
Picked011
Done101
Total1777184
Error
0b
Counts
184 → 7
Alt Table
StatusErrorProgram
0.5b
(/.f64 (*.f64 (neg.f64 (log.f64 (hypot.f64 re im))) (pow.f64 (log.f64 10) -1/2)) (neg.f64 (sqrt.f64 (log.f64 10))))
0.7b
(neg.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 1/10)))
0.2b
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (log.f64 (pow.f64 (hypot.f64 re im) (pow.f64 (log.f64 10) -1/2))))
0.6b
(/.f64 (/.f64 (/.f64 (log.f64 (hypot.f64 re im)) (sqrt.f64 (log.f64 10))) (pow.f64 (log.f64 10) 1/4)) (pow.f64 (log.f64 10) 1/4))
0.6b
(+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10)))) (cbrt.f64 (exp.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10)))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))))))
0.5b
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (/.f64 (log.f64 (hypot.f64 re im)) (sqrt.f64 (log.f64 10))))
13.2b
(exp.f64 (log.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))))
Compiler

Compiled 4350 to 3366 computations (22.6% saved)

localize13.0ms (0.4%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (log.f64 (pow.f64 (hypot.f64 re im) (pow.f64 (log.f64 10) -1/2))))
3.9b
(pow.f64 (hypot.f64 re im) (pow.f64 (log.f64 10) -1/2))

series136.0ms (4%)

Counts
2 → 48
Calls

12 calls:

15.0ms
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (log.f64 (pow.f64 (hypot.f64 re im) (pow.f64 (log.f64 10) -1/2))))
im
-inf
14.0ms
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (log.f64 (pow.f64 (hypot.f64 re im) (pow.f64 (log.f64 10) -1/2))))
re
-inf
13.0ms
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (log.f64 (pow.f64 (hypot.f64 re im) (pow.f64 (log.f64 10) -1/2))))
im
0
13.0ms
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (log.f64 (pow.f64 (hypot.f64 re im) (pow.f64 (log.f64 10) -1/2))))
im
inf
13.0ms
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (log.f64 (pow.f64 (hypot.f64 re im) (pow.f64 (log.f64 10) -1/2))))
re
inf

rewrite44.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
544×log-prod_binary64
212×expm1-udef_binary64
211×log1p-udef_binary64
198×log-pow_binary64
136×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01433
128626
2322026
Stop Event
node limit
Counts
2 → 49

simplify78.0ms (2.3%)

Algorithm
egg-herbie
Rules
517×cancel-sign-sub-inv_binary64
279×fma-neg_binary64
256×fma-def_binary64
200×associate-*r/_binary64
199×associate-/l*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02733924
19733843
239313503
Stop Event
node limit
Counts
97 → 143

prune181.0ms (5.2%)

Pruning

7 alts after pruning (5 fresh and 2 done)

PrunedKeptTotal
New1412143
Fresh235
Picked011
Done011
Total1437150
Error
0b
Counts
150 → 7
Alt Table
StatusErrorProgram
0.7b
(neg.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 1/10)))
0.2b
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (log.f64 (pow.f64 (hypot.f64 re im) (pow.f64 (log.f64 10) -1/2))))
0.6b
(+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10)))) (cbrt.f64 (exp.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10)))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))))))
0.5b
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (/.f64 (log.f64 (hypot.f64 re im)) (sqrt.f64 (log.f64 10))))
0.5b
(/.f64 (*.f64 (pow.f64 (log.f64 10) -1/2) (log.f64 (hypot.f64 re im))) (sqrt.f64 (log.f64 10)))
13.2b
(exp.f64 (log.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 10))))
0.6b
(cbrt.f64 (/.f64 (pow.f64 (*.f64 (pow.f64 (log.f64 10) -1/2) (log.f64 (hypot.f64 re im))) 3) (pow.f64 (log.f64 10) 3/2)))
Compiler

Compiled 6246 to 5194 computations (16.8% saved)

localize12.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.3b
(*.f64 (pow.f64 (log.f64 10) -1/2) (log.f64 (hypot.f64 re im)))
0.4b
(/.f64 (*.f64 (pow.f64 (log.f64 10) -1/2) (log.f64 (hypot.f64 re im))) (sqrt.f64 (log.f64 10)))

series57.0ms (1.7%)

Counts
2 → 48
Calls

12 calls:

6.0ms
(*.f64 (pow.f64 (log.f64 10) -1/2) (log.f64 (hypot.f64 re im)))
re
inf
6.0ms
(*.f64 (pow.f64 (log.f64 10) -1/2) (log.f64 (hypot.f64 re im)))
im
-inf
5.0ms
(/.f64 (*.f64 (pow.f64 (log.f64 10) -1/2) (log.f64 (hypot.f64 re im))) (sqrt.f64 (log.f64 10)))
im
0
5.0ms
(*.f64 (pow.f64 (log.f64 10) -1/2) (log.f64 (hypot.f64 re im)))
re
0
5.0ms
(*.f64 (pow.f64 (log.f64 10) -1/2) (log.f64 (hypot.f64 re im)))
im
0

rewrite49.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
565×log-prod_binary64
208×expm1-udef_binary64
207×log1p-udef_binary64
186×log-pow_binary64
122×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01235
124928
2300828
Stop Event
node limit
Counts
2 → 63

simplify46.0ms (1.3%)

Algorithm
egg-herbie
Rules
581×fma-def_binary64
422×times-frac_binary64
304×associate-/r*_binary64
281×associate-/l*_binary64
215×associate-*r*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01422156
14522108
213941872
Stop Event
node limit
Counts
111 → 142

prune108.0ms (3.1%)

Pruning

4 alts after pruning (2 fresh and 2 done)

PrunedKeptTotal
New1411142
Fresh314
Picked011
Done112
Total1454149
Error
0b
Counts
149 → 4
Alt Table
StatusErrorProgram
0.7b
(neg.f64 (/.f64 (log.f64 (hypot.f64 re im)) (log.f64 1/10)))
0.2b
(*.f64 (/.f64 1 (sqrt.f64 (log.f64 10))) (log.f64 (pow.f64 (hypot.f64 re im) (pow.f64 (log.f64 10) -1/2))))
0.3b
(*.f64 (/.f64 (pow.f64 (log.f64 10) -1/2) (sqrt.f64 (log.f64 10))) (log.f64 (hypot.f64 re im)))
0.5b
(/.f64 (*.f64 (pow.f64 (log.f64 10) -1/2) (log.f64 (hypot.f64 re im))) (sqrt.f64 (log.f64 10)))
Compiler

Compiled 3581 to 2822 computations (21.2% saved)

regimes993.0ms (28.8%)

Accuracy

Total 0.3b remaining (99.4%)

Threshold costs 0.3b (99.4%)

Counts
120 → 1
Compiler

Compiled 16451 to 13659 computations (17% saved)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
1-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01424
11724
Stop Event
saturated

end108.0ms (3.1%)

Stop Event
fuel
Remove

(sort re im)

Compiler

Compiled 125 to 109 computations (12.8% saved)

Profiling

Loading profile data...