Details

Time bar (total: 18.7s)

analyze1.2s (6.3%)

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)

sample295.0ms (1.6%)

Algorithm
intervals
Results
161.0ms119×body1024valid
35.0ms41×body512valid
18.0ms73×body128valid
14.0ms23×body256valid
Compiler

Compiled 107 to 83 computations (22.4% 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

prune7.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.3b
Counts
3 → 2
Alt Table
StatusErrorProgram
0.5b
(/.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.4b
(/.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)

localize31.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.5b
(*.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))
2.3b
(-.f64 (cos.f64 x) (cos.f64 y))

series26.0ms (0.1%)

Counts
4 → 32
Calls

4 calls:

19.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)

rewrite66.0ms (0.4%)

Algorithm
rewrite-expression-head
Rules
179×add-sqr-sqrt_binary64
154×*-un-lft-identity_binary64
128×add-cube-cbrt_binary64
106×times-frac_binary64
105×prod-diff_binary64
Counts
4 → 273
Calls

4 calls:

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

simplify251.0ms (1.3%)

Algorithm
egg-herbie
Rules
387×cancel-sign-sub-inv_binary64
375×fma-neg_binary64
336×associate-*l*_binary64
316×associate-*r*_binary64
280×*-commutative_binary64
Counts
305 → 333
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
05948679
111996233
232235425
346335425
449815425
546965425

prune1.3s (7%)

Pruning

9 alts after pruning (9 fresh and 0 done)

PrunedKeptTotal
New3258333
Fresh011
Picked101
Done000
Total3269335
Error
0.1b
Counts
335 → 9
Alt Table
StatusErrorProgram
0.5b
(/.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.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))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (*.f64 (*.f64 (cbrt.f64 (+.f64 -1 (sqrt.f64 5))) (cbrt.f64 (+.f64 -1 (sqrt.f64 5)))) (/.f64 (cbrt.f64 (+.f64 -1 (sqrt.f64 5))) 2/3)) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.4b
(/.f64 (fma.f64 (*.f64 (+.f64 (*.f64 (sqrt.f64 2) (sin.f64 x)) (*.f64 (sqrt.f64 2) (neg.f64 (/.f64 (sin.f64 y) (pow.f64 (cbrt.f64 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.4b
(/.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 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (*.f64 (*.f64 (cbrt.f64 (-.f64 (cos.f64 x) (cos.f64 y))) (cbrt.f64 (-.f64 (cos.f64 x) (cos.f64 y)))) (cbrt.f64 (-.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.4b
(/.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 1 (sqrt.f64 2/3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 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))) (-.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 (fma.f64 1 3 (neg.f64 (*.f64 (sqrt.f64 (sqrt.f64 5)) (sqrt.f64 (sqrt.f64 5))))) (fma.f64 (neg.f64 (sqrt.f64 (sqrt.f64 5))) (sqrt.f64 (sqrt.f64 5)) (*.f64 (sqrt.f64 (sqrt.f64 5)) (sqrt.f64 (sqrt.f64 5)))))) 3)))
1.1b
(/.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 (*.f64 (cbrt.f64 (-.f64 (sqrt.f64 5) 1)) (cbrt.f64 (-.f64 (sqrt.f64 5) 1))) (sqrt.f64 2/3)) (/.f64 (cbrt.f64 (-.f64 (sqrt.f64 5) 1)) (sqrt.f64 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.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))) (-.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 (*.f64 (neg.f64 (sqrt.f64 (sqrt.f64 5))) (sqrt.f64 (sqrt.f64 5))))) 3)))
Compiler

Compiled 21978 to 14233 computations (35.2% saved)

localize80.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
1.0b
(*.f64 (/.f64 1 (sqrt.f64 2/3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3)))
1.0b
(-.f64 3 (sqrt.f64 5))
1.0b
(/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3))
2.3b
(-.f64 (cos.f64 x) (cos.f64 y))

series0.0ms (0%)

Counts
2 → 0
Calls

2 calls:

0.0ms
(/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3))
0.0ms
(*.f64 (/.f64 1 (sqrt.f64 2/3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3)))

rewrite69.0ms (0.4%)

Algorithm
rewrite-expression-head
Rules
238×add-sqr-sqrt_binary64
172×times-frac_binary64
146×*-un-lft-identity_binary64
141×sqrt-prod_binary64
75×add-cube-cbrt_binary64
Counts
2 → 233
Calls

2 calls:

32.0ms
(*.f64 (/.f64 1 (sqrt.f64 2/3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3)))
10.0ms
(/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3))

simplify208.0ms (1.1%)

Algorithm
egg-herbie
Rules
633×times-frac_binary64
528×cancel-sign-sub-inv_binary64
496×associate-/l*_binary64
318×sub-neg_binary64
318×fma-def_binary64
Counts
233 → 212
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01515163
13754567
212164565
331224503
440954447
552814447

prune876.0ms (4.7%)

Pruning

8 alts after pruning (8 fresh and 0 done)

PrunedKeptTotal
New3062308
Fresh268
Picked101
Done000
Total3098317
Error
0.1b
Counts
317 → 8
Alt Table
StatusErrorProgram
0.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))) (-.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 (*.f64 (neg.f64 (sqrt.f64 (sqrt.f64 5))) (sqrt.f64 (sqrt.f64 5))))) 3)))
0.3b
(/.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 1 (sqrt.f64 2/3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
0.4b
(/.f64 (fma.f64 (*.f64 (+.f64 (*.f64 (sqrt.f64 2) (sin.f64 x)) (*.f64 (sqrt.f64 2) (neg.f64 (/.f64 (sin.f64 y) (pow.f64 (cbrt.f64 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.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 (*.f64 (cbrt.f64 (-.f64 (cos.f64 x) (cos.f64 y))) (cbrt.f64 (-.f64 (cos.f64 x) (cos.f64 y)))) (cbrt.f64 (-.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 (+.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)))))
1.1b
(/.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 (*.f64 (cbrt.f64 (-.f64 (sqrt.f64 5) 1)) (cbrt.f64 (-.f64 (sqrt.f64 5) 1))) (sqrt.f64 2/3)) (/.f64 (cbrt.f64 (-.f64 (sqrt.f64 5) 1)) (sqrt.f64 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))) (-.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 (fma.f64 1 3 (neg.f64 (*.f64 (sqrt.f64 (sqrt.f64 5)) (sqrt.f64 (sqrt.f64 5))))) (fma.f64 (neg.f64 (sqrt.f64 (sqrt.f64 5))) (sqrt.f64 (sqrt.f64 5)) (*.f64 (sqrt.f64 (sqrt.f64 5)) (sqrt.f64 (sqrt.f64 5)))))) 3)))
0.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))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (*.f64 (/.f64 1 (pow.f64 (sqrt.f64 (sqrt.f64 2/3)) 3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 (sqrt.f64 2/3)))) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
Compiler

Compiled 19734 to 13993 computations (29.1% saved)

localize40.0ms (0.2%)

Local error

Found 4 expressions with local error:

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

prune1.2s (6.3%)

Pruning

8 alts after pruning (8 fresh and 0 done)

PrunedKeptTotal
New4204424
Fresh347
Picked101
Done000
Total4248432
Error
0.1b
Counts
432 → 8
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))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (*.f64 (/.f64 1 (sqrt.f64 2/3)) (/.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) (*.f64 (cbrt.f64 (sqrt.f64 2/3)) (cbrt.f64 (sqrt.f64 2/3)))) (cbrt.f64 (sqrt.f64 2/3)))) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
1.1b
(/.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 (*.f64 (cbrt.f64 (-.f64 (sqrt.f64 5) 1)) (cbrt.f64 (-.f64 (sqrt.f64 5) 1))) (sqrt.f64 2/3)) (/.f64 (cbrt.f64 (-.f64 (sqrt.f64 5) 1)) (sqrt.f64 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.4b
(/.f64 (fma.f64 (*.f64 (+.f64 (*.f64 (sqrt.f64 2) (sin.f64 x)) (*.f64 (sqrt.f64 2) (neg.f64 (/.f64 (sin.f64 y) (pow.f64 (cbrt.f64 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.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 (*.f64 (cbrt.f64 (-.f64 (cos.f64 x) (cos.f64 y))) (cbrt.f64 (-.f64 (cos.f64 x) (cos.f64 y)))) (cbrt.f64 (-.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.3b
(/.f64 (fma.f64 (*.f64 (log.f64 (exp.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 1 (sqrt.f64 2/3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
0.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))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (*.f64 (/.f64 1 (pow.f64 (sqrt.f64 (sqrt.f64 2/3)) 3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 (sqrt.f64 2/3)))) (fma.f64 (cos.f64 y) (*.f64 3/2 (-.f64 3 (sqrt.f64 5))) 3)))
0.3b
(/.f64 (fma.f64 (*.f64 (/.f64 (*.f64 (sqrt.f64 2) (-.f64 (*.f64 (sin.f64 x) (sin.f64 x)) (pow.f64 (cbrt.f64 (/.f64 (sin.f64 y) 16)) 6))) (+.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 1 (sqrt.f64 2/3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.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))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (*.f64 (/.f64 1 (sqrt.f64 2/3)) (*.f64 (-.f64 (sqrt.f64 5) 1) (/.f64 1 (sqrt.f64 2/3)))) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
Compiler

Compiled 30165 to 20885 computations (30.8% saved)

localize37.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
1.0b
(*.f64 (/.f64 1 (sqrt.f64 2/3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3)))
1.0b
(/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3))
2.3b
(-.f64 (cos.f64 x) (cos.f64 y))
3.5b
(log.f64 (exp.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))))

series16.0ms (0.1%)

Counts
1 → 24
Calls

1 calls:

16.0ms
(log.f64 (exp.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))))

rewrite43.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
109×log-prod_binary64
106×exp-sum_binary64
84×*-un-lft-identity_binary64
84×add-sqr-sqrt_binary64
84×add-cube-cbrt_binary64
Counts
1 → 122
Calls

1 calls:

13.0ms
(log.f64 (exp.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16)))))

simplify141.0ms (0.8%)

Algorithm
egg-herbie
Rules
517×fma-def_binary64
442×exp-prod_binary64
410×associate-/l*_binary64
348×log-pow_binary64
334×fma-neg_binary64
Counts
146 → 152
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
05825236
19033812
216842529
344152529
446612529

prune1.3s (6.9%)

Pruning

10 alts after pruning (10 fresh and 0 done)

PrunedKeptTotal
New4114415
Fresh167
Picked101
Done000
Total41310423
Error
0.1b
Counts
423 → 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))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (*.f64 (/.f64 1 (sqrt.f64 2/3)) (*.f64 (-.f64 (sqrt.f64 5) 1) (/.f64 1 (sqrt.f64 2/3)))) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
0.5b
(/.f64 (fma.f64 (*.f64 (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))))) (cbrt.f64 (exp.f64 (*.f64 (sqrt.f64 2) (-.f64 (sin.f64 x) (/.f64 (sin.f64 y) 16))))))) (log.f64 (cbrt.f64 (exp.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 1 (sqrt.f64 2/3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
0.8b
(/.f64 (fma.f64 (*.f64 (log.f64 (exp.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 1 (pow.f64 (sqrt.f64 (sqrt.f64 2/3)) 3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 (sqrt.f64 2/3)))) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
1.1b
(/.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 (*.f64 (cbrt.f64 (-.f64 (sqrt.f64 5) 1)) (cbrt.f64 (-.f64 (sqrt.f64 5) 1))) (sqrt.f64 2/3)) (/.f64 (cbrt.f64 (-.f64 (sqrt.f64 5) 1)) (sqrt.f64 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 1 (sqrt.f64 2/3)) (/.f64 (/.f64 (-.f64 (sqrt.f64 5) 1) (*.f64 (cbrt.f64 (sqrt.f64 2/3)) (cbrt.f64 (sqrt.f64 2/3)))) (cbrt.f64 (sqrt.f64 2/3)))) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
0.4b
(/.f64 (fma.f64 (*.f64 (+.f64 (*.f64 (sqrt.f64 2) (sin.f64 x)) (*.f64 (sqrt.f64 2) (neg.f64 (/.f64 (sin.f64 y) (pow.f64 (cbrt.f64 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.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 (*.f64 (cbrt.f64 (-.f64 (cos.f64 x) (cos.f64 y))) (cbrt.f64 (-.f64 (cos.f64 x) (cos.f64 y)))) (cbrt.f64 (-.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.3b
(/.f64 (fma.f64 (*.f64 (+.f64 (log.f64 (sqrt.f64 (exp.f64 (*.f64 (sqrt.f64 2) (fma.f64 -1/16 (sin.f64 y) (sin.f64 x)))))) (log.f64 (sqrt.f64 (exp.f64 (*.f64 (sqrt.f64 2) (fma.f64 -1/16 (sin.f64 y) (sin.f64 x))))))) (-.f64 (sin.f64 y) (/.f64 (sin.f64 x) 16))) (-.f64 (cos.f64 x) (cos.f64 y)) 2) (fma.f64 (cos.f64 x) (*.f64 (/.f64 1 (sqrt.f64 2/3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
0.3b
(/.f64 (fma.f64 (*.f64 (/.f64 (*.f64 (sqrt.f64 2) (-.f64 (*.f64 (sin.f64 x) (sin.f64 x)) (pow.f64 (cbrt.f64 (/.f64 (sin.f64 y) 16)) 6))) (+.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 1 (sqrt.f64 2/3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
0.3b
(/.f64 (fma.f64 (*.f64 (+.f64 (log.f64 (exp.f64 (*.f64 (sin.f64 x) (sqrt.f64 2)))) (log.f64 (exp.f64 (*.f64 (*.f64 (neg.f64 (/.f64 (*.f64 (cbrt.f64 (sin.f64 y)) (cbrt.f64 (sin.f64 y))) (*.f64 (cbrt.f64 16) (cbrt.f64 16)))) (/.f64 (cbrt.f64 (sin.f64 y)) (cbrt.f64 16))) (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 1 (sqrt.f64 2/3)) (/.f64 (-.f64 (sqrt.f64 5) 1) (sqrt.f64 2/3))) (fma.f64 (cos.f64 y) (*.f64 3/2 (/.f64 4 (+.f64 3 (sqrt.f64 5)))) 3)))
Compiler

Compiled 30219 to 21212 computations (29.8% saved)

regimes3.1s (16.8%)

Accuracy

Total 0.3b remaining (71.7%)

Threshold costs 0.3b (71.7%)

Counts
447 → 1
Compiler

Compiled 83435 to 64564 computations (22.6% saved)

simplify5.0ms (0%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
04093
15693
27093
38093
48793
58993
68793

end1.0ms (0%)

Compiler

Compiled 60 to 48 computations (20% saved)

sample8.4s (44.8%)

Algorithm
intervals
Results
5.2s3630×body1024valid
1.2s1344×body512valid
641.0ms2421×body128valid
373.0ms586×body256valid
55.0ms19×body2048valid
Compiler

Compiled 780 to 600 computations (23.1% saved)

Profiling

Loading profile data...