Details

Time bar (total: 9.0s)

analyze100.0ms (1.1%)

Algorithm
search
Search
TrueOtherFalseIter
0%100%0%0
0%100%0%1
0%100%0%2
0%100%0%3
75%25%0%4
87.5%12.5%0%5
93.7%6.2%0%6
96.8%3.1%0%7
98.4%1.6%0%8
99.2%0.8%0%9
99.6%0.4%0%10
99.8%0.2%0%11
99.9%0.1%0%12
99.9%0%0%13
99.9%0%0%14
Compiler

Compiled 15 to 11 computations (26.7% saved)

sample27.0ms (0.3%)

Algorithm
intervals
Results
9.0ms63×body1024valid
5.0ms139×body128valid
3.0ms30×body512valid
1.0ms20×body256valid
1.0msbody2048valid
Compiler

Compiled 30 to 22 computations (26.7% saved)

simplify104.0ms (1.1%)

Algorithm
egg-herbie
Rules
859×fma-neg_binary64
770×fma-def_binary64
322×div-sub_binary64
178×associate-/l*_binary64
150×sub-neg_binary64
Counts
1 → 1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0819
11619
22219
33419
45719
59119
617819
727719
864319
978819
10102419
11126519
12124219
13124819
14124619
15124819
16125019
17126019
18126019
19117119

prune2.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New011
Fresh011
Picked000
Done000
Total022
Error
28.9b
Counts
2 → 1
Alt Table
StatusErrorProgram
28.9b
(-.f64 (/.f64 x (+.f64 x 1)) (/.f64 (+.f64 x 1) (-.f64 x 1)))
Compiler

Compiled 42 to 30 computations (28.6% saved)

localize6.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(/.f64 x (+.f64 x 1))
0.0b
(/.f64 (+.f64 x 1) (-.f64 x 1))
3.1b
(-.f64 (/.f64 x (+.f64 x 1)) (/.f64 (+.f64 x 1) (-.f64 x 1)))

series8.0ms (0.1%)

Counts
3 → 36
Calls

3 calls:

3.0ms
(-.f64 (/.f64 x (+.f64 x 1)) (/.f64 (+.f64 x 1) (-.f64 x 1)))
2.0ms
(/.f64 (+.f64 x 1) (-.f64 x 1))
2.0ms
(/.f64 x (+.f64 x 1))

rewrite233.0ms (2.6%)

Algorithm
rewrite-expression-head
Rules
1322×*-un-lft-identity_binary64
1012×times-frac_binary64
869×add-sqr-sqrt_binary64
612×prod-diff_binary64
533×add-cube-cbrt_binary64
Counts
3 → 783
Calls

3 calls:

50.0ms
(-.f64 (/.f64 x (+.f64 x 1)) (/.f64 (+.f64 x 1) (-.f64 x 1)))
6.0ms
(/.f64 (+.f64 x 1) (-.f64 x 1))
4.0ms
(/.f64 x (+.f64 x 1))

simplify997.0ms (11%)

Algorithm
egg-herbie
Rules
654×fma-neg_binary64
367×unsub-neg_binary64
299×fma-udef_binary64
213×sub-neg_binary64
202×associate-+r-_binary64
Counts
819 → 619
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
054554602
1129031108
2304322839
3432322837
4498322837
5499122837
6474222837

prune1.4s (15%)

Pruning

5 alts after pruning (5 fresh and 0 done)

PrunedKeptTotal
New6145619
Fresh000
Picked101
Done000
Total6155620
Error
0.0b
Counts
620 → 5
Alt Table
StatusErrorProgram
31.8b
(+.f64 1 (*.f64 x (+.f64 3 x)))
29.9b
(/.f64 (fma.f64 x (+.f64 x -1) (*.f64 (+.f64 1 x) (-.f64 -1 x))) (fma.f64 x x -1))
32.3b
(-.f64 (-.f64 (/.f64 -3 x) (+.f64 (/.f64 1 (*.f64 x x)) (/.f64 3 (pow.f64 x 3)))) (/.f64 1 (pow.f64 x 4)))
29.4b
(+.f64 (fma.f64 (/.f64 x (-.f64 (*.f64 x x) (*.f64 1 1))) (-.f64 x 1) (neg.f64 (*.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1))))))) (fma.f64 (neg.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1)))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1)))) (*.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1)))))))
47.5b
(+.f64 (fma.f64 (+.f64 x -1) (/.f64 x (fma.f64 x x -1)) (/.f64 (/.f64 (-.f64 -1 x) (+.f64 1 (sqrt.f64 x))) (+.f64 -1 (sqrt.f64 x)))) 0)
Compiler

Compiled 30580 to 22537 computations (26.3% saved)

localize39.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.3b
(cbrt.f64 (-.f64 x 1))
13.4b
(/.f64 x (-.f64 (*.f64 x x) (*.f64 1 1)))
29.0b
(fma.f64 (/.f64 x (-.f64 (*.f64 x x) (*.f64 1 1))) (-.f64 x 1) (neg.f64 (*.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1)))))))
33.0b
(fma.f64 (neg.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1)))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1)))) (*.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1))))))

series137.0ms (1.5%)

Counts
4 → 48
Calls

4 calls:

87.0ms
(fma.f64 (neg.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1)))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1)))) (*.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1))))))
23.0ms
(cbrt.f64 (-.f64 x 1))
20.0ms
(fma.f64 (/.f64 x (-.f64 (*.f64 x x) (*.f64 1 1))) (-.f64 x 1) (neg.f64 (*.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1)))))))
6.0ms
(/.f64 x (-.f64 (*.f64 x x) (*.f64 1 1)))

rewrite24.0ms (0.3%)

Algorithm
rewrite-expression-head
Rules
18×add-sqr-sqrt_binary64
17×*-un-lft-identity_binary64
14×add-cube-cbrt_binary64
12×times-frac_binary64
cbrt-prod_binary64
Counts
4 → 74
Calls

4 calls:

9.0ms
(/.f64 x (-.f64 (*.f64 x x) (*.f64 1 1)))
6.0ms
(cbrt.f64 (-.f64 x 1))
1.0ms
(fma.f64 (neg.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1)))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1)))) (*.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1))))))
1.0ms
(fma.f64 (/.f64 x (-.f64 (*.f64 x x) (*.f64 1 1))) (-.f64 x 1) (neg.f64 (*.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1)))))))

simplify194.0ms (2.1%)

Algorithm
egg-herbie
Rules
679×times-frac_binary64
502×fma-neg_binary64
262×cancel-sign-sub-inv_binary64
204×distribute-neg-in_binary64
193×distribute-rgt-neg-in_binary64
Counts
122 → 197
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
02533001
16582329
222791940
346311936
448811936

prune2.7s (30.3%)

Pruning

5 alts after pruning (5 fresh and 0 done)

PrunedKeptTotal
New6281629
Fresh044
Picked101
Done000
Total6295634
Error
0.0b
Counts
634 → 5
Alt Table
StatusErrorProgram
30.9b
(+.f64 (exp.f64 (log.f64 (fma.f64 (/.f64 x (-.f64 (*.f64 x x) (*.f64 1 1))) (-.f64 x 1) (neg.f64 (*.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1))))))))) (fma.f64 (neg.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1)))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1)))) (*.f64 (/.f64 (+.f64 x 1) (cbrt.f64 (-.f64 x 1))) (/.f64 1 (*.f64 (cbrt.f64 (-.f64 x 1)) (cbrt.f64 (-.f64 x 1)))))))
47.5b
(+.f64 (fma.f64 (+.f64 x -1) (/.f64 x (fma.f64 x x -1)) (/.f64 (/.f64 (-.f64 -1 x) (+.f64 1 (sqrt.f64 x))) (+.f64 -1 (sqrt.f64 x)))) 0)
31.8b
(+.f64 1 (*.f64 x (+.f64 3 x)))
29.9b
(/.f64 (fma.f64 x (+.f64 x -1) (*.f64 (+.f64 1 x) (-.f64 -1 x))) (fma.f64 x x -1))
32.3b
(-.f64 (-.f64 (/.f64 -3 x) (+.f64 (/.f64 1 (*.f64 x x)) (/.f64 3 (pow.f64 x 3)))) (/.f64 1 (pow.f64 x 4)))
Compiler

Compiled 52726 to 41146 computations (22% saved)

localize19.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(*.f64 (+.f64 1 x) (-.f64 -1 x))
0.0b
(/.f64 (fma.f64 x (+.f64 x -1) (*.f64 (+.f64 1 x) (-.f64 -1 x))) (fma.f64 x x -1))
29.8b
(fma.f64 x (+.f64 x -1) (*.f64 (+.f64 1 x) (-.f64 -1 x)))

series17.0ms (0.2%)

Counts
3 → 36
Calls

3 calls:

7.0ms
(/.f64 (fma.f64 x (+.f64 x -1) (*.f64 (+.f64 1 x) (-.f64 -1 x))) (fma.f64 x x -1))
6.0ms
(fma.f64 x (+.f64 x -1) (*.f64 (+.f64 1 x) (-.f64 -1 x)))
4.0ms
(*.f64 (+.f64 1 x) (-.f64 -1 x))

rewrite36.0ms (0.4%)

Algorithm
rewrite-expression-head
Rules
31×*-un-lft-identity_binary64
31×add-sqr-sqrt_binary64
27×add-cube-cbrt_binary64
18×prod-diff_binary64
13×distribute-lft-in_binary64
Counts
3 → 96
Calls

3 calls:

17.0ms
(*.f64 (+.f64 1 x) (-.f64 -1 x))
4.0ms
(/.f64 (fma.f64 x (+.f64 x -1) (*.f64 (+.f64 1 x) (-.f64 -1 x))) (fma.f64 x x -1))
1.0ms
(fma.f64 x (+.f64 x -1) (*.f64 (+.f64 1 x) (-.f64 -1 x)))

simplify163.0ms (1.8%)

Algorithm
egg-herbie
Rules
795×distribute-rgt-in_binary64
696×distribute-lft-in_binary64
603×fma-neg_binary64
160×associate-*l*_binary64
149×associate-*r*_binary64
Counts
132 → 165
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
02242768
14652474
216472284
347162272
449882272

prune199.0ms (2.2%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New1641165
Fresh314
Picked101
Done000
Total1682170
Error
0.0b
Counts
170 → 2
Alt Table
StatusErrorProgram
13.5b
(/.f64 (fma.f64 x -3 -1) (fma.f64 x x -1))
32.3b
(-.f64 (-.f64 (/.f64 -3 x) (+.f64 (/.f64 1 (*.f64 x x)) (/.f64 3 (pow.f64 x 3)))) (/.f64 1 (pow.f64 x 4)))
Compiler

Compiled 4571 to 2981 computations (34.8% saved)

localize16.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 x -3 -1)
13.5b
(/.f64 (fma.f64 x -3 -1) (fma.f64 x x -1))

series7.0ms (0.1%)

Counts
2 → 24
Calls

2 calls:

5.0ms
(/.f64 (fma.f64 x -3 -1) (fma.f64 x x -1))
3.0ms
(fma.f64 x -3 -1)

rewrite7.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
10×*-un-lft-identity_binary64
10×add-sqr-sqrt_binary64
10×add-cube-cbrt_binary64
times-frac_binary64
add-cbrt-cube_binary64
Counts
2 → 39
Calls

2 calls:

4.0ms
(/.f64 (fma.f64 x -3 -1) (fma.f64 x x -1))
1.0ms
(fma.f64 x -3 -1)

simplify95.0ms (1.1%)

Algorithm
egg-herbie
Rules
661×fma-def_binary64
370×distribute-rgt-in_binary64
362×div-sub_binary64
336×neg-mul-1_binary64
289×distribute-lft-in_binary64
Counts
63 → 63
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
089997
1188875
2506871
31616868
44434860
54943860

prune92.0ms (1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New60363
Fresh101
Picked101
Done000
Total62365
Error
0b
Counts
65 → 3
Alt Table
StatusErrorProgram
13.5b
(expm1.f64 (log1p.f64 (/.f64 (fma.f64 x -3 -1) (fma.f64 x x -1))))
19.2b
(cbrt.f64 (pow.f64 (/.f64 (fma.f64 x -3 -1) (fma.f64 x x -1)) 3))
32.3b
(+.f64 (fma.f64 (/.f64 1 (*.f64 x x)) (-.f64 -1 (/.f64 3 x)) (/.f64 -3 x)) (/.f64 -1 (pow.f64 x 4)))
Compiler

Compiled 981 to 722 computations (26.4% saved)

regimes548.0ms (6.1%)

Accuracy

Total 0.0b remaining (28.2%)

Threshold costs 0.0b (28.2%)

Counts
80 → 3
Compiler

Compiled 4374 to 3300 computations (24.6% saved)

bsearch12.0ms (0.1%)

Steps
ItersRangePoint
2
7.006997086362317
31673153790710.03
22131881926.828556
0
-13980.750242557919
-13484.244541746411
-13732.497392152165
Compiler

Compiled 2 to 1 computations (50% saved)

simplify9.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
02970
14070
25570
36770
47270
57370
67070

end2.0ms (0%)

Compiler

Compiled 49 to 35 computations (28.6% saved)

sample1.8s (20.5%)

Algorithm
intervals
Results
644.0ms2054×body1024valid
347.0ms4249×body128valid
228.0ms974×body512valid
84.0ms514×body256valid
84.0ms209×body2048valid
Compiler

Compiled 111 to 82 computations (26.1% saved)

Profiling

Loading profile data...