Details

Time bar (total: 10.7s)

analyze1.4s (13.3%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.7%0.3%0
0%99.7%0.3%1
0%99.7%0.3%2
0%99.7%0.3%3
0%99.7%0.3%4
0%99.7%0.3%5
0%99.7%0.3%6
0%99.7%0.3%7
0%74.8%25.2%8
0%74.8%25.2%9
0%74.8%25.2%10
0%74.8%25.2%11
0%74.8%25.2%12
24.9%49.9%25.2%13
24.9%37.4%37.7%14
Compiler

Compiled 26 to 20 computations (23.1% saved)

sample4.1s (38.3%)

Symmetry

(sort z t)

Results
1.1s1580×body1024valid
904.0ms4818×body128valid
851.0ms753×body2048valid
653.0ms3522×body128invalid
402.0ms780×body512valid
108.0ms324×body256valid
2.0msbody4096valid
Compiler

Compiled 77 to 59 computations (23.4% saved)

simplify45.0ms (0.4%)

Algorithm
egg-herbie
Rules
718×fma-def_binary64
437×fma-neg_binary64
148×cancel-sign-sub-inv_binary64
110×distribute-rgt-neg-in_binary64
108×associate-/l*_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01929
13429
26529
312027
424125
539925
663925
792225
8121325
9174825
10241225
11278025
12287125
13288725
14288725
Stop Event
saturated
Counts
1 → 2

prune5.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
20.8b
Counts
3 → 2
Alt Table
StatusErrorProgram
21.3b
(-.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (-.f64 y (/.f64 (*.f64 z t) 3)))) (/.f64 a (*.f64 b 3)))
21.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))) (*.f64 a (/.f64 -1/3 b)))
Compiler

Compiled 138 to 101 computations (26.8% saved)

localize13.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))
0.3b
(/.f64 -1/3 b)
0.3b
(*.f64 t -1/3)
23.8b
(cos.f64 (fma.f64 z (*.f64 t -1/3) y))

series39.0ms (0.4%)

Counts
4 → 84
Calls

4 calls:

26.0ms
(*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))
10.0ms
(cos.f64 (fma.f64 z (*.f64 t -1/3) y))
1.0ms
(*.f64 t -1/3)
1.0ms
(/.f64 -1/3 b)

rewrite60.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
615×log-prod_binary64
236×expm1-udef_binary64
236×log1p-udef_binary64
218×log-pow_binary64
132×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01333
126333
2313433
Stop Event
node limit
Counts
4 → 86
Calls

4 calls:

59.0ms
(*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))
59.0ms
(/.f64 -1/3 b)
59.0ms
(*.f64 t -1/3)
59.0ms
(cos.f64 (fma.f64 z (*.f64 t -1/3) y))

simplify56.0ms (0.5%)

Algorithm
egg-herbie
Rules
729×associate-*l*_binary64
653×associate-*r*_binary64
364×cancel-sign-sub-inv_binary64
320×fma-def_binary64
220×*-commutative_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
0831491
12801422
29901366
348191366
Stop Event
node limit
Counts
170 → 124

prune192.0ms (1.8%)

Pruning

24 alts after pruning (24 fresh and 0 done)

PrunedKeptTotal
New10123124
Fresh011
Picked101
Done000
Total10224126
Error
13.6b
Counts
126 → 24
Alt Table
StatusErrorProgram
44.5b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (pow.f64 (pow.f64 (*.f64 t -1/3) 3) 1/3) y))) (*.f64 a (/.f64 -1/3 b)))
21.7b
(fma.f64 2 (*.f64 (sqrt.f64 x) (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))) (cbrt.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))))) (log.f64 (cbrt.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))) (*.f64 a (/.f64 -1/3 b)))
45.1b
(fma.f64 2 (log.f64 (pow.f64 (exp.f64 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))) (*.f64 a (/.f64 -1/3 b)))
38.9b
(fma.f64 2 (*.f64 (sqrt.f64 x) (+.f64 (*.f64 (cos.f64 (exp.f64 (log1p.f64 (fma.f64 z (*.f64 t -1/3) y)))) (cos.f64 1)) (*.f64 (sin.f64 (exp.f64 (log1p.f64 (fma.f64 z (*.f64 t -1/3) y)))) (sin.f64 1)))) (*.f64 a (/.f64 -1/3 b)))
21.3b
(-.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (-.f64 y (/.f64 (*.f64 z t) 3)))) (/.f64 a (*.f64 b 3)))
21.5b
(fma.f64 2 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x))) 3) (*.f64 a (/.f64 -1/3 b)))
21.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (log1p.f64 (expm1.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))) (*.f64 a (/.f64 -1/3 b)))
40.5b
(fma.f64 2 (pow.f64 (pow.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x)) 3) 1/3) (*.f64 a (/.f64 -1/3 b)))
21.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cbrt.f64 (pow.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) 3))) (*.f64 a (/.f64 -1/3 b)))
24.9b
(fma.f64 2 (*.f64 (sqrt.f64 x) (sqrt.f64 (pow.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) 2))) (*.f64 a (/.f64 -1/3 b)))
29.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (*.f64 1/3 (*.f64 t z)))) (*.f64 a (/.f64 -1/3 b)))
39.5b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))) (*.f64 a (sqrt.f64 (/.f64 1/9 (*.f64 b b)))))
21.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (pow.f64 (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))) 3)) (*.f64 a (/.f64 -1/3 b)))
35.2b
(fma.f64 2 (exp.f64 (log.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x)))) (*.f64 a (/.f64 -1/3 b)))
21.6b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))) (*.f64 a (*.f64 (cbrt.f64 (/.f64 -1/3 b)) (pow.f64 (cbrt.f64 (/.f64 -1/3 b)) 2))))
28.2b
(fma.f64 2 (expm1.f64 (log1p.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x)))) (*.f64 a (/.f64 -1/3 b)))
21.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))) (*.f64 a (*.f64 -1/3 (/.f64 1 b))))
26.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (fma.f64 1/3 (*.f64 (sin.f64 y) (*.f64 t z)) (cos.f64 y))) (*.f64 a (/.f64 -1/3 b)))
20.6b
(fma.f64 2 (*.f64 (sqrt.f64 x) (-.f64 (*.f64 (cos.f64 (*.f64 z (*.f64 t -1/3))) (cos.f64 y)) (*.f64 (sin.f64 (*.f64 z (*.f64 t -1/3))) (sin.f64 y)))) (*.f64 a (/.f64 -1/3 b)))
16.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (*.f64 a (/.f64 -1/3 b)))
24.9b
(fma.f64 2 (sqrt.f64 (*.f64 x (pow.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) 2))) (*.f64 a (/.f64 -1/3 b)))
54.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (exp.f64 (log.f64 (*.f64 t -1/3))) y))) (*.f64 a (/.f64 -1/3 b)))
26.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (sqrt.f64 (*.f64 (*.f64 t t) 1/9)) y))) (*.f64 a (/.f64 -1/3 b)))
21.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (pow.f64 (cbrt.f64 (*.f64 t -1/3)) 3) y))) (*.f64 a (/.f64 -1/3 b)))
Compiler

Compiled 4420 to 2904 computations (34.3% saved)

localize11.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (*.f64 a (/.f64 -1/3 b)))
0.2b
(*.f64 (sqrt.f64 x) (cos.f64 y))
0.2b
(*.f64 a (/.f64 -1/3 b))
0.3b
(/.f64 -1/3 b)

series46.0ms (0.4%)

Counts
3 → 73
Calls

3 calls:

31.0ms
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (*.f64 a (/.f64 -1/3 b)))
9.0ms
(*.f64 (sqrt.f64 x) (cos.f64 y))
6.0ms
(*.f64 a (/.f64 -1/3 b))

rewrite54.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
604×log-prod_binary64
240×prod-diff_binary64
235×expm1-udef_binary64
235×log1p-udef_binary64
211×log-pow_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01333
126733
2315133
Stop Event
node limit
Counts
3 → 74
Calls

3 calls:

52.0ms
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (*.f64 a (/.f64 -1/3 b)))
52.0ms
(*.f64 (sqrt.f64 x) (cos.f64 y))
52.0ms
(*.f64 a (/.f64 -1/3 b))

simplify49.0ms (0.5%)

Algorithm
egg-herbie
Rules
644×cancel-sign-sub-inv_binary64
503×fma-neg_binary64
426×sub-neg_binary64
200×*-commutative_binary64
173×fma-def_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0481026
1137960
2406934
31435925
44226925
Stop Event
node limit
Counts
147 → 97

prune214.0ms (2%)

Pruning

33 alts after pruning (33 fresh and 0 done)

PrunedKeptTotal
New10418122
Fresh81523
Picked101
Done000
Total11333146
Error
13.4b
Counts
146 → 33
Alt Table
StatusErrorProgram
44.5b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (pow.f64 (pow.f64 (*.f64 t -1/3) 3) 1/3) y))) (*.f64 a (/.f64 -1/3 b)))
21.7b
(fma.f64 2 (*.f64 (sqrt.f64 x) (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))) (cbrt.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))))) (log.f64 (cbrt.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))) (*.f64 a (/.f64 -1/3 b)))
38.9b
(fma.f64 2 (*.f64 (sqrt.f64 x) (+.f64 (*.f64 (cos.f64 (exp.f64 (log1p.f64 (fma.f64 z (*.f64 t -1/3) y)))) (cos.f64 1)) (*.f64 (sin.f64 (exp.f64 (log1p.f64 (fma.f64 z (*.f64 t -1/3) y)))) (sin.f64 1)))) (*.f64 a (/.f64 -1/3 b)))
16.2b
(fma.f64 -1/3 (/.f64 a b) (*.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y))))
31.1b
(fma.f64 2 (exp.f64 (log.f64 (*.f64 (sqrt.f64 x) (cos.f64 y)))) (*.f64 a (/.f64 -1/3 b)))
21.5b
(fma.f64 2 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x))) 3) (*.f64 a (/.f64 -1/3 b)))
21.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (log1p.f64 (expm1.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))) (*.f64 a (/.f64 -1/3 b)))
26.3b
(fma.f64 2 (cbrt.f64 (*.f64 (pow.f64 x 3/2) (pow.f64 (cos.f64 y) 3))) (*.f64 a (/.f64 -1/3 b)))
16.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (*.f64 a (*.f64 (/.f64 1 b) -1/3)))
24.9b
(fma.f64 2 (*.f64 (sqrt.f64 x) (sqrt.f64 (pow.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) 2))) (*.f64 a (/.f64 -1/3 b)))
29.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (*.f64 1/3 (*.f64 t z)))) (*.f64 a (/.f64 -1/3 b)))
37.6b
(fma.f64 2 (*.f64 (sqrt.f64 x) (+.f64 1 (*.f64 y (*.f64 y -1/2)))) (*.f64 a (/.f64 -1/3 b)))
30.2b
(fma.f64 2 (pow.f64 (sqrt.f64 (*.f64 (sqrt.f64 x) (cos.f64 y))) 2) (*.f64 a (/.f64 -1/3 b)))
21.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (pow.f64 (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))) 3)) (*.f64 a (/.f64 -1/3 b)))
35.2b
(fma.f64 2 (exp.f64 (log.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x)))) (*.f64 a (/.f64 -1/3 b)))
41.6b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (*.f64 a (exp.f64 (log.f64 (/.f64 -1/3 b)))))
16.5b
(fma.f64 2 (pow.f64 (cbrt.f64 (*.f64 (sqrt.f64 x) (cos.f64 y))) 3) (*.f64 a (/.f64 -1/3 b)))
28.2b
(fma.f64 2 (expm1.f64 (log1p.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x)))) (*.f64 a (/.f64 -1/3 b)))
26.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (fma.f64 1/3 (*.f64 (sin.f64 y) (*.f64 t z)) (cos.f64 y))) (*.f64 a (/.f64 -1/3 b)))
16.7b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (/.f64 (/.f64 (*.f64 a -1/3) (pow.f64 (cbrt.f64 b) 2)) (cbrt.f64 b)))
62.4b
(log.f64 (exp.f64 (fma.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y) (/.f64 (*.f64 a -1/3) b))))
54.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (exp.f64 (log.f64 (*.f64 t -1/3))) y))) (*.f64 a (/.f64 -1/3 b)))
16.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (/.f64 (*.f64 a -1/3) b))
16.6b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (pow.f64 (cbrt.f64 (/.f64 (*.f64 a -1/3) b)) 3))
20.6b
(fma.f64 2 (*.f64 (sqrt.f64 x) (-.f64 (*.f64 (cos.f64 (*.f64 z (*.f64 t -1/3))) (cos.f64 y)) (*.f64 (sin.f64 (*.f64 z (*.f64 t -1/3))) (sin.f64 y)))) (*.f64 a (/.f64 -1/3 b)))
16.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (/.f64 a (*.f64 b -3)))
50.8b
(pow.f64 (pow.f64 (fma.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y) (/.f64 (*.f64 a -1/3) b)) 3) 1/3)
26.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (sqrt.f64 (*.f64 (*.f64 t t) 1/9)) y))) (*.f64 a (/.f64 -1/3 b)))
16.9b
(*.f64 (cbrt.f64 (fma.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y) (/.f64 (*.f64 a -1/3) b))) (pow.f64 (cbrt.f64 (fma.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y) (/.f64 (*.f64 a -1/3) b))) 2))
23.8b
(fma.f64 (sqrt.f64 x) 2 (/.f64 -1/3 (/.f64 b a)))
26.3b
(fma.f64 2 (cbrt.f64 (pow.f64 (*.f64 (sqrt.f64 x) (cos.f64 y)) 3)) (*.f64 a (/.f64 -1/3 b)))
19.7b
(fma.f64 2 (sqrt.f64 (*.f64 x (pow.f64 (cos.f64 y) 2))) (*.f64 a (/.f64 -1/3 b)))
21.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (pow.f64 (cbrt.f64 (*.f64 t -1/3)) 3) y))) (*.f64 a (/.f64 -1/3 b)))
Compiler

Compiled 3718 to 2411 computations (35.2% saved)

localize11.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(cos.f64 y)
0.0b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (/.f64 a (*.f64 b -3)))
0.2b
(*.f64 (sqrt.f64 x) (cos.f64 y))
0.2b
(/.f64 a (*.f64 b -3))

series46.0ms (0.4%)

Counts
3 → 65
Calls

3 calls:

38.0ms
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (/.f64 a (*.f64 b -3)))
6.0ms
(/.f64 a (*.f64 b -3))
1.0ms
(cos.f64 y)

rewrite52.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
288×prod-diff_binary64
236×expm1-udef_binary64
236×log1p-udef_binary64
212×log-pow_binary64
132×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01328
126628
2327128
Stop Event
node limit
Counts
3 → 85
Calls

3 calls:

50.0ms
(cos.f64 y)
50.0ms
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (/.f64 a (*.f64 b -3)))
50.0ms
(/.f64 a (*.f64 b -3))

simplify32.0ms (0.3%)

Algorithm
egg-herbie
Rules
687×fma-def_binary64
536×associate-*l*_binary64
489×cancel-sign-sub-inv_binary64
421×associate-*r*_binary64
411×fma-neg_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
049928
1133861
2365845
31230836
Stop Event
node limit
Counts
150 → 104

prune221.0ms (2.1%)

Pruning

31 alts after pruning (31 fresh and 0 done)

PrunedKeptTotal
New1247131
Fresh82432
Picked101
Done000
Total13331164
Error
13.3b
Counts
164 → 31
Alt Table
StatusErrorProgram
44.5b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (pow.f64 (pow.f64 (*.f64 t -1/3) 3) 1/3) y))) (*.f64 a (/.f64 -1/3 b)))
21.7b
(fma.f64 2 (*.f64 (sqrt.f64 x) (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))) (cbrt.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))))) (log.f64 (cbrt.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))) (*.f64 a (/.f64 -1/3 b)))
16.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (log1p.f64 (expm1.f64 (cos.f64 y)))) (/.f64 a (*.f64 b -3)))
38.9b
(fma.f64 2 (*.f64 (sqrt.f64 x) (+.f64 (*.f64 (cos.f64 (exp.f64 (log1p.f64 (fma.f64 z (*.f64 t -1/3) y)))) (cos.f64 1)) (*.f64 (sin.f64 (exp.f64 (log1p.f64 (fma.f64 z (*.f64 t -1/3) y)))) (sin.f64 1)))) (*.f64 a (/.f64 -1/3 b)))
16.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cbrt.f64 (pow.f64 (cos.f64 y) 3))) (/.f64 a (*.f64 b -3)))
16.2b
(fma.f64 -1/3 (/.f64 a b) (*.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y))))
31.1b
(fma.f64 2 (exp.f64 (log.f64 (*.f64 (sqrt.f64 x) (cos.f64 y)))) (*.f64 a (/.f64 -1/3 b)))
21.5b
(fma.f64 2 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x))) 3) (*.f64 a (/.f64 -1/3 b)))
24.9b
(fma.f64 2 (*.f64 (sqrt.f64 x) (sqrt.f64 (pow.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) 2))) (*.f64 a (/.f64 -1/3 b)))
29.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (*.f64 1/3 (*.f64 t z)))) (*.f64 a (/.f64 -1/3 b)))
19.7b
(fma.f64 2 (sqrt.f64 (*.f64 x (pow.f64 (cos.f64 y) 2))) (*.f64 a (/.f64 -1/3 b)))
33.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (+.f64 (*.f64 (cos.f64 (exp.f64 (log1p.f64 y))) (cos.f64 1)) (*.f64 (sin.f64 (exp.f64 (log1p.f64 y))) (sin.f64 1)))) (/.f64 a (*.f64 b -3)))
30.2b
(fma.f64 2 (pow.f64 (sqrt.f64 (*.f64 (sqrt.f64 x) (cos.f64 y))) 2) (*.f64 a (/.f64 -1/3 b)))
35.2b
(fma.f64 2 (exp.f64 (log.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x)))) (*.f64 a (/.f64 -1/3 b)))
41.6b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (*.f64 a (exp.f64 (log.f64 (/.f64 -1/3 b)))))
16.5b
(fma.f64 2 (pow.f64 (cbrt.f64 (*.f64 (sqrt.f64 x) (cos.f64 y))) 3) (*.f64 a (/.f64 -1/3 b)))
28.2b
(fma.f64 2 (expm1.f64 (log1p.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x)))) (*.f64 a (/.f64 -1/3 b)))
26.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (fma.f64 1/3 (*.f64 (sin.f64 y) (*.f64 t z)) (cos.f64 y))) (*.f64 a (/.f64 -1/3 b)))
16.7b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (/.f64 (/.f64 (*.f64 a -1/3) (pow.f64 (cbrt.f64 b) 2)) (cbrt.f64 b)))
62.4b
(log.f64 (exp.f64 (fma.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y) (/.f64 (*.f64 a -1/3) b))))
54.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (exp.f64 (log.f64 (*.f64 t -1/3))) y))) (*.f64 a (/.f64 -1/3 b)))
16.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (/.f64 (*.f64 a -1/3) b))
20.6b
(fma.f64 2 (*.f64 (sqrt.f64 x) (-.f64 (*.f64 (cos.f64 (*.f64 z (*.f64 t -1/3))) (cos.f64 y)) (*.f64 (sin.f64 (*.f64 z (*.f64 t -1/3))) (sin.f64 y)))) (*.f64 a (/.f64 -1/3 b)))
50.8b
(pow.f64 (pow.f64 (fma.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y) (/.f64 (*.f64 a -1/3) b)) 3) 1/3)
26.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (sqrt.f64 (*.f64 (*.f64 t t) 1/9)) y))) (*.f64 a (/.f64 -1/3 b)))
23.7b
(fma.f64 2 (sqrt.f64 x) (/.f64 a (*.f64 b -3)))
16.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (pow.f64 (*.f64 -3 (/.f64 b a)) -1))
16.9b
(*.f64 (cbrt.f64 (fma.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y) (/.f64 (*.f64 a -1/3) b))) (pow.f64 (cbrt.f64 (fma.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y) (/.f64 (*.f64 a -1/3) b))) 2))
37.6b
(fma.f64 2 (*.f64 (sqrt.f64 x) (fma.f64 y (*.f64 y -1/2) 1)) (/.f64 a (*.f64 b -3)))
16.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (pow.f64 (cbrt.f64 (cos.f64 y)) 3)) (/.f64 a (*.f64 b -3)))
21.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (pow.f64 (cbrt.f64 (*.f64 t -1/3)) 3) y))) (*.f64 a (/.f64 -1/3 b)))
Compiler

Compiled 3802 to 2444 computations (35.7% saved)

localize15.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (sqrt.f64 x) (log1p.f64 (expm1.f64 (cos.f64 y))))
0.2b
(/.f64 a (*.f64 b -3))
0.2b
(log1p.f64 (expm1.f64 (cos.f64 y)))
0.6b
(expm1.f64 (cos.f64 y))

series15.0ms (0.1%)

Counts
3 → 36
Calls

3 calls:

11.0ms
(*.f64 (sqrt.f64 x) (log1p.f64 (expm1.f64 (cos.f64 y))))
3.0ms
(expm1.f64 (cos.f64 y))
1.0ms
(log1p.f64 (expm1.f64 (cos.f64 y)))

rewrite39.0ms (0.4%)

Algorithm
batch-egg-rewrite
Rules
567×expm1-log1p-u_binary64
566×log1p-expm1-u_binary64
317×log-prod_binary64
169×pow2_binary64
119×pow1/3_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0816
113916
2158216
Stop Event
node limit
Counts
3 → 69
Calls

3 calls:

38.0ms
(*.f64 (sqrt.f64 x) (log1p.f64 (expm1.f64 (cos.f64 y))))
38.0ms
(log1p.f64 (expm1.f64 (cos.f64 y)))
38.0ms
(expm1.f64 (cos.f64 y))

simplify35.0ms (0.3%)

Algorithm
egg-herbie
Rules
571×fma-neg_binary64
476×sub-neg_binary64
243×*-commutative_binary64
181×associate-+l-_binary64
174×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
054362
1151345
2440320
31689312
44204312
Stop Event
node limit
Counts
105 → 93

prune248.0ms (2.3%)

Pruning

35 alts after pruning (35 fresh and 0 done)

PrunedKeptTotal
New1285133
Fresh03030
Picked101
Done000
Total12935164
Error
13.3b
Counts
164 → 35
Alt Table
StatusErrorProgram
44.5b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (pow.f64 (pow.f64 (*.f64 t -1/3) 3) 1/3) y))) (*.f64 a (/.f64 -1/3 b)))
21.7b
(fma.f64 2 (*.f64 (sqrt.f64 x) (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))) (cbrt.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))))) (log.f64 (cbrt.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))) (*.f64 a (/.f64 -1/3 b)))
16.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (log1p.f64 (cbrt.f64 (pow.f64 (expm1.f64 (cos.f64 y)) 3)))) (/.f64 a (*.f64 b -3)))
38.9b
(fma.f64 2 (*.f64 (sqrt.f64 x) (+.f64 (*.f64 (cos.f64 (exp.f64 (log1p.f64 (fma.f64 z (*.f64 t -1/3) y)))) (cos.f64 1)) (*.f64 (sin.f64 (exp.f64 (log1p.f64 (fma.f64 z (*.f64 t -1/3) y)))) (sin.f64 1)))) (*.f64 a (/.f64 -1/3 b)))
16.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cbrt.f64 (pow.f64 (cos.f64 y) 3))) (/.f64 a (*.f64 b -3)))
16.2b
(fma.f64 -1/3 (/.f64 a b) (*.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y))))
31.1b
(fma.f64 2 (exp.f64 (log.f64 (*.f64 (sqrt.f64 x) (cos.f64 y)))) (*.f64 a (/.f64 -1/3 b)))
21.5b
(fma.f64 2 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x))) 3) (*.f64 a (/.f64 -1/3 b)))
19.7b
(fma.f64 2 (*.f64 (sqrt.f64 x) (log1p.f64 (sqrt.f64 (pow.f64 (expm1.f64 (cos.f64 y)) 2)))) (/.f64 a (*.f64 b -3)))
24.9b
(fma.f64 2 (*.f64 (sqrt.f64 x) (sqrt.f64 (pow.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) 2))) (*.f64 a (/.f64 -1/3 b)))
29.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (*.f64 1/3 (*.f64 t z)))) (*.f64 a (/.f64 -1/3 b)))
19.7b
(fma.f64 2 (sqrt.f64 (*.f64 x (pow.f64 (cos.f64 y) 2))) (*.f64 a (/.f64 -1/3 b)))
33.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (+.f64 (*.f64 (cos.f64 (exp.f64 (log1p.f64 y))) (cos.f64 1)) (*.f64 (sin.f64 (exp.f64 (log1p.f64 y))) (sin.f64 1)))) (/.f64 a (*.f64 b -3)))
16.5b
(fma.f64 2 (*.f64 (sqrt.f64 x) (log1p.f64 (*.f64 (cbrt.f64 (expm1.f64 (cos.f64 y))) (pow.f64 (cbrt.f64 (expm1.f64 (cos.f64 y))) 2)))) (/.f64 a (*.f64 b -3)))
30.2b
(fma.f64 2 (pow.f64 (sqrt.f64 (*.f64 (sqrt.f64 x) (cos.f64 y))) 2) (*.f64 a (/.f64 -1/3 b)))
35.2b
(fma.f64 2 (exp.f64 (log.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x)))) (*.f64 a (/.f64 -1/3 b)))
16.4b
(fma.f64 2 (*.f64 (sqrt.f64 x) (log1p.f64 (+.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (expm1.f64 (cos.f64 y)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (expm1.f64 (cos.f64 y)))))))) (/.f64 a (*.f64 b -3)))
41.6b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (*.f64 a (exp.f64 (log.f64 (/.f64 -1/3 b)))))
16.5b
(fma.f64 2 (pow.f64 (cbrt.f64 (*.f64 (sqrt.f64 x) (cos.f64 y))) 3) (*.f64 a (/.f64 -1/3 b)))
28.2b
(fma.f64 2 (expm1.f64 (log1p.f64 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x)))) (*.f64 a (/.f64 -1/3 b)))
26.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (fma.f64 1/3 (*.f64 (sin.f64 y) (*.f64 t z)) (cos.f64 y))) (*.f64 a (/.f64 -1/3 b)))
16.7b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (/.f64 (/.f64 (*.f64 a -1/3) (pow.f64 (cbrt.f64 b) 2)) (cbrt.f64 b)))
62.4b
(log.f64 (exp.f64 (fma.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y) (/.f64 (*.f64 a -1/3) b))))
54.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (exp.f64 (log.f64 (*.f64 t -1/3))) y))) (*.f64 a (/.f64 -1/3 b)))
16.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (/.f64 (*.f64 a -1/3) b))
20.6b
(fma.f64 2 (*.f64 (sqrt.f64 x) (-.f64 (*.f64 (cos.f64 (*.f64 z (*.f64 t -1/3))) (cos.f64 y)) (*.f64 (sin.f64 (*.f64 z (*.f64 t -1/3))) (sin.f64 y)))) (*.f64 a (/.f64 -1/3 b)))
50.8b
(pow.f64 (pow.f64 (fma.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y) (/.f64 (*.f64 a -1/3) b)) 3) 1/3)
26.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (sqrt.f64 (*.f64 (*.f64 t t) 1/9)) y))) (*.f64 a (/.f64 -1/3 b)))
23.7b
(fma.f64 2 (sqrt.f64 x) (/.f64 a (*.f64 b -3)))
16.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)) (pow.f64 (*.f64 -3 (/.f64 b a)) -1))
16.9b
(*.f64 (cbrt.f64 (fma.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y) (/.f64 (*.f64 a -1/3) b))) (pow.f64 (cbrt.f64 (fma.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y) (/.f64 (*.f64 a -1/3) b))) 2))
21.2b
(fma.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 (fma.f64 z (pow.f64 (cbrt.f64 (*.f64 t -1/3)) 3) y))) (*.f64 a (/.f64 -1/3 b)))
16.7b
(fma.f64 2 (*.f64 (sqrt.f64 x) (log1p.f64 (fma.f64 (pow.f64 (cbrt.f64 (exp.f64 (cos.f64 y))) 2) (cbrt.f64 (exp.f64 (cos.f64 y))) -1))) (/.f64 a (*.f64 b -3)))
37.6b
(fma.f64 2 (*.f64 (sqrt.f64 x) (fma.f64 y (*.f64 y -1/2) 1)) (/.f64 a (*.f64 b -3)))
16.3b
(fma.f64 2 (*.f64 (sqrt.f64 x) (pow.f64 (cbrt.f64 (cos.f64 y)) 3)) (/.f64 a (*.f64 b -3)))
Compiler

Compiled 3365 to 2023 computations (39.9% saved)

regimes2.9s (27.4%)

Accuracy

Total 1.7b remaining (10.3%)

Threshold costs 0b (0%)

Counts
115 → 3
Compiler

Compiled 50139 to 38473 computations (23.3% saved)

bsearch4.0ms (0%)

Compiler

Compiled 9 to 7 computations (22.2% saved)

simplify5.0ms (0.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
045113
160113
272113
378113
482113
583113
Stop Event
saturated

end738.0ms (6.9%)

Compiler

Compiled 1197 to 890 computations (25.6% saved)

Profiling

Loading profile data...