Details

Time bar (total: 8.0s)

analyze1.2s (15.1%)

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
0%99.9%0.1%6
18.7%81.2%0.1%7
32.8%67.1%0.1%8
38.2%61.7%0.1%9
41%58.9%0.1%10
43.9%56%0.1%11
45.4%54.5%0.1%12
46.9%53%0.1%13
47.6%52.3%0.1%14
Compiler

Compiled 16 to 12 computations (25% saved)

sample3.9s (48.7%)

Results
1.4s1207×body2048valid
1.1s1368×body1024valid
717.0ms4294×body128valid
427.0ms863×body512valid
172.0ms516×body256valid
30.0msbody4096valid
Compiler

Compiled 47 to 35 computations (25.5% saved)

simplify11.0ms (0.1%)

Algorithm
egg-herbie
Rules
associate-/r*_binary64
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0920
11220
21420
Stop Event
saturated
Counts
1 → 1

prune2.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New011
Fresh011
Picked000
Done000
Total022
Error
35.6b
Counts
2 → 1
Alt Table
StatusErrorProgram
35.6b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (sin.f64 (/.f64 x (*.f64 y 2))))
Compiler

Compiled 45 to 33 computations (26.7% saved)

localize7.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
7.2b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (sin.f64 (/.f64 x (*.f64 y 2))))
27.9b
(sin.f64 (/.f64 x (*.f64 y 2)))
28.4b
(tan.f64 (/.f64 x (*.f64 y 2)))

series74.0ms (0.9%)

Counts
3 → 72
Calls

3 calls:

35.0ms
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (sin.f64 (/.f64 x (*.f64 y 2))))
32.0ms
(tan.f64 (/.f64 x (*.f64 y 2)))
6.0ms
(sin.f64 (/.f64 x (*.f64 y 2)))

rewrite56.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
621×prod-diff_binary64
522×log-prod_binary64
180×expm1-udef_binary64
180×log1p-udef_binary64
159×log-pow_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0938
119338
2264238
Stop Event
node limit
Counts
3 → 87
Calls

3 calls:

55.0ms
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (sin.f64 (/.f64 x (*.f64 y 2))))
55.0ms
(sin.f64 (/.f64 x (*.f64 y 2)))
55.0ms
(tan.f64 (/.f64 x (*.f64 y 2)))

simplify49.0ms (0.6%)

Algorithm
egg-herbie
Rules
363×associate-/r/_binary64
360×cancel-sign-sub-inv_binary64
359×times-frac_binary64
339×associate-/l/_binary64
215×fma-neg_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0701410
11871392
25441326
326621299
Stop Event
node limit
Counts
159 → 110

prune219.0ms (2.7%)

Pruning

18 alts after pruning (18 fresh and 0 done)

PrunedKeptTotal
New9218110
Fresh000
Picked101
Done000
Total9318111
Error
24.9b
Counts
111 → 18
Alt Table
StatusErrorProgram
35.7b
(log1p.f64 (expm1.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))))
53.9b
(/.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) 2)) (sin.f64 (/.f64 x (*.f64 y 2))))
27.6b
1
35.6b
(pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 3)
37.7b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (fma.f64 (pow.f64 (/.f64 x y) 3) -1/48 (*.f64 1/2 (/.f64 x y))))
36.2b
(*.f64 (/.f64 1 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))) 2)) (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))
35.6b
(*.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 2))
36.3b
(/.f64 (*.f64 (cbrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (pow.f64 (cbrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) 2)) (sin.f64 (/.f64 x (*.f64 y 2))))
59.3b
(/.f64 (log.f64 (+.f64 1 (expm1.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))))) (sin.f64 (/.f64 x (*.f64 y 2))))
59.4b
(/.f64 (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)))) (cbrt.f64 (exp.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)))))) (log.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)))))) (sin.f64 (/.f64 x (*.f64 y 2))))
30.8b
(fma.f64 (/.f64 1/8 y) (/.f64 x (/.f64 y x)) 1)
54.6b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (sqrt.f64 (pow.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)) 2)))
49.3b
(*.f64 (/.f64 (sqrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))) 2)) (/.f64 (sqrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))
61.6b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (-.f64 (*.f64 (sin.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 x y) 1/2)))) (cos.f64 1)) (*.f64 (cos.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 x y) 1/2)))) (sin.f64 1))))
36.3b
(/.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))) 2) (/.f64 (cos.f64 (*.f64 (/.f64 x y) 1/2)) (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))))) (sin.f64 (/.f64 x (*.f64 y 2))))
60.2b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (cbrt.f64 (exp.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))) (log.f64 (cbrt.f64 (exp.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))))
37.9b
(/.f64 (*.f64 1/2 (/.f64 x y)) (sin.f64 (/.f64 x (*.f64 y 2))))
36.5b
(+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))) (cbrt.f64 (exp.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))))))
Compiler

Compiled 3175 to 2144 computations (32.5% saved)

localize0.0ms (0%)

prune30.0ms (0.4%)

Pruning

18 alts after pruning (17 fresh and 1 done)

PrunedKeptTotal
New000
Fresh01717
Picked011
Done000
Total01818
Error
24.9b
Counts
18 → 18
Alt Table
StatusErrorProgram
35.7b
(log1p.f64 (expm1.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))))
53.9b
(/.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) 2)) (sin.f64 (/.f64 x (*.f64 y 2))))
27.6b
1
35.6b
(pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 3)
37.7b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (fma.f64 (pow.f64 (/.f64 x y) 3) -1/48 (*.f64 1/2 (/.f64 x y))))
36.2b
(*.f64 (/.f64 1 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))) 2)) (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))
35.6b
(*.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 2))
36.3b
(/.f64 (*.f64 (cbrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (pow.f64 (cbrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) 2)) (sin.f64 (/.f64 x (*.f64 y 2))))
59.3b
(/.f64 (log.f64 (+.f64 1 (expm1.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))))) (sin.f64 (/.f64 x (*.f64 y 2))))
59.4b
(/.f64 (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)))) (cbrt.f64 (exp.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)))))) (log.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)))))) (sin.f64 (/.f64 x (*.f64 y 2))))
30.8b
(fma.f64 (/.f64 1/8 y) (/.f64 x (/.f64 y x)) 1)
54.6b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (sqrt.f64 (pow.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)) 2)))
49.3b
(*.f64 (/.f64 (sqrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))) 2)) (/.f64 (sqrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))
61.6b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (-.f64 (*.f64 (sin.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 x y) 1/2)))) (cos.f64 1)) (*.f64 (cos.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 x y) 1/2)))) (sin.f64 1))))
36.3b
(/.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))) 2) (/.f64 (cos.f64 (*.f64 (/.f64 x y) 1/2)) (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))))) (sin.f64 (/.f64 x (*.f64 y 2))))
60.2b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (cbrt.f64 (exp.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))) (log.f64 (cbrt.f64 (exp.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))))
37.9b
(/.f64 (*.f64 1/2 (/.f64 x y)) (sin.f64 (/.f64 x (*.f64 y 2))))
36.5b
(+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))) (cbrt.f64 (exp.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))))))
Compiler

Compiled 901 to 645 computations (28.4% saved)

localize6.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.1b
(/.f64 x (/.f64 y x))
1.5b
(fma.f64 (/.f64 1/8 y) (/.f64 x (/.f64 y x)) 1)

series24.0ms (0.3%)

Counts
2 → 48
Calls

2 calls:

15.0ms
(fma.f64 (/.f64 1/8 y) (/.f64 x (/.f64 y x)) 1)
9.0ms
(/.f64 x (/.f64 y x))

rewrite45.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
471×log-prod_binary64
242×pow2_binary64
170×pow1/3_binary64
166×expm1-udef_binary64
166×log1p-udef_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0921
119121
2252621
Stop Event
node limit
Counts
2 → 72
Calls

2 calls:

44.0ms
(/.f64 x (/.f64 y x))
44.0ms
(fma.f64 (/.f64 1/8 y) (/.f64 x (/.f64 y x)) 1)

simplify48.0ms (0.6%)

Algorithm
egg-herbie
Rules
706×associate-/l*_binary64
427×associate-/l/_binary64
423×associate-/r*_binary64
399×unswap-sqr_binary64
325×associate-*l*_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
012498
125462
251462
3146462
4762462
54776462
Stop Event
node limit
Counts
120 → 78

prune97.0ms (1.2%)

Pruning

18 alts after pruning (16 fresh and 2 done)

PrunedKeptTotal
New78078
Fresh01616
Picked011
Done011
Total781896
Error
24.9b
Counts
96 → 18
Alt Table
StatusErrorProgram
35.7b
(log1p.f64 (expm1.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))))
53.9b
(/.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) 2)) (sin.f64 (/.f64 x (*.f64 y 2))))
27.6b
1
35.6b
(pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 3)
37.7b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (fma.f64 (pow.f64 (/.f64 x y) 3) -1/48 (*.f64 1/2 (/.f64 x y))))
36.2b
(*.f64 (/.f64 1 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))) 2)) (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))
35.6b
(*.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 2))
36.3b
(/.f64 (*.f64 (cbrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (pow.f64 (cbrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) 2)) (sin.f64 (/.f64 x (*.f64 y 2))))
59.3b
(/.f64 (log.f64 (+.f64 1 (expm1.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))))) (sin.f64 (/.f64 x (*.f64 y 2))))
59.4b
(/.f64 (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)))) (cbrt.f64 (exp.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)))))) (log.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)))))) (sin.f64 (/.f64 x (*.f64 y 2))))
30.8b
(fma.f64 (/.f64 1/8 y) (/.f64 x (/.f64 y x)) 1)
54.6b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (sqrt.f64 (pow.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)) 2)))
49.3b
(*.f64 (/.f64 (sqrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))) 2)) (/.f64 (sqrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))
61.6b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (-.f64 (*.f64 (sin.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 x y) 1/2)))) (cos.f64 1)) (*.f64 (cos.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 x y) 1/2)))) (sin.f64 1))))
36.3b
(/.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))) 2) (/.f64 (cos.f64 (*.f64 (/.f64 x y) 1/2)) (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))))) (sin.f64 (/.f64 x (*.f64 y 2))))
60.2b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (cbrt.f64 (exp.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))) (log.f64 (cbrt.f64 (exp.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))))
37.9b
(/.f64 (*.f64 1/2 (/.f64 x y)) (sin.f64 (/.f64 x (*.f64 y 2))))
36.5b
(+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))) (cbrt.f64 (exp.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))))))
Compiler

Compiled 2064 to 1252 computations (39.3% saved)

localize14.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.3b
(pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 2)
7.2b
(/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))
27.9b
(sin.f64 (*.f64 (/.f64 x y) 1/2))
28.4b
(tan.f64 (*.f64 (/.f64 x y) 1/2))

series389.0ms (4.9%)

Counts
4 → 96
Calls

4 calls:

306.0ms
(pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 2)
54.0ms
(/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))
19.0ms
(tan.f64 (*.f64 (/.f64 x y) 1/2))
10.0ms
(sin.f64 (*.f64 (/.f64 x y) 1/2))

rewrite68.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
292×prod-diff_binary64
218×expm1-udef_binary64
218×log1p-udef_binary64
194×log-pow_binary64
136×log-div_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01263
125563
2318863
Stop Event
node limit
Counts
4 → 99
Calls

4 calls:

66.0ms
(pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 2)
66.0ms
(/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))
66.0ms
(sin.f64 (*.f64 (/.f64 x y) 1/2))
66.0ms
(tan.f64 (*.f64 (/.f64 x y) 1/2))

simplify57.0ms (0.7%)

Algorithm
egg-herbie
Rules
407×times-frac_binary64
383×associate-/l/_binary64
360×cancel-sign-sub-inv_binary64
215×fma-neg_binary64
204×fma-def_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0861878
12331854
26551782
330891728
Stop Event
node limit
Counts
195 → 130

prune375.0ms (4.7%)

Pruning

21 alts after pruning (20 fresh and 1 done)

PrunedKeptTotal
New21912231
Fresh7815
Picked101
Done112
Total22821249
Error
24.6b
Counts
249 → 21
Alt Table
StatusErrorProgram
53.9b
(*.f64 (cbrt.f64 (/.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) 2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 2))
59.3b
(/.f64 (log.f64 (+.f64 1 (expm1.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))))) (sin.f64 (/.f64 x (*.f64 y 2))))
35.6b
(*.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (pow.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 3)) 2))
53.9b
(/.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) 2)) (sin.f64 (/.f64 x (*.f64 y 2))))
36.5b
(*.f64 (cbrt.f64 1) (pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 2))
35.6b
(*.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (/.f64 (*.f64 (cbrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))) (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))
27.6b
1
36.2b
(*.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (pow.f64 (cbrt.f64 1) 2))
35.6b
(*.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (*.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))) 2) (*.f64 (cbrt.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))) (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))))))
37.6b
(*.f64 (cbrt.f64 (/.f64 (*.f64 1/2 (/.f64 x y)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 2))
49.3b
(*.f64 (/.f64 (sqrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))) 2)) (/.f64 (sqrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))
36.4b
(*.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (pow.f64 (cbrt.f64 (*.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) 2) (*.f64 (cbrt.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2))) (/.f64 1 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))) 2))
37.7b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (fma.f64 (pow.f64 (/.f64 x y) 3) -1/48 (*.f64 1/2 (/.f64 x y))))
36.2b
(*.f64 (/.f64 1 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2))) 2)) (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (cbrt.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))
61.5b
(*.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (-.f64 (*.f64 (sin.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 x y) 1/2)))) (cos.f64 1)) (*.f64 (cos.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 x y) 1/2)))) (sin.f64 1))))) (pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 2))
60.2b
(/.f64 (tan.f64 (/.f64 x (*.f64 y 2))) (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (cbrt.f64 (exp.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))) (log.f64 (cbrt.f64 (exp.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)))))))
59.4b
(/.f64 (+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)))) (cbrt.f64 (exp.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)))))) (log.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)))))) (sin.f64 (/.f64 x (*.f64 y 2))))
54.6b
(*.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sqrt.f64 (pow.f64 (sin.f64 (*.f64 (/.f64 x y) 1/2)) 2)))) (pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 2))
35.6b
(*.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (pow.f64 (cbrt.f64 (*.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) 4)) (*.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))) 2) (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))))) 2))
61.4b
(*.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))) (pow.f64 (cbrt.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (-.f64 (*.f64 (sin.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 x y) 1/2)))) (cos.f64 1)) (*.f64 (cos.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 x y) 1/2)))) (sin.f64 1))))) 2))
36.5b
(+.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))) (cbrt.f64 (exp.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2))))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (tan.f64 (*.f64 (/.f64 x y) 1/2)) (sin.f64 (*.f64 (/.f64 x y) 1/2)))))))
Compiler

Compiled 9731 to 6293 computations (35.3% saved)

regimes917.0ms (11.4%)

Accuracy

Total 3.1b remaining (10.6%)

Threshold costs 0b (0%)

Counts
118 → 1
Compiler

Compiled 17396 to 12253 computations (29.6% saved)

simplify2.0ms (0%)

Algorithm
egg-herbie
Rules
1-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
011
141
Stop Event
saturated

end409.0ms (5.1%)

Compiler

Compiled 765 to 535 computations (30.1% saved)

Profiling

Loading profile data...