Details

Time bar (total: 3.9s)

analyze8.0ms (0.2%)

Algorithm
search
Search
TrueOtherFalseIter
0%50%50%0
0%50%50%1
0%50%50%2
0%50%50%3
31.2%18.7%50%4
40.6%9.4%50%5
45.3%4.7%50%6
47.6%2.3%50%7
48.8%1.2%50%8
49.4%0.6%50%9
49.7%0.3%50%10
49.8%0.1%50%11
49.9%0.1%50%12
Compiler

Compiled 29 to 19 computations (34.5% saved)

sample2.0s (50.7%)

Results
1.9s8256×body256valid

preprocess63.0ms (1.6%)

Algorithm
egg-herbie
Rules
579×associate-/r*_binary64
516×cancel-sign-sub-inv_binary64
496×distribute-rgt-in_binary64
478×distribute-lft-in_binary64
434×associate-/r/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01131
14026
220017
3134113
4377413
5622013
011
Stop Event
saturated
node limit
Calls
Call 1
Inputs
0
Outputs
0
Call 2
Inputs
(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))
Outputs
(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))
(/.f64 (*.f64 i (*.f64 i (*.f64 i i))) (*.f64 (+.f64 (*.f64 4 (*.f64 i i)) -1) (*.f64 4 (*.f64 i i))))
(*.f64 (/.f64 i (fma.f64 4 (*.f64 i i) -1)) (/.f64 (pow.f64 i 3) (*.f64 i (*.f64 i 4))))
(*.f64 (/.f64 i (fma.f64 (*.f64 i i) 4 -1)) (/.f64 i 4))
(/.f64 1/4 (-.f64 4 (/.f64 i (pow.f64 i 3))))
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
Compiler

Compiled 27 to 18 computations (33.3% saved)

simplify47.0ms (1.2%)

Algorithm
egg-herbie
Rules
579×associate-/r*_binary64
516×cancel-sign-sub-inv_binary64
496×distribute-rgt-in_binary64
478×distribute-lft-in_binary64
434×associate-/r/_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01131
14026
220017
3134113
4377413
5622013
Stop Event
node limit
Counts
1 → 2
Calls
Call 1
Inputs
(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))
Outputs
(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))
(/.f64 (*.f64 i (*.f64 i (*.f64 i i))) (*.f64 (+.f64 (*.f64 4 (*.f64 i i)) -1) (*.f64 4 (*.f64 i i))))
(*.f64 (/.f64 i (fma.f64 4 (*.f64 i i) -1)) (/.f64 (pow.f64 i 3) (*.f64 i (*.f64 i 4))))
(*.f64 (/.f64 i (fma.f64 (*.f64 i i) 4 -1)) (/.f64 i 4))
(/.f64 1/4 (-.f64 4 (/.f64 i (pow.f64 i 3))))
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))

eval1.0ms (0%)

Compiler

Compiled 35 to 23 computations (34.3% saved)

prune1.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
Click to see full alt table
StatusErrorProgram
43.6b
(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))
0.3b
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
Compiler

Compiled 36 to 25 computations (30.6% saved)

localize10.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.3b
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
1.0b
(/.f64 -1 (*.f64 i i))
Compiler

Compiled 29 to 17 computations (41.4% saved)

series3.0ms (0.1%)

Counts
2 → 24
Calls

6 calls:

TimeVariablePointExpression
1.0ms
i
@0
(/.f64 -1 (*.f64 i i))
1.0ms
i
@0
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
0.0ms
i
@inf
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
0.0ms
i
@inf
(/.f64 -1 (*.f64 i i))
0.0ms
i
@-inf
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))

rewrite72.0ms (1.9%)

Algorithm
batch-egg-rewrite
Rules
521×unpow-prod-down_binary64
386×log-prod_binary64
305×exp-prod_binary64
256×prod-exp_binary64
243×pow2_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0920
120317
2251417
Stop Event
node limit
Counts
2 → 99
Calls
Call 1
Inputs
(/.f64 -1 (*.f64 i i))
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (neg.f64 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (neg.f64 (pow.f64 i -2)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (neg.f64 (pow.f64 i -2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (neg.f64 (pow.f64 i -2))))) (log.f64 (sqrt.f64 (exp.f64 (neg.f64 (pow.f64 i -2))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (neg.f64 (pow.f64 i -2)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (pow.f64 i -2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (pow.f64 i -2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (neg.f64 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (neg.f64 (pow.f64 i -2))) (cbrt.f64 (pow.f64 i -4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 i -4)) (cbrt.f64 (neg.f64 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 -1) i) (/.f64 (sqrt.f64 -1) i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 i -2) -1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 -1 i) (/.f64 1 i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 -1 i) (pow.f64 (/.f64 1 i) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 i) (/.f64 -1 i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (*.f64 (cbrt.f64 i) i)) (pow.f64 (neg.f64 (pow.f64 (cbrt.f64 i) 2)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (neg.f64 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (neg.f64 (pow.f64 i -2)))) 3) (pow.f64 (sqrt.f64 (cbrt.f64 (neg.f64 (pow.f64 i -2)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 -1 1/3) (pow.f64 i -2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (neg.f64 (pow.f64 i -2)))) 2) 3) (cbrt.f64 (neg.f64 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 -1) 2) (pow.f64 i -2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (*.f64 i (neg.f64 i))) 2) -1) (cbrt.f64 (neg.f64 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (neg.f64 (*.f64 (cbrt.f64 i) i)) -1) (pow.f64 (pow.f64 (cbrt.f64 i) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (pow.f64 i -4) -1) 1/3) (cbrt.f64 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (pow.f64 i -4) (cbrt.f64 (pow.f64 i -4))) 1/3) (cbrt.f64 (cbrt.f64 (neg.f64 (pow.f64 i -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (neg.f64 (pow.f64 i -2)) 5/2) 1/3) (cbrt.f64 (/.f64 (sqrt.f64 -1) i)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (neg.f64 (pow.f64 i -2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 i -4) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (neg.f64 (pow.f64 i -2))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sqrt.f64 -1) i) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 i (neg.f64 i)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 -1 (pow.f64 i -6)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (neg.f64 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (neg.f64 (pow.f64 i -2)))) 2)) (cbrt.f64 (log.f64 (neg.f64 (pow.f64 i -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (neg.f64 (pow.f64 i -2))))) (sqrt.f64 (log.f64 (neg.f64 (pow.f64 i -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (pow.f64 i -2))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 i -4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (neg.f64 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (neg.f64 (pow.f64 i -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 -1 (pow.f64 i -6)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (neg.f64 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (neg.f64 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (neg.f64 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (neg.f64 (pow.f64 i -2))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (neg.f64 (pow.f64 i -2)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sqrt.f64 -1) i)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 i (neg.f64 i))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 -1 (pow.f64 i -6))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (neg.f64 (pow.f64 i -2))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (neg.f64 (pow.f64 i -2))) 3) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log.f64 (/.f64 -1 i)) (*.f64 (log.f64 i) 1)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/4 (/.f64 1 (fma.f64 -1 (pow.f64 i -2) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))) (pow.f64 (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))) 2) (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/2 (sqrt.f64 (fma.f64 -1 (pow.f64 i -2) 4))) (/.f64 1/2 (sqrt.f64 (fma.f64 -1 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1/4 (/.f64 1 (neg.f64 (fma.f64 -1 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1/4 (pow.f64 (/.f64 1 (neg.f64 (fma.f64 -1 (pow.f64 i -2) 4))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 -1 (pow.f64 i -2) 4)) 1/4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -6) 64)) (-.f64 (+.f64 16 (pow.f64 i -4)) (*.f64 -4 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/4 (-.f64 16 (pow.f64 i -4))) (+.f64 4 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -6) 64)) 1) (-.f64 (+.f64 16 (pow.f64 i -4)) (*.f64 -4 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 1/4 (-.f64 16 (pow.f64 i -4))) 1) (+.f64 4 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (pow.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)) 3)) 1/3) (pow.f64 (sqrt.f64 (pow.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)) 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (*.f64 1/16 (pow.f64 (fma.f64 -1 (pow.f64 i -2) 4) -2)) 1/4) 1/3) (cbrt.f64 (/.f64 1 (fma.f64 -1 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (*.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)) (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))) 2) 1/3) (cbrt.f64 (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)) 5/2) 1/3) (cbrt.f64 (/.f64 1/2 (sqrt.f64 (fma.f64 -1 (pow.f64 i -2) 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 1/4) 3) (/.f64 1 (fma.f64 -1 (pow.f64 i -2) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))) 2) 3) (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))) 3) (pow.f64 (sqrt.f64 (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (*.f64 (fma.f64 -1 (pow.f64 i -2) 4) 4)) 2) -1) (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 1/16 (pow.f64 (fma.f64 -1 (pow.f64 i -2) 4) -2)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1/2 (sqrt.f64 (fma.f64 -1 (pow.f64 i -2) 4))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (fma.f64 -1 (pow.f64 i -2) 4) 4) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (*.f64 (fma.f64 -1 (pow.f64 i -2) 4) 4) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))) 2)) (cbrt.f64 (log.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))))) (sqrt.f64 (log.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 1/16 (pow.f64 (fma.f64 -1 (pow.f64 i -2) 4) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 1/2 (sqrt.f64 (fma.f64 -1 (pow.f64 i -2) 4)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (fma.f64 -1 (pow.f64 i -2) 4) 4)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 1/4 (fma.f64 -1 (pow.f64 i -2) 4))) 1) 1))))))

simplify46.0ms (1.2%)

Algorithm
egg-herbie
Rules
691×cancel-sign-sub-inv_binary64
657×fma-neg_binary64
472×distribute-lft-out_binary64
413×unswap-sqr_binary64
410×fma-def_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
039270
191267
2214267
3643267
43200267
Stop Event
node limit
Counts
123 → 116
Calls
Call 1
Inputs
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(*.f64 -1/4 (pow.f64 i 2))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6))))
(+.f64 (*.f64 -16 (pow.f64 i 8)) (+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6)))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
Outputs
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(*.f64 -1/4 (pow.f64 i 2))
(*.f64 (*.f64 i i) -1/4)
(*.f64 i (*.f64 i -1/4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 (*.f64 i i) -1/4))
(-.f64 (*.f64 (*.f64 i i) -1/4) (pow.f64 i 4))
(-.f64 (*.f64 i (*.f64 i -1/4)) (pow.f64 i 4))
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6))))
(fma.f64 -1 (pow.f64 i 4) (fma.f64 -1/4 (*.f64 i i) (*.f64 -4 (pow.f64 i 6))))
(-.f64 (fma.f64 (*.f64 i i) -1/4 (*.f64 -4 (pow.f64 i 6))) (pow.f64 i 4))
(-.f64 (fma.f64 -4 (pow.f64 i 6) (*.f64 i (*.f64 i -1/4))) (pow.f64 i 4))
(fma.f64 i (fma.f64 i -1/4 (neg.f64 (pow.f64 i 3))) (*.f64 -4 (pow.f64 i 6)))
(-.f64 (*.f64 -4 (pow.f64 i 6)) (*.f64 (*.f64 i i) (fma.f64 i i 1/4)))
(+.f64 (*.f64 -16 (pow.f64 i 8)) (+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6)))))
(fma.f64 -16 (pow.f64 i 8) (fma.f64 -1 (pow.f64 i 4) (fma.f64 -1/4 (*.f64 i i) (*.f64 -4 (pow.f64 i 6)))))
(fma.f64 -16 (pow.f64 i 8) (-.f64 (fma.f64 (*.f64 i i) -1/4 (*.f64 -4 (pow.f64 i 6))) (pow.f64 i 4)))
(-.f64 (fma.f64 -16 (pow.f64 i 8) (fma.f64 -4 (pow.f64 i 6) (*.f64 i (*.f64 i -1/4)))) (pow.f64 i 4))
(fma.f64 i (*.f64 i -1/4) (fma.f64 -4 (pow.f64 i 6) (-.f64 (*.f64 -16 (pow.f64 i 8)) (pow.f64 i 4))))
(-.f64 (*.f64 -16 (pow.f64 i 8)) (fma.f64 i (*.f64 i (fma.f64 i i 1/4)) (*.f64 4 (pow.f64 i 6))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 1/16 (/.f64 1/64 (*.f64 i i)))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (+.f64 1/16 (/.f64 1/64 (*.f64 i i))) (/.f64 1/256 (pow.f64 i 4)))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 1/16 (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
(+.f64 (/.f64 1/256 (pow.f64 i 4)) (+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/1024 (pow.f64 i 6)))))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 (/.f64 1/1024 (pow.f64 i 6)) (/.f64 1/256 (pow.f64 i 4)))))
(+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 (/.f64 1/1024 (pow.f64 i 6)) (+.f64 1/16 (/.f64 1/256 (pow.f64 i 4)))))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 (/.f64 1/256 (pow.f64 i 4)) (/.f64 1/1024 (pow.f64 i 6)))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 1/16 (/.f64 1/64 (*.f64 i i)))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (+.f64 1/16 (/.f64 1/64 (*.f64 i i))) (/.f64 1/256 (pow.f64 i 4)))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 1/16 (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
(+.f64 (/.f64 1/256 (pow.f64 i 4)) (+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/1024 (pow.f64 i 6)))))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 (/.f64 1/1024 (pow.f64 i 6)) (/.f64 1/256 (pow.f64 i 4)))))
(+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 (/.f64 1/1024 (pow.f64 i 6)) (+.f64 1/16 (/.f64 1/256 (pow.f64 i 4)))))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 (/.f64 1/256 (pow.f64 i 4)) (/.f64 1/1024 (pow.f64 i 6)))))

localize25.0ms (0.7%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (*.f64 i i) (*.f64 i i))
13.6b
(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))
40.1b
(/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i)))
Compiler

Compiled 73 to 39 computations (46.6% saved)

series4.0ms (0.1%)

Counts
3 → 36
Calls

9 calls:

TimeVariablePointExpression
1.0ms
i
@0
(/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i)))
1.0ms
i
@inf
(/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i)))
0.0ms
i
@inf
(*.f64 (*.f64 i i) (*.f64 i i))
0.0ms
i
@0
(*.f64 (*.f64 i i) (*.f64 i i))
0.0ms
i
@0
(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))

rewrite86.0ms (2.2%)

Algorithm
batch-egg-rewrite
Rules
775×log-prod_binary64
508×prod-diff_binary64
288×fma-def_binary64
260×log-div_binary64
217×fma-neg_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01151
125540
2396540
Stop Event
node limit
Counts
3 → 131
Calls
Call 1
Inputs
(/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i)))
(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))
(*.f64 (*.f64 i i) (*.f64 i i))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (pow.f64 i 4)) (/.f64 1/4 (*.f64 i i)))) (cbrt.f64 (pow.f64 (exp.f64 (pow.f64 i 4)) (/.f64 1/4 (*.f64 i i)))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (pow.f64 i 4)) (/.f64 1/4 (*.f64 i i))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (pow.f64 i 4)) (/.f64 1/4 (*.f64 i i))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (pow.f64 i 4)) (/.f64 1/4 (*.f64 i i))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 i (*.f64 (pow.f64 i 3) (/.f64 1/4 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 i i) (/.f64 1 (*.f64 4 (/.f64 (*.f64 i i) (*.f64 i i)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 i i) (*.f64 (*.f64 i i) (/.f64 1/4 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 i 3) (*.f64 i (/.f64 1/4 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) (pow.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) 2) (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 i (cbrt.f64 i)) 2) (*.f64 (*.f64 i (cbrt.f64 i)) (/.f64 1/4 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) (*.f64 (/.f64 i i) (/.f64 i 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (pow.f64 i 4)) (/.f64 1 (*.f64 -4 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/4 (*.f64 i i)) (pow.f64 i 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 1/2 (/.f64 (pow.f64 i 4) i)) (/.f64 1 (+.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (/.f64 (pow.f64 i 4) (*.f64 i (+.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 i 2) (/.f64 (pow.f64 i 3) (*.f64 i (+.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 i i) 2) (/.f64 (*.f64 i i) (*.f64 i (+.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i 3) 2) (/.f64 i (*.f64 i (+.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (*.f64 i (cbrt.f64 i)) 2) 2) (/.f64 (*.f64 i (cbrt.f64 i)) (*.f64 i (+.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 i (+.f64 i i)) (/.f64 (pow.f64 i 3) (+.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i 3) (+.f64 i i)) (/.f64 i (+.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 i i)) (*.f64 1/2 (/.f64 (pow.f64 i 4) i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (*.f64 i (cbrt.f64 i)) 2) (+.f64 i i)) (/.f64 (*.f64 i (cbrt.f64 i)) (+.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 i 1) (/.f64 (pow.f64 i 3) (*.f64 i (*.f64 i 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 i i) 1) (/.f64 (*.f64 i i) (*.f64 i (*.f64 i 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 i i) (*.f64 i (*.f64 i 4))) (*.f64 i i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i 3) 1) (/.f64 i (*.f64 i (*.f64 i 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (*.f64 i (cbrt.f64 i)) 2) 1) (/.f64 (*.f64 i (cbrt.f64 i)) (*.f64 i (*.f64 i 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 i 4) (/.f64 (pow.f64 i 3) (*.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 i i) 4) (/.f64 (*.f64 i i) (*.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/4 (/.f64 (pow.f64 i 4) (*.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i 3) 4) (/.f64 i (*.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (*.f64 i (cbrt.f64 i)) 2) 4) (/.f64 (*.f64 i (cbrt.f64 i)) (*.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 i (cbrt.f64 (*.f64 16 (pow.f64 i 4)))) (/.f64 (pow.f64 i 3) (pow.f64 (cbrt.f64 (+.f64 i i)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 i i) (cbrt.f64 (*.f64 16 (pow.f64 i 4)))) (/.f64 (*.f64 i i) (pow.f64 (cbrt.f64 (+.f64 i i)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cbrt.f64 (*.f64 16 (pow.f64 i 4)))) (/.f64 (pow.f64 i 4) (pow.f64 (cbrt.f64 (+.f64 i i)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i 3) (cbrt.f64 (*.f64 16 (pow.f64 i 4)))) (/.f64 i (pow.f64 (cbrt.f64 (+.f64 i i)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (*.f64 i (cbrt.f64 i)) 2) (cbrt.f64 (*.f64 16 (pow.f64 i 4)))) (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 i (*.f64 i 4)) (/.f64 (pow.f64 i 3) i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 i i) (*.f64 i 4)) (/.f64 (*.f64 i i) i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (*.f64 i 4)) (/.f64 (pow.f64 i 4) i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i 3) (*.f64 i 4)) (/.f64 i i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (*.f64 i (cbrt.f64 i)) 2) (*.f64 i 4)) (/.f64 (*.f64 i (cbrt.f64 i)) i))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 4 (/.f64 (*.f64 i i) (pow.f64 i 4))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (pow.f64 i 4) (*.f64 -4 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (/.f64 (pow.f64 (*.f64 i i) 4) (*.f64 16 (pow.f64 i 4))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (pow.f64 i 4)) (/.f64 1/4 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (pow.f64 i 4) 3) (pow.f64 (+.f64 i i) 6)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1))))) (cbrt.f64 (exp.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1))))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 i 4) (/.f64 1 (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 i 4) (*.f64 (/.f64 1/4 (*.f64 i i)) (/.f64 1 (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))) (/.f64 1 (fma.f64 i (*.f64 i 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))) (pow.f64 (cbrt.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))) 2) (cbrt.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) 2) (*.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) (/.f64 1 (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) (sqrt.f64 (fma.f64 i (*.f64 i 4) -1))) (/.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) (sqrt.f64 (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) (*.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) (/.f64 1 (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (neg.f64 (pow.f64 i 4)) (/.f64 1/4 (*.f64 i i))) (/.f64 1 (fma.f64 -4 (*.f64 i i) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 i (*.f64 i 4) -1)) (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 i (fma.f64 i (*.f64 i 4) -1)) (/.f64 (pow.f64 i 3) (*.f64 i (*.f64 i 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 i i) (fma.f64 i (*.f64 i 4) -1)) (/.f64 (*.f64 i i) (*.f64 i (*.f64 i 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i 3) (fma.f64 i (*.f64 i 4) -1)) (/.f64 i (*.f64 i (*.f64 i 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (*.f64 i (cbrt.f64 i)) 2) (fma.f64 i (*.f64 i 4) -1)) (/.f64 (*.f64 i (cbrt.f64 i)) (*.f64 i (*.f64 i 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i 4) 1) (/.f64 (/.f64 1/4 (*.f64 i i)) (fma.f64 i (*.f64 i 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) 2) 1) (/.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) (fma.f64 i (*.f64 i 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) 1) (/.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) (fma.f64 i (*.f64 i 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i 4) (pow.f64 (cbrt.f64 (fma.f64 i (*.f64 i 4) -1)) 2)) (/.f64 (/.f64 1/4 (*.f64 i i)) (cbrt.f64 (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (fma.f64 i (*.f64 i 4) -1)) 2)) (/.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))) (cbrt.f64 (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) 2) (pow.f64 (cbrt.f64 (fma.f64 i (*.f64 i 4) -1)) 2)) (cbrt.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) (pow.f64 (cbrt.f64 (fma.f64 i (*.f64 i 4) -1)) 2)) (/.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) (cbrt.f64 (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i 4) (sqrt.f64 (fma.f64 i (*.f64 i 4) -1))) (/.f64 (/.f64 1/4 (*.f64 i i)) (sqrt.f64 (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (fma.f64 i (*.f64 i 4) -1))) (/.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))) (sqrt.f64 (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) 2) (sqrt.f64 (fma.f64 i (*.f64 i 4) -1))) (/.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) (sqrt.f64 (fma.f64 i (*.f64 i 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i 4) (fma.f64 i 2 1)) (/.f64 (/.f64 1/4 (*.f64 i i)) (fma.f64 i 2 -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 i 2 1)) (/.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))) (fma.f64 i 2 -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) 2) (fma.f64 i 2 1)) (/.f64 (cbrt.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i)))) (fma.f64 i 2 -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) (fma.f64 i 2 1)) (/.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) (fma.f64 i 2 -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))) (+.f64 (pow.f64 (+.f64 i i) 6) -1)) (fma.f64 16 (pow.f64 i 4) (fma.f64 (*.f64 4 i) i 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))) (fma.f64 16 (pow.f64 i 4) -1)) (fma.f64 (*.f64 4 i) i 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (*.f64 (/.f64 i i) (/.f64 i 2)) (sqrt.f64 (fma.f64 i (*.f64 i 4) -1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (fma.f64 i (*.f64 i 4) -1) (*.f64 4 (/.f64 (*.f64 i i) (pow.f64 i 4)))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))) (fma.f64 -4 (*.f64 i i) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (*.f64 (pow.f64 i 4) (/.f64 1/4 (*.f64 i i))) 3) (pow.f64 (fma.f64 i (*.f64 i 4) -1) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (pow.f64 i 4) (*.f64 (*.f64 i (*.f64 i 4)) (fma.f64 i (*.f64 i 4) -1)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (pow.f64 i 4))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (pow.f64 i 4))) (cbrt.f64 (exp.f64 (pow.f64 i 4))))) (log.f64 (cbrt.f64 (exp.f64 (pow.f64 i 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (pow.f64 i 4)))) (log.f64 (sqrt.f64 (exp.f64 (pow.f64 i 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (pow.f64 i 4))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 i 4)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 i i) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 i 4) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (pow.f64 i 4) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 i (cbrt.f64 i)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 i i) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 i 4)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (pow.f64 i 4))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (pow.f64 i 4) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 i 4)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 i 4)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (pow.f64 i 4)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2 (log.f64 i)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 i 4)) 1))))))

simplify58.0ms (1.5%)

Algorithm
egg-herbie
Rules
691×cancel-sign-sub-inv_binary64
657×fma-neg_binary64
473×distribute-lft-out_binary64
413×unswap-sqr_binary64
410×fma-def_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
040318
193315
2218315
3652315
43251315
Stop Event
node limit
Counts
167 → 148
Calls
Call 1
Inputs
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 -1/4 (pow.f64 i 2))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6))))
(+.f64 (*.f64 -16 (pow.f64 i 8)) (+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6)))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
Outputs
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (*.f64 i i))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (*.f64 i i))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (*.f64 i i))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (*.f64 i i))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (*.f64 i i))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (*.f64 i i))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (*.f64 i i))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (*.f64 i i))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (*.f64 i i))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (*.f64 i i))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (*.f64 i i))
(*.f64 1/4 (pow.f64 i 2))
(*.f64 1/4 (*.f64 i i))
(*.f64 -1/4 (pow.f64 i 2))
(*.f64 (*.f64 i i) -1/4)
(*.f64 i (*.f64 i -1/4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 (*.f64 i i) -1/4))
(-.f64 (*.f64 i (*.f64 i -1/4)) (pow.f64 i 4))
(*.f64 i (-.f64 (*.f64 i -1/4) (pow.f64 i 3)))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6))))
(fma.f64 -1 (pow.f64 i 4) (fma.f64 -1/4 (*.f64 i i) (*.f64 -4 (pow.f64 i 6))))
(-.f64 (fma.f64 (*.f64 i i) -1/4 (*.f64 -4 (pow.f64 i 6))) (pow.f64 i 4))
(fma.f64 -4 (pow.f64 i 6) (*.f64 i (-.f64 (*.f64 i -1/4) (pow.f64 i 3))))
(fma.f64 i (-.f64 (*.f64 i -1/4) (pow.f64 i 3)) (*.f64 -4 (pow.f64 i 6)))
(-.f64 (*.f64 -4 (pow.f64 i 6)) (*.f64 (*.f64 i i) (fma.f64 i i 1/4)))
(+.f64 (*.f64 -16 (pow.f64 i 8)) (+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6)))))
(fma.f64 -16 (pow.f64 i 8) (fma.f64 -1 (pow.f64 i 4) (fma.f64 -1/4 (*.f64 i i) (*.f64 -4 (pow.f64 i 6)))))
(fma.f64 -16 (pow.f64 i 8) (-.f64 (fma.f64 (*.f64 i i) -1/4 (*.f64 -4 (pow.f64 i 6))) (pow.f64 i 4)))
(fma.f64 -16 (pow.f64 i 8) (fma.f64 -4 (pow.f64 i 6) (*.f64 i (-.f64 (*.f64 i -1/4) (pow.f64 i 3)))))
(fma.f64 -16 (pow.f64 i 8) (fma.f64 i (-.f64 (*.f64 i -1/4) (pow.f64 i 3)) (*.f64 -4 (pow.f64 i 6))))
(-.f64 (fma.f64 i (*.f64 i -1/4) (fma.f64 -4 (pow.f64 i 6) (*.f64 -16 (pow.f64 i 8)))) (pow.f64 i 4))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 1/16 (/.f64 1/64 (*.f64 i i)))
(+.f64 1/16 (/.f64 (/.f64 1/64 i) i))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (+.f64 1/16 (/.f64 1/64 (*.f64 i i))) (/.f64 1/256 (pow.f64 i 4)))
(+.f64 (+.f64 (/.f64 1/256 (pow.f64 i 4)) (/.f64 (/.f64 1/64 i) i)) 1/16)
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
(+.f64 (/.f64 1/256 (pow.f64 i 4)) (+.f64 (+.f64 1/16 (/.f64 1/1024 (pow.f64 i 6))) (/.f64 1/64 (*.f64 i i))))
(+.f64 (/.f64 1/256 (pow.f64 i 4)) (+.f64 1/16 (+.f64 (/.f64 (/.f64 1/64 i) i) (/.f64 1/1024 (pow.f64 i 6)))))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 (/.f64 1/1024 (pow.f64 i 6)) (/.f64 1/256 (pow.f64 i 4)))))
(+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 (/.f64 1/256 (pow.f64 i 4)) (+.f64 1/16 (/.f64 1/1024 (pow.f64 i 6)))))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 (/.f64 1/256 (pow.f64 i 4)) (/.f64 1/1024 (pow.f64 i 6)))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 1/16 (/.f64 1/64 (*.f64 i i)))
(+.f64 1/16 (/.f64 (/.f64 1/64 i) i))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (+.f64 1/16 (/.f64 1/64 (*.f64 i i))) (/.f64 1/256 (pow.f64 i 4)))
(+.f64 (+.f64 (/.f64 1/256 (pow.f64 i 4)) (/.f64 (/.f64 1/64 i) i)) 1/16)
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
(+.f64 (/.f64 1/256 (pow.f64 i 4)) (+.f64 (+.f64 1/16 (/.f64 1/1024 (pow.f64 i 6))) (/.f64 1/64 (*.f64 i i))))
(+.f64 (/.f64 1/256 (pow.f64 i 4)) (+.f64 1/16 (+.f64 (/.f64 (/.f64 1/64 i) i) (/.f64 1/1024 (pow.f64 i 6)))))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 (/.f64 1/1024 (pow.f64 i 6)) (/.f64 1/256 (pow.f64 i 4)))))
(+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 (/.f64 1/256 (pow.f64 i 4)) (+.f64 1/16 (/.f64 1/1024 (pow.f64 i 6)))))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 (/.f64 1/256 (pow.f64 i 4)) (/.f64 1/1024 (pow.f64 i 6)))))
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)
(pow.f64 i 4)

eval112.0ms (2.9%)

Compiler

Compiled 5022 to 3769 computations (25% saved)

prune34.0ms (0.9%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New2595264
Fresh000
Picked101
Done011
Total2606266
Error
0b
Counts
266 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
32.2b
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))
32.5b
(*.f64 i (*.f64 i -1/4))
31.6b
(+.f64 1/16 (/.f64 (/.f64 1/64 i) i))
0.4b
(/.f64 1/4 (+.f64 4 (*.f64 (/.f64 1 i) (/.f64 -1 i))))
0.3b
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
31.4b
1/16
Compiler

Compiled 48 to 35 computations (27.1% saved)

localize6.0ms (0.1%)

Compiler

Compiled 11 to 7 computations (36.4% saved)

localize7.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))
Compiler

Compiled 20 to 8 computations (60% saved)

series2.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
1.0ms
i
@inf
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))
1.0ms
i
@0
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))
0.0ms
i
@-inf
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))

rewrite54.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
711×pow1_binary64
669×add-log-exp_binary64
669×log1p-expm1-u_binary64
669×expm1-log1p-u_binary64
656×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0613
113713
2181413
Stop Event
node limit
Counts
1 → 19
Calls
Call 1
Inputs
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 i i) -1/4) (*.f64 (*.f64 i (neg.f64 i)) (*.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 i i) -1/4) (*.f64 (*.f64 i i) (*.f64 i (neg.f64 i))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 i (*.f64 i (-.f64 -1/4 (*.f64 i i))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 -1/64 (pow.f64 i 6)) (*.f64 i i)) (+.f64 1/16 (+.f64 (pow.f64 i 4) (*.f64 (*.f64 i i) -1/4))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 1/16 (pow.f64 i 4)) (*.f64 i i)) (+.f64 (*.f64 i i) -1/4))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 i i) (-.f64 -1/64 (pow.f64 i 6))) (+.f64 1/16 (+.f64 (pow.f64 i 4) (*.f64 (*.f64 i i) -1/4))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 i i) (-.f64 1/16 (pow.f64 i 4))) (+.f64 (*.f64 i i) -1/4))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 i (*.f64 i (-.f64 -1/4 (*.f64 i i)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 i (*.f64 i (-.f64 -1/4 (*.f64 i i)))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 i (*.f64 i (-.f64 -1/4 (*.f64 i i))))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 i (sqrt.f64 (-.f64 -1/4 (*.f64 i i)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 i 4) (pow.f64 (-.f64 -1/4 (*.f64 i i)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (pow.f64 (exp.f64 i) i) (-.f64 -1/4 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 i (*.f64 i (-.f64 -1/4 (*.f64 i i)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 i 6) (pow.f64 (-.f64 -1/4 (*.f64 i i)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (-.f64 -1/4 (*.f64 i i)) 3) (pow.f64 i 6)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 i (*.f64 i (-.f64 -1/4 (*.f64 i i))))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 i (*.f64 i (-.f64 -1/4 (*.f64 i i))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 i (*.f64 i (-.f64 -1/4 (*.f64 i i))))))))))

simplify85.0ms (2.2%)

Algorithm
egg-herbie
Rules
777×fma-neg_binary64
648×distribute-rgt-neg-in_binary64
529×distribute-lft-neg-in_binary64
514×fma-def_binary64
379×associate-*l*_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
011145
123136
251136
3146136
4503136
51930136
64416136
76515136
87548136
Stop Event
node limit
Counts
31 → 25
Calls
Call 1
Inputs
(*.f64 -1/4 (pow.f64 i 2))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(*.f64 -1 (pow.f64 i 4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(*.f64 -1 (pow.f64 i 4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
Outputs
(*.f64 -1/4 (pow.f64 i 2))
(*.f64 -1/4 (*.f64 i i))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 -1/4 (*.f64 i i)))
(-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 -1/4 (*.f64 i i)))
(-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 -1/4 (*.f64 i i)))
(-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))
(*.f64 -1 (pow.f64 i 4))
(neg.f64 (pow.f64 i 4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 -1/4 (*.f64 i i)))
(-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 -1/4 (*.f64 i i)))
(-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 -1/4 (*.f64 i i)))
(-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))
(*.f64 -1 (pow.f64 i 4))
(neg.f64 (pow.f64 i 4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 -1/4 (*.f64 i i)))
(-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 -1/4 (*.f64 i i)))
(-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 -1/4 (*.f64 i i)))
(-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))

localize8.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(/.f64 (/.f64 1/64 i) i)
Compiler

Compiled 19 to 13 computations (31.6% saved)

series3.0ms (0.1%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
2.0ms
i
@inf
(/.f64 (/.f64 1/64 i) i)
1.0ms
i
@0
(/.f64 (/.f64 1/64 i) i)
0.0ms
i
@-inf
(/.f64 (/.f64 1/64 i) i)

rewrite52.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
578×pow1_binary64
546×add-log-exp_binary64
546×log1p-expm1-u_binary64
546×expm1-log1p-u_binary64
536×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
057
11137
214817
Stop Event
node limit
Counts
1 → 35
Calls
Call 1
Inputs
(/.f64 (/.f64 1/64 i) i)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (/.f64 1/64 (*.f64 i i))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/64 (*.f64 (/.f64 1 i) (/.f64 1 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/64 (/.f64 (/.f64 1 i) i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/64 (/.f64 1 (*.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/64 i) (/.f64 1 i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/64 (*.f64 i i)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 1/64 (*.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/4 (pow.f64 (cbrt.f64 i) 2)) (pow.f64 (/.f64 1/4 (pow.f64 (cbrt.f64 i) 2)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 1/4 (pow.f64 (cbrt.f64 i) 2)) 2) (/.f64 1/4 (pow.f64 (cbrt.f64 i) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 1/4 (cbrt.f64 i)) 2) (*.f64 (/.f64 1/4 (cbrt.f64 i)) (/.f64 1 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/8 i) (/.f64 1/8 i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 1/64 i)) (*.f64 (sqrt.f64 (/.f64 1/64 i)) (/.f64 1 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 -1/64 i) (/.f64 1 (neg.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 i) (/.f64 1/64 i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (/.f64 1/4 (cbrt.f64 i)) 2) 1) (/.f64 (/.f64 1/4 (cbrt.f64 i)) i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (/.f64 1/64 i)) 1) (/.f64 (sqrt.f64 (/.f64 1/64 i)) i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/64 (pow.f64 (cbrt.f64 i) 2)) (/.f64 (/.f64 1 i) (cbrt.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 i) 2)) (/.f64 (/.f64 1/64 i) (cbrt.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (/.f64 1/4 (cbrt.f64 i)) 2) (pow.f64 (cbrt.f64 i) 2)) (/.f64 1/4 (pow.f64 (cbrt.f64 i) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (/.f64 1/64 i)) (pow.f64 (cbrt.f64 i) 2)) (/.f64 (sqrt.f64 (/.f64 1/64 i)) (cbrt.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/64 (sqrt.f64 i)) (/.f64 (/.f64 1 i) (sqrt.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 i)) (/.f64 (/.f64 1/64 i) (sqrt.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (/.f64 1/4 (cbrt.f64 i)) 2) (sqrt.f64 i)) (/.f64 (/.f64 1/4 (cbrt.f64 i)) (sqrt.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1/64 (*.f64 i i)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 1/64 (*.f64 i i)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1/4 (pow.f64 (cbrt.f64 i) 2)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1/8 i) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 i (*.f64 i 64)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (/.f64 1/64 i) (neg.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 1/64 (*.f64 i i)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 1/64 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 1/64 (*.f64 i i)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 1/64 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 1/64 (*.f64 i i))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 1/64 (*.f64 i i))))))))

simplify180.0ms (4.7%)

Algorithm
egg-herbie
Rules
1140×associate-/r*_binary64
1082×sqr-pow_binary64
560×cube-prod_binary64
554×fabs-mul_binary64
523×pow-sqr_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0684
11184
22084
33584
47584
522484
683484
7204284
8220884
9239284
10260084
11289984
12329284
13377184
14433784
15502384
16585684
17624684
18653884
19681684
20689084
21692684
Stop Event
node limit
Counts
47 → 37
Calls
Call 1
Inputs
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (pow.f64 i 2))
Outputs
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (*.f64 i i))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (*.f64 i i))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (*.f64 i i))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (*.f64 i i))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (*.f64 i i))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (*.f64 i i))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (*.f64 i i))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (*.f64 i i))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (*.f64 i i))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (*.f64 i i))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (*.f64 i i))
(/.f64 1/64 (pow.f64 i 2))
(/.f64 1/64 (*.f64 i i))

localize21.0ms (0.5%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.3b
(*.f64 (/.f64 1 i) (/.f64 -1 i))
0.3b
(/.f64 1/4 (+.f64 4 (*.f64 (/.f64 1 i) (/.f64 -1 i))))
Compiler

Compiled 39 to 30 computations (23.1% saved)

series2.0ms (0%)

Counts
2 → 24
Calls

6 calls:

TimeVariablePointExpression
0.0ms
i
@0
(/.f64 1/4 (+.f64 4 (*.f64 (/.f64 1 i) (/.f64 -1 i))))
0.0ms
i
@0
(*.f64 (/.f64 1 i) (/.f64 -1 i))
0.0ms
i
@-inf
(/.f64 1/4 (+.f64 4 (*.f64 (/.f64 1 i) (/.f64 -1 i))))
0.0ms
i
@inf
(/.f64 1/4 (+.f64 4 (*.f64 (/.f64 1 i) (/.f64 -1 i))))
0.0ms
i
@inf
(*.f64 (/.f64 1 i) (/.f64 -1 i))

rewrite71.0ms (1.8%)

Algorithm
batch-egg-rewrite
Rules
967×pow1_binary64
911×add-log-exp_binary64
909×log1p-expm1-u_binary64
909×expm1-log1p-u_binary64
110×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01120
124214
2306514
Stop Event
node limit
Counts
2 → 56
Calls
Call 1
Inputs
(/.f64 1/4 (+.f64 4 (*.f64 (/.f64 1 i) (/.f64 -1 i))))
(*.f64 (/.f64 1 i) (/.f64 -1 i))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/4 (/.f64 1 (+.f64 4 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 1/4 (+.f64 4 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2)))) (cbrt.f64 (/.f64 1/16 (pow.f64 (+.f64 4 (pow.f64 i -2)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 1/16 (pow.f64 (+.f64 4 (pow.f64 i -2)) 2))) (cbrt.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/2 (sqrt.f64 (+.f64 4 (pow.f64 i -2)))) (/.f64 1/2 (sqrt.f64 (+.f64 4 (pow.f64 i -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1/4 (/.f64 1 (+.f64 (neg.f64 (pow.f64 i -2)) -4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 4 (pow.f64 i -2))) 1/4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/4 (+.f64 64 (pow.f64 (pow.f64 i -2) 3))) (+.f64 16 (*.f64 (pow.f64 i -2) (-.f64 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/4 (-.f64 16 (pow.f64 (pow.f64 i -2) 2))) (+.f64 4 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1/2 (sqrt.f64 (+.f64 4 (pow.f64 i -2)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (+.f64 4 (pow.f64 i -2)) 4) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (/.f64 1/16 (pow.f64 (+.f64 4 (pow.f64 i -2)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 1/4 (+.f64 4 (pow.f64 i -2)))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (pow.f64 i -2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (*.f64 i i))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (*.f64 (neg.f64 i) (neg.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (neg.f64 (*.f64 i i)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (*.f64 (neg.f64 i) i))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (*.f64 i (neg.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (*.f64 i i) -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 i (/.f64 1 i)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 -1 (*.f64 i i))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 -1 (*.f64 (neg.f64 i) (neg.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 -1 (*.f64 (neg.f64 i) i))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 -1 (*.f64 i (neg.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 -1 (/.f64 i (/.f64 1 i)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 1 i) i)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 1 i) (neg.f64 i))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (cbrt.f64 (pow.f64 i -2)) (/.f64 i (/.f64 1 (cbrt.f64 i))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (pow.f64 i -1/2) (/.f64 i (pow.f64 i -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (/.f64 1 i) (sqrt.f64 i)) (sqrt.f64 i))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (/.f64 1 i) 1) i)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (/.f64 1 i) (pow.f64 (cbrt.f64 i) 2)) (cbrt.f64 i))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 i -2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 i) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 i -2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 i i) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (pow.f64 i -2)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (pow.f64 i -2) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (pow.f64 i -2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (pow.f64 i -2) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (pow.f64 i -2)))))))

simplify44.0ms (1.1%)

Algorithm
egg-herbie
Rules
691×cancel-sign-sub-inv_binary64
657×fma-neg_binary64
472×distribute-lft-out_binary64
413×unswap-sqr_binary64
410×fma-def_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
039270
191267
2214267
3648267
43214267
Stop Event
node limit
Counts
80 → 72
Calls
Call 1
Inputs
(*.f64 -1/4 (pow.f64 i 2))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6))))
(+.f64 (*.f64 -16 (pow.f64 i 8)) (+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6)))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
Outputs
(*.f64 -1/4 (pow.f64 i 2))
(*.f64 -1/4 (*.f64 i i))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 -1/4 (*.f64 i i)))
(-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6))))
(fma.f64 -1 (pow.f64 i 4) (fma.f64 -1/4 (*.f64 i i) (*.f64 -4 (pow.f64 i 6))))
(-.f64 (fma.f64 -1/4 (*.f64 i i) (*.f64 -4 (pow.f64 i 6))) (pow.f64 i 4))
(-.f64 (fma.f64 -4 (pow.f64 i 6) (*.f64 -1/4 (*.f64 i i))) (pow.f64 i 4))
(-.f64 (*.f64 -4 (pow.f64 i 6)) (*.f64 (*.f64 i i) (fma.f64 i i 1/4)))
(+.f64 (*.f64 -16 (pow.f64 i 8)) (+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6)))))
(fma.f64 -16 (pow.f64 i 8) (fma.f64 -1 (pow.f64 i 4) (fma.f64 -1/4 (*.f64 i i) (*.f64 -4 (pow.f64 i 6)))))
(fma.f64 -16 (pow.f64 i 8) (-.f64 (fma.f64 -1/4 (*.f64 i i) (*.f64 -4 (pow.f64 i 6))) (pow.f64 i 4)))
(-.f64 (fma.f64 -16 (pow.f64 i 8) (fma.f64 -4 (pow.f64 i 6) (*.f64 -1/4 (*.f64 i i)))) (pow.f64 i 4))
(fma.f64 -4 (pow.f64 i 6) (fma.f64 -16 (pow.f64 i 8) (-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))))
(-.f64 (*.f64 -16 (pow.f64 i 8)) (fma.f64 i (*.f64 i (fma.f64 i i 1/4)) (*.f64 4 (pow.f64 i 6))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 1/16 (/.f64 1/64 (*.f64 i i)))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (+.f64 1/16 (/.f64 1/64 (*.f64 i i))) (/.f64 1/256 (pow.f64 i 4)))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 1/16 (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
(+.f64 (/.f64 1/256 (pow.f64 i 4)) (+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/1024 (pow.f64 i 6)))))
(+.f64 1/16 (+.f64 (/.f64 1/1024 (pow.f64 i 6)) (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/256 (pow.f64 i 4)))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 1/16 (/.f64 1/64 (*.f64 i i)))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (+.f64 1/16 (/.f64 1/64 (*.f64 i i))) (/.f64 1/256 (pow.f64 i 4)))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 1/16 (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
(+.f64 (/.f64 1/256 (pow.f64 i 4)) (+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/1024 (pow.f64 i 6)))))
(+.f64 1/16 (+.f64 (/.f64 1/1024 (pow.f64 i 6)) (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/256 (pow.f64 i 4)))))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))

eval36.0ms (0.9%)

Compiler

Compiled 1532 to 1132 computations (26.1% saved)

prune29.0ms (0.7%)

Pruning

6 alts after pruning (2 fresh and 4 done)

PrunedKeptTotal
New1322134
Fresh101
Picked101
Done044
Total1346140
Error
0b
Counts
140 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
32.2b
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))
32.5b
(*.f64 i (*.f64 i -1/4))
31.6b
(+.f64 1/16 (/.f64 (/.f64 1/64 i) i))
0.3b
(/.f64 1/4 (+.f64 4 (/.f64 (/.f64 1 i) (neg.f64 i))))
0.3b
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
31.4b
1/16
Compiler

Compiled 47 to 34 computations (27.7% saved)

localize13.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.1b
(/.f64 (/.f64 1 i) (neg.f64 i))
0.3b
(/.f64 1/4 (+.f64 4 (/.f64 (/.f64 1 i) (neg.f64 i))))
Compiler

Compiled 34 to 22 computations (35.3% saved)

series2.0ms (0%)

Counts
2 → 24
Calls

6 calls:

TimeVariablePointExpression
0.0ms
i
@0
(/.f64 1/4 (+.f64 4 (/.f64 (/.f64 1 i) (neg.f64 i))))
0.0ms
i
@-inf
(/.f64 1/4 (+.f64 4 (/.f64 (/.f64 1 i) (neg.f64 i))))
0.0ms
i
@inf
(/.f64 1/4 (+.f64 4 (/.f64 (/.f64 1 i) (neg.f64 i))))
0.0ms
i
@-inf
(/.f64 (/.f64 1 i) (neg.f64 i))
0.0ms
i
@0
(/.f64 (/.f64 1 i) (neg.f64 i))

rewrite58.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
942×pow1_binary64
890×add-log-exp_binary64
889×log1p-expm1-u_binary64
889×expm1-log1p-u_binary64
107×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01024
122814
2313014
Stop Event
node limit
Counts
2 → 57
Calls
Call 1
Inputs
(/.f64 1/4 (+.f64 4 (/.f64 (/.f64 1 i) (neg.f64 i))))
(/.f64 (/.f64 1 i) (neg.f64 i))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/4 (/.f64 1 (+.f64 4 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4))) (pow.f64 (cbrt.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4))) 2) (cbrt.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4))) (sqrt.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1/4 (/.f64 1 (+.f64 (pow.f64 i -2) -4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 4 (pow.f64 i -2))) 1/4)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/4 (+.f64 64 (pow.f64 (pow.f64 i -2) 3))) (+.f64 16 (*.f64 (pow.f64 i -2) (-.f64 (pow.f64 i -2) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/4 (+.f64 16 (pow.f64 (pow.f64 i -2) 2))) (+.f64 4 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (+.f64 4 (pow.f64 i -2)) 4) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 -1/4 (+.f64 (pow.f64 i -2) -4))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (pow.f64 i -2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 i -2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 i) (/.f64 1 i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 i -2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (pow.f64 i -2)) 2) (cbrt.f64 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 i -2)) (pow.f64 (cbrt.f64 (pow.f64 i -2)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 i -2)) (/.f64 (/.f64 1 i) (cbrt.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 i -2)) (*.f64 (/.f64 1 (cbrt.f64 i)) (/.f64 1 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 i -1/2) (/.f64 (/.f64 1 i) (sqrt.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 i -1/2) (*.f64 (pow.f64 i -1/2) (/.f64 1 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (pow.f64 i -2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 1 i) (pow.f64 i -1/2)) (pow.f64 i -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 i -2)) 1) (/.f64 (/.f64 1 (cbrt.f64 i)) i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i -1/2) 1) (/.f64 (pow.f64 i -1/2) i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 i -2)) (pow.f64 (cbrt.f64 i) 2)) (cbrt.f64 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i -1/2) (pow.f64 (cbrt.f64 i) 2)) (/.f64 (pow.f64 i -1/2) (cbrt.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 i -2)) (sqrt.f64 i)) (/.f64 (/.f64 1 (cbrt.f64 i)) (sqrt.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 i -2)) -1) (/.f64 (/.f64 1 (cbrt.f64 i)) i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 i -1/2) -1) (/.f64 (pow.f64 i -1/2) i))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 1 i) (cbrt.f64 (pow.f64 i -2))) (/.f64 1 (cbrt.f64 i)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 i -2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 i) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 i -2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (pow.f64 i -2)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (pow.f64 i -2) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 i i) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (pow.f64 i -2))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (pow.f64 i -2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (pow.f64 i -2))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (pow.f64 i -2) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 i -2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (pow.f64 i -2)))))))

simplify43.0ms (1.1%)

Algorithm
egg-herbie
Rules
691×cancel-sign-sub-inv_binary64
657×fma-neg_binary64
472×distribute-lft-out_binary64
413×unswap-sqr_binary64
410×fma-def_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
039270
191267
2214267
3648267
43214267
Stop Event
node limit
Counts
81 → 74
Calls
Call 1
Inputs
(*.f64 -1/4 (pow.f64 i 2))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6))))
(+.f64 (*.f64 -16 (pow.f64 i 8)) (+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6)))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (pow.f64 i 2))
Outputs
(*.f64 -1/4 (pow.f64 i 2))
(*.f64 -1/4 (*.f64 i i))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (*.f64 -1/4 (pow.f64 i 2)))
(fma.f64 -1 (pow.f64 i 4) (*.f64 -1/4 (*.f64 i i)))
(-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))
(+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6))))
(fma.f64 -1 (pow.f64 i 4) (fma.f64 -1/4 (*.f64 i i) (*.f64 -4 (pow.f64 i 6))))
(-.f64 (fma.f64 -1/4 (*.f64 i i) (*.f64 -4 (pow.f64 i 6))) (pow.f64 i 4))
(-.f64 (fma.f64 -4 (pow.f64 i 6) (*.f64 -1/4 (*.f64 i i))) (pow.f64 i 4))
(-.f64 (*.f64 -4 (pow.f64 i 6)) (*.f64 (*.f64 i i) (fma.f64 i i 1/4)))
(+.f64 (*.f64 -16 (pow.f64 i 8)) (+.f64 (*.f64 -1 (pow.f64 i 4)) (+.f64 (*.f64 -1/4 (pow.f64 i 2)) (*.f64 -4 (pow.f64 i 6)))))
(fma.f64 -16 (pow.f64 i 8) (fma.f64 -1 (pow.f64 i 4) (fma.f64 -1/4 (*.f64 i i) (*.f64 -4 (pow.f64 i 6)))))
(fma.f64 -16 (pow.f64 i 8) (-.f64 (fma.f64 -1/4 (*.f64 i i) (*.f64 -4 (pow.f64 i 6))) (pow.f64 i 4)))
(-.f64 (fma.f64 -16 (pow.f64 i 8) (fma.f64 -4 (pow.f64 i 6) (*.f64 -1/4 (*.f64 i i)))) (pow.f64 i 4))
(fma.f64 -4 (pow.f64 i 6) (fma.f64 -16 (pow.f64 i 8) (-.f64 (*.f64 -1/4 (*.f64 i i)) (pow.f64 i 4))))
(-.f64 (*.f64 -16 (pow.f64 i 8)) (fma.f64 i (*.f64 i (fma.f64 i i 1/4)) (*.f64 4 (pow.f64 i 6))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 1/16 (/.f64 1/64 (*.f64 i i)))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (+.f64 1/16 (/.f64 1/64 (*.f64 i i))) (/.f64 1/256 (pow.f64 i 4)))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 1/16 (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
(+.f64 (/.f64 1/256 (pow.f64 i 4)) (+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/1024 (pow.f64 i 6)))))
(+.f64 1/16 (+.f64 (/.f64 1/1024 (pow.f64 i 6)) (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/256 (pow.f64 i 4)))))
1/16
(+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))
(+.f64 1/16 (/.f64 1/64 (*.f64 i i)))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (*.f64 1/64 (/.f64 1 (pow.f64 i 2)))))
(+.f64 (+.f64 1/16 (/.f64 1/64 (*.f64 i i))) (/.f64 1/256 (pow.f64 i 4)))
(+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (/.f64 1/64 (*.f64 i i)) (+.f64 1/16 (/.f64 1/256 (pow.f64 i 4))))
(+.f64 (*.f64 1/256 (/.f64 1 (pow.f64 i 4))) (+.f64 1/16 (+.f64 (*.f64 1/1024 (/.f64 1 (pow.f64 i 6))) (*.f64 1/64 (/.f64 1 (pow.f64 i 2))))))
(+.f64 (/.f64 1/256 (pow.f64 i 4)) (+.f64 1/16 (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/1024 (pow.f64 i 6)))))
(+.f64 1/16 (+.f64 (/.f64 1/1024 (pow.f64 i 6)) (+.f64 (/.f64 1/64 (*.f64 i i)) (/.f64 1/256 (pow.f64 i 4)))))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))
(/.f64 -1 (pow.f64 i 2))
(/.f64 -1 (*.f64 i i))

eval22.0ms (0.6%)

Compiler

Compiled 898 to 742 computations (17.4% saved)

prune11.0ms (0.3%)

Pruning

6 alts after pruning (1 fresh and 5 done)

PrunedKeptTotal
New74074
Fresh011
Picked011
Done044
Total74680
Error
0b
Counts
80 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
32.2b
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))
32.5b
(*.f64 i (*.f64 i -1/4))
31.6b
(+.f64 1/16 (/.f64 (/.f64 1/64 i) i))
0.3b
(/.f64 1/4 (+.f64 4 (/.f64 (/.f64 1 i) (neg.f64 i))))
0.3b
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
31.4b
1/16
Compiler

Compiled 47 to 34 computations (27.7% saved)

eval0.0ms (0%)

Compiler

Compiled 1 to 1 computations (0% saved)

prune3.0ms (0.1%)

Pruning

6 alts after pruning (1 fresh and 5 done)

PrunedKeptTotal
New000
Fresh011
Picked000
Done055
Total066
Error
0b
Counts
6 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
32.2b
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))
32.5b
(*.f64 i (*.f64 i -1/4))
31.6b
(+.f64 1/16 (/.f64 (/.f64 1/64 i) i))
0.3b
(/.f64 1/4 (+.f64 4 (/.f64 (/.f64 1 i) (neg.f64 i))))
0.3b
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
31.4b
1/16
Compiler

Compiled 47 to 34 computations (27.7% saved)

regimes56.0ms (1.5%)

Counts
9 → 1
Calls
Call 1
Inputs
1/16
1/16
(*.f64 i (*.f64 i -1/4))
(+.f64 1/16 (/.f64 (/.f64 1/64 i) i))
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
(/.f64 1/4 (+.f64 4 (/.f64 (/.f64 1 i) (neg.f64 i))))
(/.f64 1/4 (+.f64 4 (*.f64 (/.f64 1 i) (/.f64 -1 i))))
(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))
Outputs
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
Calls

3 calls:

44.0ms
(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))
6.0ms
i
4.0ms
(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))
Results
ErrorSegmentsBranch
0.3b1i
0.3b1(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))
0.3b1(/.f64 (/.f64 (*.f64 (*.f64 i i) (*.f64 i i)) (*.f64 (*.f64 2 i) (*.f64 2 i))) (-.f64 (*.f64 (*.f64 2 i) (*.f64 2 i)) 1))
Compiler

Compiled 133 to 88 computations (33.8% saved)

regimes17.0ms (0.4%)

Counts
5 → 2
Calls
Call 1
Inputs
1/16
1/16
(*.f64 i (*.f64 i -1/4))
(+.f64 1/16 (/.f64 (/.f64 1/64 i) i))
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))
Outputs
(*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i)))
(+.f64 1/16 (/.f64 (/.f64 1/64 i) i))
Calls

1 calls:

16.0ms
i
Results
ErrorSegmentsBranch
0.2b2i
Compiler

Compiled 26 to 16 computations (38.5% saved)

bsearch27.0ms (0.7%)

Algorithm
binary-search
Steps
TimeLeftRight
27.0ms
0.00012387664648386409
104.65918454657539
Compiler

Compiled 30 to 20 computations (33.3% saved)

regimes9.0ms (0.2%)

Counts
4 → 2
Calls
Call 1
Inputs
1/16
1/16
(*.f64 i (*.f64 i -1/4))
(+.f64 1/16 (/.f64 (/.f64 1/64 i) i))
Outputs
(*.f64 i (*.f64 i -1/4))
(+.f64 1/16 (/.f64 (/.f64 1/64 i) i))
Calls

1 calls:

8.0ms
i
Results
ErrorSegmentsBranch
0.6b2i
Compiler

Compiled 17 to 12 computations (29.4% saved)

bsearch26.0ms (0.7%)

Algorithm
binary-search
Steps
TimeLeftRight
25.0ms
0.00012387664648386409
104.65918454657539
Compiler

Compiled 30 to 20 computations (33.3% saved)

regimes29.0ms (0.7%)

Counts
3 → 2
Calls
Call 1
Inputs
1/16
1/16
(*.f64 i (*.f64 i -1/4))
Outputs
(*.f64 i (*.f64 i -1/4))
1/16
Calls

1 calls:

27.0ms
i
Results
ErrorSegmentsBranch
0.9b2i
Compiler

Compiled 10 to 7 computations (30% saved)

bsearch25.0ms (0.7%)

Algorithm
binary-search
Steps
TimeLeftRight
25.0ms
0.00012387664648386409
104.65918454657539
Compiler

Compiled 30 to 20 computations (33.3% saved)

regimes4.0ms (0.1%)

Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0.0b (-0%)

Counts
2 → 1
Calls
Call 1
Inputs
1/16
1/16
Outputs
1/16
Calls

1 calls:

3.0ms
i
Results
ErrorSegmentsBranch
31.4b1i
Compiler

Compiled 5 to 4 computations (20% saved)

simplify7.0ms (0.2%)

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
02580
13580
24280
34680
44880
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
(if (<=.f64 i 2285120794397233/18446744073709551616) (*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i))) (+.f64 1/16 (/.f64 (/.f64 1/64 i) i)))
(if (<=.f64 i 2285120794397233/18446744073709551616) (*.f64 i (*.f64 i -1/4)) (+.f64 1/16 (/.f64 (/.f64 1/64 i) i)))
(if (<=.f64 i 2285120794397233/18446744073709551616) (*.f64 i (*.f64 i -1/4)) 1/16)
1/16
Outputs
(/.f64 1/4 (+.f64 4 (/.f64 -1 (*.f64 i i))))
(if (<=.f64 i 2285120794397233/18446744073709551616) (*.f64 (*.f64 i i) (-.f64 -1/4 (*.f64 i i))) (+.f64 1/16 (/.f64 (/.f64 1/64 i) i)))
(if (<=.f64 i 2285120794397233/18446744073709551616) (*.f64 i (*.f64 i -1/4)) (+.f64 1/16 (/.f64 (/.f64 1/64 i) i)))
(if (<=.f64 i 2285120794397233/18446744073709551616) (*.f64 i (*.f64 i -1/4)) 1/16)
1/16
Compiler

Compiled 61 to 43 computations (29.5% saved)

soundness311.0ms (8.1%)

Algorithm
egg-herbie
Rules
691×cancel-sign-sub-inv_binary64
691×cancel-sign-sub-inv_binary64
657×fma-neg_binary64
657×fma-neg_binary64
579×associate-/r*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01131
14026
220017
3134113
4377413
5622013
039270
191267
2214267
3643267
43200267
040318
193315
2218315
3652315
43251315
Stop Event
node limit
node limit
node limit
Compiler

Compiled 774 to 504 computations (34.9% saved)

end71.0ms (1.8%)

Compiler

Compiled 57 to 38 computations (33.3% saved)

Profiling

Loading profile data...