Details

Time bar (total: 2.5s)

analyze320.0ms (12.9%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.9%0.1%0
0%99.9%0.1%1
0%99.9%0.1%2
0%99.9%0.1%3
0%99.9%0.1%4
0%99.9%0.1%5
9.4%65.5%25.1%6
14%60.8%25.1%7
14%56.2%29.8%8
14%36.7%49.3%9
14.8%30.4%54.8%10
15.5%28.3%56.2%11
16.4%18.3%65.2%12
17.2%15.2%67.6%13
17.7%14.2%68.1%14
Compiler

Compiled 13 to 9 computations (30.8% saved)

sample1.5s (62.1%)

Results
1.0s8256×body128valid
515.0ms4322×body128invalid
Compiler

Compiled 26 to 18 computations (30.8% saved)

preprocess43.0ms (1.7%)

Algorithm
egg-herbie
Rules
574×times-frac_binary64
403×associate-*l*_binary64
372×associate-*r*_binary64
304×fma-neg_binary64
216×exp-sum_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02256
15548
213348
329948
454048
5122248
6492548
033
Stop Event
saturated
node limit
Calls
Call 1
Inputs
0
1
2
Outputs
0
1
2
Call 2
Inputs
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
(exp.f64 (-.f64 (+.f64 y (*.f64 x (log.f64 x))) z))
(exp.f64 (-.f64 (+.f64 z (*.f64 y (log.f64 y))) x))
(exp.f64 (-.f64 (+.f64 x (*.f64 z (log.f64 z))) y))
Outputs
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
(exp.f64 (+.f64 x (-.f64 (*.f64 y (log.f64 y)) z)))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(exp.f64 (-.f64 (+.f64 y (*.f64 x (log.f64 x))) z))
(exp.f64 (-.f64 (fma.f64 x (log.f64 x) y) z))
(*.f64 (pow.f64 x x) (exp.f64 (-.f64 y z)))
(/.f64 (pow.f64 x x) (exp.f64 (-.f64 z y)))
(exp.f64 (-.f64 (+.f64 z (*.f64 y (log.f64 y))) x))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) z) x))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) z) x))
(exp.f64 (fma.f64 y (log.f64 y) (-.f64 z x)))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(exp.f64 (-.f64 (+.f64 x (*.f64 z (log.f64 z))) y))
(exp.f64 (-.f64 (fma.f64 z (log.f64 z) x) y))
(*.f64 (pow.f64 z z) (exp.f64 (-.f64 x y)))
(/.f64 (pow.f64 z z) (exp.f64 (-.f64 y x)))
Compiler

Compiled 12 to 8 computations (33.3% saved)

simplify22.0ms (0.9%)

Algorithm
egg-herbie
Rules
508×unswap-sqr_binary64
477×associate-/l/_binary64
420×associate-/r/_binary64
262×times-frac_binary64
256×associate-*l/_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0914
11812
24112
38912
415712
531312
696912
7257012
Stop Event
node limit
Counts
1 → 2
Calls
Call 1
Inputs
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
Outputs
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
(exp.f64 (+.f64 x (-.f64 (*.f64 y (log.f64 y)) z)))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))

prune3.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0b
Counts
3 → 2
Alt Table
StatusErrorProgram
14.3b
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
0.0b
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
Compiler

Compiled 66 to 42 computations (36.4% saved)

localize7.0ms (0.3%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(+.f64 x (*.f64 y (log.f64 y)))
0.0b
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
0.2b
(*.f64 y (log.f64 y))

series72.0ms (2.9%)

Counts
3 → 68
Calls

18 calls:

TimeVariablePointExpression
32.0ms
y
@0
(*.f64 y (log.f64 y))
24.0ms
y
@-inf
(*.f64 y (log.f64 y))
7.0ms
y
@inf
(*.f64 y (log.f64 y))
3.0ms
x
@0
(+.f64 x (*.f64 y (log.f64 y)))
1.0ms
x
@0
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))

rewrite56.0ms (2.2%)

Algorithm
batch-egg-rewrite
Rules
528×fma-def_binary64
494×log-prod_binary64
255×fma-neg_binary64
184×expm1-udef_binary64
184×log1p-udef_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0929
119525
2286725
Stop Event
node limit
Counts
3 → 99
Calls
Call 1
Inputs
(*.f64 y (log.f64 y))
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
(+.f64 x (*.f64 y (log.f64 y)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 y (log.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 y y)) (cbrt.f64 (pow.f64 y y)))) (log.f64 (cbrt.f64 (pow.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 y y))) (log.f64 (sqrt.f64 (pow.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 y (log.f64 y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (log.f64 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (log.f64 y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 y (log.f64 y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (log.f64 y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 y (log.f64 y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 y y))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (-.f64 (pow.f64 y y) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (log.f64 y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (-.f64 (pow.f64 y y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (log.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (log.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 y (log.f64 y))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z))))) (cbrt.f64 (exp.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z))))))) (log.f64 (cbrt.f64 (exp.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))))) (log.f64 (sqrt.f64 (exp.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (exp.f64 x) (exp.f64 (fma.f64 y (log.f64 y) (neg.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (exp.f64 x) (pow.f64 y y)) (exp.f64 (neg.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (exp.f64 x) (pow.f64 y y)) (/.f64 1 (exp.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))) (pow.f64 (cbrt.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))) 2) (cbrt.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))) (sqrt.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (exp.f64 z) (*.f64 (exp.f64 x) (pow.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (exp.f64 x) (pow.f64 y y)) (exp.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 (exp.f64 x) (pow.f64 y y))) (neg.f64 (exp.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (fma.f64 y (log.f64 y) (-.f64 x z))) 2)) (cbrt.f64 (fma.f64 y (log.f64 y) (-.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))) (sqrt.f64 (fma.f64 y (log.f64 y) (-.f64 x z))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (fma.f64 y (log.f64 y) (-.f64 x z)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (exp.f64 (fma.f64 y (log.f64 y) (-.f64 x z)))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 y (log.f64 y) x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (*.f64 x x) (-.f64 x (*.f64 y (log.f64 y)))) (/.f64 (pow.f64 (*.f64 y (log.f64 y)) 2) (-.f64 x (*.f64 y (log.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 y (log.f64 y) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 y (log.f64 y) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 y (log.f64 y) x)) (pow.f64 (cbrt.f64 (fma.f64 y (log.f64 y) x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 y (log.f64 y) x)) 2) (cbrt.f64 (fma.f64 y (log.f64 y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 y (log.f64 y) x)) (sqrt.f64 (fma.f64 y (log.f64 y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 x 3) (pow.f64 (*.f64 y (log.f64 y)) 3)) (/.f64 1 (fma.f64 (*.f64 y (log.f64 y)) (-.f64 (*.f64 y (log.f64 y)) x) (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 y (log.f64 y)) 2)) (/.f64 1 (-.f64 x (*.f64 y (log.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 (*.f64 y (log.f64 y)) (-.f64 (*.f64 y (log.f64 y)) x) (*.f64 x x)) (+.f64 (pow.f64 x 3) (pow.f64 (*.f64 y (log.f64 y)) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 x (*.f64 y (log.f64 y))) (-.f64 (*.f64 x x) (pow.f64 (*.f64 y (log.f64 y)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 x 3) (pow.f64 (*.f64 y (log.f64 y)) 3)) (fma.f64 (*.f64 y (log.f64 y)) (-.f64 (*.f64 y (log.f64 y)) x) (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 x 3) (pow.f64 (*.f64 y (log.f64 y)) 3)) (+.f64 (pow.f64 (*.f64 y (log.f64 y)) 2) (-.f64 (*.f64 x x) (*.f64 (*.f64 y (log.f64 y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 y (log.f64 y)) 2)) (-.f64 x (*.f64 y (log.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 x 3) (pow.f64 (*.f64 y (log.f64 y)) 3))) (neg.f64 (fma.f64 (*.f64 y (log.f64 y)) (-.f64 (*.f64 y (log.f64 y)) x) (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (*.f64 x x) (pow.f64 (*.f64 y (log.f64 y)) 2))) (neg.f64 (-.f64 x (*.f64 y (log.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 y (log.f64 y)) 2) (*.f64 x x)) (-.f64 (*.f64 y (log.f64 y)) x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 y (log.f64 y) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 y (log.f64 y) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 y (log.f64 y) x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 y (log.f64 y) x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 y (log.f64 y) x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 x) (pow.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 y (log.f64 y) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (-.f64 (pow.f64 y y) 1)) (exp.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 y y) (+.f64 1 (expm1.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (-.f64 (pow.f64 y y) 1)) (+.f64 1 (expm1.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 x)) (pow.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 x) (+.f64 1 (-.f64 (pow.f64 y y) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 x)) (+.f64 1 (-.f64 (pow.f64 y y) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 y (log.f64 y) x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 y (log.f64 y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y (log.f64 y) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (log.f64 y) y x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (log.f64 y)) 1 x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x 1 (*.f64 y (log.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 y (log.f64 y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 x (*.f64 y (log.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 x) (pow.f64 (cbrt.f64 x) 2) (*.f64 y (log.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) 2) (cbrt.f64 x) (*.f64 y (log.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) (log.f64 y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (log.f64 y)) 2) (*.f64 (cbrt.f64 (log.f64 y)) y) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 y (log.f64 y))) (pow.f64 (cbrt.f64 (*.f64 y (log.f64 y))) 2) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 y (log.f64 y))) 2) (cbrt.f64 (*.f64 y (log.f64 y))) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (sqrt.f64 x) (*.f64 y (log.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) (log.f64 y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (log.f64 y)) (*.f64 (sqrt.f64 (log.f64 y)) y) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 y (log.f64 y))) (sqrt.f64 (*.f64 y (log.f64 y))) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (pow.f64 (cbrt.f64 (log.f64 y)) 2)) (cbrt.f64 (log.f64 y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (sqrt.f64 (log.f64 y))) (sqrt.f64 (log.f64 y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (log.f64 y) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y) x)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (log.f64 y) (sqrt.f64 y)) (sqrt.f64 y) x)))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 y (log.f64 y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 y (log.f64 y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 y (log.f64 y) x)) 1))))))

simplify43.0ms (1.7%)

Algorithm
egg-herbie
Rules
462×cancel-sign-sub-inv_binary64
404×associate-*l*_binary64
360×associate-*r*_binary64
360×fma-neg_binary64
336×fma-def_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
082946
1258904
2740794
33067792
Stop Event
node limit
Counts
167 → 133
Calls
Call 1
Inputs
(*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y))))
(*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y))))
(*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y))))
(*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y))))
(*.f64 y (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 y))))
(*.f64 y (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 y))))
(*.f64 y (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 y))))
(*.f64 y (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 y))))
(exp.f64 (-.f64 (*.f64 y (log.f64 y)) z))
(+.f64 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) x) (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)))
(+.f64 (*.f64 1/2 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) (pow.f64 x 2))) (+.f64 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) x) (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z))))
(+.f64 (*.f64 1/2 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) (pow.f64 x 2))) (+.f64 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) x) (+.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) (*.f64 1/6 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) (pow.f64 x 3))))))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 x z))
(+.f64 (*.f64 y (*.f64 (exp.f64 (-.f64 x z)) (log.f64 y))) (exp.f64 (-.f64 x z)))
(+.f64 (*.f64 y (*.f64 (exp.f64 (-.f64 x z)) (log.f64 y))) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (log.f64 y) 2) (exp.f64 (-.f64 x z))))) (exp.f64 (-.f64 x z))))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) (*.f64 (exp.f64 (-.f64 x z)) (pow.f64 (log.f64 y) 2)))) (+.f64 (*.f64 y (*.f64 (exp.f64 (-.f64 x z)) (log.f64 y))) (+.f64 (*.f64 1/6 (*.f64 (pow.f64 y 3) (*.f64 (exp.f64 (-.f64 x z)) (pow.f64 (log.f64 y) 3)))) (exp.f64 (-.f64 x z)))))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (+.f64 (*.f64 y (log.f64 y)) x))
(-.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) (*.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) z))
(-.f64 (+.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) (*.f64 1/2 (*.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) (pow.f64 z 2)))) (*.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) z))
(-.f64 (+.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) (*.f64 1/2 (*.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) (pow.f64 z 2)))) (+.f64 (*.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) z) (*.f64 1/6 (*.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) (pow.f64 z 3)))))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(*.f64 y (log.f64 y))
(+.f64 (*.f64 y (log.f64 y)) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(+.f64 (*.f64 y (log.f64 y)) x)
x
(+.f64 (*.f64 y (log.f64 y)) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(+.f64 (*.f64 y (log.f64 y)) x)
x
(+.f64 (*.f64 y (log.f64 y)) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(+.f64 (*.f64 y (log.f64 y)) x)
x
(+.f64 (*.f64 y (log.f64 y)) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y))))
(-.f64 x (*.f64 y (log.f64 (/.f64 1 y))))
(-.f64 x (*.f64 y (log.f64 (/.f64 1 y))))
(-.f64 x (*.f64 y (log.f64 (/.f64 1 y))))
(*.f64 -1 (*.f64 y (-.f64 (log.f64 (/.f64 -1 y)) (log.f64 -1))))
(-.f64 (+.f64 (*.f64 y (log.f64 -1)) x) (*.f64 (log.f64 (/.f64 -1 y)) y))
(-.f64 (+.f64 (*.f64 y (log.f64 -1)) x) (*.f64 (log.f64 (/.f64 -1 y)) y))
(-.f64 (+.f64 (*.f64 y (log.f64 -1)) x) (*.f64 (log.f64 (/.f64 -1 y)) y))
Outputs
(*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y))))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 y (neg.f64 (neg.f64 (log.f64 y))))
(*.f64 y (log.f64 y))
(*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y))))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 y (neg.f64 (neg.f64 (log.f64 y))))
(*.f64 y (log.f64 y))
(*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y))))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 y (neg.f64 (neg.f64 (log.f64 y))))
(*.f64 y (log.f64 y))
(*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y))))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 y (neg.f64 (neg.f64 (log.f64 y))))
(*.f64 y (log.f64 y))
(*.f64 y (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 y))))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 y (neg.f64 (neg.f64 (log.f64 y))))
(*.f64 y (log.f64 y))
(*.f64 y (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 y))))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 y (neg.f64 (neg.f64 (log.f64 y))))
(*.f64 y (log.f64 y))
(*.f64 y (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 y))))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 y (neg.f64 (neg.f64 (log.f64 y))))
(*.f64 y (log.f64 y))
(*.f64 y (-.f64 (log.f64 -1) (log.f64 (/.f64 -1 y))))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 y (neg.f64 (neg.f64 (log.f64 y))))
(*.f64 y (log.f64 y))
(exp.f64 (-.f64 (*.f64 y (log.f64 y)) z))
(/.f64 (pow.f64 y y) (exp.f64 z))
(+.f64 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) x) (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)))
(fma.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) x (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)))
(*.f64 (+.f64 x 1) (/.f64 (pow.f64 y y) (exp.f64 z)))
(/.f64 (*.f64 (+.f64 1 x) (pow.f64 y y)) (exp.f64 z))
(+.f64 (*.f64 1/2 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) (pow.f64 x 2))) (+.f64 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) x) (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z))))
(fma.f64 1/2 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) (*.f64 x x)) (fma.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) x (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z))))
(fma.f64 1/2 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 x x)) (*.f64 (+.f64 x 1) (/.f64 (pow.f64 y y) (exp.f64 z))))
(*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (+.f64 (*.f64 x (*.f64 x 1/2)) (+.f64 1 x)))
(+.f64 (*.f64 1/2 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) (pow.f64 x 2))) (+.f64 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) x) (+.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) (*.f64 1/6 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) (pow.f64 x 3))))))
(fma.f64 1/2 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) (*.f64 x x)) (+.f64 (fma.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) x (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z))) (*.f64 1/6 (*.f64 (exp.f64 (-.f64 (*.f64 y (log.f64 y)) z)) (pow.f64 x 3)))))
(+.f64 (fma.f64 1/2 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 x x)) (*.f64 (+.f64 x 1) (/.f64 (pow.f64 y y) (exp.f64 z)))) (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 (pow.f64 x 3) 1/6)))
(fma.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 x (*.f64 x 1/2)) (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (+.f64 (+.f64 1 x) (*.f64 1/6 (pow.f64 x 3)))))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 x z))
(+.f64 (*.f64 y (*.f64 (exp.f64 (-.f64 x z)) (log.f64 y))) (exp.f64 (-.f64 x z)))
(fma.f64 y (*.f64 (log.f64 y) (exp.f64 (-.f64 x z))) (exp.f64 (-.f64 x z)))
(*.f64 (+.f64 (*.f64 y (log.f64 y)) 1) (exp.f64 (-.f64 x z)))
(+.f64 (*.f64 y (*.f64 (exp.f64 (-.f64 x z)) (log.f64 y))) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (log.f64 y) 2) (exp.f64 (-.f64 x z))))) (exp.f64 (-.f64 x z))))
(fma.f64 y (*.f64 (log.f64 y) (exp.f64 (-.f64 x z))) (fma.f64 1/2 (*.f64 (*.f64 y y) (*.f64 (exp.f64 (-.f64 x z)) (pow.f64 (log.f64 y) 2))) (exp.f64 (-.f64 x z))))
(fma.f64 y (*.f64 (log.f64 y) (exp.f64 (-.f64 x z))) (fma.f64 1/2 (*.f64 (exp.f64 (-.f64 x z)) (*.f64 y (*.f64 y (pow.f64 (log.f64 y) 2)))) (exp.f64 (-.f64 x z))))
(+.f64 (exp.f64 (-.f64 x z)) (*.f64 (exp.f64 (-.f64 x z)) (+.f64 (*.f64 y (log.f64 y)) (*.f64 1/2 (*.f64 (*.f64 y y) (pow.f64 (log.f64 y) 2))))))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) (*.f64 (exp.f64 (-.f64 x z)) (pow.f64 (log.f64 y) 2)))) (+.f64 (*.f64 y (*.f64 (exp.f64 (-.f64 x z)) (log.f64 y))) (+.f64 (*.f64 1/6 (*.f64 (pow.f64 y 3) (*.f64 (exp.f64 (-.f64 x z)) (pow.f64 (log.f64 y) 3)))) (exp.f64 (-.f64 x z)))))
(fma.f64 1/2 (*.f64 (*.f64 y y) (*.f64 (exp.f64 (-.f64 x z)) (pow.f64 (log.f64 y) 2))) (fma.f64 y (*.f64 (log.f64 y) (exp.f64 (-.f64 x z))) (fma.f64 1/6 (*.f64 (pow.f64 y 3) (*.f64 (exp.f64 (-.f64 x z)) (pow.f64 (log.f64 y) 3))) (exp.f64 (-.f64 x z)))))
(fma.f64 1/2 (*.f64 (exp.f64 (-.f64 x z)) (*.f64 y (*.f64 y (pow.f64 (log.f64 y) 2)))) (fma.f64 y (*.f64 (log.f64 y) (exp.f64 (-.f64 x z))) (fma.f64 1/6 (*.f64 (exp.f64 (-.f64 x z)) (*.f64 (pow.f64 (log.f64 y) 3) (pow.f64 y 3))) (exp.f64 (-.f64 x z)))))
(+.f64 (*.f64 (+.f64 (*.f64 (pow.f64 (log.f64 y) 3) (*.f64 1/6 (pow.f64 y 3))) 1) (exp.f64 (-.f64 x z))) (*.f64 (exp.f64 (-.f64 x z)) (+.f64 (*.f64 y (log.f64 y)) (*.f64 1/2 (*.f64 (*.f64 y y) (pow.f64 (log.f64 y) 2))))))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (+.f64 (*.f64 y (log.f64 y)) x))
(exp.f64 (fma.f64 y (log.f64 y) x))
(*.f64 (exp.f64 x) (pow.f64 y y))
(-.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) (*.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) z))
(-.f64 (exp.f64 (fma.f64 y (log.f64 y) x)) (*.f64 z (exp.f64 (fma.f64 y (log.f64 y) x))))
(-.f64 (*.f64 (exp.f64 x) (pow.f64 y y)) (*.f64 z (*.f64 (exp.f64 x) (pow.f64 y y))))
(*.f64 (pow.f64 y y) (-.f64 (exp.f64 x) (*.f64 z (exp.f64 x))))
(-.f64 (+.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) (*.f64 1/2 (*.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) (pow.f64 z 2)))) (*.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) z))
(+.f64 (exp.f64 (fma.f64 y (log.f64 y) x)) (-.f64 (*.f64 1/2 (*.f64 (exp.f64 (fma.f64 y (log.f64 y) x)) (*.f64 z z))) (*.f64 z (exp.f64 (fma.f64 y (log.f64 y) x)))))
(-.f64 (fma.f64 1/2 (*.f64 (*.f64 (exp.f64 x) (pow.f64 y y)) (*.f64 z z)) (*.f64 (exp.f64 x) (pow.f64 y y))) (*.f64 z (*.f64 (exp.f64 x) (pow.f64 y y))))
(fma.f64 (exp.f64 x) (pow.f64 y y) (*.f64 (*.f64 (exp.f64 x) (pow.f64 y y)) (-.f64 (*.f64 (*.f64 1/2 z) z) z)))
(-.f64 (+.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) (*.f64 1/2 (*.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) (pow.f64 z 2)))) (+.f64 (*.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) z) (*.f64 1/6 (*.f64 (exp.f64 (+.f64 (*.f64 y (log.f64 y)) x)) (pow.f64 z 3)))))
(+.f64 (exp.f64 (fma.f64 y (log.f64 y) x)) (-.f64 (*.f64 1/2 (*.f64 (exp.f64 (fma.f64 y (log.f64 y) x)) (*.f64 z z))) (fma.f64 (exp.f64 (fma.f64 y (log.f64 y) x)) z (*.f64 1/6 (*.f64 (exp.f64 (fma.f64 y (log.f64 y) x)) (pow.f64 z 3))))))
(-.f64 (fma.f64 1/2 (*.f64 (*.f64 (exp.f64 x) (pow.f64 y y)) (*.f64 z z)) (*.f64 (exp.f64 x) (pow.f64 y y))) (fma.f64 z (*.f64 (exp.f64 x) (pow.f64 y y)) (*.f64 1/6 (*.f64 (*.f64 (exp.f64 x) (pow.f64 y y)) (pow.f64 z 3)))))
(-.f64 (*.f64 (+.f64 (*.f64 (*.f64 1/2 z) z) 1) (*.f64 (exp.f64 x) (pow.f64 y y))) (*.f64 (*.f64 (exp.f64 x) (pow.f64 y y)) (+.f64 z (*.f64 1/6 (pow.f64 z 3)))))
(fma.f64 (*.f64 (exp.f64 x) (pow.f64 y y)) (fma.f64 z (*.f64 z 1/2) (*.f64 (pow.f64 z 3) -1/6)) (*.f64 (pow.f64 y y) (-.f64 (exp.f64 x) (*.f64 z (exp.f64 x)))))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 (*.f64 y (log.f64 y)) x) z))
(exp.f64 (-.f64 (fma.f64 y (log.f64 y) x) z))
(*.f64 (pow.f64 y y) (exp.f64 (-.f64 x z)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(*.f64 y (log.f64 y))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 y (neg.f64 (neg.f64 (log.f64 y))))
(+.f64 (*.f64 y (log.f64 y)) x)
(fma.f64 y (log.f64 y) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(fma.f64 y (log.f64 y) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(fma.f64 y (log.f64 y) x)
x
(+.f64 (*.f64 y (log.f64 y)) x)
(fma.f64 y (log.f64 y) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(fma.f64 y (log.f64 y) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(fma.f64 y (log.f64 y) x)
x
(+.f64 (*.f64 y (log.f64 y)) x)
(fma.f64 y (log.f64 y) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(fma.f64 y (log.f64 y) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(fma.f64 y (log.f64 y) x)
x
(+.f64 (*.f64 y (log.f64 y)) x)
(fma.f64 y (log.f64 y) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(fma.f64 y (log.f64 y) x)
(+.f64 (*.f64 y (log.f64 y)) x)
(fma.f64 y (log.f64 y) x)
(*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y))))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 y (neg.f64 (neg.f64 (log.f64 y))))
(*.f64 y (log.f64 y))
(-.f64 x (*.f64 y (log.f64 (/.f64 1 y))))
(fma.f64 y (log.f64 y) x)
(-.f64 x (*.f64 y (log.f64 (/.f64 1 y))))
(fma.f64 y (log.f64 y) x)
(-.f64 x (*.f64 y (log.f64 (/.f64 1 y))))
(fma.f64 y (log.f64 y) x)
(*.f64 -1 (*.f64 y (-.f64 (log.f64 (/.f64 -1 y)) (log.f64 -1))))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 y (neg.f64 (neg.f64 (log.f64 y))))
(*.f64 y (log.f64 y))
(-.f64 (+.f64 (*.f64 y (log.f64 -1)) x) (*.f64 (log.f64 (/.f64 -1 y)) y))
(fma.f64 y (log.f64 y) x)
(-.f64 (+.f64 (*.f64 y (log.f64 -1)) x) (*.f64 (log.f64 (/.f64 -1 y)) y))
(fma.f64 y (log.f64 y) x)
(-.f64 (+.f64 (*.f64 y (log.f64 -1)) x) (*.f64 (log.f64 (/.f64 -1 y)) y))
(fma.f64 y (log.f64 y) x)

prune80.0ms (3.2%)

Pruning

2 alts after pruning (1 fresh and 1 done)

PrunedKeptTotal
New1330133
Fresh011
Picked011
Done000
Total1332135
Error
0b
Counts
135 → 2
Alt Table
StatusErrorProgram
14.3b
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
0.0b
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
Compiler

Compiled 2058 to 741 computations (64% saved)

localize7.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))

series29.0ms (1.2%)

Counts
1 → 12
Calls

9 calls:

TimeVariablePointExpression
11.0ms
z
@inf
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
8.0ms
x
@inf
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
4.0ms
x
@0
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
1.0ms
y
@0
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
1.0ms
z
@0
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))

rewrite45.0ms (1.8%)

Algorithm
batch-egg-rewrite
Rules
487×prod-diff_binary64
458×log-prod_binary64
197×fma-def_binary64
167×expm1-udef_binary64
167×log1p-udef_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0812
117712
2250212
Stop Event
node limit
Counts
1 → 37
Calls
Call 1
Inputs
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x))))) (cbrt.f64 (exp.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x))))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 y y) (exp.f64 (neg.f64 (-.f64 z x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))) (pow.f64 (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))) 2) (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (pow.f64 y y)) 2) (*.f64 (cbrt.f64 (pow.f64 y y)) (exp.f64 (neg.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))) (sqrt.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (pow.f64 y y)) (/.f64 1 (neg.f64 (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (exp.f64 (neg.f64 (-.f64 z x))) (pow.f64 y y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (pow.f64 y y)) (*.f64 (sqrt.f64 (pow.f64 y y)) (exp.f64 (neg.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (pow.f64 y y)) 2) 1) (/.f64 (cbrt.f64 (pow.f64 y y)) (exp.f64 (-.f64 z x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (pow.f64 y y)) 1) (/.f64 (sqrt.f64 (pow.f64 y y)) (exp.f64 (-.f64 z x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (exp.f64 (-.f64 z x))) 2)) (/.f64 (pow.f64 y y) (cbrt.f64 (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (pow.f64 y y)) 2) (pow.f64 (cbrt.f64 (exp.f64 (-.f64 z x))) 2)) (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (pow.f64 y y)) (pow.f64 (cbrt.f64 (exp.f64 (-.f64 z x))) 2)) (/.f64 (sqrt.f64 (pow.f64 y y)) (cbrt.f64 (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (exp.f64 (-.f64 z x)))) (/.f64 (pow.f64 y y) (sqrt.f64 (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (pow.f64 y y)) 2) (sqrt.f64 (exp.f64 (-.f64 z x)))) (/.f64 (cbrt.f64 (pow.f64 y y)) (sqrt.f64 (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (exp.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (exp.f64 (-.f64 z x)) (pow.f64 y y)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (pow.f64 y y) (neg.f64 (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (pow.f64 y y) 3) (pow.f64 (exp.f64 (-.f64 z x)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 y (log.f64 y)) (-.f64 z x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 (*.f64 y (log.f64 y)) (-.f64 z x)) 1))))))

simplify38.0ms (1.5%)

Algorithm
egg-herbie
Rules
792×fma-def_binary64
449×unswap-sqr_binary64
281×cancel-sign-sub-inv_binary64
249×associate-*r*_binary64
232×associate-*l*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
066437
1195433
2598377
32906373
Stop Event
node limit
Counts
49 → 60
Calls
Call 1
Inputs
(/.f64 1 (exp.f64 (-.f64 z x)))
(+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x))) (/.f64 1 (exp.f64 (-.f64 z x))))
(+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y 2) (pow.f64 (log.f64 y) 2)) (exp.f64 (-.f64 z x)))) (+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x))) (/.f64 1 (exp.f64 (-.f64 z x)))))
(+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y 2) (pow.f64 (log.f64 y) 2)) (exp.f64 (-.f64 z x)))) (+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3)) (exp.f64 (-.f64 z x)))) (/.f64 1 (exp.f64 (-.f64 z x))))))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))
(-.f64 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))) (/.f64 (*.f64 (pow.f64 y y) z) (exp.f64 (neg.f64 x))))
(-.f64 (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y y) (pow.f64 z 2)) (exp.f64 (neg.f64 x)))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (/.f64 (*.f64 (pow.f64 y y) z) (exp.f64 (neg.f64 x))))
(-.f64 (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y y) (pow.f64 z 2)) (exp.f64 (neg.f64 x)))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (+.f64 (/.f64 (*.f64 (pow.f64 y y) z) (exp.f64 (neg.f64 x))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 y y) (pow.f64 z 3)) (exp.f64 (neg.f64 x))))))
(/.f64 (pow.f64 y y) (exp.f64 z))
(+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (/.f64 (*.f64 (pow.f64 y y) x) (exp.f64 z)))
(+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y y) (pow.f64 x 2)) (exp.f64 z))) (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (/.f64 (*.f64 (pow.f64 y y) x) (exp.f64 z))))
(+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y y) (pow.f64 x 2)) (exp.f64 z))) (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (+.f64 (/.f64 (*.f64 (pow.f64 y y) x) (exp.f64 z)) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 y y) (pow.f64 x 3)) (exp.f64 z))))))
Outputs
(/.f64 1 (exp.f64 (-.f64 z x)))
(exp.f64 (neg.f64 (-.f64 z x)))
(exp.f64 (-.f64 x z))
(+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x))) (/.f64 1 (exp.f64 (-.f64 z x))))
(+.f64 (exp.f64 (neg.f64 (-.f64 z x))) (/.f64 y (/.f64 (exp.f64 (-.f64 z x)) (log.f64 y))))
(fma.f64 (/.f64 y (exp.f64 (-.f64 z x))) (log.f64 y) (exp.f64 (-.f64 x z)))
(fma.f64 (log.f64 y) (/.f64 y (exp.f64 (-.f64 z x))) (exp.f64 (-.f64 x z)))
(+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y 2) (pow.f64 (log.f64 y) 2)) (exp.f64 (-.f64 z x)))) (+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x))) (/.f64 1 (exp.f64 (-.f64 z x)))))
(fma.f64 1/2 (/.f64 (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 y y)) (exp.f64 (-.f64 z x))) (+.f64 (exp.f64 (neg.f64 (-.f64 z x))) (/.f64 y (/.f64 (exp.f64 (-.f64 z x)) (log.f64 y)))))
(fma.f64 1/2 (/.f64 (*.f64 y (*.f64 y (pow.f64 (log.f64 y) 2))) (exp.f64 (-.f64 z x))) (+.f64 (exp.f64 (neg.f64 (-.f64 z x))) (/.f64 y (/.f64 (exp.f64 (-.f64 z x)) (log.f64 y)))))
(fma.f64 1/2 (*.f64 (/.f64 (pow.f64 (log.f64 y) 2) (exp.f64 (-.f64 z x))) (*.f64 y y)) (fma.f64 (/.f64 y (exp.f64 (-.f64 z x))) (log.f64 y) (exp.f64 (-.f64 x z))))
(fma.f64 1/2 (*.f64 (/.f64 (pow.f64 (log.f64 y) 2) (exp.f64 (-.f64 z x))) (*.f64 y y)) (fma.f64 (log.f64 y) (/.f64 y (exp.f64 (-.f64 z x))) (exp.f64 (-.f64 x z))))
(+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y 2) (pow.f64 (log.f64 y) 2)) (exp.f64 (-.f64 z x)))) (+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3)) (exp.f64 (-.f64 z x)))) (/.f64 1 (exp.f64 (-.f64 z x))))))
(fma.f64 1/2 (/.f64 (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 y y)) (exp.f64 (-.f64 z x))) (+.f64 (/.f64 y (/.f64 (exp.f64 (-.f64 z x)) (log.f64 y))) (fma.f64 1/6 (/.f64 (pow.f64 y 3) (/.f64 (exp.f64 (-.f64 z x)) (pow.f64 (log.f64 y) 3))) (exp.f64 (neg.f64 (-.f64 z x))))))
(+.f64 (fma.f64 1/6 (*.f64 (/.f64 (pow.f64 y 3) (exp.f64 (-.f64 z x))) (pow.f64 (log.f64 y) 3)) (exp.f64 (neg.f64 (-.f64 z x)))) (fma.f64 1/2 (/.f64 (*.f64 y (*.f64 y (pow.f64 (log.f64 y) 2))) (exp.f64 (-.f64 z x))) (/.f64 y (/.f64 (exp.f64 (-.f64 z x)) (log.f64 y)))))
(fma.f64 1/2 (*.f64 (/.f64 (pow.f64 (log.f64 y) 2) (exp.f64 (-.f64 z x))) (*.f64 y y)) (fma.f64 1/6 (*.f64 (/.f64 (pow.f64 (log.f64 y) 3) (exp.f64 (-.f64 z x))) (pow.f64 y 3)) (fma.f64 (/.f64 y (exp.f64 (-.f64 z x))) (log.f64 y) (exp.f64 (-.f64 x z)))))
(fma.f64 (log.f64 y) (/.f64 y (exp.f64 (-.f64 z x))) (fma.f64 1/2 (*.f64 (/.f64 (pow.f64 (log.f64 y) 2) (exp.f64 (-.f64 z x))) (*.f64 y y)) (fma.f64 1/6 (*.f64 (/.f64 (pow.f64 (log.f64 y) 3) (exp.f64 (-.f64 z x))) (pow.f64 y 3)) (exp.f64 (-.f64 x z)))))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))
(*.f64 (pow.f64 y y) (exp.f64 x))
(-.f64 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))) (/.f64 (*.f64 (pow.f64 y y) z) (exp.f64 (neg.f64 x))))
(-.f64 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))) (/.f64 (pow.f64 y y) (/.f64 (exp.f64 (neg.f64 x)) z)))
(-.f64 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))) (*.f64 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))) z))
(*.f64 (exp.f64 x) (-.f64 (pow.f64 y y) (*.f64 z (pow.f64 y y))))
(-.f64 (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y y) (pow.f64 z 2)) (exp.f64 (neg.f64 x)))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (/.f64 (*.f64 (pow.f64 y y) z) (exp.f64 (neg.f64 x))))
(-.f64 (fma.f64 1/2 (/.f64 (*.f64 (pow.f64 y y) (*.f64 z z)) (exp.f64 (neg.f64 x))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (/.f64 (pow.f64 y y) (/.f64 (exp.f64 (neg.f64 x)) z)))
(-.f64 (fma.f64 1/2 (/.f64 (*.f64 z (*.f64 z (pow.f64 y y))) (exp.f64 (neg.f64 x))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (*.f64 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))) z))
(fma.f64 1/2 (*.f64 (*.f64 z (*.f64 z (pow.f64 y y))) (exp.f64 x)) (*.f64 (exp.f64 x) (-.f64 (pow.f64 y y) (*.f64 z (pow.f64 y y)))))
(-.f64 (*.f64 (exp.f64 x) (fma.f64 z (*.f64 (*.f64 z (pow.f64 y y)) 1/2) (pow.f64 y y))) (*.f64 z (*.f64 (pow.f64 y y) (exp.f64 x))))
(-.f64 (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y y) (pow.f64 z 2)) (exp.f64 (neg.f64 x)))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (+.f64 (/.f64 (*.f64 (pow.f64 y y) z) (exp.f64 (neg.f64 x))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 y y) (pow.f64 z 3)) (exp.f64 (neg.f64 x))))))
(-.f64 (fma.f64 1/2 (/.f64 (*.f64 (pow.f64 y y) (*.f64 z z)) (exp.f64 (neg.f64 x))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (+.f64 (/.f64 (pow.f64 y y) (/.f64 (exp.f64 (neg.f64 x)) z)) (/.f64 (*.f64 1/6 (*.f64 (pow.f64 y y) (pow.f64 z 3))) (exp.f64 (neg.f64 x)))))
(-.f64 (fma.f64 1/2 (/.f64 (*.f64 z (*.f64 z (pow.f64 y y))) (exp.f64 (neg.f64 x))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (fma.f64 1/6 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))) (pow.f64 z 3)) (*.f64 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))) z)))
(-.f64 (*.f64 (exp.f64 x) (+.f64 (pow.f64 y y) (*.f64 z (*.f64 (*.f64 z (pow.f64 y y)) 1/2)))) (*.f64 (exp.f64 x) (+.f64 (*.f64 z (pow.f64 y y)) (*.f64 1/6 (*.f64 (pow.f64 y y) (pow.f64 z 3))))))
(-.f64 (*.f64 (exp.f64 x) (fma.f64 z (*.f64 (*.f64 z (pow.f64 y y)) 1/2) (pow.f64 y y))) (*.f64 (exp.f64 x) (fma.f64 1/6 (*.f64 (pow.f64 y y) (pow.f64 z 3)) (*.f64 z (pow.f64 y y)))))
(/.f64 (pow.f64 y y) (exp.f64 z))
(+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (/.f64 (*.f64 (pow.f64 y y) x) (exp.f64 z)))
(+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (/.f64 (pow.f64 y y) (/.f64 (exp.f64 z) x)))
(+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) x))
(fma.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) x (/.f64 (pow.f64 y y) (exp.f64 z)))
(fma.f64 x (/.f64 (pow.f64 y y) (exp.f64 z)) (/.f64 (pow.f64 y y) (exp.f64 z)))
(+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y y) (pow.f64 x 2)) (exp.f64 z))) (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (/.f64 (*.f64 (pow.f64 y y) x) (exp.f64 z))))
(fma.f64 1/2 (/.f64 (pow.f64 y y) (/.f64 (exp.f64 z) (*.f64 x x))) (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (/.f64 (pow.f64 y y) (/.f64 (exp.f64 z) x))))
(+.f64 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) x) (fma.f64 1/2 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 x x)) (/.f64 (pow.f64 y y) (exp.f64 z))))
(fma.f64 1/2 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 x x)) (fma.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) x (/.f64 (pow.f64 y y) (exp.f64 z))))
(fma.f64 x (/.f64 (pow.f64 y y) (exp.f64 z)) (fma.f64 1/2 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 x x)) (/.f64 (pow.f64 y y) (exp.f64 z))))
(+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y y) (pow.f64 x 2)) (exp.f64 z))) (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (+.f64 (/.f64 (*.f64 (pow.f64 y y) x) (exp.f64 z)) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 y y) (pow.f64 x 3)) (exp.f64 z))))))
(fma.f64 1/2 (/.f64 (pow.f64 y y) (/.f64 (exp.f64 z) (*.f64 x x))) (+.f64 (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (/.f64 (pow.f64 y y) (/.f64 (exp.f64 z) x))) (*.f64 1/6 (/.f64 (pow.f64 y y) (/.f64 (exp.f64 z) (pow.f64 x 3))))))
(+.f64 (fma.f64 1/6 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (pow.f64 x 3)) (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) x)) (fma.f64 1/2 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 x x)) (/.f64 (pow.f64 y y) (exp.f64 z))))
(fma.f64 1/2 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 x x)) (fma.f64 1/6 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (pow.f64 x 3)) (fma.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) x (/.f64 (pow.f64 y y) (exp.f64 z)))))
(fma.f64 x (/.f64 (pow.f64 y y) (exp.f64 z)) (fma.f64 1/2 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 x x)) (fma.f64 1/6 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (pow.f64 x 3)) (/.f64 (pow.f64 y y) (exp.f64 z)))))

prune39.0ms (1.6%)

Pruning

2 alts after pruning (0 fresh and 2 done)

PrunedKeptTotal
New60060
Fresh000
Picked011
Done011
Total60262
Error
0b
Counts
62 → 2
Alt Table
StatusErrorProgram
14.3b
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
0.0b
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
Compiler

Compiled 1091 to 304 computations (72.1% saved)

regimes61.0ms (2.5%)

Accuracy

Total 0.0b remaining (90.2%)

Threshold costs 0.0b (90.2%)

Counts
12 → 1
Compiler

Compiled 143 to 74 computations (48.3% saved)

simplify2.0ms (0.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0812
11012
21512
31712
41812
Stop Event
saturated
Calls
Call 1
Inputs
(exp.f64 (-.f64 (fma.f64 (log.f64 y) y x) z))
Outputs
(exp.f64 (-.f64 (fma.f64 (log.f64 y) y x) z))

end75.0ms (3%)

Stop Event
done
Compiler

Compiled 45 to 29 computations (35.6% saved)

Profiling

Loading profile data...