Details

Time bar (total: 6.8s)

analyze1.3s (19.6%)

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

Compiled 16 to 11 computations (31.3% saved)

sample4.1s (59.9%)

Results
2.5s4102×body2048valid
985.0ms2088×body1024valid
349.0ms1036×body512valid
144.0ms527×body256valid
65.0ms503×body128valid
1.0msbody128invalid
Compiler

Compiled 32 to 22 computations (31.3% saved)

preprocess36.0ms (0.5%)

Algorithm
egg-herbie
Rules
685×div-sub_binary64
303×associate-/r*_binary64
302×fma-def_binary64
296×fma-neg_binary64
220×associate-/l/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01019
13119
27617
321517
464017
5182817
6439417
011
Stop Event
saturated
node limit
Calls
Call 1
Inputs
0
Outputs
0
Call 2
Inputs
(acos.f64 (/.f64 (-.f64 1 (*.f64 5 (*.f64 v v))) (-.f64 (*.f64 v v) 1)))
Outputs
(acos.f64 (/.f64 (-.f64 1 (*.f64 5 (*.f64 v v))) (-.f64 (*.f64 v v) 1)))
(acos.f64 (/.f64 (+.f64 1 (*.f64 -5 (*.f64 v v))) (fma.f64 v v -1)))
(acos.f64 (/.f64 (+.f64 1 (*.f64 (*.f64 v v) -5)) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 (*.f64 v v) -5 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
Compiler

Compiled 15 to 10 computations (33.3% saved)

simplify28.0ms (0.4%)

Algorithm
egg-herbie
Rules
685×div-sub_binary64
303×associate-/r*_binary64
302×fma-def_binary64
296×fma-neg_binary64
220×associate-/l/_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01019
13119
27617
321517
464017
5182817
6439417
Stop Event
node limit
Counts
1 → 2
Calls
Call 1
Inputs
(acos.f64 (/.f64 (-.f64 1 (*.f64 5 (*.f64 v v))) (-.f64 (*.f64 v v) 1)))
Outputs
(acos.f64 (/.f64 (-.f64 1 (*.f64 5 (*.f64 v v))) (-.f64 (*.f64 v v) 1)))
(acos.f64 (/.f64 (+.f64 1 (*.f64 -5 (*.f64 v v))) (fma.f64 v v -1)))
(acos.f64 (/.f64 (+.f64 1 (*.f64 (*.f64 v v) -5)) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 (*.f64 v v) -5 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))

prune3.0ms (0%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New112
Fresh101
Picked000
Done000
Total213
Error
0.7b
Counts
3 → 1
Alt Table
StatusErrorProgram
0.7b
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
Compiler

Compiled 53 to 36 computations (32.1% saved)

localize7.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 v (*.f64 v -5) 1)
0.0b
(/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))
0.6b
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))

series5.0ms (0.1%)

Counts
3 → 36
Calls

9 calls:

TimeVariablePointExpression
1.0ms
v
@0
(/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))
1.0ms
v
@-inf
(/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))
1.0ms
v
@inf
(/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))
1.0ms
v
@inf
(fma.f64 v (*.f64 v -5) 1)
1.0ms
v
@-inf
(fma.f64 v (*.f64 v -5) 1)

rewrite51.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
891×log1p-expm1-u_binary64
891×expm1-log1p-u_binary64
98×add-sqr-sqrt_binary64
93×*-un-lft-identity_binary64
93×pow1_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01040
119940
2233140
Stop Event
node limit
Counts
3 → 78
Calls
Call 1
Inputs
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))
(fma.f64 v (*.f64 v -5) 1)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (PI.f64) 1/2) (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (PI.f64) 1/2) (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (sqrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (PI.f64) 1/2) 3) (pow.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3)) (+.f64 (*.f64 (*.f64 (PI.f64) 1/2) (*.f64 (PI.f64) 1/2)) (+.f64 (*.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (*.f64 (*.f64 (PI.f64) 1/2) (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 (PI.f64) 1/2) (*.f64 (PI.f64) 1/2)) (*.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (+.f64 (*.f64 (PI.f64) 1/2) (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 v (*.f64 v -5) 1) (/.f64 1 (fma.f64 v v -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) (pow.f64 (cbrt.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 2) (cbrt.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 v (*.f64 v -5) 1)) 2) (*.f64 (cbrt.f64 (fma.f64 v (*.f64 v -5) 1)) (/.f64 1 (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) (sqrt.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 v (*.f64 v -5) 1)) (*.f64 (sqrt.f64 (fma.f64 v (*.f64 v -5) 1)) (/.f64 1 (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (fma.f64 v (*.f64 v -5) 1)) (/.f64 1 (neg.f64 (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 v v -1)) (fma.f64 v (*.f64 v -5) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 v (*.f64 v -5) 1)) 2) 1) (/.f64 (cbrt.f64 (fma.f64 v (*.f64 v -5) 1)) (fma.f64 v v -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (fma.f64 v (*.f64 v -5) 1)) 1) (/.f64 (sqrt.f64 (fma.f64 v (*.f64 v -5) 1)) (fma.f64 v v -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cbrt.f64 (pow.f64 (fma.f64 v v -1) 2))) (/.f64 (fma.f64 v (*.f64 v -5) 1) (cbrt.f64 (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 v (*.f64 v -5) 1)) 2) (cbrt.f64 (pow.f64 (fma.f64 v v -1) 2))) (cbrt.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (fma.f64 v (*.f64 v -5) 1)) (cbrt.f64 (pow.f64 (fma.f64 v v -1) 2))) (/.f64 (sqrt.f64 (fma.f64 v (*.f64 v -5) 1)) (cbrt.f64 (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (fma.f64 v v -1))) (/.f64 (fma.f64 v (*.f64 v -5) 1) (sqrt.f64 (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (fma.f64 v (*.f64 v -5) 1)) 2) (sqrt.f64 (fma.f64 v v -1))) (/.f64 (cbrt.f64 (fma.f64 v (*.f64 v -5) 1)) (sqrt.f64 (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 v v -1) (fma.f64 v (*.f64 v -5) 1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (neg.f64 (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (fma.f64 v (*.f64 v -5) 1) 3) (pow.f64 (fma.f64 v v -1) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (*.f64 v (*.f64 v -5)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 v (*.f64 v -5)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 v (*.f64 v -5)) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 v (*.f64 v -5) 1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 v (*.f64 v -5) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 v (*.f64 v -5) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 v (*.f64 v -5) 1)) (pow.f64 (cbrt.f64 (fma.f64 v (*.f64 v -5) 1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 v (*.f64 v -5) 1)) 2) (cbrt.f64 (fma.f64 v (*.f64 v -5) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 v (*.f64 v -5) 1)) (sqrt.f64 (fma.f64 v (*.f64 v -5) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 v (*.f64 v -5)) 3) 1) (+.f64 (*.f64 (*.f64 v (*.f64 v -5)) (*.f64 v (*.f64 v -5))) (-.f64 1 (*.f64 (*.f64 v (*.f64 v -5)) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 v (*.f64 v -5)) (*.f64 v (*.f64 v -5))) 1) (-.f64 (*.f64 v (*.f64 v -5)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 v (*.f64 v -5) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 v (*.f64 v -5) 1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 v (*.f64 v -5) 1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 v (*.f64 v -5) 1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 v (*.f64 v -5) 1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 v (*.f64 v -5) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 v (*.f64 v -5) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 v (*.f64 v -5) 1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 v (*.f64 v -5) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 v (*.f64 v -5) 1)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 v (*.f64 v -5) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 v (*.f64 v -5) 1)))))))

simplify36.0ms (0.5%)

Algorithm
egg-herbie
Rules
660×cancel-sign-sub-inv_binary64
537×fma-def_binary64
285×unswap-sqr_binary64
211×distribute-neg-frac_binary64
195×associate-*l*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
042485
1118448
2329446
31005446
43277446
Stop Event
node limit
Counts
114 → 99
Calls
Call 1
Inputs
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
-1
(-.f64 (*.f64 4 (pow.f64 v 2)) 1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (+.f64 (*.f64 4 (pow.f64 v 4)) (*.f64 4 (pow.f64 v 6)))) 1)
-5
(neg.f64 (+.f64 5 (*.f64 4 (/.f64 1 (pow.f64 v 2)))))
(neg.f64 (+.f64 5 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 v 2))) (*.f64 4 (/.f64 1 (pow.f64 v 4))))))
(neg.f64 (+.f64 5 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 v 6))) (+.f64 (*.f64 4 (/.f64 1 (pow.f64 v 2))) (*.f64 4 (/.f64 1 (pow.f64 v 4)))))))
-5
(neg.f64 (+.f64 5 (*.f64 4 (/.f64 1 (pow.f64 v 2)))))
(neg.f64 (+.f64 5 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 v 2))) (*.f64 4 (/.f64 1 (pow.f64 v 4))))))
(neg.f64 (+.f64 5 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 v 6))) (+.f64 (*.f64 4 (/.f64 1 (pow.f64 v 2))) (*.f64 4 (/.f64 1 (pow.f64 v 4)))))))
1
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(*.f64 -5 (pow.f64 v 2))
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(*.f64 -5 (pow.f64 v 2))
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
Outputs
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
-1
(-.f64 (*.f64 4 (pow.f64 v 2)) 1)
(fma.f64 4 (*.f64 v v) -1)
(fma.f64 v (*.f64 v 4) -1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(+.f64 (*.f64 4 (+.f64 (*.f64 v v) (pow.f64 v 4))) -1)
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (+.f64 (*.f64 4 (pow.f64 v 4)) (*.f64 4 (pow.f64 v 6)))) 1)
(+.f64 (fma.f64 4 (*.f64 v v) (*.f64 4 (+.f64 (pow.f64 v 4) (pow.f64 v 6)))) -1)
(+.f64 -1 (*.f64 4 (+.f64 (fma.f64 v v (pow.f64 v 4)) (pow.f64 v 6))))
(fma.f64 4 (fma.f64 v v (+.f64 (pow.f64 v 4) (pow.f64 v 6))) -1)
(fma.f64 4 (+.f64 (pow.f64 v 4) (fma.f64 v v (pow.f64 v 6))) -1)
-5
(neg.f64 (+.f64 5 (*.f64 4 (/.f64 1 (pow.f64 v 2)))))
(+.f64 -5 (neg.f64 (/.f64 4 (*.f64 v v))))
(+.f64 -5 (/.f64 -4 (*.f64 v v)))
(-.f64 -5 (/.f64 4 (*.f64 v v)))
(neg.f64 (+.f64 5 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 v 2))) (*.f64 4 (/.f64 1 (pow.f64 v 4))))))
(+.f64 -5 (neg.f64 (+.f64 (/.f64 4 (*.f64 v v)) (/.f64 4 (pow.f64 v 4)))))
(-.f64 (+.f64 -5 (/.f64 -4 (*.f64 v v))) (/.f64 4 (pow.f64 v 4)))
(+.f64 -5 (+.f64 (/.f64 -4 (*.f64 v v)) (/.f64 -4 (pow.f64 v 4))))
(neg.f64 (+.f64 5 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 v 6))) (+.f64 (*.f64 4 (/.f64 1 (pow.f64 v 2))) (*.f64 4 (/.f64 1 (pow.f64 v 4)))))))
(+.f64 -5 (neg.f64 (+.f64 (+.f64 (/.f64 4 (*.f64 v v)) (/.f64 4 (pow.f64 v 4))) (/.f64 4 (pow.f64 v 6)))))
(-.f64 -5 (+.f64 (/.f64 4 (pow.f64 v 4)) (+.f64 (/.f64 4 (*.f64 v v)) (/.f64 4 (pow.f64 v 6)))))
(+.f64 (+.f64 (+.f64 -5 (/.f64 -4 (pow.f64 v 6))) (/.f64 -4 (pow.f64 v 4))) (/.f64 -4 (*.f64 v v)))
(+.f64 (/.f64 -4 (*.f64 v v)) (+.f64 -5 (-.f64 (/.f64 -4 (pow.f64 v 6)) (/.f64 4 (pow.f64 v 4)))))
(+.f64 -5 (-.f64 (-.f64 (/.f64 -4 (*.f64 v v)) (/.f64 4 (pow.f64 v 6))) (/.f64 4 (pow.f64 v 4))))
-5
(neg.f64 (+.f64 5 (*.f64 4 (/.f64 1 (pow.f64 v 2)))))
(+.f64 -5 (neg.f64 (/.f64 4 (*.f64 v v))))
(+.f64 -5 (/.f64 -4 (*.f64 v v)))
(-.f64 -5 (/.f64 4 (*.f64 v v)))
(neg.f64 (+.f64 5 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 v 2))) (*.f64 4 (/.f64 1 (pow.f64 v 4))))))
(+.f64 -5 (neg.f64 (+.f64 (/.f64 4 (*.f64 v v)) (/.f64 4 (pow.f64 v 4)))))
(-.f64 (+.f64 -5 (/.f64 -4 (*.f64 v v))) (/.f64 4 (pow.f64 v 4)))
(+.f64 -5 (+.f64 (/.f64 -4 (*.f64 v v)) (/.f64 -4 (pow.f64 v 4))))
(neg.f64 (+.f64 5 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 v 6))) (+.f64 (*.f64 4 (/.f64 1 (pow.f64 v 2))) (*.f64 4 (/.f64 1 (pow.f64 v 4)))))))
(+.f64 -5 (neg.f64 (+.f64 (+.f64 (/.f64 4 (*.f64 v v)) (/.f64 4 (pow.f64 v 4))) (/.f64 4 (pow.f64 v 6)))))
(-.f64 -5 (+.f64 (/.f64 4 (pow.f64 v 4)) (+.f64 (/.f64 4 (*.f64 v v)) (/.f64 4 (pow.f64 v 6)))))
(+.f64 (+.f64 (+.f64 -5 (/.f64 -4 (pow.f64 v 6))) (/.f64 -4 (pow.f64 v 4))) (/.f64 -4 (*.f64 v v)))
(+.f64 (/.f64 -4 (*.f64 v v)) (+.f64 -5 (-.f64 (/.f64 -4 (pow.f64 v 6)) (/.f64 4 (pow.f64 v 4)))))
(+.f64 -5 (-.f64 (-.f64 (/.f64 -4 (*.f64 v v)) (/.f64 4 (pow.f64 v 6))) (/.f64 4 (pow.f64 v 4))))
1
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (*.f64 v v)))
(fma.f64 v (*.f64 v -5) 1)
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (*.f64 v v)))
(fma.f64 v (*.f64 v -5) 1)
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (*.f64 v v)))
(fma.f64 v (*.f64 v -5) 1)
(*.f64 -5 (pow.f64 v 2))
(*.f64 -5 (*.f64 v v))
(*.f64 v (*.f64 v -5))
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (*.f64 v v)))
(fma.f64 v (*.f64 v -5) 1)
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (*.f64 v v)))
(fma.f64 v (*.f64 v -5) 1)
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (*.f64 v v)))
(fma.f64 v (*.f64 v -5) 1)
(*.f64 -5 (pow.f64 v 2))
(*.f64 -5 (*.f64 v v))
(*.f64 v (*.f64 v -5))
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (*.f64 v v)))
(fma.f64 v (*.f64 v -5) 1)
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (*.f64 v v)))
(fma.f64 v (*.f64 v -5) 1)
(+.f64 1 (*.f64 -5 (pow.f64 v 2)))
(+.f64 1 (*.f64 -5 (*.f64 v v)))
(fma.f64 v (*.f64 v -5) 1)

prune79.0ms (1.2%)

Pruning

5 alts after pruning (5 fresh and 0 done)

PrunedKeptTotal
New94599
Fresh000
Picked101
Done000
Total955100
Error
0.6b
Counts
100 → 5
Alt Table
StatusErrorProgram
1.0b
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
0.7b
(expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
1.6b
(pow.f64 (sqrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)
1.6b
(pow.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 3)
2.1b
(*.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))
Compiler

Compiled 1910 to 1404 computations (26.5% saved)

localize11.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))
0.0b
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
0.1b
(expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
0.6b
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))

series79.0ms (1.2%)

Counts
2 → 24
Calls

6 calls:

TimeVariablePointExpression
29.0ms
v
@inf
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
28.0ms
v
@0
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
20.0ms
v
@-inf
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
0.0ms
v
@0
(expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
0.0ms
v
@-inf
(expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))

rewrite50.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
471×log-prod_binary64
272×pow2_binary64
190×pow1/3_binary64
188×expm1-udef_binary64
188×log1p-udef_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01236
122036
2254036
Stop Event
node limit
Counts
2 → 66
Calls
Call 1
Inputs
(expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) (fma.f64 (neg.f64 (sqrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (sqrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (PI.f64) 1/2) (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (PI.f64) 1/2) (neg.f64 (*.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1))) (fma.f64 (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1 (*.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (PI.f64) 1/2 (neg.f64 (*.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1))) (fma.f64 (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1 (*.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 2) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (*.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1))) (fma.f64 (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1 (*.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (PI.f64) 1/2)) (sqrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (*.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1))) (fma.f64 (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1 (*.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (PI.f64) 1/2) (neg.f64 (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (PI.f64) 1/2 (neg.f64 (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 2) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (PI.f64) 1/2)) (sqrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 2)) (log.f64 (cbrt.f64 (exp.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))) (log.f64 (sqrt.f64 (exp.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (PI.f64) (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (neg.f64 (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (PI.f64) 1/2) (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (sqrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 3) 1) (+.f64 (pow.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) (+.f64 1 (*.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (PI.f64) 1/2) 3) (pow.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3)) (+.f64 (pow.f64 (*.f64 (PI.f64) 1/2) 2) (+.f64 (pow.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 2) (*.f64 (*.f64 (PI.f64) 1/2) (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) 1) (+.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (PI.f64) 1/2) 2) (pow.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 2)) (fma.f64 (PI.f64) 1/2 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (PI.f64) 1/2) (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (PI.f64) 1/2 (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 2) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 2) (cbrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (PI.f64) 1/2)) (sqrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (sqrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 2)) (log.f64 (cbrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))) (log.f64 (sqrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (log1p.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3)) (log.f64 (+.f64 1 (-.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 2) (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (log.f64 (-.f64 1 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 2))) (log.f64 (-.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (cbrt.f64 (pow.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)) (cbrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (sqrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))))

simplify50.0ms (0.7%)

Algorithm
egg-herbie
Rules
862×fma-neg_binary64
335×fma-def_binary64
328×div-sub_binary64
246×sub-neg_binary64
207×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
012432
121432
228432
337432
455432
596432
6178432
7388432
8786432
92475432
104590432
Stop Event
node limit
Counts
90 → 69
Calls
Call 1
Inputs
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
Outputs
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
(log.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 -5 v) 1) (fma.f64 v v -1)))))
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))

prune136.0ms (2%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New1364140
Fresh314
Picked011
Done000
Total1396145
Error
0.6b
Counts
145 → 6
Alt Table
StatusErrorProgram
2.1b
(expm1.f64 (+.f64 (log.f64 (pow.f64 (cbrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 2)) (log.f64 (cbrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))
2.1b
(fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 2) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
2.5b
(+.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 2) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))))
1.0b
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
0.7b
(expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
3.3b
(expm1.f64 (pow.f64 (cbrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 3))
Compiler

Compiled 3792 to 2852 computations (24.8% saved)

localize6.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)
0.6b
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))

series2.0ms (0%)

Counts
2 → 12
Calls

6 calls:

TimeVariablePointExpression
1.0ms
v
@inf
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)
0.0ms
v
@-inf
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)
0.0ms
v
@0
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)
0.0ms
v
@0
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
0.0ms
v
@inf
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))

rewrite41.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
723×pow1_binary64
667×add-log-exp_binary64
667×log1p-expm1-u_binary64
667×expm1-log1p-u_binary64
78×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0826
116426
2180026
Stop Event
node limit
Counts
2 → 43
Calls
Call 1
Inputs
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (PI.f64) 1/2) (neg.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (PI.f64) 1/2) (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) (pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 2) (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) (sqrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (PI.f64) 1/2) 3) (pow.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 3)) (+.f64 (*.f64 (*.f64 (PI.f64) 1/2) (*.f64 (PI.f64) 1/2)) (+.f64 (*.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) (*.f64 (*.f64 (PI.f64) 1/2) (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 (PI.f64) 1/2) (*.f64 (PI.f64) 1/2)) (*.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) (+.f64 (*.f64 (PI.f64) 1/2) (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (*.f64 4 (fma.f64 v v (pow.f64 v 4))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 4 (fma.f64 v v (pow.f64 v 4))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 4 (fma.f64 v v (pow.f64 v 4))) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) (pow.f64 (cbrt.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 2) (cbrt.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) (sqrt.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 4 (fma.f64 v v (pow.f64 v 4))) 3) -1) (+.f64 (*.f64 (*.f64 4 (fma.f64 v v (pow.f64 v 4))) (*.f64 4 (fma.f64 v v (pow.f64 v 4)))) (-.f64 1 (*.f64 (*.f64 4 (fma.f64 v v (pow.f64 v 4))) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 4 (fma.f64 v v (pow.f64 v 4))) (*.f64 4 (fma.f64 v v (pow.f64 v 4)))) 1) (-.f64 (*.f64 4 (fma.f64 v v (pow.f64 v 4))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))))

simplify21.0ms (0.3%)

Algorithm
egg-herbie
Rules
843×fma-def_binary64
451×associate-*l*_binary64
398×distribute-rgt-neg-in_binary64
357×distribute-lft-neg-in_binary64
342×unswap-sqr_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
013145
133117
270117
3164117
4561117
52166117
Stop Event
node limit
Counts
55 → 51
Calls
Call 1
Inputs
-1
(-.f64 (*.f64 4 (pow.f64 v 2)) 1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(*.f64 4 (pow.f64 v 4))
(+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4)))
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(*.f64 4 (pow.f64 v 4))
(+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4)))
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
Outputs
-1
(-.f64 (*.f64 4 (pow.f64 v 2)) 1)
(fma.f64 4 (*.f64 v v) -1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(+.f64 (*.f64 4 (+.f64 (*.f64 v v) (pow.f64 v 4))) -1)
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(+.f64 (*.f64 4 (+.f64 (*.f64 v v) (pow.f64 v 4))) -1)
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)
(*.f64 4 (pow.f64 v 4))
(+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4)))
(*.f64 4 (+.f64 (*.f64 v v) (pow.f64 v 4)))
(*.f64 4 (fma.f64 v v (pow.f64 v 4)))
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(+.f64 (*.f64 4 (+.f64 (*.f64 v v) (pow.f64 v 4))) -1)
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(+.f64 (*.f64 4 (+.f64 (*.f64 v v) (pow.f64 v 4))) -1)
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)
(*.f64 4 (pow.f64 v 4))
(+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4)))
(*.f64 4 (+.f64 (*.f64 v v) (pow.f64 v 4)))
(*.f64 4 (fma.f64 v v (pow.f64 v 4)))
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(+.f64 (*.f64 4 (+.f64 (*.f64 v v) (pow.f64 v 4))) -1)
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 v 2)) (*.f64 4 (pow.f64 v 4))) 1)
(+.f64 (*.f64 4 (+.f64 (*.f64 v v) (pow.f64 v 4))) -1)
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)

prune73.0ms (1.1%)

Pruning

7 alts after pruning (6 fresh and 1 done)

PrunedKeptTotal
New49251
Fresh044
Picked101
Done011
Total50757
Error
0.6b
Counts
57 → 7
Alt Table
StatusErrorProgram
0.7b
(expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
1.0b
(exp.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))
2.1b
(expm1.f64 (+.f64 (log.f64 (pow.f64 (cbrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 2)) (log.f64 (cbrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))
2.1b
(fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 2) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
2.5b
(+.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 2) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))))
2.0b
(pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 3)
3.3b
(expm1.f64 (pow.f64 (cbrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 3))
Compiler

Compiled 1247 to 948 computations (24% saved)

localize12.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)
0.0b
(exp.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))
0.0b
(log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))
0.6b
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))

series78.0ms (1.1%)

Counts
2 → 12
Calls

6 calls:

TimeVariablePointExpression
40.0ms
v
@0
(log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))
20.0ms
v
@-inf
(log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))
17.0ms
v
@inf
(log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))
0.0ms
v
@0
(exp.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))
0.0ms
v
@inf
(exp.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))

rewrite45.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
792×pow1_binary64
729×log1p-expm1-u_binary64
729×expm1-log1p-u_binary64
86×add-sqr-sqrt_binary64
84×*-un-lft-identity_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01030
118830
2198630
Stop Event
node limit
Counts
2 → 43
Calls
Call 1
Inputs
(log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))
(exp.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 2)) (log.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) (log.f64 (sqrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) (pow.f64 (cbrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) 2) (cbrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) (sqrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (-.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (PI.f64) 1/2) (neg.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (PI.f64) 1/2) (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) (pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 2) (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) (sqrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (PI.f64) 1/2) 3) (pow.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 3)) (+.f64 (*.f64 (*.f64 (PI.f64) 1/2) (*.f64 (PI.f64) 1/2)) (+.f64 (*.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) (*.f64 (*.f64 (PI.f64) 1/2) (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 (PI.f64) 1/2) (*.f64 (PI.f64) 1/2)) (*.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) (+.f64 (*.f64 (PI.f64) 1/2) (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) 2)) (cbrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))) (sqrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))))

simplify54.0ms (0.8%)

Algorithm
egg-herbie
Rules
953×fma-def_binary64
447×associate-*l*_binary64
342×unswap-sqr_binary64
284×associate-*r*_binary64
264×sqr-pow_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
08168
116168
231168
368168
4160168
5510168
61859168
73952168
84118168
94317168
104531168
114812168
Stop Event
node limit
Counts
55 → 43
Calls
Call 1
Inputs
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
Outputs
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))

prune86.0ms (1.3%)

Pruning

7 alts after pruning (6 fresh and 1 done)

PrunedKeptTotal
New91394
Fresh235
Picked101
Done011
Total947101
Error
0.6b
Counts
101 → 7
Alt Table
StatusErrorProgram
2.0b
(exp.f64 (log.f64 (pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 3)))
2.1b
(fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 2) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
2.1b
(expm1.f64 (+.f64 (log.f64 (pow.f64 (cbrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 2)) (log.f64 (cbrt.f64 (+.f64 1 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))
2.9b
(exp.f64 (+.f64 (log.f64 (pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 2)) (log.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))
0.7b
(expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
3.3b
(expm1.f64 (pow.f64 (cbrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 3))
3.4b
(exp.f64 (*.f64 (cbrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) (pow.f64 (cbrt.f64 (log.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) 2)))
Compiler

Compiled 1880 to 1462 computations (22.2% saved)

regimes208.0ms (3.1%)

Accuracy

Total 0.0b remaining (3.4%)

Threshold costs 0.0b (3.4%)

Counts
87 → 1
Compiler

Compiled 1533 to 1158 computations (24.5% saved)

simplify2.0ms (0%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
1-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01446
11746
Stop Event
saturated
Calls
Call 1
Inputs
(expm1.f64 (*.f64 (sqrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (sqrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))
Outputs
(expm1.f64 (*.f64 (sqrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (sqrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))

end193.0ms (2.8%)

Stop Event
fuel
Compiler

Compiled 231 to 179 computations (22.5% saved)

Profiling

Loading profile data...