Details

Time bar (total: 11.6s)

analyze1.6s (13.5%)

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.3s (36.9%)

Symmetry

(sort z t)

Results
1.2s1622×body1024valid
955.0ms4765×body128valid
794.0ms715×body2048valid
677.0ms3580×body128invalid
404.0ms776×body512valid
150.0ms377×body256valid
3.0msbody4096valid
Compiler

Compiled 77 to 59 computations (23.4% saved)

simplify61.0ms (0.5%)

Algorithm
egg-herbie
Rules
718×fma-def_binary64
437×fma-neg_binary64
146×cancel-sign-sub-inv_binary64
110×distribute-rgt-neg-in_binary64
104×associate-/l*_binary64
Counts
1 → 2
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01929
13429
26429
311427
420925
532225
649425
764425
881025
997925
10119725
11129725
12130825
13132425
14132425
15121325

prune4.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
23.0b
Counts
3 → 2
Alt Table
StatusErrorProgram
23.2b
(-.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (-.f64 y (/.f64 (*.f64 z t) 3)))) (/.f64 a (*.f64 b 3)))
23.1b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))
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 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))
0.4b
(*.f64 t -1/3)
0.4b
(/.f64 -1/3 b)
25.6b
(cos.f64 (fma.f64 z (*.f64 t -1/3) y))

series55.0ms (0.5%)

Counts
4 → 84
Calls

4 calls:

42.0ms
(*.f64 (*.f64 2 (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 -1/3 b)
1.0ms
(*.f64 t -1/3)

rewrite13.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
17×add-sqr-sqrt_binary64
15×*-un-lft-identity_binary64
15×add-cube-cbrt_binary64
13×add-cbrt-cube_binary64
13×add-exp-log_binary64
Counts
4 → 79
Calls

4 calls:

5.0ms
(*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))
3.0ms
(*.f64 t -1/3)
2.0ms
(/.f64 -1/3 b)
1.0ms
(cos.f64 (fma.f64 z (*.f64 t -1/3) y))

simplify143.0ms (1.2%)

Algorithm
egg-herbie
Rules
786×fma-neg_binary64
414×fma-def_binary64
405×distribute-rgt-neg-in_binary64
387×cancel-sign-sub-inv_binary64
371×distribute-lft-neg-in_binary64
Counts
163 → 134
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
02132679
15212489
215812422
330432410
446872408
549812408
649382408

prune229.0ms (2%)

Pruning

23 alts after pruning (23 fresh and 0 done)

PrunedKeptTotal
New11222134
Fresh011
Picked101
Done000
Total11323136
Error
14.8b
Counts
136 → 23
Alt Table
StatusErrorProgram
23.1b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 (*.f64 t (*.f64 (cbrt.f64 -1/3) (cbrt.f64 -1/3))) (cbrt.f64 -1/3)) y))))
32.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (*.f64 1/3 (*.f64 t z)))))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 (*.f64 (cbrt.f64 t) (cbrt.f64 t)) (*.f64 (cbrt.f64 t) -1/3)) y))))
23.4b
(fma.f64 a (*.f64 (*.f64 (cbrt.f64 (/.f64 -1/3 b)) (cbrt.f64 (/.f64 -1/3 b))) (cbrt.f64 (/.f64 -1/3 b))) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))
30.1b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (fma.f64 (*.f64 (cos.f64 y) (*.f64 (*.f64 t z) (*.f64 t z))) -1/18 (fma.f64 1/3 (*.f64 (sin.f64 y) (*.f64 t z)) (cos.f64 y)))))
23.2b
(-.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (-.f64 y (/.f64 (*.f64 z t) 3)))) (/.f64 a (*.f64 b 3)))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cbrt.f64 (pow.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) 3))))
23.3b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (*.f64 (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))) (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))) (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (log.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
23.5b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 (cbrt.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))) (cbrt.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))) (cbrt.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
22.4b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (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)))))
29.6b
(fma.f64 a (/.f64 -1/3 b) (cbrt.f64 (*.f64 (*.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
23.2b
(fma.f64 a (/.f64 1 (/.f64 b -1/3)) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (expm1.f64 (log1p.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
50.0b
(fma.f64 a (/.f64 -1/3 b) (log.f64 (exp.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
41.0b
(fma.f64 a (*.f64 (/.f64 1 (sqrt.f64 b)) (/.f64 -1/3 (sqrt.f64 b))) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))
26.0b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (sqrt.f64 x) (fma.f64 (cos.f64 y) 2 (*.f64 (*.f64 (sin.f64 y) (*.f64 t z)) 2/3))))
37.0b
(fma.f64 a (/.f64 -1/3 b) (exp.f64 (log.f64 (*.f64 2 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x))))))
35.0b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (fma.f64 y (sin.f64 (*.f64 1/3 (*.f64 t z))) (cos.f64 (*.f64 1/3 (*.f64 t z))))))
23.0b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 (*.f64 (cbrt.f64 (*.f64 t -1/3)) (cbrt.f64 (*.f64 t -1/3))) (cbrt.f64 (*.f64 t -1/3))) y))))
17.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))
36.0b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (exp.f64 (log.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
22.4b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (-.f64 (*.f64 (cos.f64 y) (cos.f64 (*.f64 1/3 (*.f64 t z)))) (*.f64 (sin.f64 y) (sin.f64 (*.f64 z (*.f64 t -1/3)))))))
Compiler

Compiled 4834 to 3080 computations (36.3% saved)

localize10.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))
0.1b
(*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y))
0.4b
(/.f64 -1/3 b)

series54.0ms (0.5%)

Counts
2 → 49
Calls

2 calls:

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

rewrite7.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
add-cbrt-cube_binary64
add-exp-log_binary64
pow1_binary64
associate-*r*_binary64
*-un-lft-identity_binary64
Counts
2 → 30
Calls

2 calls:

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

simplify88.0ms (0.8%)

Algorithm
egg-herbie
Rules
640×fma-def_binary64
549×cancel-sign-sub-inv_binary64
370×sub-neg_binary64
327×fma-neg_binary64
256×*-commutative_binary64
Counts
79 → 65
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0901413
12211267
27101241
314131237
432351237
545001237
649191237

prune241.0ms (2.1%)

Pruning

25 alts after pruning (25 fresh and 0 done)

PrunedKeptTotal
New881098
Fresh71522
Picked101
Done000
Total9625121
Error
14.5b
Counts
121 → 25
Alt Table
StatusErrorProgram
23.1b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 (*.f64 t (*.f64 (cbrt.f64 -1/3) (cbrt.f64 -1/3))) (cbrt.f64 -1/3)) y))))
32.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (*.f64 1/3 (*.f64 t z)))))
17.9b
(*.f64 (*.f64 (cbrt.f64 (fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))) (cbrt.f64 (fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y))))) (cbrt.f64 (fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 (*.f64 (cbrt.f64 t) (cbrt.f64 t)) (*.f64 (cbrt.f64 t) -1/3)) y))))
30.0b
(fma.f64 a (/.f64 -1/3 b) (exp.f64 (log.f64 (*.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y))))))
23.4b
(fma.f64 a (*.f64 (*.f64 (cbrt.f64 (/.f64 -1/3 b)) (cbrt.f64 (/.f64 -1/3 b))) (cbrt.f64 (/.f64 -1/3 b))) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))
23.0b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 (*.f64 (cbrt.f64 (*.f64 t -1/3)) (cbrt.f64 (*.f64 t -1/3))) (cbrt.f64 (*.f64 t -1/3))) y))))
37.0b
(*.f64 -1/3 (/.f64 a b))
23.2b
(-.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (-.f64 y (/.f64 (*.f64 z t) 3)))) (/.f64 a (*.f64 b 3)))
61.8b
(log.f64 (exp.f64 (fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cbrt.f64 (pow.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) 3))))
17.6b
(fma.f64 a (*.f64 (/.f64 1 (*.f64 (cbrt.f64 b) (cbrt.f64 b))) (/.f64 -1/3 (cbrt.f64 b))) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))
36.0b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (exp.f64 (log.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
17.2b
(fma.f64 a (/.f64 1 (/.f64 b -1/3)) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))
23.3b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (*.f64 (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))) (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))) (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))))
26.0b
(fma.f64 a (/.f64 -1/3 b) (*.f64 2 (sqrt.f64 x)))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (log.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
17.2b
(fma.f64 a (*.f64 -1/3 (/.f64 1 b)) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))
33.4b
(expm1.f64 (log1p.f64 (fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))))
22.4b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (-.f64 (*.f64 (cos.f64 y) (cos.f64 (*.f64 1/3 (*.f64 t z)))) (*.f64 (sin.f64 y) (sin.f64 (*.f64 z (*.f64 t -1/3)))))))
23.5b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 (cbrt.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))) (cbrt.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))) (cbrt.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
22.4b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (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)))))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (expm1.f64 (log1p.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
23.8b
(fma.f64 a (/.f64 -1/3 b) (cbrt.f64 (*.f64 (*.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (*.f64 2 (sqrt.f64 x))) (*.f64 2 (sqrt.f64 x))) (*.f64 (*.f64 (cos.f64 y) (cos.f64 y)) (cos.f64 y)))))
37.0b
(fma.f64 a (/.f64 -1/3 b) (exp.f64 (log.f64 (*.f64 2 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x))))))
Compiler

Compiled 3148 to 1989 computations (36.8% saved)

localize10.0ms (0.1%)

Local error

Found 4 expressions with local error:

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

series44.0ms (0.4%)

Counts
3 → 61
Calls

3 calls:

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

rewrite14.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
84×times-frac_binary64
53×*-un-lft-identity_binary64
53×add-sqr-sqrt_binary64
53×add-cube-cbrt_binary64
16×associate-/r*_binary64
Counts
3 → 117
Calls

3 calls:

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

simplify115.0ms (1%)

Algorithm
egg-herbie
Rules
652×fma-def_binary64
381×cancel-sign-sub-inv_binary64
328×fma-neg_binary64
241×times-frac_binary64
223×unsub-neg_binary64
Counts
178 → 184
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01472421
12772076
26232035
315992028
444832028
549852028

prune358.0ms (3.1%)

Pruning

24 alts after pruning (24 fresh and 0 done)

PrunedKeptTotal
New2163219
Fresh32124
Picked101
Done000
Total22024244
Error
14.5b
Counts
244 → 24
Alt Table
StatusErrorProgram
23.1b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 (*.f64 t (*.f64 (cbrt.f64 -1/3) (cbrt.f64 -1/3))) (cbrt.f64 -1/3)) y))))
32.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (*.f64 1/3 (*.f64 t z)))))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 (*.f64 (cbrt.f64 t) (cbrt.f64 t)) (*.f64 (cbrt.f64 t) -1/3)) y))))
23.4b
(fma.f64 a (*.f64 (*.f64 (cbrt.f64 (/.f64 -1/3 b)) (cbrt.f64 (/.f64 -1/3 b))) (cbrt.f64 (/.f64 -1/3 b))) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))
17.2b
(fma.f64 a (/.f64 1 (*.f64 -3 b)) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))
23.0b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 (*.f64 (cbrt.f64 (*.f64 t -1/3)) (cbrt.f64 (*.f64 t -1/3))) (cbrt.f64 (*.f64 t -1/3))) y))))
37.0b
(*.f64 -1/3 (/.f64 a b))
23.2b
(-.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (-.f64 y (/.f64 (*.f64 z t) 3)))) (/.f64 a (*.f64 b 3)))
61.8b
(log.f64 (exp.f64 (fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cbrt.f64 (pow.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) 3))))
26.0b
(fma.f64 a (/.f64 -1/3 b) (*.f64 2 (sqrt.f64 x)))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (log.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
23.3b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (*.f64 (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))) (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))) (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))))
17.2b
(fma.f64 a (*.f64 -1/3 (/.f64 1 b)) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))
33.4b
(expm1.f64 (log1p.f64 (fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))))
22.4b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (-.f64 (*.f64 (cos.f64 y) (cos.f64 (*.f64 1/3 (*.f64 t z)))) (*.f64 (sin.f64 y) (sin.f64 (*.f64 z (*.f64 t -1/3)))))))
23.5b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 (cbrt.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))) (cbrt.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))) (cbrt.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
22.4b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (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)))))
37.0b
(fma.f64 a (/.f64 -1/3 b) (exp.f64 (log.f64 (*.f64 2 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x))))))
29.1b
(fma.f64 a (/.f64 1 (/.f64 b -1/3)) (*.f64 (sqrt.f64 (*.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)))) (sqrt.f64 (*.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y))))))
42.4b
(*.f64 2 (*.f64 (cos.f64 y) (sqrt.f64 x)))
36.0b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (exp.f64 (log.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (expm1.f64 (log1p.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
23.8b
(fma.f64 a (/.f64 -1/3 b) (cbrt.f64 (*.f64 (*.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (*.f64 2 (sqrt.f64 x))) (*.f64 2 (sqrt.f64 x))) (*.f64 (*.f64 (cos.f64 y) (cos.f64 y)) (cos.f64 y)))))
Compiler

Compiled 5784 to 3713 computations (35.8% saved)

localize16.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 a (/.f64 1 (*.f64 -3 b)) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))
0.1b
(*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y))
0.6b
(/.f64 1 (*.f64 -3 b))

series41.0ms (0.4%)

Counts
2 → 49
Calls

2 calls:

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

rewrite5.0ms (0%)

Algorithm
rewrite-expression-head
Rules
13×add-exp-log_binary64
add-cbrt-cube_binary64
pow1_binary64
*-un-lft-identity_binary64
add-sqr-sqrt_binary64
Counts
2 → 40
Calls

2 calls:

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

simplify79.0ms (0.7%)

Algorithm
egg-herbie
Rules
691×fma-def_binary64
533×times-frac_binary64
381×cancel-sign-sub-inv_binary64
332×fma-neg_binary64
197×associate-*l/_binary64
Counts
89 → 71
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0931182
11991055
24881043
314501036
441871036
549081036

prune175.0ms (1.5%)

Pruning

23 alts after pruning (23 fresh and 0 done)

PrunedKeptTotal
New1042106
Fresh22123
Picked101
Done000
Total10723130
Error
14.5b
Counts
130 → 23
Alt Table
StatusErrorProgram
23.1b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 (*.f64 t (*.f64 (cbrt.f64 -1/3) (cbrt.f64 -1/3))) (cbrt.f64 -1/3)) y))))
32.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (*.f64 1/3 (*.f64 t z)))))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 (*.f64 (cbrt.f64 t) (cbrt.f64 t)) (*.f64 (cbrt.f64 t) -1/3)) y))))
23.4b
(fma.f64 a (*.f64 (*.f64 (cbrt.f64 (/.f64 -1/3 b)) (cbrt.f64 (/.f64 -1/3 b))) (cbrt.f64 (/.f64 -1/3 b))) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))
23.0b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 (*.f64 (cbrt.f64 (*.f64 t -1/3)) (cbrt.f64 (*.f64 t -1/3))) (cbrt.f64 (*.f64 t -1/3))) y))))
37.0b
(*.f64 -1/3 (/.f64 a b))
23.2b
(-.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (-.f64 y (/.f64 (*.f64 z t) 3)))) (/.f64 a (*.f64 b 3)))
61.8b
(log.f64 (exp.f64 (fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cbrt.f64 (pow.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) 3))))
23.3b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (*.f64 (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))) (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))) (cbrt.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (log.f64 (exp.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
17.2b
(fma.f64 a (*.f64 -1/3 (/.f64 1 b)) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))
33.4b
(expm1.f64 (log1p.f64 (fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 y)))))
22.4b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (-.f64 (*.f64 (cos.f64 y) (cos.f64 (*.f64 1/3 (*.f64 t z)))) (*.f64 (sin.f64 y) (sin.f64 (*.f64 z (*.f64 t -1/3)))))))
23.5b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 (cbrt.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y)))) (cbrt.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))) (cbrt.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
22.4b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (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)))))
17.5b
(fma.f64 a (/.f64 1 (*.f64 -3 b)) (*.f64 (*.f64 (cbrt.f64 (*.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y)))) (cbrt.f64 (*.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y))))) (cbrt.f64 (*.f64 2 (*.f64 (sqrt.f64 x) (cos.f64 y))))))
42.4b
(*.f64 2 (*.f64 (cos.f64 y) (sqrt.f64 x)))
36.0b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (exp.f64 (log.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
26.0b
(fma.f64 a (/.f64 1 (*.f64 -3 b)) (*.f64 2 (sqrt.f64 x)))
23.2b
(fma.f64 a (/.f64 -1/3 b) (*.f64 (*.f64 2 (sqrt.f64 x)) (expm1.f64 (log1p.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y))))))
23.8b
(fma.f64 a (/.f64 -1/3 b) (cbrt.f64 (*.f64 (*.f64 (*.f64 (*.f64 2 (sqrt.f64 x)) (*.f64 2 (sqrt.f64 x))) (*.f64 2 (sqrt.f64 x))) (*.f64 (*.f64 (cos.f64 y) (cos.f64 y)) (cos.f64 y)))))
37.0b
(fma.f64 a (/.f64 -1/3 b) (exp.f64 (log.f64 (*.f64 2 (*.f64 (cos.f64 (fma.f64 z (*.f64 t -1/3) y)) (sqrt.f64 x))))))
Compiler

Compiled 2631 to 1645 computations (37.5% saved)

regimes3.4s (29%)

Accuracy

Total 1.6b remaining (10.2%)

Threshold costs 0b (0%)

Counts
124 → 3
Compiler

Compiled 60586 to 44895 computations (25.9% saved)

bsearch7.0ms (0.1%)

Compiler

Compiled 9 to 7 computations (22.2% saved)

simplify5.0ms (0%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
03792
15292
26192
36792
47192
57292
67192

end607.0ms (5.2%)

Compiler

Compiled 908 to 656 computations (27.8% saved)

Profiling

Loading profile data...