Details

Time bar (total: 19.1s)

analyze1.6s (8.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
50%50%0.1%4
74.9%25%0.1%5
74.9%25%0.1%6
74.9%25%0.1%7
74.9%25%0.1%8
74.9%25%0.1%9
74.9%25%0.1%10
74.9%25%0.1%11
74.9%25%0.1%12
74.9%25%0.1%13
74.9%25%0.1%14
Compiler

Compiled 53 to 41 computations (22.6% saved)

sample8.8s (46%)

Results
6.0s3635×body1024valid
1.4s1430×body512valid
833.0ms2547×body128valid
445.0ms624×body256valid
65.0ms20×body2048valid
Compiler

Compiled 158 to 122 computations (22.8% saved)

simplify50.0ms (0.3%)

Algorithm
egg-herbie
Rules
770×neg-mul-1_binary64
444×distribute-rgt-neg-out_binary64
438×distribute-lft-neg-out_binary64
418×distribute-rgt-in_binary64
417×distribute-lft-in_binary64
Counts
1 → 2
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
03380
18074
220174
362673
4226171
5446071
6542271

prune9.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.4b
Counts
3 → 2
Alt Table
StatusErrorProgram
0.6b
(/.f64 (+.f64 2 (*.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)))) (*.f64 3 (+.f64 (+.f64 1 (*.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2) (cos.f64 x))) (*.f64 (/.f64 (-.f64 3 (sqrt.f64 5)) 2) (cos.f64 y)))))
0.5b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
Compiler

Compiled 295 to 218 computations (26.1% saved)

localize28.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.4b
(*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))
1.0b
(/.f64 (-.f64 (sqrt.f64 5) 1) 2/3)
1.0b
(-.f64 3 (sqrt.f64 5))
1.8b
(-.f64 (cos.f64 x) (cos.f64 y))

series23.0ms (0.1%)

Counts
4 → 32
Calls

4 calls:

16.0ms
(*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))
7.0ms
(-.f64 (cos.f64 x) (cos.f64 y))
0.0ms
(-.f64 3 (sqrt.f64 5))
0.0ms
(/.f64 (-.f64 (sqrt.f64 5) 1) 2/3)

rewrite71.0ms (0.4%)

Algorithm
batch-egg-rewrite
Rules
241×add-sqr-sqrt_binary64
237×log1p-expm1-u_binary64
237×expm1-log1p-u_binary64
232×add-log-exp_binary64
231×add-exp-log_binary64
Counts
4 → 81
Calls

4 calls:

68.0ms
(*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))
68.0ms
(/.f64 (-.f64 (sqrt.f64 5) 1) 2/3)
68.0ms
(-.f64 3 (sqrt.f64 5))
68.0ms
(-.f64 (cos.f64 x) (cos.f64 y))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02239
150039
2483439
3481939
000
100

simplify64.0ms (0.3%)

Algorithm
egg-herbie
Rules
819×sub-neg_binary64
783×fma-neg_binary64
287×fma-def_binary64
277×associate-+l-_binary64
267×distribute-rgt-neg-in_binary64
Counts
113 → 111
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
082605
1233566
2699510
32122507
44683507
55552507

prune331.0ms (1.7%)

Pruning

10 alts after pruning (10 fresh and 0 done)

PrunedKeptTotal
New1029111
Fresh011
Picked101
Done000
Total10310113
Error
0.2b
Counts
113 → 10
Alt Table
StatusErrorProgram
0.5b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.6b
(/.f64 (+.f64 2 (*.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)))) (*.f64 3 (+.f64 (+.f64 1 (*.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2) (cos.f64 x))) (*.f64 (/.f64 (-.f64 3 (sqrt.f64 5)) 2) (cos.f64 y)))))
0.7b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (*.f64 (pow.f64 (cbrt.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3)) 2) (cbrt.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
27.4b
(/.f64 (fma.f64 (*.f64 (*.f64 -1/16 (*.f64 (sin.f64 y) (sqrt.f64 2))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.5b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 x)) 2) (cbrt.f64 (cos.f64 x)) (neg.f64 (cos.f64 y))) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.6b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
0.5b
(/.f64 (fma.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))) 3) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.7b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (pow.f64 (/.f64 2/3 (-.f64 (sqrt.f64 5) 1)) -1) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
10.7b
(/.f64 (fma.f64 (*.f64 (-.f64 (exp.f64 (log1p.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))))) 1) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.7b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (log.f64 (exp.f64 (-.f64 3 (sqrt.f64 5))))) 3)))
Compiler

Compiled 6651 to 4428 computations (33.4% saved)

localize35.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.5b
(pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)
1.0b
(/.f64 (-.f64 (sqrt.f64 5) 1) 2/3)
1.0b
(-.f64 3 (sqrt.f64 5))
1.8b
(-.f64 (cos.f64 x) (cos.f64 y))

series25.0ms (0.1%)

Counts
1 → 8
Calls

1 calls:

25.0ms
(pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)

rewrite54.0ms (0.3%)

Algorithm
batch-egg-rewrite
Rules
582×prod-diff_binary64
411×log-prod_binary64
265×fma-def_binary64
167×expm1-udef_binary64
167×log1p-udef_binary64
Counts
1 → 37
Calls

1 calls:

53.0ms
(pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0811
118111
2227911
3521211
000
100

simplify39.0ms (0.2%)

Algorithm
egg-herbie
Rules
744×associate--r+_binary64
636×associate--l+_binary64
342×associate-*l*_binary64
326×associate-*r*_binary64
197×cancel-sign-sub-inv_binary64
Counts
45 → 51
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
0111573
1383533
21454516
35627516

prune564.0ms (3%)

Pruning

12 alts after pruning (12 fresh and 0 done)

PrunedKeptTotal
New1256131
Fresh369
Picked101
Done000
Total12912141
Error
0.2b
Counts
141 → 12
Alt Table
StatusErrorProgram
0.7b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (log.f64 (exp.f64 (-.f64 3 (sqrt.f64 5))))) 3)))
0.8b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (+.f64 (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)))) (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)))))) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.6b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
10.7b
(/.f64 (fma.f64 (*.f64 (-.f64 (exp.f64 (log1p.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))))) 1) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.7b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (*.f64 (pow.f64 (cbrt.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3)) 2) (cbrt.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
27.4b
(/.f64 (fma.f64 (*.f64 (*.f64 -1/16 (*.f64 (sin.f64 y) (sqrt.f64 2))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.5b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (pow.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 x)) 2) (cbrt.f64 (cos.f64 x)) (neg.f64 (cos.f64 y))) 3)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
9.9b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (-.f64 (exp.f64 (log1p.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3))) 1)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
1.0b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3))) (cbrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3))))) (log.f64 (cbrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)))))) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.5b
(/.f64 (fma.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))) 3) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.6b
(/.f64 (+.f64 2 (*.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)))) (*.f64 3 (+.f64 (+.f64 1 (*.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2) (cos.f64 x))) (*.f64 (/.f64 (-.f64 3 (sqrt.f64 5)) 2) (cos.f64 y)))))
0.7b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (pow.f64 (/.f64 2/3 (-.f64 (sqrt.f64 5) 1)) -1) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
Compiler

Compiled 9152 to 6119 computations (33.1% saved)

localize42.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.5b
(pow.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 x)) 2) (cbrt.f64 (cos.f64 x)) (neg.f64 (cos.f64 y))) 3)
1.0b
(-.f64 3 (sqrt.f64 5))
1.0b
(/.f64 (-.f64 (sqrt.f64 5) 1) 2/3)
1.8b
(fma.f64 (pow.f64 (cbrt.f64 (cos.f64 x)) 2) (cbrt.f64 (cos.f64 x)) (neg.f64 (cos.f64 y)))

series1.4s (7.3%)

Counts
2 → 48
Calls

2 calls:

713.0ms
(fma.f64 (pow.f64 (cbrt.f64 (cos.f64 x)) 2) (cbrt.f64 (cos.f64 x)) (neg.f64 (cos.f64 y)))
686.0ms
(pow.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 x)) 2) (cbrt.f64 (cos.f64 x)) (neg.f64 (cos.f64 y))) 3)

rewrite93.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
854×log1p-expm1-u_binary64
854×expm1-log1p-u_binary64
224×prod-diff_binary64
133×egg-rr
114×add-sqr-sqrt_binary64
Counts
2 → 133
Calls

2 calls:

89.0ms
(pow.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 x)) 2) (cbrt.f64 (cos.f64 x)) (neg.f64 (cos.f64 y))) 3)
89.0ms
(fma.f64 (pow.f64 (cbrt.f64 (cos.f64 x)) 2) (cbrt.f64 (cos.f64 x)) (neg.f64 (cos.f64 y)))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01223
124319
2226219
3546419
000
100

simplify90.0ms (0.5%)

Algorithm
egg-herbie
Rules
705×associate--l+_binary64
379×associate-*l*_binary64
368×associate-*r*_binary64
296×cancel-sign-sub-inv_binary64
220×fma-def_binary64
Counts
181 → 162
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01351021
1458969
21730953
35162953

prune547.0ms (2.9%)

Pruning

12 alts after pruning (11 fresh and 1 done)

PrunedKeptTotal
New1990199
Fresh01111
Picked011
Done000
Total19912211
Error
0.2b
Counts
211 → 12
Alt Table
StatusErrorProgram
0.7b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (log.f64 (exp.f64 (-.f64 3 (sqrt.f64 5))))) 3)))
0.8b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (+.f64 (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)))) (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)))))) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.6b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
10.7b
(/.f64 (fma.f64 (*.f64 (-.f64 (exp.f64 (log1p.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))))) 1) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.7b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (*.f64 (pow.f64 (cbrt.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3)) 2) (cbrt.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
27.4b
(/.f64 (fma.f64 (*.f64 (*.f64 -1/16 (*.f64 (sin.f64 y) (sqrt.f64 2))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.5b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (pow.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 x)) 2) (cbrt.f64 (cos.f64 x)) (neg.f64 (cos.f64 y))) 3)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
9.9b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (-.f64 (exp.f64 (log1p.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3))) 1)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
1.0b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3))) (cbrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3))))) (log.f64 (cbrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)))))) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.5b
(/.f64 (fma.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))) 3) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.6b
(/.f64 (+.f64 2 (*.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)))) (*.f64 3 (+.f64 (+.f64 1 (*.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2) (cos.f64 x))) (*.f64 (/.f64 (-.f64 3 (sqrt.f64 5)) 2) (cos.f64 y)))))
0.7b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (pow.f64 (/.f64 2/3 (-.f64 (sqrt.f64 5) 1)) -1) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
Compiler

Compiled 14348 to 9072 computations (36.8% saved)

localize37.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.8b
(pow.f64 (cbrt.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))) 3)
1.0b
(/.f64 (-.f64 (sqrt.f64 5) 1) 2/3)
1.0b
(-.f64 3 (sqrt.f64 5))
1.8b
(-.f64 (cos.f64 x) (cos.f64 y))

series1.2s (6.3%)

Counts
1 → 24
Calls

1 calls:

1.2s
(pow.f64 (cbrt.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))) 3)

rewrite82.0ms (0.4%)

Algorithm
batch-egg-rewrite
Rules
538×prod-diff_binary64
233×expm1-udef_binary64
233×log1p-udef_binary64
131×log1p-expm1-u_binary64
131×expm1-log1p-u_binary64
Counts
1 → 41
Calls

1 calls:

80.0ms
(pow.f64 (cbrt.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))) 3)
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01416
128416
2320616
3482316
000
100

simplify85.0ms (0.4%)

Algorithm
egg-herbie
Rules
835×fma-neg_binary64
634×distribute-rgt-neg-in_binary64
369×sub-neg_binary64
261×distribute-lft-neg-in_binary64
258×associate-*r*_binary64
Counts
65 → 58
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
053508
1160476
2505402
31796392
43992392
55058392

prune1.2s (6.1%)

Pruning

14 alts after pruning (12 fresh and 2 done)

PrunedKeptTotal
New1362138
Fresh01010
Picked011
Done011
Total13614150
Error
0.2b
Counts
150 → 14
Alt Table
StatusErrorProgram
0.7b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (log.f64 (exp.f64 (-.f64 3 (sqrt.f64 5))))) 3)))
0.8b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (+.f64 (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)))) (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)))))) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.6b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
10.7b
(/.f64 (fma.f64 (*.f64 (-.f64 (exp.f64 (log1p.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))))) 1) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.5b
(/.f64 (fma.f64 (*.f64 (*.f64 (*.f64 (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)) (cbrt.f64 2)) (cbrt.f64 (sqrt.f64 2))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.7b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (*.f64 (pow.f64 (cbrt.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3)) 2) (cbrt.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
27.4b
(/.f64 (fma.f64 (*.f64 (*.f64 -1/16 (*.f64 (sin.f64 y) (sqrt.f64 2))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.5b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (pow.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 x)) 2) (cbrt.f64 (cos.f64 x)) (neg.f64 (cos.f64 y))) 3)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
9.9b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (-.f64 (exp.f64 (log1p.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3))) 1)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
1.0b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (cbrt.f64 (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3))) (cbrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3))))) (log.f64 (cbrt.f64 (exp.f64 (pow.f64 (-.f64 (cos.f64 x) (cos.f64 y)) 3)))))) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.5b
(/.f64 (fma.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))) 3) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.6b
(/.f64 (+.f64 2 (*.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)))) (*.f64 3 (+.f64 (+.f64 1 (*.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) 2) (cos.f64 x))) (*.f64 (/.f64 (-.f64 3 (sqrt.f64 5)) 2) (cos.f64 y)))))
0.7b
(/.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (pow.f64 (/.f64 2/3 (-.f64 (sqrt.f64 5) 1)) -1) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.5b
(/.f64 (fma.f64 (*.f64 (*.f64 (pow.f64 2 1/4) (*.f64 (pow.f64 2 1/4) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (/.f64 (-.f64 (sqrt.f64 5) 1) 2/3) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
Compiler

Compiled 8263 to 5537 computations (33% saved)

regimes1.5s (7.7%)

Accuracy

Total 0.3b remaining (66%)

Threshold costs 0.3b (66%)

Counts
127 → 1
Compiler

Compiled 19916 to 15013 computations (24.6% saved)

simplify9.0ms (0%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
03581
15181
26881
38081
48881
59081
68881

end1.1s (5.9%)

Compiler

Compiled 866 to 658 computations (24% saved)

Profiling

Loading profile data...