Quotient of sum of exps

Time bar (total: 1.0s)

analyze9.0ms (0.9%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
50%50%50%0.1%0%0%0%2
75%74.9%25%0.1%0%0%0%3
87.5%87.4%12.5%0.1%0%0%0%4
93.8%93.7%6.2%0.1%0%0%0%5
93.8%93.7%6.2%0.1%0%0%0%6
95.2%93.7%4.7%0.1%0%0%1.6%7
96%93.7%3.9%0.1%0%0%2.3%8
97.2%93.7%2.7%0.1%0%0%3.5%9
97.8%93.7%2.1%0.1%0%0%4.1%10
98.5%93.7%1.5%0.1%0%0%4.8%11
98.8%93.7%1.1%0.1%0%0%5.1%12
Compiler

Compiled 11 to 7 computations (36.4% saved)

sample913.0ms (87.7%)

Results
714.0ms8256×body256valid
181.0ms2861×body256unsamplable
Bogosity

preprocess119.0ms (11.4%)

Algorithm
egg-herbie
Rules
579×associate-*r*
529×distribute-lft-in
476×distribute-rgt-in
455×*-commutative
381×times-frac
Problems
253×No Errors
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
Iterations

Useful iterations: 7 (0.0ms)

IterNodesCost
024270
144268
269268
3103268
4193240
5437240
61080240
72938239
85939239
Stop Event
node limit
Calls
Call 1
Inputs
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b)))
(/.f64 (exp.f64 (neg.f64 a)) (+.f64 (exp.f64 (neg.f64 a)) (exp.f64 b)))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 (neg.f64 b))))
(neg.f64 (/.f64 (exp.f64 (neg.f64 a)) (+.f64 (exp.f64 (neg.f64 a)) (exp.f64 b))))
(neg.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 (neg.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 a) (+.f64 (exp.f64 a) (exp.f64 b)))
(/.f64 (exp.f64 (neg.f64 a)) (+.f64 (exp.f64 (neg.f64 a)) (exp.f64 b)))
(/.f64 (exp.f64 (neg.f64 a)) (+.f64 (exp.f64 b) (exp.f64 (neg.f64 a))))
(/.f64 1 (+.f64 1 (exp.f64 (+.f64 a b))))
(/.f64 1 (fma.f64 (exp.f64 a) (exp.f64 b) 1))
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 (neg.f64 b))))
(neg.f64 (/.f64 (exp.f64 (neg.f64 a)) (+.f64 (exp.f64 (neg.f64 a)) (exp.f64 b))))
(/.f64 (neg.f64 (exp.f64 (neg.f64 a))) (+.f64 (exp.f64 b) (exp.f64 (neg.f64 a))))
(/.f64 (/.f64 -1 (exp.f64 a)) (+.f64 (exp.f64 b) (exp.f64 (neg.f64 a))))
(/.f64 -1 (+.f64 1 (exp.f64 (+.f64 a b))))
(/.f64 -1 (fma.f64 (exp.f64 a) (exp.f64 b) 1))
(neg.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 (neg.f64 b)))))
(/.f64 (neg.f64 (exp.f64 a)) (+.f64 (exp.f64 a) (exp.f64 (neg.f64 b))))
(/.f64 -1 (-.f64 1 (/.f64 (neg.f64 (exp.f64 (neg.f64 b))) (exp.f64 a))))
(/.f64 -1 (+.f64 1 (*.f64 (exp.f64 (neg.f64 a)) (exp.f64 (neg.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 22 to 7 computations (68.2% saved)

end0.0ms (0%)

Profiling

Loading profile data...