Details

Time bar (total: 9.3s)

analyze717.0ms (7.7%)

Algorithm
search
Search
TrueOtherFalseIter
0%100%0%0
0%100%0%1
0%100%0%2
50%50%0%3
50%50%0%4
50%50%0%5
50%50%0%6
50%50%0%7
50%50%0%8
50%50%0%9
50%50%0%10
50%50%0%11
50%50%0%12
50%50%0%13
50%49.9%0%14
Compiler

Compiled 17 to 9 computations (47.1% saved)

sample1.6s (17.7%)

Results
754.0ms2082×body1024valid
477.0ms4579×body128valid
291.0ms1036×body512valid
109.0ms552×body256valid
3.0msbody2048valid
Compiler

Compiled 34 to 18 computations (47.1% saved)

preprocess34.0ms (0.4%)

Algorithm
egg-herbie
Rules
627×times-frac_binary64
563×div-sub_binary64
543×fma-def_binary64
333×fma-neg_binary64
263×distribute-rgt-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0824
11922
23122
34922
49922
516922
627922
758822
8146622
9371722
011
Stop Event
saturated
node limit
Compiler

Compiled 16 to 8 computations (50% saved)

simplify23.0ms (0.3%)

Algorithm
egg-herbie
Rules
627×times-frac_binary64
563×div-sub_binary64
543×fma-def_binary64
333×fma-neg_binary64
263×distribute-rgt-in_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0824
11922
23122
34922
49922
516922
627922
758822
8146622
9371722
Stop Event
node limit
Counts
1 → 2

prune5.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.4b
(/.f64 (-.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))) (fma.f64 (tan.f64 x) (tan.f64 x) 1))
0.4b
(/.f64 (-.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
Compiler

Compiled 92 to 45 computations (51.1% saved)

localize6.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x)))
0.2b
(/.f64 (-.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
0.2b
(-.f64 1 (*.f64 (tan.f64 x) (tan.f64 x)))
0.3b
(*.f64 (tan.f64 x) (tan.f64 x))

series85.0ms (0.9%)

Counts
4 → 48
Calls

12 calls:

28.0ms
(/.f64 (-.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
x
inf
28.0ms
(/.f64 (-.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
x
-inf
5.0ms
(-.f64 1 (*.f64 (tan.f64 x) (tan.f64 x)))
x
inf
4.0ms
(-.f64 1 (*.f64 (tan.f64 x) (tan.f64 x)))
x
-inf
4.0ms
(+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x)))
x
-inf

rewrite90.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
434×log-prod_binary64
381×prod-diff_binary64
236×egg-rr
196×fma-def_binary64
157×expm1-udef_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0844
118244
2252844
Stop Event
node limit
Counts
4 → 236

simplify36.0ms (0.4%)

Algorithm
egg-herbie
Rules
669×fma-def_binary64
515×associate-*l*_binary64
460×associate-*r*_binary64
342×cancel-sign-sub-inv_binary64
184×fma-neg_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
046868
1132864
2345858
31101856
Stop Event
node limit
Counts
284 → 269

prune635.0ms (6.8%)

Pruning

14 alts after pruning (14 fresh and 0 done)

PrunedKeptTotal
New29414308
Fresh101
Picked101
Done000
Total29614310
Error
0.0b
Counts
310 → 14
Alt Table
StatusErrorProgram
0.6b
(+.f64 (fma.f64 1 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) (neg.f64 (*.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (hypot.f64 1 (tan.f64 x))) (/.f64 1 (hypot.f64 1 (tan.f64 x)))))) (fma.f64 (neg.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (hypot.f64 1 (tan.f64 x)))) (/.f64 1 (hypot.f64 1 (tan.f64 x))) (*.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (hypot.f64 1 (tan.f64 x))) (/.f64 1 (hypot.f64 1 (tan.f64 x))))))
0.8b
(/.f64 (fma.f64 (*.f64 (cbrt.f64 (neg.f64 (pow.f64 (tan.f64 x) 2))) (cbrt.f64 (neg.f64 (pow.f64 (tan.f64 x) 2)))) (cbrt.f64 (neg.f64 (pow.f64 (tan.f64 x) 2))) 1) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
0.4b
(/.f64 (-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x))) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
0.8b
(+.f64 (fma.f64 (/.f64 1 (+.f64 1 (pow.f64 (tan.f64 x) 6))) (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (neg.f64 (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))))))) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))))))
0.7b
(/.f64 (fma.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (neg.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2)) 1) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
0.6b
(-.f64 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))
0.9b
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) 2) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)) (cbrt.f64 (/.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))))
0.8b
(*.f64 (/.f64 1 (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)) (/.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))))
0.5b
(+.f64 (fma.f64 (/.f64 1 (-.f64 1 (pow.f64 (tan.f64 x) 4))) (-.f64 1 (pow.f64 (tan.f64 x) 2)) (neg.f64 (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4)))))) (fma.f64 (neg.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))) (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))))))
0.7b
(+.f64 (fma.f64 (/.f64 1 (+.f64 1 (pow.f64 (tan.f64 x) 6))) (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (neg.f64 (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4)))))) (fma.f64 (neg.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))) (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))))))
0.7b
(+.f64 (fma.f64 (sqrt.f64 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (sqrt.f64 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (neg.f64 (*.f64 (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (+.f64 1 (pow.f64 (tan.f64 x) 6)))))) (fma.f64 (neg.f64 (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2)))) (/.f64 (pow.f64 (tan.f64 x) 2) (+.f64 1 (pow.f64 (tan.f64 x) 6))) (*.f64 (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (+.f64 1 (pow.f64 (tan.f64 x) 6))))))
0.5b
(*.f64 (neg.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) (/.f64 1 (fma.f64 -1 (pow.f64 (tan.f64 x) 2) -1)))
1.0b
(+.f64 (fma.f64 1 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) (neg.f64 (*.f64 (/.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (/.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2))))) (fma.f64 (neg.f64 (/.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))) (/.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)) (*.f64 (/.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (/.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)))))
1.2b
(/.f64 (+.f64 (log.f64 (sqrt.f64 (exp.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))))) (log.f64 (sqrt.f64 (exp.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)))))) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
Compiler

Compiled 11831 to 7826 computations (33.9% saved)

localize12.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(/.f64 (-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x))) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
0.2b
(-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x)))
0.2b
(*.f64 (sin.f64 x) (tan.f64 x))
0.3b
(*.f64 (tan.f64 x) (tan.f64 x))

series87.0ms (0.9%)

Counts
3 → 36
Calls

9 calls:

31.0ms
(/.f64 (-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x))) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
x
-inf
31.0ms
(/.f64 (-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x))) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
x
inf
7.0ms
(-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x)))
x
-inf
7.0ms
(-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x)))
x
inf
4.0ms
(*.f64 (sin.f64 x) (tan.f64 x))
x
-inf

rewrite58.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
282×fma-def_binary64
217×expm1-udef_binary64
216×log1p-udef_binary64
184×fma-neg_binary64
134×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01251
126737
2403837
Stop Event
node limit
Counts
3 → 103

simplify29.0ms (0.3%)

Algorithm
egg-herbie
Rules
660×fma-def_binary64
628×associate-*l*_binary64
543×associate-*r*_binary64
342×cancel-sign-sub-inv_binary64
184×fma-neg_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
050665
1136665
2351661
31147659
Stop Event
node limit
Counts
139 → 127

prune329.0ms (3.5%)

Pruning

13 alts after pruning (13 fresh and 0 done)

PrunedKeptTotal
New1642166
Fresh21113
Picked101
Done000
Total16713180
Error
0.0b
Counts
180 → 13
Alt Table
StatusErrorProgram
0.6b
(+.f64 (fma.f64 1 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) (neg.f64 (*.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (hypot.f64 1 (tan.f64 x))) (/.f64 1 (hypot.f64 1 (tan.f64 x)))))) (fma.f64 (neg.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (hypot.f64 1 (tan.f64 x)))) (/.f64 1 (hypot.f64 1 (tan.f64 x))) (*.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (hypot.f64 1 (tan.f64 x))) (/.f64 1 (hypot.f64 1 (tan.f64 x))))))
0.8b
(/.f64 (fma.f64 (*.f64 (cbrt.f64 (neg.f64 (pow.f64 (tan.f64 x) 2))) (cbrt.f64 (neg.f64 (pow.f64 (tan.f64 x) 2)))) (cbrt.f64 (neg.f64 (pow.f64 (tan.f64 x) 2))) 1) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
0.4b
(-.f64 (/.f64 1 (fma.f64 (tan.f64 x) (tan.f64 x) 1)) (/.f64 (pow.f64 (tan.f64 x) 2) (fma.f64 (tan.f64 x) (tan.f64 x) 1)))
0.8b
(+.f64 (fma.f64 (/.f64 1 (+.f64 1 (pow.f64 (tan.f64 x) 6))) (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (neg.f64 (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))))))) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))))))
0.7b
(/.f64 (fma.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (neg.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2)) 1) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
0.4b
(/.f64 (-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x))) (+.f64 1 (/.f64 (*.f64 (tan.f64 x) (sin.f64 x)) (cos.f64 x))))
0.9b
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) 2) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)) (cbrt.f64 (/.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))))
0.8b
(*.f64 (/.f64 1 (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)) (/.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))))
0.5b
(+.f64 (fma.f64 (/.f64 1 (-.f64 1 (pow.f64 (tan.f64 x) 4))) (-.f64 1 (pow.f64 (tan.f64 x) 2)) (neg.f64 (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4)))))) (fma.f64 (neg.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))) (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))))))
0.7b
(+.f64 (fma.f64 (/.f64 1 (+.f64 1 (pow.f64 (tan.f64 x) 6))) (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (neg.f64 (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4)))))) (fma.f64 (neg.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))) (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))))))
0.7b
(+.f64 (fma.f64 (sqrt.f64 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (sqrt.f64 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (neg.f64 (*.f64 (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (+.f64 1 (pow.f64 (tan.f64 x) 6)))))) (fma.f64 (neg.f64 (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2)))) (/.f64 (pow.f64 (tan.f64 x) 2) (+.f64 1 (pow.f64 (tan.f64 x) 6))) (*.f64 (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (+.f64 1 (pow.f64 (tan.f64 x) 6))))))
1.0b
(+.f64 (fma.f64 1 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) (neg.f64 (*.f64 (/.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (/.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2))))) (fma.f64 (neg.f64 (/.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))) (/.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)) (*.f64 (/.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (/.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)))))
1.2b
(/.f64 (+.f64 (log.f64 (sqrt.f64 (exp.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))))) (log.f64 (sqrt.f64 (exp.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)))))) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
Compiler

Compiled 5062 to 3056 computations (39.6% saved)

localize13.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(/.f64 (-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x))) (+.f64 1 (/.f64 (*.f64 (tan.f64 x) (sin.f64 x)) (cos.f64 x))))
0.2b
(-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x)))
0.2b
(*.f64 (tan.f64 x) (sin.f64 x))
0.2b
(*.f64 (sin.f64 x) (tan.f64 x))

series78.0ms (0.8%)

Counts
2 → 24
Calls

6 calls:

35.0ms
(/.f64 (-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x))) (+.f64 1 (/.f64 (*.f64 (tan.f64 x) (sin.f64 x)) (cos.f64 x))))
x
-inf
34.0ms
(/.f64 (-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x))) (+.f64 1 (/.f64 (*.f64 (tan.f64 x) (sin.f64 x)) (cos.f64 x))))
x
inf
3.0ms
(*.f64 (tan.f64 x) (sin.f64 x))
x
-inf
3.0ms
(*.f64 (tan.f64 x) (sin.f64 x))
x
inf
1.0ms
(*.f64 (tan.f64 x) (sin.f64 x))
x
0

rewrite65.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
290×fma-def_binary64
216×expm1-udef_binary64
215×log1p-udef_binary64
195×fma-neg_binary64
125×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01342
130128
2373528
Stop Event
node limit
Counts
2 → 58

simplify38.0ms (0.4%)

Algorithm
egg-herbie
Rules
498×associate-*l*_binary64
481×fma-def_binary64
466×unswap-sqr_binary64
417×associate-*r*_binary64
175×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
042486
1110486
2268482
3848480
44139480
Stop Event
node limit
Counts
82 → 74

prune301.0ms (3.2%)

Pruning

13 alts after pruning (12 fresh and 1 done)

PrunedKeptTotal
New1510151
Fresh01212
Picked011
Done000
Total15113164
Error
0.0b
Counts
164 → 13
Alt Table
StatusErrorProgram
0.6b
(+.f64 (fma.f64 1 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) (neg.f64 (*.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (hypot.f64 1 (tan.f64 x))) (/.f64 1 (hypot.f64 1 (tan.f64 x)))))) (fma.f64 (neg.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (hypot.f64 1 (tan.f64 x)))) (/.f64 1 (hypot.f64 1 (tan.f64 x))) (*.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (hypot.f64 1 (tan.f64 x))) (/.f64 1 (hypot.f64 1 (tan.f64 x))))))
0.8b
(/.f64 (fma.f64 (*.f64 (cbrt.f64 (neg.f64 (pow.f64 (tan.f64 x) 2))) (cbrt.f64 (neg.f64 (pow.f64 (tan.f64 x) 2)))) (cbrt.f64 (neg.f64 (pow.f64 (tan.f64 x) 2))) 1) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
0.4b
(-.f64 (/.f64 1 (fma.f64 (tan.f64 x) (tan.f64 x) 1)) (/.f64 (pow.f64 (tan.f64 x) 2) (fma.f64 (tan.f64 x) (tan.f64 x) 1)))
0.8b
(+.f64 (fma.f64 (/.f64 1 (+.f64 1 (pow.f64 (tan.f64 x) 6))) (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (neg.f64 (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))))))) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))))))
0.7b
(/.f64 (fma.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (neg.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2)) 1) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
0.4b
(/.f64 (-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x))) (+.f64 1 (/.f64 (*.f64 (tan.f64 x) (sin.f64 x)) (cos.f64 x))))
0.9b
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) 2) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)) (cbrt.f64 (/.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))))
0.8b
(*.f64 (/.f64 1 (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)) (/.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))))
0.5b
(+.f64 (fma.f64 (/.f64 1 (-.f64 1 (pow.f64 (tan.f64 x) 4))) (-.f64 1 (pow.f64 (tan.f64 x) 2)) (neg.f64 (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4)))))) (fma.f64 (neg.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))) (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))))))
0.7b
(+.f64 (fma.f64 (/.f64 1 (+.f64 1 (pow.f64 (tan.f64 x) 6))) (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (neg.f64 (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4)))))) (fma.f64 (neg.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))) (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))))))
0.7b
(+.f64 (fma.f64 (sqrt.f64 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (sqrt.f64 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (neg.f64 (*.f64 (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (+.f64 1 (pow.f64 (tan.f64 x) 6)))))) (fma.f64 (neg.f64 (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2)))) (/.f64 (pow.f64 (tan.f64 x) 2) (+.f64 1 (pow.f64 (tan.f64 x) 6))) (*.f64 (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (+.f64 1 (pow.f64 (tan.f64 x) 6))))))
1.0b
(+.f64 (fma.f64 1 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) (neg.f64 (*.f64 (/.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (/.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2))))) (fma.f64 (neg.f64 (/.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))) (/.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)) (*.f64 (/.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (/.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)))))
1.2b
(/.f64 (+.f64 (log.f64 (sqrt.f64 (exp.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))))) (log.f64 (sqrt.f64 (exp.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)))))) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
Compiler

Compiled 4944 to 2912 computations (41.1% saved)

localize8.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(fma.f64 (tan.f64 x) (tan.f64 x) 1)
0.2b
(/.f64 (pow.f64 (tan.f64 x) 2) (fma.f64 (tan.f64 x) (tan.f64 x) 1))
0.3b
(pow.f64 (tan.f64 x) 2)
0.4b
(-.f64 (/.f64 1 (fma.f64 (tan.f64 x) (tan.f64 x) 1)) (/.f64 (pow.f64 (tan.f64 x) 2) (fma.f64 (tan.f64 x) (tan.f64 x) 1)))

series191.0ms (2%)

Counts
4 → 48
Calls

12 calls:

53.0ms
(-.f64 (/.f64 1 (fma.f64 (tan.f64 x) (tan.f64 x) 1)) (/.f64 (pow.f64 (tan.f64 x) 2) (fma.f64 (tan.f64 x) (tan.f64 x) 1)))
x
inf
53.0ms
(-.f64 (/.f64 1 (fma.f64 (tan.f64 x) (tan.f64 x) 1)) (/.f64 (pow.f64 (tan.f64 x) 2) (fma.f64 (tan.f64 x) (tan.f64 x) 1)))
x
-inf
30.0ms
(/.f64 (pow.f64 (tan.f64 x) 2) (fma.f64 (tan.f64 x) (tan.f64 x) 1))
x
-inf
30.0ms
(/.f64 (pow.f64 (tan.f64 x) 2) (fma.f64 (tan.f64 x) (tan.f64 x) 1))
x
inf
6.0ms
(fma.f64 (tan.f64 x) (tan.f64 x) 1)
x
inf

rewrite120.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
760×prod-diff_binary64
273×egg-rr
187×expm1-udef_binary64
187×log1p-udef_binary64
108×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01052
122652
2307752
Stop Event
node limit
Counts
4 → 273

simplify41.0ms (0.4%)

Algorithm
egg-herbie
Rules
871×fma-def_binary64
416×cancel-sign-sub-inv_binary64
241×fma-neg_binary64
232×times-frac_binary64
216×*-commutative_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0561169
11541161
24221153
314291151
Stop Event
node limit
Counts
321 → 306

prune1.1s (11.4%)

Pruning

13 alts after pruning (12 fresh and 1 done)

PrunedKeptTotal
New3373340
Fresh2911
Picked101
Done011
Total34013353
Error
0.0b
Counts
353 → 13
Alt Table
StatusErrorProgram
0.5b
(/.f64 (+.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (*.f64 (+.f64 1 (pow.f64 (tan.f64 x) 2)) (pow.f64 (tan.f64 x) 2)))) (pow.f64 (+.f64 1 (pow.f64 (tan.f64 x) 2)) 2))
0.7b
(+.f64 (fma.f64 1 (/.f64 1 (+.f64 1 (pow.f64 (tan.f64 x) 2))) (neg.f64 (*.f64 (cbrt.f64 (/.f64 1 (+.f64 1 (pow.f64 (tan.f64 x) 2)))) (*.f64 (pow.f64 (tan.f64 x) 2) (cbrt.f64 (pow.f64 (+.f64 1 (pow.f64 (tan.f64 x) 2)) -2)))))) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 1 (+.f64 1 (pow.f64 (tan.f64 x) 2))))) (*.f64 (pow.f64 (tan.f64 x) 2) (cbrt.f64 (pow.f64 (+.f64 1 (pow.f64 (tan.f64 x) 2)) -2))) (*.f64 (cbrt.f64 (/.f64 1 (+.f64 1 (pow.f64 (tan.f64 x) 2)))) (*.f64 (pow.f64 (tan.f64 x) 2) (cbrt.f64 (pow.f64 (+.f64 1 (pow.f64 (tan.f64 x) 2)) -2))))))
0.4b
(/.f64 (-.f64 1 (/.f64 (*.f64 (sin.f64 x) (tan.f64 x)) (cos.f64 x))) (+.f64 1 (/.f64 (*.f64 (tan.f64 x) (sin.f64 x)) (cos.f64 x))))
0.4b
(-.f64 (/.f64 1 (fma.f64 (tan.f64 x) (tan.f64 x) 1)) (sqrt.f64 (*.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (+.f64 1 (pow.f64 (tan.f64 x) 2)) -2))))
0.6b
(+.f64 (fma.f64 1 (/.f64 1 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) (neg.f64 (*.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (hypot.f64 1 (tan.f64 x))) (/.f64 1 (hypot.f64 1 (tan.f64 x)))))) (fma.f64 (neg.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (hypot.f64 1 (tan.f64 x)))) (/.f64 1 (hypot.f64 1 (tan.f64 x))) (*.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (hypot.f64 1 (tan.f64 x))) (/.f64 1 (hypot.f64 1 (tan.f64 x))))))
0.8b
(/.f64 (fma.f64 (*.f64 (cbrt.f64 (neg.f64 (pow.f64 (tan.f64 x) 2))) (cbrt.f64 (neg.f64 (pow.f64 (tan.f64 x) 2)))) (cbrt.f64 (neg.f64 (pow.f64 (tan.f64 x) 2))) 1) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
0.8b
(+.f64 (fma.f64 (/.f64 1 (+.f64 1 (pow.f64 (tan.f64 x) 6))) (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (neg.f64 (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))))))) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (*.f64 (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))) (cbrt.f64 (/.f64 (pow.f64 (tan.f64 x) 2) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)))))))
0.7b
(/.f64 (fma.f64 (cbrt.f64 (pow.f64 (tan.f64 x) 4)) (neg.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2)) 1) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
0.9b
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) 2) (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)) (cbrt.f64 (/.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))))
0.8b
(*.f64 (/.f64 1 (pow.f64 (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2)) 2)) (/.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (cbrt.f64 (pow.f64 (hypot.f64 1 (tan.f64 x)) 2))))
0.5b
(+.f64 (fma.f64 (/.f64 1 (-.f64 1 (pow.f64 (tan.f64 x) 4))) (-.f64 1 (pow.f64 (tan.f64 x) 2)) (neg.f64 (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4)))))) (fma.f64 (neg.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))) (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))))))
0.7b
(+.f64 (fma.f64 (/.f64 1 (+.f64 1 (pow.f64 (tan.f64 x) 6))) (+.f64 1 (-.f64 (pow.f64 (tan.f64 x) 4) (pow.f64 (tan.f64 x) 2))) (neg.f64 (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4)))))) (fma.f64 (neg.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))) (*.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)) (/.f64 (pow.f64 (tan.f64 x) 2) (-.f64 1 (pow.f64 (tan.f64 x) 4))))))
1.2b
(/.f64 (+.f64 (log.f64 (sqrt.f64 (exp.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2))))) (log.f64 (sqrt.f64 (exp.f64 (-.f64 1 (pow.f64 (tan.f64 x) 2)))))) (+.f64 1 (*.f64 (tan.f64 x) (tan.f64 x))))
Compiler

Compiled 16026 to 11174 computations (30.3% saved)

regimes3.2s (34.5%)

Accuracy

Total 0.3b remaining (79.8%)

Threshold costs 0.3b (79.8%)

Counts
546 → 1
Compiler

Compiled 71748 to 51004 computations (28.9% saved)

simplify3.0ms (0%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01334
12034
22634
33634
44334
54834
65034
Stop Event
saturated

end385.0ms (4.1%)

Stop Event
fuel
Compiler

Compiled 697 to 494 computations (29.1% saved)

Profiling

Loading profile data...