Details

Time bar (total: 2.8s)

analyze80.0ms (2.9%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.9%0.1%0
0%99.9%0.1%1
0%99.9%0.1%2
0%99.9%0.1%3
0%99.9%0.1%4
25%74.9%0.1%5
25%50%25.1%6
25%31.2%43.8%7
25%21.9%53.2%8
25%14%61%9
28.1%10.9%61%10
31.6%7.4%61%11
33.4%5.7%61%12
35.2%3.8%61%13
36.1%2.9%61%14
Compiler

Compiled 18 to 13 computations (27.8% saved)

sample18.0ms (0.7%)

Algorithm
intervals
Results
11.0ms256×body128valid
Compiler

Compiled 35 to 27 computations (22.9% saved)

simplify42.0ms (1.5%)

Algorithm
egg-herbie
Counts
1 → 1
Iterations

Useful iterations: 0 (35.0ms)

IterNodesCost
0512625

prune6.0ms (0.2%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New101
Fresh011
Picked000
Done000
Total112

Merged error: 0.2b

Counts
2 → 1
Compiler

Compiled 34 to 24 computations (29.4% saved)

localize10.0ms (0.4%)

Local error

Found 4 expressions with local error:

0.0b
(*.f64 4 (*.f64 b b))
0.0b
(+.f64 (*.f64 a a) (*.f64 b b))
0.0b
(+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b)))
0.3b
(pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2)

rewrite31.0ms (1.1%)

Algorithm
rewrite-expression-head
Rules
10×pow1_binary64 add-exp-log_binary64
add-cbrt-cube_binary64
add-log-exp_binary64 add-sqr-sqrt_binary64
*-un-lft-identity_binary64 add-cube-cbrt_binary64
pow-prod-down_binary64 pow-unpow_binary64 cbrt-unprod_binary64 associate-*l*_binary64 unpow-prod-down_binary64 prod-exp_binary64
flip3-+_binary64 +-commutative_binary64 flip-+_binary64 sum-log_binary64
pow-to-exp_binary64 associate-*r*_binary64 unpow2_binary64 pow-pow_binary64 sqr-pow_binary64 unswap-sqr_binary64 pow-exp_binary64 *-commutative_binary64
Counts
4 → 59
Calls

4 calls:

9.0ms
(+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b)))
6.0ms
(*.f64 4 (*.f64 b b))
6.0ms
(pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2)
5.0ms
(+.f64 (*.f64 a a) (*.f64 b b))

series221.0ms (8%)

Counts
4 → 12
Calls

4 calls:

89.0ms
(+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b)))
52.0ms
(pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2)
42.0ms
(+.f64 (*.f64 a a) (*.f64 b b))
38.0ms
(*.f64 4 (*.f64 b b))

simplify71.0ms (2.6%)

Algorithm
egg-herbie
Counts
71 → 71
Iterations

Useful iterations: 0 (57.0ms)

IterNodesCost
049231108
149231108

prune198.0ms (7.1%)

Pruning

4 alts after pruning (4 fresh and 0 done)

PrunedKeptTotal
New67471
Fresh000
Picked101
Done000
Total68472

Merged error: 0.0b

Counts
72 → 4
Compiler

Compiled 4056 to 2243 computations (44.7% saved)

localize16.0ms (0.6%)

Local error

Found 4 expressions with local error:

0.0b
(*.f64 4 (*.f64 b b))
0.0b
(+.f64 (*.f64 (*.f64 a a) (*.f64 b (*.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
0.0b
(+.f64 (+.f64 (*.f64 (*.f64 a a) (*.f64 b (*.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4))) (*.f64 4 (*.f64 b b)))
3.2b
(*.f64 (*.f64 a a) (*.f64 b (*.f64 b 2)))

rewrite68.0ms (2.5%)

Algorithm
rewrite-expression-head
Rules
30×pow1_binary64 add-exp-log_binary64 add-cbrt-cube_binary64
18×pow-prod-down_binary64 add-log-exp_binary64 cbrt-unprod_binary64 prod-exp_binary64
sum-log_binary64
add-sqr-sqrt_binary64
*-un-lft-identity_binary64 add-cube-cbrt_binary64
associate-*l*_binary64
flip3-+_binary64 associate-*r*_binary64 +-commutative_binary64 flip-+_binary64 *-commutative_binary64
associate-+l+_binary64 unswap-sqr_binary64 associate-+r+_binary64
Counts
4 → 74
Calls

4 calls:

23.0ms
(+.f64 (+.f64 (*.f64 (*.f64 a a) (*.f64 b (*.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4))) (*.f64 4 (*.f64 b b)))
19.0ms
(+.f64 (*.f64 (*.f64 a a) (*.f64 b (*.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
11.0ms
(*.f64 (*.f64 a a) (*.f64 b (*.f64 b 2)))
6.0ms
(*.f64 4 (*.f64 b b))

series252.0ms (9.1%)

Counts
4 → 12
Calls

4 calls:

89.0ms
(+.f64 (+.f64 (*.f64 (*.f64 a a) (*.f64 b (*.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4))) (*.f64 4 (*.f64 b b)))
72.0ms
(+.f64 (*.f64 (*.f64 a a) (*.f64 b (*.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
57.0ms
(*.f64 (*.f64 a a) (*.f64 b (*.f64 b 2)))
33.0ms
(*.f64 4 (*.f64 b b))

simplify64.0ms (2.3%)

Algorithm
egg-herbie
Counts
86 → 86
Iterations

Useful iterations: 0 (42.0ms)

IterNodesCost
049751703
149751703

prune124.0ms (4.5%)

Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New86086
Fresh033
Picked011
Done000
Total86490

Merged error: 0.0b

Counts
90 → 4
Compiler

Compiled 2627 to 1707 computations (35% saved)

localize12.0ms (0.5%)

Local error

Found 4 expressions with local error:

0.0b
(+.f64 (pow.f64 (*.f64 (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b))) (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))) 2) (*.f64 4 (*.f64 b b)))
0.3b
(pow.f64 (*.f64 (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b))) (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))) 2)
11.6b
(sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))
11.6b
(sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))

rewrite41.0ms (1.5%)

Algorithm
rewrite-expression-head
Rules
22×pow1_binary64
14×pow-pow_binary64
10×pow1/2_binary64 sqrt-pow1_binary64
add-sqr-sqrt_binary64
*-un-lft-identity_binary64 add-cube-cbrt_binary64 add-exp-log_binary64
add-log-exp_binary64 sqrt-prod_binary64
pow-prod-up_binary64
add-cbrt-cube_binary64 sqrt-div_binary64
pow-prod-down_binary64 flip3-+_binary64 pow-unpow_binary64 pow-sqr_binary64 flip-+_binary64
rem-sqrt-square_binary64 pow-exp_binary64
pow-to-exp_binary64 sqrt-pow2_binary64 unpow2_binary64 sqr-pow_binary64 pow-plus_binary64 sqrt-unprod_binary64 unpow-prod-down_binary64 prod-exp_binary64 +-commutative_binary64 pow2_binary64 sum-log_binary64
Counts
4 → 72
Calls

4 calls:

15.0ms
(pow.f64 (*.f64 (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b))) (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))) 2)
9.0ms
(+.f64 (pow.f64 (*.f64 (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b))) (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))) 2) (*.f64 4 (*.f64 b b)))
5.0ms
(sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))
5.0ms
(sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))

series236.0ms (8.5%)

Counts
4 → 12
Calls

4 calls:

88.0ms
(+.f64 (pow.f64 (*.f64 (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b))) (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))) 2) (*.f64 4 (*.f64 b b)))
58.0ms
(pow.f64 (*.f64 (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b))) (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))) 2)
48.0ms
(sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))
42.0ms
(sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))

simplify49.0ms (1.8%)

Algorithm
egg-herbie
Counts
84 → 84
Iterations

Useful iterations: 0 (30.0ms)

IterNodesCost
051951233

prune97.0ms (3.5%)

Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New83184
Fresh022
Picked101
Done011
Total84488

Merged error: 0.0b

Counts
88 → 4
Compiler

Compiled 2523 to 976 computations (61.3% saved)

localize11.0ms (0.4%)

Local error

Found 4 expressions with local error:

0.0b
(+.f64 (*.f64 a a) (*.f64 b b))
0.0b
(pow.f64 (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b))) 4)
0.0b
(+.f64 (pow.f64 (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b))) 4) (*.f64 4 (*.f64 b b)))
11.6b
(sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))

rewrite32.0ms (1.1%)

Algorithm
rewrite-expression-head
Rules
add-sqr-sqrt_binary64
*-un-lft-identity_binary64 add-log-exp_binary64 add-cube-cbrt_binary64
pow1_binary64
unpow-prod-down_binary64 sqrt-prod_binary64
add-exp-log_binary64
add-cbrt-cube_binary64
flip3-+_binary64 pow-unpow_binary64 pow-pow_binary64 flip-+_binary64
pow1/2_binary64 sqrt-pow1_binary64 +-commutative_binary64 sqrt-div_binary64 sum-log_binary64
pow-to-exp_binary64 sqrt-pow2_binary64 sqr-pow_binary64 rem-sqrt-square_binary64 pow-exp_binary64
Counts
4 → 60
Calls

4 calls:

11.0ms
(+.f64 (pow.f64 (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b))) 4) (*.f64 4 (*.f64 b b)))
6.0ms
(pow.f64 (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b))) 4)
5.0ms
(+.f64 (*.f64 a a) (*.f64 b b))
5.0ms
(sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))

series245.0ms (8.8%)

Counts
4 → 12
Calls

4 calls:

79.0ms
(pow.f64 (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b))) 4)
77.0ms
(+.f64 (pow.f64 (sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b))) 4) (*.f64 4 (*.f64 b b)))
53.0ms
(sqrt.f64 (+.f64 (*.f64 a a) (*.f64 b b)))
37.0ms
(+.f64 (*.f64 a a) (*.f64 b b))

simplify57.0ms (2%)

Algorithm
egg-herbie
Counts
72 → 72
Iterations

Useful iterations: 0 (39.0ms)

IterNodesCost
054671281

prune85.0ms (3.1%)

Pruning

4 alts after pruning (2 fresh and 2 done)

PrunedKeptTotal
New72072
Fresh022
Picked011
Done011
Total72476

Merged error: 0.0b

Counts
76 → 4
Compiler

Compiled 1923 to 897 computations (53.4% saved)

regimes50.0ms (1.8%)

Compiler

Compiled 512 to 320 computations (37.5% saved)

bsearch0.0ms (0%)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (1.0ms)

IterNodesCost
02627
12627

end0.0ms (0%)

sample653.0ms (23.5%)

Algorithm
intervals
Results
367.0ms8000×body128valid
0.0msbody128invalid
Compiler

Compiled 160 to 103 computations (35.6% saved)

Profiling

Loading profile data...