Details

Time bar (total: 1.1s)

analyze42.0ms (3.7%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.9%0.1%0
0%99.9%0.1%1
0%99.9%0.1%2
25%74.9%0.1%3
62.4%37.5%0.1%4
68.7%31.2%0.1%5
68.7%18.7%12.6%6
68.7%17.2%14.1%7
68.7%10.1%21.2%8
68.7%9%22.3%9
68.7%5.3%26%10
68.7%4.6%26.7%11
68.7%2.7%28.6%12
68.7%2.3%29%13
68.7%1.4%30%14
Compiler

Compiled 11 to 7 computations (36.4% saved)

sample796.0ms (70.2%)

Results
780.0ms8256×body128valid
2.0ms30×body128invalid
Compiler

Compiled 22 to 14 computations (36.4% saved)

preprocess16.0ms (1.4%)

Algorithm
egg-herbie
Rules
+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0926
11026
022
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
(/.f64 (exp.f64 b) (+.f64 (exp.f64 b) (exp.f64 a)))
Outputs
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
(/.f64 (exp.f64 b) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 b) (+.f64 (exp.f64 a) (exp.f64 b)))
Compiler

Compiled 10 to 6 computations (40% saved)

simplify7.0ms (0.6%)

Algorithm
egg-herbie
Rules
+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0713
1813
Stop Event
saturated
Counts
1 → 1
Calls
Call 1
Inputs
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
Outputs
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))

prune1.0ms (0.1%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New011
Fresh011
Picked000
Done000
Total022
Error
0.2b
Counts
2 → 1
Alt Table
StatusErrorProgram
0.2b
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
Compiler

Compiled 30 to 18 computations (40% saved)

localize5.0ms (0.4%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))

series8.0ms (0.7%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
3.0ms
b
@0
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
2.0ms
a
@0
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
1.0ms
a
@inf
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
1.0ms
b
@inf
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
1.0ms
a
@-inf
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))

rewrite43.0ms (3.8%)

Algorithm
batch-egg-rewrite
Rules
854×pow1_binary64
793×log1p-expm1-u_binary64
793×expm1-log1p-u_binary64
79×add-sqr-sqrt_binary64
78×*-un-lft-identity_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0713
114713
2211613
Stop Event
node limit
Counts
1 → 35
Calls
Call 1
Inputs
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (exp.f64 a) (/.f64 1 (+.f64 (exp.f64 a) (exp.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (exp.f64 (+.f64 a a))) (*.f64 (cbrt.f64 (exp.f64 a)) (/.f64 1 (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))) (pow.f64 (cbrt.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))) 2) (cbrt.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (exp.f64 a)) (*.f64 (sqrt.f64 (exp.f64 a)) (/.f64 1 (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))) (sqrt.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (exp.f64 a)) (/.f64 1 (neg.f64 (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 (exp.f64 a) (exp.f64 b))) (exp.f64 a))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (exp.f64 (+.f64 a a))) 1) (/.f64 (cbrt.f64 (exp.f64 a)) (+.f64 (exp.f64 a) (exp.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (exp.f64 a)) 1) (/.f64 (sqrt.f64 (exp.f64 a)) (+.f64 (exp.f64 a) (exp.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (+.f64 (exp.f64 a) (exp.f64 b))) 2)) (/.f64 (exp.f64 a) (cbrt.f64 (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (exp.f64 (+.f64 a a))) (pow.f64 (cbrt.f64 (+.f64 (exp.f64 a) (exp.f64 b))) 2)) (cbrt.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (exp.f64 a)) (pow.f64 (cbrt.f64 (+.f64 (exp.f64 a) (exp.f64 b))) 2)) (/.f64 (sqrt.f64 (exp.f64 a)) (cbrt.f64 (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (+.f64 (exp.f64 a) (exp.f64 b)))) (/.f64 (exp.f64 a) (sqrt.f64 (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (exp.f64 (+.f64 a a))) (sqrt.f64 (+.f64 (exp.f64 a) (exp.f64 b)))) (/.f64 (cbrt.f64 (exp.f64 a)) (sqrt.f64 (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 (*.f64 a 3)) (pow.f64 (exp.f64 b) 3))) (+.f64 (exp.f64 (+.f64 a a)) (*.f64 (exp.f64 b) (-.f64 (exp.f64 b) (exp.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 (+.f64 a a)) (pow.f64 (exp.f64 b) 2))) (-.f64 (exp.f64 a) (exp.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 (exp.f64 a) (exp.f64 b)) (exp.f64 a)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (exp.f64 a) (neg.f64 (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (exp.f64 (*.f64 a 3)) (pow.f64 (+.f64 (exp.f64 a) (exp.f64 b)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 a (log.f64 (+.f64 (exp.f64 a) (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 a (log.f64 (+.f64 (exp.f64 a) (exp.f64 b)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))))))))

simplify30.0ms (2.6%)

Algorithm
egg-herbie
Rules
463×times-frac_binary64
306×associate-+l+_binary64
281×associate-/l*_binary64
270×fma-def_binary64
240×associate--l+_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
085782
1280745
2982729
Stop Event
node limit
Counts
59 → 49
Calls
Call 1
Inputs
(/.f64 1 (+.f64 1 (exp.f64 b)))
(-.f64 (+.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) (/.f64 a (+.f64 1 (exp.f64 b)))) (/.f64 a (*.f64 (+.f64 1 (exp.f64 b)) (+.f64 (exp.f64 b) 1))))
(-.f64 (+.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 a 2) (+.f64 1 (exp.f64 b)))) (+.f64 (/.f64 a (+.f64 1 (exp.f64 b))) (/.f64 (pow.f64 a 2) (*.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) (+.f64 (exp.f64 b) 1)))))) (+.f64 (*.f64 3/2 (/.f64 (pow.f64 a 2) (*.f64 (+.f64 1 (exp.f64 b)) (+.f64 (exp.f64 b) 1)))) (/.f64 a (*.f64 (+.f64 1 (exp.f64 b)) (+.f64 (exp.f64 b) 1)))))
(-.f64 (+.f64 (*.f64 1/6 (/.f64 (pow.f64 a 3) (+.f64 1 (exp.f64 b)))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 a 2) (+.f64 1 (exp.f64 b)))) (+.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) (+.f64 (/.f64 a (+.f64 1 (exp.f64 b))) (+.f64 (*.f64 2 (/.f64 (pow.f64 a 3) (*.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) (+.f64 (exp.f64 b) 1)))) (/.f64 (pow.f64 a 2) (*.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) (+.f64 (exp.f64 b) 1)))))))) (+.f64 (*.f64 3/2 (/.f64 (pow.f64 a 2) (*.f64 (+.f64 1 (exp.f64 b)) (+.f64 (exp.f64 b) 1)))) (+.f64 (/.f64 (pow.f64 a 3) (*.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) (pow.f64 (+.f64 (exp.f64 b) 1) 2))) (+.f64 (/.f64 a (*.f64 (+.f64 1 (exp.f64 b)) (+.f64 (exp.f64 b) 1))) (*.f64 7/6 (/.f64 (pow.f64 a 3) (*.f64 (+.f64 1 (exp.f64 b)) (+.f64 (exp.f64 b) 1))))))))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a)))
(-.f64 (/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a))) (/.f64 (*.f64 b (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2)))
(-.f64 (+.f64 (/.f64 (*.f64 (pow.f64 b 2) (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 3)) (/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a)))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (exp.f64 a) (pow.f64 b 2)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))) (/.f64 (*.f64 b (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))))
(-.f64 (+.f64 (/.f64 (*.f64 (pow.f64 b 3) (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 3)) (+.f64 (/.f64 (*.f64 (pow.f64 b 2) (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 3)) (/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a))))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (pow.f64 b 3) (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 b 2) (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))) (+.f64 (/.f64 (*.f64 (pow.f64 b 3) (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 4)) (/.f64 (*.f64 b (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))))))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
Outputs
(/.f64 1 (+.f64 1 (exp.f64 b)))
(-.f64 (+.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) (/.f64 a (+.f64 1 (exp.f64 b)))) (/.f64 a (*.f64 (+.f64 1 (exp.f64 b)) (+.f64 (exp.f64 b) 1))))
(+.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) (-.f64 (/.f64 a (+.f64 1 (exp.f64 b))) (/.f64 a (pow.f64 (+.f64 1 (exp.f64 b)) 2))))
(-.f64 (+.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 a 2) (+.f64 1 (exp.f64 b)))) (+.f64 (/.f64 a (+.f64 1 (exp.f64 b))) (/.f64 (pow.f64 a 2) (*.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) (+.f64 (exp.f64 b) 1)))))) (+.f64 (*.f64 3/2 (/.f64 (pow.f64 a 2) (*.f64 (+.f64 1 (exp.f64 b)) (+.f64 (exp.f64 b) 1)))) (/.f64 a (*.f64 (+.f64 1 (exp.f64 b)) (+.f64 (exp.f64 b) 1)))))
(+.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) (-.f64 (fma.f64 1/2 (/.f64 (*.f64 a a) (+.f64 1 (exp.f64 b))) (+.f64 (/.f64 a (+.f64 1 (exp.f64 b))) (/.f64 (/.f64 (*.f64 a a) (pow.f64 (+.f64 1 (exp.f64 b)) 2)) (+.f64 1 (exp.f64 b))))) (fma.f64 3/2 (/.f64 (*.f64 a a) (pow.f64 (+.f64 1 (exp.f64 b)) 2)) (/.f64 a (pow.f64 (+.f64 1 (exp.f64 b)) 2)))))
(+.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) (+.f64 (fma.f64 1/2 (/.f64 (*.f64 a a) (+.f64 1 (exp.f64 b))) (/.f64 a (+.f64 1 (exp.f64 b)))) (-.f64 (/.f64 (*.f64 a a) (pow.f64 (+.f64 1 (exp.f64 b)) 3)) (fma.f64 3/2 (/.f64 a (/.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) a)) (/.f64 a (pow.f64 (+.f64 1 (exp.f64 b)) 2))))))
(+.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) (+.f64 (/.f64 a (/.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 3) a)) (-.f64 (fma.f64 1/2 (/.f64 a (/.f64 (+.f64 1 (exp.f64 b)) a)) (/.f64 a (+.f64 1 (exp.f64 b)))) (fma.f64 3/2 (/.f64 a (/.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) a)) (/.f64 a (pow.f64 (+.f64 1 (exp.f64 b)) 2))))))
(-.f64 (+.f64 (*.f64 1/6 (/.f64 (pow.f64 a 3) (+.f64 1 (exp.f64 b)))) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 a 2) (+.f64 1 (exp.f64 b)))) (+.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) (+.f64 (/.f64 a (+.f64 1 (exp.f64 b))) (+.f64 (*.f64 2 (/.f64 (pow.f64 a 3) (*.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) (+.f64 (exp.f64 b) 1)))) (/.f64 (pow.f64 a 2) (*.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) (+.f64 (exp.f64 b) 1)))))))) (+.f64 (*.f64 3/2 (/.f64 (pow.f64 a 2) (*.f64 (+.f64 1 (exp.f64 b)) (+.f64 (exp.f64 b) 1)))) (+.f64 (/.f64 (pow.f64 a 3) (*.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) (pow.f64 (+.f64 (exp.f64 b) 1) 2))) (+.f64 (/.f64 a (*.f64 (+.f64 1 (exp.f64 b)) (+.f64 (exp.f64 b) 1))) (*.f64 7/6 (/.f64 (pow.f64 a 3) (*.f64 (+.f64 1 (exp.f64 b)) (+.f64 (exp.f64 b) 1))))))))
(-.f64 (fma.f64 1/6 (/.f64 (pow.f64 a 3) (+.f64 1 (exp.f64 b))) (fma.f64 1/2 (/.f64 (*.f64 a a) (+.f64 1 (exp.f64 b))) (+.f64 (+.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) (/.f64 a (+.f64 1 (exp.f64 b)))) (fma.f64 2 (/.f64 (pow.f64 a 3) (*.f64 (+.f64 1 (exp.f64 b)) (pow.f64 (+.f64 1 (exp.f64 b)) 2))) (/.f64 (/.f64 (*.f64 a a) (pow.f64 (+.f64 1 (exp.f64 b)) 2)) (+.f64 1 (exp.f64 b))))))) (fma.f64 3/2 (/.f64 (*.f64 a a) (pow.f64 (+.f64 1 (exp.f64 b)) 2)) (+.f64 (/.f64 (pow.f64 a 3) (*.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) (pow.f64 (+.f64 1 (exp.f64 b)) 2))) (+.f64 (/.f64 a (pow.f64 (+.f64 1 (exp.f64 b)) 2)) (/.f64 (*.f64 7/6 (pow.f64 a 3)) (pow.f64 (+.f64 1 (exp.f64 b)) 2))))))
(-.f64 (fma.f64 1/6 (/.f64 (pow.f64 a 3) (+.f64 1 (exp.f64 b))) (+.f64 (+.f64 (/.f64 a (+.f64 1 (exp.f64 b))) (fma.f64 2 (/.f64 (pow.f64 a 3) (pow.f64 (+.f64 1 (exp.f64 b)) 3)) (/.f64 (*.f64 a a) (pow.f64 (+.f64 1 (exp.f64 b)) 3)))) (fma.f64 1/2 (/.f64 (*.f64 a a) (+.f64 1 (exp.f64 b))) (/.f64 1 (+.f64 1 (exp.f64 b)))))) (+.f64 (fma.f64 7/6 (/.f64 (pow.f64 a 3) (pow.f64 (+.f64 1 (exp.f64 b)) 2)) (/.f64 a (pow.f64 (+.f64 1 (exp.f64 b)) 2))) (fma.f64 3/2 (/.f64 a (/.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) a)) (/.f64 (pow.f64 a 3) (pow.f64 (+.f64 1 (exp.f64 b)) 4)))))
(fma.f64 1/6 (/.f64 (pow.f64 a 3) (+.f64 1 (exp.f64 b))) (fma.f64 1/2 (/.f64 a (/.f64 (+.f64 1 (exp.f64 b)) a)) (-.f64 (-.f64 (+.f64 (fma.f64 2 (pow.f64 (/.f64 a (+.f64 1 (exp.f64 b))) 3) (/.f64 a (+.f64 1 (exp.f64 b)))) (+.f64 (/.f64 a (/.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 3) a)) (/.f64 1 (+.f64 1 (exp.f64 b))))) (*.f64 (/.f64 a (/.f64 (pow.f64 (+.f64 1 (exp.f64 b)) 2) a)) (+.f64 3/2 (/.f64 a (pow.f64 (+.f64 1 (exp.f64 b)) 2))))) (fma.f64 7/6 (/.f64 (pow.f64 a 3) (pow.f64 (+.f64 1 (exp.f64 b)) 2)) (/.f64 a (pow.f64 (+.f64 1 (exp.f64 b)) 2))))))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a)))
(-.f64 (/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a))) (/.f64 (*.f64 b (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2)))
(-.f64 (+.f64 (/.f64 (*.f64 (pow.f64 b 2) (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 3)) (/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a)))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (exp.f64 a) (pow.f64 b 2)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))) (/.f64 (*.f64 b (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))))
(-.f64 (+.f64 (/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a))) (/.f64 (*.f64 (exp.f64 a) (*.f64 b b)) (pow.f64 (+.f64 1 (exp.f64 a)) 3))) (fma.f64 1/2 (/.f64 (*.f64 (exp.f64 a) (*.f64 b b)) (pow.f64 (+.f64 1 (exp.f64 a)) 2)) (/.f64 (*.f64 b (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))))
(-.f64 (+.f64 (/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a))) (/.f64 (*.f64 b (*.f64 b (exp.f64 a))) (pow.f64 (+.f64 1 (exp.f64 a)) 3))) (fma.f64 1/2 (*.f64 (/.f64 (exp.f64 a) (pow.f64 (+.f64 1 (exp.f64 a)) 2)) (*.f64 b b)) (/.f64 (*.f64 b (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))))
(-.f64 (fma.f64 (/.f64 (*.f64 b b) (pow.f64 (+.f64 1 (exp.f64 a)) 3)) (exp.f64 a) (/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a)))) (fma.f64 1/2 (/.f64 (*.f64 (exp.f64 a) (*.f64 b b)) (pow.f64 (+.f64 1 (exp.f64 a)) 2)) (/.f64 (*.f64 b (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))))
(-.f64 (+.f64 (/.f64 (*.f64 (pow.f64 b 3) (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 3)) (+.f64 (/.f64 (*.f64 (pow.f64 b 2) (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 3)) (/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a))))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (pow.f64 b 3) (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 b 2) (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))) (+.f64 (/.f64 (*.f64 (pow.f64 b 3) (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 4)) (/.f64 (*.f64 b (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))))))
(+.f64 (/.f64 (*.f64 (exp.f64 a) (pow.f64 b 3)) (pow.f64 (+.f64 1 (exp.f64 a)) 3)) (-.f64 (+.f64 (/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a))) (/.f64 (*.f64 (exp.f64 a) (*.f64 b b)) (pow.f64 (+.f64 1 (exp.f64 a)) 3))) (fma.f64 1/6 (/.f64 (pow.f64 b 3) (/.f64 (pow.f64 (+.f64 1 (exp.f64 a)) 2) (exp.f64 a))) (fma.f64 1/2 (/.f64 (*.f64 (exp.f64 a) (*.f64 b b)) (pow.f64 (+.f64 1 (exp.f64 a)) 2)) (+.f64 (/.f64 (*.f64 b (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2)) (/.f64 (*.f64 (exp.f64 a) (pow.f64 b 3)) (pow.f64 (+.f64 1 (exp.f64 a)) 4)))))))
(-.f64 (+.f64 (/.f64 (*.f64 b (*.f64 b (exp.f64 a))) (pow.f64 (+.f64 1 (exp.f64 a)) 3)) (+.f64 (/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a))) (*.f64 (/.f64 (pow.f64 b 3) (pow.f64 (+.f64 1 (exp.f64 a)) 3)) (exp.f64 a)))) (fma.f64 1/6 (*.f64 (/.f64 (pow.f64 b 3) (pow.f64 (+.f64 1 (exp.f64 a)) 2)) (exp.f64 a)) (+.f64 (fma.f64 1/2 (*.f64 (/.f64 (exp.f64 a) (pow.f64 (+.f64 1 (exp.f64 a)) 2)) (*.f64 b b)) (/.f64 (*.f64 b (exp.f64 a)) (pow.f64 (+.f64 1 (exp.f64 a)) 2))) (/.f64 (exp.f64 a) (/.f64 (pow.f64 (+.f64 1 (exp.f64 a)) 4) (pow.f64 b 3))))))
(+.f64 (/.f64 (exp.f64 a) (+.f64 1 (exp.f64 a))) (-.f64 (*.f64 (exp.f64 a) (+.f64 (/.f64 (*.f64 b b) (pow.f64 (+.f64 1 (exp.f64 a)) 3)) (/.f64 (pow.f64 b 3) (pow.f64 (+.f64 1 (exp.f64 a)) 3)))) (fma.f64 1/6 (*.f64 (/.f64 (exp.f64 a) (pow.f64 (+.f64 1 (exp.f64 a)) 2)) (pow.f64 b 3)) (fma.f64 1/2 (/.f64 (*.f64 (exp.f64 a) (*.f64 b b)) (pow.f64 (+.f64 1 (exp.f64 a)) 2)) (*.f64 (exp.f64 a) (+.f64 (/.f64 b (pow.f64 (+.f64 1 (exp.f64 a)) 2)) (/.f64 (pow.f64 b 3) (pow.f64 (+.f64 1 (exp.f64 a)) 4))))))))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))

prune35.0ms (3.1%)

Pruning

2 alts after pruning (1 fresh and 1 done)

PrunedKeptTotal
New48149
Fresh000
Picked011
Done000
Total48250
Error
0b
Counts
50 → 2
Alt Table
StatusErrorProgram
13.5b
(/.f64 1 (+.f64 1 (exp.f64 b)))
0.2b
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
Compiler

Compiled 1242 to 602 computations (51.5% saved)

localize3.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(/.f64 1 (+.f64 1 (exp.f64 b)))

series2.0ms (0.2%)

Counts
1 → 4
Calls

3 calls:

TimeVariablePointExpression
1.0ms
b
@0
(/.f64 1 (+.f64 1 (exp.f64 b)))
1.0ms
b
@inf
(/.f64 1 (+.f64 1 (exp.f64 b)))
1.0ms
b
@-inf
(/.f64 1 (+.f64 1 (exp.f64 b)))

rewrite40.0ms (3.5%)

Algorithm
batch-egg-rewrite
Rules
596×pow1_binary64
554×add-log-exp_binary64
554×log1p-expm1-u_binary64
554×expm1-log1p-u_binary64
62×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
069
11249
215619
Stop Event
node limit
Counts
1 → 23
Calls
Call 1
Inputs
(/.f64 1 (+.f64 1 (exp.f64 b)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 1 (+.f64 1 (exp.f64 b))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 1 (+.f64 1 (exp.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cbrt.f64 (+.f64 1 (exp.f64 b)))) (cbrt.f64 (pow.f64 (+.f64 1 (exp.f64 b)) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (+.f64 1 (exp.f64 b)) -2)) (/.f64 1 (cbrt.f64 (+.f64 1 (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (+.f64 1 (exp.f64 b)) -1/2) (pow.f64 (+.f64 1 (exp.f64 b)) -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (/.f64 1 (+.f64 -1 (neg.f64 (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (+.f64 1 (exp.f64 b))) 2) -1) (pow.f64 (cbrt.f64 (+.f64 1 (exp.f64 b))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (hypot.f64 1 (sqrt.f64 (exp.f64 b))) -1) (pow.f64 (hypot.f64 1 (sqrt.f64 (exp.f64 b))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (+.f64 1 (exp.f64 (*.f64 b 3)))) (+.f64 1 (*.f64 (exp.f64 b) (expm1.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (-.f64 1 (exp.f64 (+.f64 b b)))) (-.f64 1 (exp.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 1 (exp.f64 b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (cbrt.f64 (+.f64 1 (exp.f64 b)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 1 (exp.f64 b)) -1/2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 1 (exp.f64 b)) -2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 1 (+.f64 1 (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 1 (+.f64 1 (exp.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 1 (+.f64 1 (exp.f64 b))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 1 (+.f64 1 (exp.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (neg.f64 (log1p.f64 (exp.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 1 (+.f64 1 (exp.f64 b)))))))))

simplify32.0ms (2.8%)

Algorithm
egg-herbie
Rules
492×unswap-sqr_binary64
421×fma-def_binary64
340×fma-neg_binary64
339×distribute-rgt-neg-in_binary64
285×associate-*l*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01847
15243
213439
338937
493537
5275137
6426737
Stop Event
node limit
Counts
27 → 30
Calls
Call 1
Inputs
1/2
(-.f64 1/2 (*.f64 1/4 b))
(-.f64 (+.f64 1/2 (*.f64 1/48 (pow.f64 b 3))) (*.f64 1/4 b))
(-.f64 (+.f64 1/2 (*.f64 1/48 (pow.f64 b 3))) (+.f64 (*.f64 1/480 (pow.f64 b 5)) (*.f64 1/4 b)))
Outputs
1/2
(-.f64 1/2 (*.f64 1/4 b))
(+.f64 1/2 (*.f64 -1/4 b))
(fma.f64 b -1/4 1/2)
(-.f64 (+.f64 1/2 (*.f64 1/48 (pow.f64 b 3))) (*.f64 1/4 b))
(+.f64 1/2 (-.f64 (*.f64 1/48 (pow.f64 b 3)) (*.f64 1/4 b)))
(+.f64 (fma.f64 1/48 (pow.f64 b 3) 1/2) (*.f64 b -1/4))
(fma.f64 b -1/4 (fma.f64 1/48 (pow.f64 b 3) 1/2))
(-.f64 (+.f64 1/2 (*.f64 1/48 (pow.f64 b 3))) (+.f64 (*.f64 1/480 (pow.f64 b 5)) (*.f64 1/4 b)))
(+.f64 1/2 (-.f64 (*.f64 1/48 (pow.f64 b 3)) (fma.f64 1/480 (pow.f64 b 5) (*.f64 1/4 b))))
(-.f64 (fma.f64 1/48 (pow.f64 b 3) 1/2) (fma.f64 1/4 b (*.f64 1/480 (pow.f64 b 5))))
(+.f64 (*.f64 (pow.f64 b 5) -1/480) (fma.f64 b -1/4 (fma.f64 1/48 (pow.f64 b 3) 1/2)))
(fma.f64 b -1/4 (fma.f64 (pow.f64 b 5) -1/480 (fma.f64 1/48 (pow.f64 b 3) 1/2)))
(fma.f64 b -1/4 (fma.f64 1/48 (pow.f64 b 3) (fma.f64 (pow.f64 b 5) -1/480 1/2)))

prune15.0ms (1.3%)

Pruning

2 alts after pruning (0 fresh and 2 done)

PrunedKeptTotal
New30030
Fresh000
Picked011
Done011
Total30232
Error
0b
Counts
32 → 2
Alt Table
StatusErrorProgram
13.5b
(/.f64 1 (+.f64 1 (exp.f64 b)))
0.2b
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
Compiler

Compiled 316 to 239 computations (24.4% saved)

regimes21.0ms (1.8%)

Accuracy

Total 0.4b remaining (63.9%)

Threshold costs 0.4b (63.9%)

Counts
7 → 1
Compiler

Compiled 62 to 40 computations (35.5% saved)

simplify2.0ms (0.2%)

Algorithm
egg-herbie
Rules
+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0713
1813
Stop Event
saturated
Calls
Call 1
Inputs
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
Outputs
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))

end36.0ms (3.2%)

Stop Event
done
Compiler

Compiled 38 to 25 computations (34.2% saved)

Profiling

Loading profile data...