Details

Time bar (total: 3.7s)

analyze260.0ms (7%)

Algorithm
search
egg-herbie
Rules
1760×associate--l+_binary64
1745×associate--r+_binary64
455×unsub-neg_binary64
435×distribute-rgt-in_binary64
425×sub-neg_binary64
323×distribute-neg-in_binary64
321×distribute-lft-in_binary64
175×associate-+l-_binary64
154×+-commutative_binary64
144×cancel-sign-sub-inv_binary64
126×associate-+r-_binary64
114×associate--l-_binary64
93×distribute-lft-neg-out_binary64
92×associate--r-_binary64
86×associate-*r*_binary64
83×associate-*l*_binary64
82×*-commutative_binary64
78×neg-sub0_binary64 distribute-rgt-neg-out_binary64
72×associate-+r+_binary64
71×distribute-rgt-neg-in_binary64
67×neg-mul-1_binary64
63×distribute-lft-neg-in_binary64 associate-+l+_binary64
55×distribute-rgt-out--_binary64
47×distribute-neg-out_binary64
29×distribute-rgt-out_binary64
28×mul0-rgt_binary64 mul0-lft_binary64
27×sub0-neg_binary64
26×*-rgt-identity_binary64
19×*-lft-identity_binary64 remove-double-neg_binary64
17×distribute-rgt1-in_binary64
16×log-prod_binary64
15×--rgt-identity_binary64
12×+-rgt-identity_binary64
10×cancel-sign-sub_binary64
+-lft-identity_binary64
distribute-lft-out--_binary64
distribute-lft-out_binary64
1-exp_binary64 +-inverses_binary64 distribute-lft1-in_binary64 count-2_binary64
not-true not-false not-not not-and not-or and-true-l and-true-r and-false-l and-false-r and-same or-true-l or-true-r or-false-l or-false-r or-same erfc-erf_binary64 erf-erfc_binary64 erf-odd_binary64 if-if-and-not_binary64 if-if-and_binary64 if-if-or-not_binary64 if-if-or_binary64 if-not_binary64 if-same_binary64 if-false_binary64 if-true_binary64 not-gte_binary64 not-lte_binary64 not-gt_binary64 not-lt_binary64 gte-same_binary64 lte-same_binary64 gt-same_binary64 lt-same_binary64 sinh---cosh_binary64 sinh-+-cosh_binary64 sinh-cosh_binary64 tanh-def-c_binary64 tanh-def-b_binary64 tanh-def-a_binary64 cosh-def_binary64 sinh-def_binary64 tan-neg_binary64 cos-neg_binary64 sin-neg_binary64 tan-0_binary64 cos-0_binary64 sin-0_binary64 hang-m-tan_binary64 hang-p-tan_binary64 hang-m0-tan_binary64 hang-p0-tan_binary64 hang-0m-tan_binary64 hang-0p-tan_binary64 tan-+PI/2_binary64 tan-+PI_binary64 tan-PI_binary64 tan-PI/3_binary64 tan-PI/4_binary64 tan-PI/6_binary64 cos-+PI/2_binary64 cos-+PI_binary64 cos-PI_binary64 cos-PI/2_binary64 cos-PI/3_binary64 cos-PI/4_binary64 cos-PI/6_binary64 sin-+PI/2_binary64 sin-+PI_binary64 sin-PI_binary64 sin-PI/2_binary64 sin-PI/3_binary64 sin-PI/4_binary64 sin-PI/6_binary64 sub-1-sin_binary64 sub-1-cos_binary64 -1-add-sin_binary64 -1-add-cos_binary64 1-sub-sin_binary64 1-sub-cos_binary64 cos-sin-sum_binary64 log-E_binary64 log-pow_binary64 log-rec_binary64 log-div_binary64 pow-base-0_binary64 unpow1/3_binary64 unpow3_binary64 unpow2_binary64 unpow1/2_binary64 pow-plus_binary64 exp-to-pow_binary64 pow-base-1_binary64 unpow0_binary64 unpow1_binary64 unpow-1_binary64 exp-lft-cube_binary64 exp-lft-sqr_binary64 exp-cbrt_binary64 exp-sqrt_binary64 exp-prod_binary64 div-exp_binary64 rec-exp_binary64 prod-exp_binary64 exp-diff_binary64 exp-neg_binary64 exp-sum_binary64 e-exp-1_binary64 exp-1-e_binary64 exp-0_binary64 rem-log-exp_binary64 rem-exp-log_binary64 cube-unmult_binary64 cube-mult_binary64 cube-div_binary64 cube-prod_binary64 cube-neg_binary64 rem-3cbrt-rft_binary64 rem-3cbrt-lft_binary64 rem-cbrt-cube_binary64 rem-cube-cbrt_binary64 sqr-abs_binary64 sqr-neg_binary64 rem-sqrt-square_binary64 rem-square-sqrt_binary64 times-frac_binary64 div-sub_binary64 mul-1-neg_binary64 /-rgt-identity_binary64 div0_binary64 *-inverses_binary64 lft-mult-inverse_binary64 rgt-mult-inverse_binary64 remove-double-div_binary64 pow-sqr_binary64 sqr-pow_binary64 difference-of-sqr--1_binary64 difference-of-sqr-1_binary64 difference-of-squares_binary64 unswap-sqr_binary64 swap-sqr_binary64 distribute-neg-frac_binary64 distribute-frac-neg_binary64 associate-/l/_binary64 associate-/r/_binary64 associate-/l*_binary64 associate-/r*_binary64 associate-*l/_binary64 associate-*r/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01023
12523
25123
39123
419523
532823
653223
781723
8142823
9144923
10167523
11175723
12181523
13182823
14202923
15196923
16203123
17204123
18205123
19205123
20208123
21206123
22206123
23218523
24213723
25213723
26609423
011
111
Search
TrueOtherFalseIter
0%23.7%76.3%0
0%23.7%76.3%1
11.9%11.9%76.3%2
17.8%5.9%76.3%3
20.8%3%76.3%4
22.2%1.5%76.3%5
23%0.7%76.3%6
23.3%0.4%76.3%7
23.3%0.4%76.3%8
23.4%0.3%76.3%9
23.5%0.2%76.3%10
23.5%0.2%76.3%11
23.5%0.2%76.3%12
23.6%0.2%76.3%13
23.6%0.1%76.3%14
Compiler

Compiled 18 to 14 computations (22.2% saved)

sample74.0ms (2%)

Algorithm
intervals
Results
36.0ms127×body1024valid
14.0ms76×body512valid
6.0ms14×body2048valid
4.0ms33×body256valid
3.0ms256×pre128true
0.0msbody128valid
Compiler

Compiled 33 to 27 computations (18.2% saved)

simplify224.0ms (6.1%)

Algorithm
egg-herbie
Rules
1760×associate--l+_binary64
1745×associate--r+_binary64
455×unsub-neg_binary64
435×distribute-rgt-in_binary64
425×sub-neg_binary64
323×distribute-neg-in_binary64
321×distribute-lft-in_binary64
175×associate-+l-_binary64
154×+-commutative_binary64
144×cancel-sign-sub-inv_binary64
126×associate-+r-_binary64
114×associate--l-_binary64
93×distribute-lft-neg-out_binary64
92×associate--r-_binary64
86×associate-*r*_binary64
83×associate-*l*_binary64
82×*-commutative_binary64
78×neg-sub0_binary64 distribute-rgt-neg-out_binary64
72×associate-+r+_binary64
71×distribute-rgt-neg-in_binary64
67×neg-mul-1_binary64
63×distribute-lft-neg-in_binary64 associate-+l+_binary64
55×distribute-rgt-out--_binary64
47×distribute-neg-out_binary64
29×distribute-rgt-out_binary64
28×mul0-rgt_binary64 mul0-lft_binary64
27×sub0-neg_binary64
26×*-rgt-identity_binary64
19×*-lft-identity_binary64 remove-double-neg_binary64
17×distribute-rgt1-in_binary64
16×log-prod_binary64
15×--rgt-identity_binary64
12×+-rgt-identity_binary64
10×cancel-sign-sub_binary64
+-lft-identity_binary64
distribute-lft-out--_binary64
distribute-lft-out_binary64
1-exp_binary64 +-inverses_binary64 distribute-lft1-in_binary64 count-2_binary64
not-true not-false not-not not-and not-or and-true-l and-true-r and-false-l and-false-r and-same or-true-l or-true-r or-false-l or-false-r or-same erfc-erf_binary64 erf-erfc_binary64 erf-odd_binary64 if-if-and-not_binary64 if-if-and_binary64 if-if-or-not_binary64 if-if-or_binary64 if-not_binary64 if-same_binary64 if-false_binary64 if-true_binary64 not-gte_binary64 not-lte_binary64 not-gt_binary64 not-lt_binary64 gte-same_binary64 lte-same_binary64 gt-same_binary64 lt-same_binary64 sinh---cosh_binary64 sinh-+-cosh_binary64 sinh-cosh_binary64 tanh-def-c_binary64 tanh-def-b_binary64 tanh-def-a_binary64 cosh-def_binary64 sinh-def_binary64 tan-neg_binary64 cos-neg_binary64 sin-neg_binary64 tan-0_binary64 cos-0_binary64 sin-0_binary64 hang-m-tan_binary64 hang-p-tan_binary64 hang-m0-tan_binary64 hang-p0-tan_binary64 hang-0m-tan_binary64 hang-0p-tan_binary64 tan-+PI/2_binary64 tan-+PI_binary64 tan-PI_binary64 tan-PI/3_binary64 tan-PI/4_binary64 tan-PI/6_binary64 cos-+PI/2_binary64 cos-+PI_binary64 cos-PI_binary64 cos-PI/2_binary64 cos-PI/3_binary64 cos-PI/4_binary64 cos-PI/6_binary64 sin-+PI/2_binary64 sin-+PI_binary64 sin-PI_binary64 sin-PI/2_binary64 sin-PI/3_binary64 sin-PI/4_binary64 sin-PI/6_binary64 sub-1-sin_binary64 sub-1-cos_binary64 -1-add-sin_binary64 -1-add-cos_binary64 1-sub-sin_binary64 1-sub-cos_binary64 cos-sin-sum_binary64 log-E_binary64 log-pow_binary64 log-rec_binary64 log-div_binary64 pow-base-0_binary64 unpow1/3_binary64 unpow3_binary64 unpow2_binary64 unpow1/2_binary64 pow-plus_binary64 exp-to-pow_binary64 pow-base-1_binary64 unpow0_binary64 unpow1_binary64 unpow-1_binary64 exp-lft-cube_binary64 exp-lft-sqr_binary64 exp-cbrt_binary64 exp-sqrt_binary64 exp-prod_binary64 div-exp_binary64 rec-exp_binary64 prod-exp_binary64 exp-diff_binary64 exp-neg_binary64 exp-sum_binary64 e-exp-1_binary64 exp-1-e_binary64 exp-0_binary64 rem-log-exp_binary64 rem-exp-log_binary64 cube-unmult_binary64 cube-mult_binary64 cube-div_binary64 cube-prod_binary64 cube-neg_binary64 rem-3cbrt-rft_binary64 rem-3cbrt-lft_binary64 rem-cbrt-cube_binary64 rem-cube-cbrt_binary64 sqr-abs_binary64 sqr-neg_binary64 rem-sqrt-square_binary64 rem-square-sqrt_binary64 times-frac_binary64 div-sub_binary64 mul-1-neg_binary64 /-rgt-identity_binary64 div0_binary64 *-inverses_binary64 lft-mult-inverse_binary64 rgt-mult-inverse_binary64 remove-double-div_binary64 pow-sqr_binary64 sqr-pow_binary64 difference-of-sqr--1_binary64 difference-of-sqr-1_binary64 difference-of-squares_binary64 unswap-sqr_binary64 swap-sqr_binary64 distribute-neg-frac_binary64 distribute-frac-neg_binary64 associate-/l/_binary64 associate-/r/_binary64 associate-/l*_binary64 associate-/r*_binary64 associate-*l/_binary64 associate-*r/_binary64
Counts
1 → 0
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01023
12523
25123
39123
419523
532823
653223
781723
8142823
9144923
10167523
11175723
12181523
13182823
14202923
15196923
16203123
17204123
18205123
19205123
20208123
21206123
22206123
23218523
24213723
25213723
26609423

prune5.0ms (0.1%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New000
Fresh011
Picked000
Done000
Total011
Error
63.0b
Counts
1 → 1
Compiler

Compiled 15 to 12 computations (20% saved)

localize9.0ms (0.2%)

Local error

Found 3 expressions with local error:

0.3b
(*.f64 (+.f64 n 1) (log.f64 (+.f64 n 1)))
0.3b
(*.f64 n (log.f64 n))
5.6b
(-.f64 (*.f64 (+.f64 n 1) (log.f64 (+.f64 n 1))) (*.f64 n (log.f64 n)))

rewrite106.0ms (2.9%)

Algorithm
rewrite-expression-head
Error
60.4b
Rules
28×log-prod_binary64
25×*-un-lft-identity_binary64
19×add-sqr-sqrt_binary64
15×add-cube-cbrt_binary64
14×distribute-rgt-in_binary64 distribute-lft-in_binary64
pow1_binary64
associate--l+_binary64 associate-*r*_binary64
add-exp-log_binary64 add-cbrt-cube_binary64 associate-*l*_binary64
associate--r+_binary64
add-log-exp_binary64 distribute-lft-out_binary64
pow-prod-down_binary64 prod-exp_binary64 cbrt-unprod_binary64 unswap-sqr_binary64 log-pow_binary64 *-commutative_binary64 associate-*l/_binary64
diff-log_binary64 flip3--_binary64 sub-neg_binary64 flip--_binary64 cancel-sign-sub-inv_binary64 flip3-+_binary64 flip-+_binary64
Counts
3 → 81
Calls

3 calls:

10.0ms
(-.f64 (*.f64 (+.f64 n 1) (log.f64 (+.f64 n 1))) (*.f64 n (log.f64 n)))
8.0ms
(*.f64 (+.f64 n 1) (log.f64 (+.f64 n 1)))
4.0ms
(*.f64 n (log.f64 n))
Compiler

Compiled 1683 to 1052 computations (37.5% saved)

series46.0ms (1.3%)

Error
0.0b
Counts
3 → 11
Calls

3 calls:

14.0ms
(*.f64 n (log.f64 n))
11.0ms
(-.f64 (*.f64 (+.f64 n 1) (log.f64 (+.f64 n 1))) (*.f64 n (log.f64 n)))
8.0ms
(*.f64 (+.f64 n 1) (log.f64 (+.f64 n 1)))
Compiler

Compiled 469 to 373 computations (20.5% saved)

simplify108.0ms (2.9%)

Algorithm
egg-herbie
Rules
378×times-frac_binary64
343×distribute-rgt-in_binary64
339×unsub-neg_binary64
317×distribute-lft-in_binary64
238×cancel-sign-sub-inv_binary64
223×distribute-rgt-neg-out_binary64
215×distribute-rgt-neg-in_binary64
205×distribute-lft-neg-out_binary64
192×*-commutative_binary64
148×distribute-lft-neg-in_binary64
136×sub-neg_binary64
120×exp-sum_binary64
118×associate-*l*_binary64
115×exp-prod_binary64
103×distribute-neg-in_binary64
97×associate-+l+_binary64
95×neg-sub0_binary64 associate-*r*_binary64
92×neg-mul-1_binary64
91×associate-+r+_binary64
87×unswap-sqr_binary64
79×log-prod_binary64
77×sqr-pow_binary64
63×+-commutative_binary64
62×cube-prod_binary64
52×distribute-rgt-out--_binary64
43×exp-diff_binary64
40×associate--l+_binary64
38×distribute-neg-out_binary64 distribute-rgt-out_binary64
37×*-rgt-identity_binary64
36×*-lft-identity_binary64
29×difference-of-squares_binary64
26×associate-+r-_binary64
24×distribute-rgt1-in_binary64
23×exp-to-pow_binary64 div-sub_binary64 remove-double-neg_binary64
21×swap-sqr_binary64
20×prod-exp_binary64
19×associate-+l-_binary64
17×associate--r-_binary64
16×log-div_binary64 sub0-neg_binary64
15×distribute-lft-out_binary64
14×sqr-neg_binary64
13×unpow3_binary64 +-rgt-identity_binary64
12×exp-neg_binary64 mul0-rgt_binary64 mul0-lft_binary64 pow-sqr_binary64
11×rem-sqrt-square_binary64 distribute-lft1-in_binary64 associate--r+_binary64
unpow1/2_binary64 --rgt-identity_binary64
log-pow_binary64 cube-div_binary64
cube-mult_binary64
cube-neg_binary64 distribute-frac-neg_binary64 associate-/l*_binary64 associate-/r*_binary64
log-rec_binary64 mul-1-neg_binary64
pow-plus_binary64 div-exp_binary64 rem-exp-log_binary64 cube-unmult_binary64 count-2_binary64
+-inverses_binary64 difference-of-sqr-1_binary64 cancel-sign-sub_binary64 distribute-lft-out--_binary64
log-E_binary64 unpow2_binary64 unpow1_binary64 unpow-1_binary64 rec-exp_binary64 1-exp_binary64 exp-1-e_binary64 rem-log-exp_binary64 +-lft-identity_binary64 difference-of-sqr--1_binary64 distribute-neg-frac_binary64
not-true not-false not-not not-and not-or and-true-l and-true-r and-false-l and-false-r and-same or-true-l or-true-r or-false-l or-false-r or-same erfc-erf_binary64 erf-erfc_binary64 erf-odd_binary64 if-if-and-not_binary64 if-if-and_binary64 if-if-or-not_binary64 if-if-or_binary64 if-not_binary64 if-same_binary64 if-false_binary64 if-true_binary64 not-gte_binary64 not-lte_binary64 not-gt_binary64 not-lt_binary64 gte-same_binary64 lte-same_binary64 gt-same_binary64 lt-same_binary64 sinh---cosh_binary64 sinh-+-cosh_binary64 sinh-cosh_binary64 tanh-def-c_binary64 tanh-def-b_binary64 tanh-def-a_binary64 cosh-def_binary64 sinh-def_binary64 tan-neg_binary64 cos-neg_binary64 sin-neg_binary64 tan-0_binary64 cos-0_binary64 sin-0_binary64 hang-m-tan_binary64 hang-p-tan_binary64 hang-m0-tan_binary64 hang-p0-tan_binary64 hang-0m-tan_binary64 hang-0p-tan_binary64 tan-+PI/2_binary64 tan-+PI_binary64 tan-PI_binary64 tan-PI/3_binary64 tan-PI/4_binary64 tan-PI/6_binary64 cos-+PI/2_binary64 cos-+PI_binary64 cos-PI_binary64 cos-PI/2_binary64 cos-PI/3_binary64 cos-PI/4_binary64 cos-PI/6_binary64 sin-+PI/2_binary64 sin-+PI_binary64 sin-PI_binary64 sin-PI/2_binary64 sin-PI/3_binary64 sin-PI/4_binary64 sin-PI/6_binary64 sub-1-sin_binary64 sub-1-cos_binary64 -1-add-sin_binary64 -1-add-cos_binary64 1-sub-sin_binary64 1-sub-cos_binary64 cos-sin-sum_binary64 pow-base-0_binary64 unpow1/3_binary64 pow-base-1_binary64 unpow0_binary64 exp-lft-cube_binary64 exp-lft-sqr_binary64 exp-cbrt_binary64 exp-sqrt_binary64 e-exp-1_binary64 exp-0_binary64 rem-3cbrt-rft_binary64 rem-3cbrt-lft_binary64 rem-cbrt-cube_binary64 rem-cube-cbrt_binary64 sqr-abs_binary64 rem-square-sqrt_binary64 /-rgt-identity_binary64 div0_binary64 *-inverses_binary64 lft-mult-inverse_binary64 rgt-mult-inverse_binary64 remove-double-div_binary64 associate-/l/_binary64 associate-/r/_binary64 associate-*l/_binary64 associate-*r/_binary64 associate--l-_binary64
Counts
92 → 73
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01451575
13301492
29081483
325901480
441551480
549811480

prune41.0ms (1.1%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New72173
Fresh000
Picked101
Done000
Total73174
Error
0.0b
Counts
74 → 1
Compiler

Compiled 1166 to 750 computations (35.7% saved)

localize4.0ms (0.1%)

Local error

Found 1 expressions with local error:

0.0b
(-.f64 (+.f64 1 (log.f64 n)) 1)

rewrite24.0ms (0.7%)

Algorithm
rewrite-expression-head
Error
0b
Rules
10×*-un-lft-identity_binary64
add-sqr-sqrt_binary64
add-log-exp_binary64
cancel-sign-sub-inv_binary64 distribute-lft-out--_binary64
diff-log_binary64 pow1_binary64 add-cube-cbrt_binary64 difference-of-squares_binary64 distribute-lft-out_binary64
sum-log_binary64 add-exp-log_binary64 add-cbrt-cube_binary64 flip3--_binary64 sub-neg_binary64 flip--_binary64 difference-of-sqr-1_binary64 log-pow_binary64 associate--l+_binary64
Counts
1 → 22
Calls

1 calls:

6.0ms
(-.f64 (+.f64 1 (log.f64 n)) 1)
Compiler

Compiled 238 to 181 computations (23.9% saved)

series12.0ms (0.3%)

Error
0b
Counts
1 → 3
Calls

1 calls:

9.0ms
(-.f64 (+.f64 1 (log.f64 n)) 1)
Compiler

Compiled 45 to 43 computations (4.4% saved)

simplify69.0ms (1.9%)

Algorithm
egg-herbie
Rules
601×distribute-rgt-in_binary64
585×sub-neg_binary64
584×unsub-neg_binary64
494×distribute-lft-in_binary64
486×times-frac_binary64
221×exp-sum_binary64
218×distribute-neg-out_binary64
205×associate-+l-_binary64
195×exp-diff_binary64
172×associate-+r-_binary64
164×log-prod_binary64
155×associate--r+_binary64
146×associate--l+_binary64
140×associate-*l*_binary64
121×log-div_binary64
108×associate-*r*_binary64
88×+-commutative_binary64
75×sub0-neg_binary64
69×associate-+l+_binary64
56×distribute-rgt-out_binary64
55×associate--r-_binary64
52×neg-sub0_binary64
46×div-sub_binary64
43×associate-+r+_binary64
42×exp-prod_binary64
35×distribute-lft-neg-out_binary64
34×distribute-rgt-neg-out_binary64 *-commutative_binary64
33×*-rgt-identity_binary64
29×neg-mul-1_binary64 *-lft-identity_binary64 sqr-pow_binary64
27×associate--l-_binary64
25×distribute-neg-in_binary64
20×cube-prod_binary64
19×distribute-rgt1-in_binary64
17×log-pow_binary64 mul-1-neg_binary64 mul0-lft_binary64 associate-/l*_binary64
16×mul0-rgt_binary64 unswap-sqr_binary64 associate-/r*_binary64
15×div-exp_binary64
13×+-rgt-identity_binary64
12×cancel-sign-sub-inv_binary64 distribute-lft1-in_binary64 associate-/r/_binary64
prod-exp_binary64
pow-plus_binary64 exp-to-pow_binary64
cube-unmult_binary64 --rgt-identity_binary64 associate-*l/_binary64
cube-neg_binary64 distribute-lft-out_binary64 associate-/l/_binary64 associate-*r/_binary64
log-rec_binary64 unpow3_binary64 swap-sqr_binary64 distribute-rgt-neg-in_binary64 distribute-rgt-out--_binary64
rec-exp_binary64 rem-exp-log_binary64 difference-of-sqr--1_binary64 difference-of-sqr-1_binary64 distribute-lft-neg-in_binary64
unpow1/2_binary64 exp-neg_binary64 sqr-neg_binary64 rem-sqrt-square_binary64 remove-double-neg_binary64 pow-sqr_binary64
difference-of-squares_binary64 cancel-sign-sub_binary64 distribute-frac-neg_binary64
log-E_binary64 1-exp_binary64 exp-1-e_binary64 rem-log-exp_binary64 cube-mult_binary64 rem-3cbrt-lft_binary64 /-rgt-identity_binary64 +-lft-identity_binary64 +-inverses_binary64 distribute-lft-out--_binary64 count-2_binary64
not-true not-false not-not not-and not-or and-true-l and-true-r and-false-l and-false-r and-same or-true-l or-true-r or-false-l or-false-r or-same erfc-erf_binary64 erf-erfc_binary64 erf-odd_binary64 if-if-and-not_binary64 if-if-and_binary64 if-if-or-not_binary64 if-if-or_binary64 if-not_binary64 if-same_binary64 if-false_binary64 if-true_binary64 not-gte_binary64 not-lte_binary64 not-gt_binary64 not-lt_binary64 gte-same_binary64 lte-same_binary64 gt-same_binary64 lt-same_binary64 sinh---cosh_binary64 sinh-+-cosh_binary64 sinh-cosh_binary64 tanh-def-c_binary64 tanh-def-b_binary64 tanh-def-a_binary64 cosh-def_binary64 sinh-def_binary64 tan-neg_binary64 cos-neg_binary64 sin-neg_binary64 tan-0_binary64 cos-0_binary64 sin-0_binary64 hang-m-tan_binary64 hang-p-tan_binary64 hang-m0-tan_binary64 hang-p0-tan_binary64 hang-0m-tan_binary64 hang-0p-tan_binary64 tan-+PI/2_binary64 tan-+PI_binary64 tan-PI_binary64 tan-PI/3_binary64 tan-PI/4_binary64 tan-PI/6_binary64 cos-+PI/2_binary64 cos-+PI_binary64 cos-PI_binary64 cos-PI/2_binary64 cos-PI/3_binary64 cos-PI/4_binary64 cos-PI/6_binary64 sin-+PI/2_binary64 sin-+PI_binary64 sin-PI_binary64 sin-PI/2_binary64 sin-PI/3_binary64 sin-PI/4_binary64 sin-PI/6_binary64 sub-1-sin_binary64 sub-1-cos_binary64 -1-add-sin_binary64 -1-add-cos_binary64 1-sub-sin_binary64 1-sub-cos_binary64 cos-sin-sum_binary64 pow-base-0_binary64 unpow1/3_binary64 unpow2_binary64 pow-base-1_binary64 unpow0_binary64 unpow1_binary64 unpow-1_binary64 exp-lft-cube_binary64 exp-lft-sqr_binary64 exp-cbrt_binary64 exp-sqrt_binary64 e-exp-1_binary64 exp-0_binary64 cube-div_binary64 rem-3cbrt-rft_binary64 rem-cbrt-cube_binary64 rem-cube-cbrt_binary64 sqr-abs_binary64 rem-square-sqrt_binary64 div0_binary64 *-inverses_binary64 lft-mult-inverse_binary64 rgt-mult-inverse_binary64 remove-double-div_binary64 distribute-neg-frac_binary64
Counts
25 → 22
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
048283
198231
2237181
3656181
42890181
54422181
65002181

prune8.0ms (0.2%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New21122
Fresh000
Picked101
Done000
Total22123
Error
0b
Counts
23 → 1
Compiler

Compiled 96 to 57 computations (40.6% saved)

localize3.0ms (0.1%)

rewrite0.0ms (0%)

Algorithm
rewrite-expression-head
Error
0b
Counts
0 → 0
Compiler

Compiled 0 to 0 computations (0% saved)

series0.0ms (0%)

Error
0b
Counts
0 → 0
Compiler

Compiled 0 to 0 computations (0% saved)

simplify10.0ms (0.3%)

Algorithm
egg-herbie
Rules
not-true not-false not-not not-and not-or and-true-l and-true-r and-false-l and-false-r and-same or-true-l or-true-r or-false-l or-false-r or-same erfc-erf_binary64 erf-erfc_binary64 erf-odd_binary64 if-if-and-not_binary64 if-if-and_binary64 if-if-or-not_binary64 if-if-or_binary64 if-not_binary64 if-same_binary64 if-false_binary64 if-true_binary64 not-gte_binary64 not-lte_binary64 not-gt_binary64 not-lt_binary64 gte-same_binary64 lte-same_binary64 gt-same_binary64 lt-same_binary64 sinh---cosh_binary64 sinh-+-cosh_binary64 sinh-cosh_binary64 tanh-def-c_binary64 tanh-def-b_binary64 tanh-def-a_binary64 cosh-def_binary64 sinh-def_binary64 tan-neg_binary64 cos-neg_binary64 sin-neg_binary64 tan-0_binary64 cos-0_binary64 sin-0_binary64 hang-m-tan_binary64 hang-p-tan_binary64 hang-m0-tan_binary64 hang-p0-tan_binary64 hang-0m-tan_binary64 hang-0p-tan_binary64 tan-+PI/2_binary64 tan-+PI_binary64 tan-PI_binary64 tan-PI/3_binary64 tan-PI/4_binary64 tan-PI/6_binary64 cos-+PI/2_binary64 cos-+PI_binary64 cos-PI_binary64 cos-PI/2_binary64 cos-PI/3_binary64 cos-PI/4_binary64 cos-PI/6_binary64 sin-+PI/2_binary64 sin-+PI_binary64 sin-PI_binary64 sin-PI/2_binary64 sin-PI/3_binary64 sin-PI/4_binary64 sin-PI/6_binary64 sub-1-sin_binary64 sub-1-cos_binary64 -1-add-sin_binary64 -1-add-cos_binary64 1-sub-sin_binary64 1-sub-cos_binary64 cos-sin-sum_binary64 log-E_binary64 log-pow_binary64 log-rec_binary64 log-div_binary64 log-prod_binary64 pow-base-0_binary64 unpow1/3_binary64 unpow3_binary64 unpow2_binary64 unpow1/2_binary64 pow-plus_binary64 exp-to-pow_binary64 pow-base-1_binary64 unpow0_binary64 unpow1_binary64 unpow-1_binary64 exp-lft-cube_binary64 exp-lft-sqr_binary64 exp-cbrt_binary64 exp-sqrt_binary64 exp-prod_binary64 div-exp_binary64 rec-exp_binary64 prod-exp_binary64 exp-diff_binary64 exp-neg_binary64 exp-sum_binary64 e-exp-1_binary64 1-exp_binary64 exp-1-e_binary64 exp-0_binary64 rem-log-exp_binary64 rem-exp-log_binary64 cube-unmult_binary64 cube-mult_binary64 cube-div_binary64 cube-prod_binary64 cube-neg_binary64 rem-3cbrt-rft_binary64 rem-3cbrt-lft_binary64 rem-cbrt-cube_binary64 rem-cube-cbrt_binary64 sqr-abs_binary64 sqr-neg_binary64 rem-sqrt-square_binary64 rem-square-sqrt_binary64 times-frac_binary64 div-sub_binary64 neg-mul-1_binary64 neg-sub0_binary64 unsub-neg_binary64 sub-neg_binary64 mul-1-neg_binary64 /-rgt-identity_binary64 *-rgt-identity_binary64 *-lft-identity_binary64 remove-double-neg_binary64 sub0-neg_binary64 --rgt-identity_binary64 +-rgt-identity_binary64 +-lft-identity_binary64 mul0-rgt_binary64 mul0-lft_binary64 div0_binary64 *-inverses_binary64 +-inverses_binary64 lft-mult-inverse_binary64 rgt-mult-inverse_binary64 remove-double-div_binary64 pow-sqr_binary64 sqr-pow_binary64 difference-of-sqr--1_binary64 difference-of-sqr-1_binary64 difference-of-squares_binary64 unswap-sqr_binary64 swap-sqr_binary64 cancel-sign-sub-inv_binary64 cancel-sign-sub_binary64 distribute-neg-frac_binary64 distribute-frac-neg_binary64 distribute-neg-out_binary64 distribute-neg-in_binary64 distribute-rgt-neg-out_binary64 distribute-lft-neg-out_binary64 distribute-rgt-neg-in_binary64 distribute-lft-neg-in_binary64 distribute-rgt1-in_binary64 distribute-lft1-in_binary64 distribute-rgt-out--_binary64 distribute-rgt-out_binary64 distribute-lft-out--_binary64 distribute-lft-out_binary64 distribute-rgt-in_binary64 distribute-lft-in_binary64 count-2_binary64 associate-/l/_binary64 associate-/r/_binary64 associate-/l*_binary64 associate-/r*_binary64 associate-*l/_binary64 associate-*r/_binary64 associate-*l*_binary64 associate-*r*_binary64 associate--r-_binary64 associate--l-_binary64 associate--l+_binary64 associate--r+_binary64 associate-+l-_binary64 associate-+r-_binary64 associate-+l+_binary64 associate-+r+_binary64 *-commutative_binary64 +-commutative_binary64
Counts
0 → 0
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
000
100

prune1.0ms (0%)

Pruning

1 alts after pruning (0 fresh and 1 done)

PrunedKeptTotal
New000
Fresh000
Picked011
Done000
Total011
Error
0b
Counts
1 → 1
Compiler

Compiled 0 to 0 computations (0% saved)

regimes224.0ms (6.1%)

Accuracy

Total 0b remaining (0%)

Threshold costs 0b (0%)

Compiler

Compiled 3276 to 2520 computations (23.1% saved)

bsearch0.0ms (0%)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Rules
not-true not-false not-not not-and not-or and-true-l and-true-r and-false-l and-false-r and-same or-true-l or-true-r or-false-l or-false-r or-same if-if-and-not_binary64 if-if-and_binary64 if-if-or-not_binary64 if-if-or_binary64 if-not_binary64 if-same_binary64 if-false_binary64 if-true_binary64 tan-0_binary64 cos-0_binary64 sin-0_binary64 unpow1_binary64 e-exp-1_binary64 1-exp_binary64 exp-1-e_binary64 exp-0_binary64 sqr-abs_binary64 sqr-neg_binary64 neg-mul-1_binary64 neg-sub0_binary64 unsub-neg_binary64 sub-neg_binary64 mul-1-neg_binary64 /-rgt-identity_binary64 *-rgt-identity_binary64 *-lft-identity_binary64 remove-double-neg_binary64 sub0-neg_binary64 --rgt-identity_binary64 +-rgt-identity_binary64 +-lft-identity_binary64 cancel-sign-sub-inv_binary64 cancel-sign-sub_binary64 distribute-neg-frac_binary64 distribute-frac-neg_binary64 distribute-neg-out_binary64 distribute-neg-in_binary64 distribute-rgt-neg-out_binary64 distribute-lft-neg-out_binary64 distribute-rgt-neg-in_binary64 distribute-lft-neg-in_binary64 *-commutative_binary64 +-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
033
133

end1.0ms (0%)

Compiler

Compiled 2 to 2 computations (0% saved)

sample2.5s (66.6%)

Algorithm
intervals
Results
1.3s4293×body1024valid
386.0ms2026×body512valid
196.0ms442×body2048valid
125.0ms1072×body256valid
99.0ms8000×pre128true
12.0ms167×body128valid
Compiler

Compiled 51 to 47 computations (7.8% saved)

Profiling

Loading profile data...