Details

Time bar (total: 2.5s)

analyze55.0ms (2.2%)

Algorithm
search
Search
TrueOtherFalseIter
0%18.7%81.3%0
0%18.7%81.3%1
0%18.7%81.3%2
0%18.7%81.3%3
0%18.7%81.3%4
4.7%14%81.3%5
5.3%13.5%81.3%6
18.1%0.6%81.3%7
18.1%0.6%81.3%8
18.6%0.1%81.3%9
18.6%0.1%81.3%10
18.7%0%81.3%11
18.7%0%81.3%12
18.7%0%81.3%13
18.7%0%81.3%14
Compiler

Compiled 28 to 17 computations (39.3% saved)

sample279.0ms (11.4%)

Algorithm
intervals
Results
12.0ms256×body128valid
5.0ms256×pre128true
Compiler

Compiled 47 to 28 computations (40.4% saved)

simplify82.0ms (3.3%)

Algorithm
egg-herbie
Rules
917×times-frac_binary64
816×unsub-neg_binary64
772×fma-def_binary64
484×fma-neg_binary64
376×sub-neg_binary64
Counts
1 → 2
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01020
12420
25520
311220
427120
565720
6123420
7262020
8328820
9465220
10507520

prune3.0ms (0.1%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New112
Fresh101
Picked000
Done000
Total213
Error
20.1b
Counts
3 → 1
Alt Table
StatusErrorProgram
20.1b
(/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y)))
Compiler

Compiled 63 to 27 computations (57.1% saved)

localize8.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 x x (*.f64 y y))
19.8b
(/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y)))

series25.0ms (1%)

Counts
2 → 48
Calls

2 calls:

19.0ms
(/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y)))
6.0ms
(fma.f64 x x (*.f64 y y))

rewrite11.0ms (0.5%)

Algorithm
rewrite-expression-head
Rules
associate-/l/_binary64
add-cbrt-cube_binary64
add-exp-log_binary64
frac-times_binary64
*-un-lft-identity_binary64
Counts
2 → 41
Calls

2 calls:

8.0ms
(/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y)))
0.0ms
(fma.f64 x x (*.f64 y y))

simplify61.0ms (2.5%)

Algorithm
egg-herbie
Rules
843×distribute-rgt-in_binary64
815×distribute-lft-in_binary64
413×times-frac_binary64
413×fma-def_binary64
73×cancel-sign-sub-inv_binary64
Counts
89 → 76
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01081667
13321473
213201435
352541435

prune39.0ms (1.6%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New73376
Fresh000
Picked101
Done000
Total74377
Error
0.0b
Counts
77 → 3
Alt Table
StatusErrorProgram
0.0b
(*.f64 (/.f64 (-.f64 x y) (hypot.f64 x y)) (/.f64 (+.f64 x y) (hypot.f64 x y)))
20.1b
(log1p.f64 (expm1.f64 (/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y)))))
21.6b
-1
Compiler

Compiled 1734 to 466 computations (73.1% saved)

localize7.0ms (0.3%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(*.f64 (/.f64 (-.f64 x y) (hypot.f64 x y)) (/.f64 (+.f64 x y) (hypot.f64 x y)))
0.0b
(/.f64 (-.f64 x y) (hypot.f64 x y))
0.0b
(/.f64 (+.f64 x y) (hypot.f64 x y))

series48.0ms (1.9%)

Counts
3 → 72
Calls

3 calls:

26.0ms
(*.f64 (/.f64 (-.f64 x y) (hypot.f64 x y)) (/.f64 (+.f64 x y) (hypot.f64 x y)))
11.0ms
(/.f64 (+.f64 x y) (hypot.f64 x y))
10.0ms
(/.f64 (-.f64 x y) (hypot.f64 x y))

rewrite35.0ms (1.4%)

Algorithm
rewrite-expression-head
Rules
67×*-un-lft-identity_binary64
65×add-sqr-sqrt_binary64
58×times-frac_binary64
39×add-cube-cbrt_binary64
19×associate-*l*_binary64
Counts
3 → 136
Calls

3 calls:

14.0ms
(*.f64 (/.f64 (-.f64 x y) (hypot.f64 x y)) (/.f64 (+.f64 x y) (hypot.f64 x y)))
5.0ms
(/.f64 (+.f64 x y) (hypot.f64 x y))
5.0ms
(/.f64 (-.f64 x y) (hypot.f64 x y))

simplify104.0ms (4.3%)

Algorithm
egg-herbie
Rules
614×times-frac_binary64
493×distribute-rgt-in_binary64
464×fma-def_binary64
222×cancel-sign-sub-inv_binary64
176×sub-neg_binary64
Counts
208 → 233
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02404519
17354135
223214033
351364033

prune125.0ms (5.1%)

Pruning

4 alts after pruning (4 fresh and 0 done)

PrunedKeptTotal
New2303233
Fresh112
Picked101
Done000
Total2324236
Error
0b
Counts
236 → 4
Alt Table
StatusErrorProgram
20.1b
(log1p.f64 (expm1.f64 (/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y)))))
41.5b
(fma.f64 (*.f64 (/.f64 y x) (/.f64 y x)) -2 1)
0.0b
(*.f64 (/.f64 (-.f64 x y) (hypot.f64 x y)) (log1p.f64 (expm1.f64 (/.f64 (+.f64 x y) (hypot.f64 x y)))))
20.8b
(fma.f64 2 (*.f64 (/.f64 x y) (/.f64 x y)) -1)
Compiler

Compiled 5801 to 1184 computations (79.6% saved)

localize12.0ms (0.5%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(*.f64 (/.f64 (-.f64 x y) (hypot.f64 x y)) (log1p.f64 (expm1.f64 (/.f64 (+.f64 x y) (hypot.f64 x y)))))
0.0b
(log1p.f64 (expm1.f64 (/.f64 (+.f64 x y) (hypot.f64 x y))))
0.0b
(/.f64 (+.f64 x y) (hypot.f64 x y))
0.6b
(expm1.f64 (/.f64 (+.f64 x y) (hypot.f64 x y)))

series60.0ms (2.4%)

Counts
3 → 72
Calls

3 calls:

28.0ms
(*.f64 (/.f64 (-.f64 x y) (hypot.f64 x y)) (log1p.f64 (expm1.f64 (/.f64 (+.f64 x y) (hypot.f64 x y)))))
20.0ms
(expm1.f64 (/.f64 (+.f64 x y) (hypot.f64 x y)))
11.0ms
(log1p.f64 (expm1.f64 (/.f64 (+.f64 x y) (hypot.f64 x y))))

rewrite13.0ms (0.5%)

Algorithm
rewrite-expression-head
Rules
24×add-sqr-sqrt_binary64
19×associate-*l*_binary64
19×*-un-lft-identity_binary64
16×times-frac_binary64
13×add-cube-cbrt_binary64
Counts
3 → 62
Calls

3 calls:

7.0ms
(*.f64 (/.f64 (-.f64 x y) (hypot.f64 x y)) (log1p.f64 (expm1.f64 (/.f64 (+.f64 x y) (hypot.f64 x y)))))
0.0ms
(expm1.f64 (/.f64 (+.f64 x y) (hypot.f64 x y)))
0.0ms
(log1p.f64 (expm1.f64 (/.f64 (+.f64 x y) (hypot.f64 x y))))

simplify98.0ms (4%)

Algorithm
egg-herbie
Rules
990×times-frac_binary64
486×fma-neg_binary64
341×fma-def_binary64
272×cancel-sign-sub-inv_binary64
214×sub-neg_binary64
Counts
134 → 161
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
02193044
16052776
220002632
346852620
449982620

prune144.0ms (5.8%)

Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New2220222
Fresh033
Picked011
Done000
Total2224226
Error
0b
Counts
226 → 4
Alt Table
StatusErrorProgram
20.1b
(log1p.f64 (expm1.f64 (/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y)))))
41.5b
(fma.f64 (*.f64 (/.f64 y x) (/.f64 y x)) -2 1)
0.0b
(*.f64 (/.f64 (-.f64 x y) (hypot.f64 x y)) (log1p.f64 (expm1.f64 (/.f64 (+.f64 x y) (hypot.f64 x y)))))
20.8b
(fma.f64 2 (*.f64 (/.f64 x y) (/.f64 x y)) -1)
Compiler

Compiled 5614 to 1554 computations (72.3% saved)

localize12.0ms (0.5%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 x x (*.f64 y y))
0.0b
(log1p.f64 (expm1.f64 (/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y)))))
0.3b
(expm1.f64 (/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y))))
19.8b
(/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y)))

series52.0ms (2.1%)

Counts
2 → 48
Calls

2 calls:

34.0ms
(expm1.f64 (/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y))))
19.0ms
(log1p.f64 (expm1.f64 (/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y)))))

rewrite2.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
log1p-expm1-u_binary64
*-un-lft-identity_binary64
add-sqr-sqrt_binary64
add-cube-cbrt_binary64
add-cbrt-cube_binary64
Counts
2 → 22
Calls

2 calls:

0.0ms
(expm1.f64 (/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y))))
0.0ms
(log1p.f64 (expm1.f64 (/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y)))))

simplify77.0ms (3.1%)

Algorithm
egg-herbie
Rules
737×fma-neg_binary64
366×times-frac_binary64
277×distribute-neg-frac_binary64
238×associate-/l*_binary64
233×associate-/r*_binary64
Counts
70 → 60
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01041942
12691772
28391718
335651706
451201706

prune80.0ms (3.3%)

Pruning

4 alts after pruning (2 fresh and 2 done)

PrunedKeptTotal
New1360136
Fresh022
Picked011
Done011
Total1364140
Error
0b
Counts
140 → 4
Alt Table
StatusErrorProgram
20.1b
(log1p.f64 (expm1.f64 (/.f64 (*.f64 (-.f64 x y) (+.f64 x y)) (fma.f64 x x (*.f64 y y)))))
41.5b
(fma.f64 (*.f64 (/.f64 y x) (/.f64 y x)) -2 1)
0.0b
(*.f64 (/.f64 (-.f64 x y) (hypot.f64 x y)) (log1p.f64 (expm1.f64 (/.f64 (+.f64 x y) (hypot.f64 x y)))))
20.8b
(fma.f64 2 (*.f64 (/.f64 x y) (/.f64 x y)) -1)
Compiler

Compiled 3192 to 1081 computations (66.1% saved)

regimes83.0ms (3.4%)

Accuracy

Total 0.0b remaining (70.9%)

Threshold costs 0.0b (70.9%)

Counts
31 → 1
Compiler

Compiled 1431 to 841 computations (41.2% saved)

simplify3.0ms (0.1%)

Algorithm
egg-herbie
Rules
+-commutative_binary64
*-commutative_binary64
sub-neg_binary64
neg-sub0_binary64
neg-mul-1_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0922
11322
21822
32022
42122
52122

end0.0ms (0%)

Compiler

Compiled 17 to 8 computations (52.9% saved)

sample941.0ms (38.3%)

Algorithm
intervals
Results
411.0ms8000×body128valid
189.0ms8000×pre128true
Compiler

Compiled 108 to 61 computations (43.5% saved)

Profiling

Loading profile data...