Details

Time bar (total: 10.3s)

analyze2.5s (24.4%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.8%0.2%0
0%99.8%0.2%1
0%99.8%0.2%2
0%99.8%0.2%3
0%99.8%0.2%4
0%99.8%0.2%5
0%99.8%0.2%6
0%99.8%0.2%7
0%99.8%0.2%8
2.3%97.4%0.2%9
3.5%96.2%0.2%10
9.5%90.2%0.2%11
14.3%85.4%0.2%12
22.4%77.4%0.2%13
29.7%70%0.2%14
Compiler

Compiled 17 to 11 computations (35.3% saved)

sample2.3s (22.1%)

Results
2.0s8256×body128valid
160.0ms718×body128invalid
Compiler

Compiled 50 to 32 computations (36% saved)

simplify127.0ms (1.2%)

Algorithm
egg-herbie
Rules
1405×fma-def_binary64
906×div-sub_binary64
613×distribute-rgt-in_binary64
583×fma-neg_binary64
525×times-frac_binary64
Counts
1 → 2
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01116
12214
24314
38214
416414
530414
665514
7159014
8304614
9278114
10295414
11302814
12311614
13428914
14518714

prune9.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
1.3b
Counts
3 → 2
Alt Table
StatusErrorProgram
1.3b
(fma.f64 y (/.f64 (-.f64 z t) (-.f64 z a)) x)
1.3b
(+.f64 x (*.f64 y (/.f64 (-.f64 z t) (-.f64 z a))))
Compiler

Compiled 88 to 49 computations (44.3% saved)

localize16.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(+.f64 x (*.f64 y (/.f64 (-.f64 z t) (-.f64 z a))))
0.0b
(/.f64 (-.f64 z t) (-.f64 z a))
1.9b
(*.f64 y (/.f64 (-.f64 z t) (-.f64 z a)))

series207.0ms (2%)

Counts
3 → 144
Calls

3 calls:

104.0ms
(+.f64 x (*.f64 y (/.f64 (-.f64 z t) (-.f64 z a))))
66.0ms
(*.f64 y (/.f64 (-.f64 z t) (-.f64 z a)))
37.0ms
(/.f64 (-.f64 z t) (-.f64 z a))

rewrite130.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
553×fma-def_binary64
280×fma-neg_binary64
254×expm1-udef_binary64
254×log1p-udef_binary64
138×add-sqr-sqrt_binary64
Counts
3 → 129
Calls

3 calls:

124.0ms
(+.f64 x (*.f64 y (/.f64 (-.f64 z t) (-.f64 z a))))
124.0ms
(/.f64 (-.f64 z t) (-.f64 z a))
124.0ms
(*.f64 y (/.f64 (-.f64 z t) (-.f64 z a)))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01139
125837
2385437
3547937
000
100

simplify195.0ms (1.9%)

Algorithm
egg-herbie
Rules
717×cancel-sign-sub-inv_binary64
661×times-frac_binary64
630×fma-neg_binary64
450×sub-neg_binary64
213×associate--l+_binary64
Counts
273 → 239
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
02024438
15944195
221933525
343623513
450273513

prune396.0ms (3.8%)

Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New2363239
Fresh101
Picked011
Done000
Total2374241
Error
0b
Counts
241 → 4
Alt Table
StatusErrorProgram
10.3b
(+.f64 x (/.f64 (*.f64 y (-.f64 z t)) (-.f64 z a)))
1.3b
(+.f64 x (*.f64 y (/.f64 (-.f64 z t) (-.f64 z a))))
1.2b
(+.f64 x (/.f64 y (/.f64 (-.f64 z a) (-.f64 z t))))
28.9b
(fma.f64 (/.f64 y (sqrt.f64 (-.f64 z a))) (/.f64 (-.f64 z t) (sqrt.f64 (-.f64 z a))) x)
Compiler

Compiled 5680 to 1866 computations (67.1% saved)

localize15.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(+.f64 x (/.f64 y (/.f64 (-.f64 z a) (-.f64 z t))))
0.0b
(/.f64 (-.f64 z a) (-.f64 z t))
1.9b
(/.f64 y (/.f64 (-.f64 z a) (-.f64 z t)))

series210.0ms (2%)

Counts
3 → 144
Calls

3 calls:

93.0ms
(+.f64 x (/.f64 y (/.f64 (-.f64 z a) (-.f64 z t))))
70.0ms
(/.f64 y (/.f64 (-.f64 z a) (-.f64 z t)))
46.0ms
(/.f64 (-.f64 z a) (-.f64 z t))

rewrite134.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
294×fma-neg_binary64
260×expm1-udef_binary64
260×log1p-udef_binary64
142×add-sqr-sqrt_binary64
137×log1p-expm1-u_binary64
Counts
3 → 132
Calls

3 calls:

128.0ms
(+.f64 x (/.f64 y (/.f64 (-.f64 z a) (-.f64 z t))))
128.0ms
(/.f64 (-.f64 z a) (-.f64 z t))
128.0ms
(/.f64 y (/.f64 (-.f64 z a) (-.f64 z t)))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01139
126437
2409237
3521937
000
100

simplify221.0ms (2.1%)

Algorithm
egg-herbie
Rules
820×times-frac_binary64
711×cancel-sign-sub-inv_binary64
596×fma-neg_binary64
435×sub-neg_binary64
210×associate--l+_binary64
Counts
276 → 243
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02154438
16194195
222994075
349384075
453364075

prune329.0ms (3.2%)

Pruning

4 alts after pruning (2 fresh and 2 done)

PrunedKeptTotal
New2430243
Fresh022
Picked011
Done011
Total2434247
Error
0b
Counts
247 → 4
Alt Table
StatusErrorProgram
10.3b
(+.f64 x (/.f64 (*.f64 y (-.f64 z t)) (-.f64 z a)))
1.3b
(+.f64 x (*.f64 y (/.f64 (-.f64 z t) (-.f64 z a))))
1.2b
(+.f64 x (/.f64 y (/.f64 (-.f64 z a) (-.f64 z t))))
28.9b
(fma.f64 (/.f64 y (sqrt.f64 (-.f64 z a))) (/.f64 (-.f64 z t) (sqrt.f64 (-.f64 z a))) x)
Compiler

Compiled 6029 to 1924 computations (68.1% saved)

localize15.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(*.f64 y (-.f64 z t))
0.0b
(+.f64 x (/.f64 (*.f64 y (-.f64 z t)) (-.f64 z a)))
10.7b
(/.f64 (*.f64 y (-.f64 z t)) (-.f64 z a))

series187.0ms (1.8%)

Counts
3 → 144
Calls

3 calls:

104.0ms
(+.f64 x (/.f64 (*.f64 y (-.f64 z t)) (-.f64 z a)))
70.0ms
(/.f64 (*.f64 y (-.f64 z t)) (-.f64 z a))
12.0ms
(*.f64 y (-.f64 z t))

rewrite122.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
521×fma-def_binary64
265×fma-neg_binary64
250×expm1-udef_binary64
250×log1p-udef_binary64
136×add-sqr-sqrt_binary64
Counts
3 → 130
Calls

3 calls:

118.0ms
(*.f64 y (-.f64 z t))
118.0ms
(+.f64 x (/.f64 (*.f64 y (-.f64 z t)) (-.f64 z a)))
118.0ms
(/.f64 (*.f64 y (-.f64 z t)) (-.f64 z a))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01136
125536
2376834
3533434
000
100

simplify186.0ms (1.8%)

Algorithm
egg-herbie
Rules
676×fma-def_binary64
544×times-frac_binary64
522×cancel-sign-sub-inv_binary64
479×associate-/l*_binary64
455×fma-neg_binary64
Counts
274 → 213
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01473581
14293338
215352828
345812826
449942826

prune262.0ms (2.5%)

Pruning

4 alts after pruning (1 fresh and 3 done)

PrunedKeptTotal
New2130213
Fresh011
Picked011
Done022
Total2134217
Error
0b
Counts
217 → 4
Alt Table
StatusErrorProgram
10.3b
(+.f64 x (/.f64 (*.f64 y (-.f64 z t)) (-.f64 z a)))
1.3b
(+.f64 x (*.f64 y (/.f64 (-.f64 z t) (-.f64 z a))))
1.2b
(+.f64 x (/.f64 y (/.f64 (-.f64 z a) (-.f64 z t))))
28.9b
(fma.f64 (/.f64 y (sqrt.f64 (-.f64 z a))) (/.f64 (-.f64 z t) (sqrt.f64 (-.f64 z a))) x)
Compiler

Compiled 4761 to 1420 computations (70.2% saved)

localize18.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(sqrt.f64 (-.f64 z a))
0.1b
(/.f64 y (sqrt.f64 (-.f64 z a)))
0.2b
(fma.f64 (/.f64 y (sqrt.f64 (-.f64 z a))) (/.f64 (-.f64 z t) (sqrt.f64 (-.f64 z a))) x)
0.2b
(/.f64 (-.f64 z t) (sqrt.f64 (-.f64 z a)))

series651.0ms (6.3%)

Counts
4 → 95
Calls

4 calls:

352.0ms
(fma.f64 (/.f64 y (sqrt.f64 (-.f64 z a))) (/.f64 (-.f64 z t) (sqrt.f64 (-.f64 z a))) x)
149.0ms
(/.f64 (-.f64 z t) (sqrt.f64 (-.f64 z a)))
113.0ms
(/.f64 y (sqrt.f64 (-.f64 z a)))
36.0ms
(sqrt.f64 (-.f64 z a))

rewrite207.0ms (2%)

Algorithm
batch-egg-rewrite
Rules
389×fma-def_binary64
259×expm1-udef_binary64
259×log1p-udef_binary64
213×fma-neg_binary64
142×add-sqr-sqrt_binary64
Counts
4 → 128
Calls

4 calls:

200.0ms
(sqrt.f64 (-.f64 z a))
200.0ms
(/.f64 y (sqrt.f64 (-.f64 z a)))
200.0ms
(fma.f64 (/.f64 y (sqrt.f64 (-.f64 z a))) (/.f64 (-.f64 z t) (sqrt.f64 (-.f64 z a))) x)
200.0ms
(/.f64 (-.f64 z t) (sqrt.f64 (-.f64 z a)))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01251
127043
2383543
3522043
000
100

simplify176.0ms (1.7%)

Algorithm
egg-herbie
Rules
609×cancel-sign-sub-inv_binary64
266×sub-neg_binary64
260×times-frac_binary64
216×fma-def_binary64
190×associate-*r*_binary64
Counts
223 → 207
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02662908
18922857
235772846
350332846

prune365.0ms (3.5%)

Pruning

4 alts after pruning (0 fresh and 4 done)

PrunedKeptTotal
New2450245
Fresh000
Picked011
Done033
Total2454249
Error
0b
Counts
249 → 4
Alt Table
StatusErrorProgram
10.3b
(+.f64 x (/.f64 (*.f64 y (-.f64 z t)) (-.f64 z a)))
1.3b
(+.f64 x (*.f64 y (/.f64 (-.f64 z t) (-.f64 z a))))
1.2b
(+.f64 x (/.f64 y (/.f64 (-.f64 z a) (-.f64 z t))))
28.9b
(fma.f64 (/.f64 y (sqrt.f64 (-.f64 z a))) (/.f64 (-.f64 z t) (sqrt.f64 (-.f64 z a))) x)
Compiler

Compiled 6806 to 2513 computations (63.1% saved)

regimes1.2s (11.8%)

Accuracy

Total 1.1b remaining (98.5%)

Threshold costs 0b (0%)

Counts
73 → 1
Compiler

Compiled 10570 to 6710 computations (36.5% saved)

simplify6.0ms (0.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01116
11616
22416
32816
43016
53016

end129.0ms (1.2%)

Compiler

Compiled 101 to 61 computations (39.6% saved)

Profiling

Loading profile data...