Details

Time bar (total: 9.8s)

analyze461.0ms (4.7%)

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
0%99.9%0.1%5
25%74.9%0.1%6
37.4%62.4%0.1%7
56.2%43.7%0.1%8
56.2%43.7%0.1%9
65.5%34.3%0.1%10
76.5%23.4%0.1%11
76.5%23.4%0.1%12
81.9%17.9%0.1%13
87.8%12.1%0.1%14
Compiler

Compiled 13 to 9 computations (30.8% saved)

sample2.4s (24.8%)

Results
1.0s1416×body1024valid
923.0ms5819×body128valid
314.0ms684×body512valid
92.0ms336×body256valid
1.0msbody2048valid
Compiler

Compiled 38 to 26 computations (31.6% saved)

simplify23.0ms (0.2%)

Algorithm
egg-herbie
Rules
230×fma-def_binary64
171×fma-neg_binary64
66×cancel-sign-sub-inv_binary64
44×associate--r+_binary64
44×distribute-rgt-in_binary64
Counts
1 → 1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0914
11814
23414
35914
49914
515514
624714
729214
837814
941014
1044414
1145414
1243114

prune2.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New011
Fresh011
Picked000
Done000
Total022
Error
0.1b
Counts
2 → 1
Alt Table
StatusErrorProgram
0.1b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
Compiler

Compiled 36 to 24 computations (33.3% saved)

localize8.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(+.f64 x (cos.f64 y))
0.0b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
0.2b
(*.f64 z (sin.f64 y))

series26.0ms (0.3%)

Counts
3 → 84
Calls

3 calls:

12.0ms
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
8.0ms
(*.f64 z (sin.f64 y))
5.0ms
(+.f64 x (cos.f64 y))

rewrite13.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
14×*-un-lft-identity_binary64
10×add-sqr-sqrt_binary64
10×add-log-exp_binary64
add-cube-cbrt_binary64
add-cbrt-cube_binary64
Counts
3 → 61
Calls

3 calls:

5.0ms
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
3.0ms
(*.f64 z (sin.f64 y))
3.0ms
(+.f64 x (cos.f64 y))

simplify142.0ms (1.4%)

Algorithm
egg-herbie
Rules
883×fma-neg_binary64
503×fma-def_binary64
418×associate-*l*_binary64
386×associate-*r*_binary64
239×cancel-sign-sub-inv_binary64
Counts
145 → 120
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01411641
13691578
210841530
337951520
446871520
548661520

prune95.0ms (1%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New1155120
Fresh000
Picked011
Done000
Total1156121
Error
0.0b
Counts
121 → 6
Alt Table
StatusErrorProgram
0.1b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
35.1b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (sqrt.f64 z) (*.f64 (sqrt.f64 z) (sin.f64 y))))
23.3b
(*.f64 (sqrt.f64 (-.f64 (+.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))) (sqrt.f64 (-.f64 (+.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))))
0.3b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (cbrt.f64 z) (cbrt.f64 z)) (*.f64 (cbrt.f64 z) (sin.f64 y))))
28.3b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) (sqrt.f64 (*.f64 z (sin.f64 y)))))
0.3b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
Compiler

Compiled 2010 to 612 computations (69.6% saved)

localize11.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 z (sin.f64 y))
0.3b
(*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))) (cbrt.f64 (*.f64 z (sin.f64 y))))
0.5b
(*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))
8.8b
(cbrt.f64 (*.f64 z (sin.f64 y)))

series1.2s (12.6%)

Counts
3 → 72
Calls

3 calls:

756.0ms
(*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))
464.0ms
(cbrt.f64 (*.f64 z (sin.f64 y)))
20.0ms
(*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))) (cbrt.f64 (*.f64 z (sin.f64 y))))

rewrite19.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
29×pow1_binary64
16×pow1/3_binary64
11×pow-prod-up_binary64
11×add-sqr-sqrt_binary64
10×add-exp-log_binary64
Counts
3 → 79
Calls

3 calls:

7.0ms
(*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))) (cbrt.f64 (*.f64 z (sin.f64 y))))
6.0ms
(*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))
2.0ms
(cbrt.f64 (*.f64 z (sin.f64 y)))

simplify122.0ms (1.2%)

Algorithm
egg-herbie
Rules
608×fma-neg_binary64
445×cancel-sign-sub-inv_binary64
352×*-commutative_binary64
346×fma-def_binary64
253×distribute-rgt-neg-in_binary64
Counts
151 → 134
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01692495
14102016
211691679
327331438
446591438
549811438
648911438

prune358.0ms (3.6%)

Pruning

6 alts after pruning (4 fresh and 2 done)

PrunedKeptTotal
New2943297
Fresh314
Picked011
Done011
Total2976303
Error
0.0b
Counts
303 → 6
Alt Table
StatusErrorProgram
28.3b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) (sqrt.f64 (*.f64 z (sin.f64 y)))))
0.4b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))) (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))))) (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
0.4b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (*.f64 (*.f64 (cbrt.f64 (cbrt.f64 (*.f64 z (sin.f64 y)))) (cbrt.f64 (cbrt.f64 (*.f64 z (sin.f64 y))))) (cbrt.f64 (cbrt.f64 (*.f64 z (sin.f64 y)))))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
0.1b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
0.3b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
0.3b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (*.f64 (cbrt.f64 z) (cbrt.f64 (sin.f64 y)))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
Compiler

Compiled 8474 to 2063 computations (75.7% saved)

localize14.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.5b
(*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (*.f64 (cbrt.f64 z) (cbrt.f64 (sin.f64 y))))
0.5b
(cbrt.f64 z)
0.7b
(cbrt.f64 (sin.f64 y))
8.8b
(cbrt.f64 (*.f64 z (sin.f64 y)))

series1.1s (10.8%)

Counts
3 → 48
Calls

3 calls:

792.0ms
(*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (*.f64 (cbrt.f64 z) (cbrt.f64 (sin.f64 y))))
229.0ms
(cbrt.f64 (sin.f64 y))
36.0ms
(cbrt.f64 z)

rewrite9.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
11×pow1/3_binary64
cbrt-prod_binary64
add-exp-log_binary64
pow1_binary64
pow-prod-down_binary64
Counts
3 → 51
Calls

3 calls:

5.0ms
(*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (*.f64 (cbrt.f64 z) (cbrt.f64 (sin.f64 y))))
1.0ms
(cbrt.f64 (sin.f64 y))
1.0ms
(cbrt.f64 z)

simplify102.0ms (1%)

Algorithm
egg-herbie
Rules
556×fma-neg_binary64
324×*-commutative_binary64
323×distribute-rgt-in_binary64
280×distribute-lft-in_binary64
249×log-prod_binary64
Counts
99 → 94
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01421489
13431360
29941221
323731042
445241022
549491022
648991022

prune166.0ms (1.7%)

Pruning

6 alts after pruning (3 fresh and 3 done)

PrunedKeptTotal
New1460146
Fresh033
Picked011
Done022
Total1466152
Error
0.0b
Counts
152 → 6
Alt Table
StatusErrorProgram
28.3b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) (sqrt.f64 (*.f64 z (sin.f64 y)))))
0.4b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))) (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))))) (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
0.4b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (*.f64 (*.f64 (cbrt.f64 (cbrt.f64 (*.f64 z (sin.f64 y)))) (cbrt.f64 (cbrt.f64 (*.f64 z (sin.f64 y))))) (cbrt.f64 (cbrt.f64 (*.f64 z (sin.f64 y)))))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
0.1b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
0.3b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
0.3b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (*.f64 (cbrt.f64 z) (cbrt.f64 (sin.f64 y)))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
Compiler

Compiled 4594 to 1359 computations (70.4% saved)

localize16.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.5b
(*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))
0.5b
(*.f64 (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))) (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))))
2.3b
(cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
8.8b
(cbrt.f64 (*.f64 z (sin.f64 y)))

series2.2s (22.4%)

Counts
2 → 48
Calls

2 calls:

1.1s
(*.f64 (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))) (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))))
1.1s
(cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))))

rewrite14.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
10×add-sqr-sqrt_binary64
cbrt-prod_binary64
pow1_binary64
pow1/3_binary64
*-un-lft-identity_binary64
Counts
2 → 47
Calls

2 calls:

7.0ms
(*.f64 (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))) (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))))
4.0ms
(cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))))

simplify94.0ms (1%)

Algorithm
egg-herbie
Rules
591×unswap-sqr_binary64
585×fma-neg_binary64
424×associate-*l*_binary64
386×associate-*r*_binary64
276×fma-def_binary64
Counts
95 → 87
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01422996
13472646
28842132
329471980
450811980

prune754.0ms (7.7%)

Pruning

7 alts after pruning (3 fresh and 4 done)

PrunedKeptTotal
New4971498
Fresh022
Picked011
Done033
Total4977504
Error
0.0b
Counts
504 → 7
Alt Table
StatusErrorProgram
28.3b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (sqrt.f64 (*.f64 z (sin.f64 y))) (sqrt.f64 (*.f64 z (sin.f64 y)))))
0.4b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))) (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))))) (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
0.4b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (*.f64 (*.f64 (cbrt.f64 (cbrt.f64 (*.f64 z (sin.f64 y)))) (cbrt.f64 (cbrt.f64 (*.f64 z (sin.f64 y))))) (cbrt.f64 (cbrt.f64 (*.f64 z (sin.f64 y)))))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
0.1b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 z (sin.f64 y)))
0.3b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
0.5b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))) (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))))) (*.f64 (*.f64 (cbrt.f64 (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))))) (cbrt.f64 (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y))))))) (cbrt.f64 (cbrt.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (cbrt.f64 (*.f64 z (sin.f64 y)))))))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
0.3b
(-.f64 (+.f64 x (cos.f64 y)) (*.f64 (*.f64 (cbrt.f64 (*.f64 z (sin.f64 y))) (*.f64 (cbrt.f64 z) (cbrt.f64 (sin.f64 y)))) (cbrt.f64 (*.f64 z (sin.f64 y)))))
Compiler

Compiled 28256 to 5217 computations (81.5% saved)

regimes328.0ms (3.3%)

Accuracy

Total 0.0b remaining (50.5%)

Threshold costs 0.0b (50.5%)

Counts
74 → 1
Compiler

Compiled 9760 to 4198 computations (57% saved)

simplify3.0ms (0%)

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
0914
11614
22614
33214
43614
53714
63714

end111.0ms (1.1%)

Compiler

Compiled 279 to 104 computations (62.7% saved)

Profiling

Loading profile data...