Details

Time bar (total: 3.7s)

analyze158.0ms (4.3%)

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
Compiler

Compiled 13 to 9 computations (30.8% saved)

sample2.4s (63.9%)

Results
1.4s8256×body256valid
955.0ms5457×body256invalid

preprocess62.0ms (1.7%)

Algorithm
egg-herbie
Rules
818×unswap-sqr_binary64
576×times-frac_binary64
387×associate-*l*_binary64
364×associate-*r*_binary64
352×associate-/r/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02256
15548
213348
329948
454048
5122648
6500448
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 z x)))
(exp.f64 (fma.f64 y (log.f64 y) (-.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)))
(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))
(*.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 15 to 11 computations (26.7% saved)

simplify82.0ms (2.2%)

Algorithm
egg-herbie
Rules
508×unswap-sqr_binary64
478×associate-/l/_binary64
408×associate-/r/_binary64
362×fma-neg_binary64
337×fma-def_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0914
11812
24112
38912
415712
531312
696812
7256012
8527812
9597612
10742512
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)))

eval1.0ms (0%)

Compiler

Compiled 20 to 12 computations (40% saved)

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
Click to see full alt table
StatusErrorProgram
0b
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
15.0b
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
Compiler

Compiled 23 to 15 computations (34.8% saved)

localize26.0ms (0.7%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 x (*.f64 y (log.f64 y)))
0.2b
(*.f64 y (log.f64 y))
Compiler

Compiled 35 to 8 computations (77.1% saved)

series94.0ms (2.6%)

Counts
2 → 32
Calls

9 calls:

TimeVariablePointExpression
52.0ms
y
@0
(*.f64 y (log.f64 y))
22.0ms
y
@-inf
(*.f64 y (log.f64 y))
10.0ms
x
@0
(+.f64 x (*.f64 y (log.f64 y)))
9.0ms
y
@inf
(*.f64 y (log.f64 y))
0.0ms
x
@inf
(+.f64 x (*.f64 y (log.f64 y)))

rewrite57.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
694×pow1_binary64
644×add-log-exp_binary64
644×log1p-expm1-u_binary64
644×expm1-log1p-u_binary64
630×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0615
112613
2174413
Stop Event
node limit
Counts
2 → 46
Calls
Call 1
Inputs
(*.f64 y (log.f64 y))
(+.f64 x (*.f64 y (log.f64 y)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.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 cbrt.f64 (pow.f64 (*.f64 y (log.f64 y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (log.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (-.f64 (pow.f64 y y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (log.f64 y))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (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 x x (*.f64 (*.f64 y (log.f64 y)) (-.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 1 (-.f64 x (*.f64 y (log.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 x x (*.f64 (*.f64 y (log.f64 y)) (-.f64 (*.f64 y (log.f64 y)) 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 x x (*.f64 (*.f64 y (log.f64 y)) (-.f64 (*.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 (pow.f64 (*.f64 y (log.f64 y)) 2) (-.f64 (*.f64 x x) (*.f64 (*.f64 x y) (log.f64 y)))))))) (#(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 x x (*.f64 (*.f64 y (log.f64 y)) (-.f64 (*.f64 y (log.f64 y)) 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 (pow.f64 (fma.f64 y (log.f64 y) x) 3) 1/3)))) (#(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 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 cbrt.f64 (pow.f64 (fma.f64 y (log.f64 y) x) 3))))) (#(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 log1p.f64 (expm1.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 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 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 (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 (*.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 (*.f64 y (log.f64 y))) (sqrt.f64 (*.f64 y (log.f64 y))) x)))))

simplify110.0ms (3%)

Algorithm
egg-herbie
Rules
995×fma-neg_binary64
871×fma-def_binary64
671×associate--r-_binary64
504×distribute-rgt-in_binary64
476×associate--l-_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
020239
143239
277195
3178195
4348195
5794195
62712195
74273195
85322195
95594195
105730195
115914195
Stop Event
node limit
Counts
78 → 54
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 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y)
(*.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 (*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y)))) x)
(+.f64 (*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y)))) x)
(+.f64 (*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y)))) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y)
(+.f64 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y) x)
(+.f64 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y) x)
(+.f64 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y) x)
Outputs
(*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y))))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 (neg.f64 (log.f64 y)) (neg.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 (neg.f64 (log.f64 y)) (neg.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 (neg.f64 (log.f64 y)) (neg.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 (neg.f64 (log.f64 y)) (neg.f64 y))
(*.f64 y (log.f64 y))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y)
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 (neg.f64 (log.f64 y)) (neg.f64 y))
(*.f64 y (log.f64 y))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y)
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 (neg.f64 (log.f64 y)) (neg.f64 y))
(*.f64 y (log.f64 y))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y)
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 (neg.f64 (log.f64 y)) (neg.f64 y))
(*.f64 y (log.f64 y))
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y)
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 (neg.f64 (log.f64 y)) (neg.f64 y))
(*.f64 y (log.f64 y))
(*.f64 y (log.f64 y))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 (neg.f64 (log.f64 y)) (neg.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 (neg.f64 (log.f64 y)) (neg.f64 y))
(*.f64 y (log.f64 y))
(+.f64 (*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y)))) x)
(fma.f64 y (log.f64 y) x)
(+.f64 (*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y)))) x)
(fma.f64 y (log.f64 y) x)
(+.f64 (*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y)))) x)
(fma.f64 y (log.f64 y) x)
(*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y)
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(*.f64 (neg.f64 (log.f64 y)) (neg.f64 y))
(*.f64 y (log.f64 y))
(+.f64 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y) x)
(fma.f64 y (log.f64 y) x)
(+.f64 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y) x)
(fma.f64 y (log.f64 y) x)
(+.f64 (*.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 y))) (log.f64 -1)) y) x)
(fma.f64 y (log.f64 y) x)

localize10.0ms (0.3%)

Local error

Found 1 expressions with local error:

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

Compiled 24 to 7 computations (70.8% saved)

series32.0ms (0.9%)

Counts
1 → 20
Calls

9 calls:

TimeVariablePointExpression
12.0ms
z
@inf
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
12.0ms
x
@inf
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
2.0ms
y
@inf
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
1.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)))

rewrite64.0ms (1.7%)

Algorithm
batch-egg-rewrite
Rules
487×prod-diff_binary64
458×log-prod_binary64
273×pow-prod-down_binary64
248×pow2_binary64
198×pow-pow_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0812
117712
2250612
Stop Event
node limit
Counts
1 → 45
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 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x))))) 2)) (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)))) (cbrt.f64 (pow.f64 (/.f64 (exp.f64 (-.f64 z x)) (pow.f64 y y)) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (exp.f64 (-.f64 z x)) (pow.f64 y y)) -2)) (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 y (+.f64 y y))) (*.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 (pow.f64 (sqrt.f64 y) y) (*.f64 (pow.f64 (sqrt.f64 y) y) (exp.f64 (neg.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 y (+.f64 y y))) 1) (/.f64 (cbrt.f64 (pow.f64 y y)) (exp.f64 (-.f64 z x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (sqrt.f64 y) y) 1) (/.f64 (pow.f64 (sqrt.f64 y) y) (exp.f64 (-.f64 z x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (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 (cbrt.f64 (pow.f64 y (+.f64 y y))) (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 (pow.f64 (sqrt.f64 y) y) (pow.f64 (cbrt.f64 (exp.f64 (-.f64 z x))) 2)) (/.f64 (pow.f64 (sqrt.f64 y) y) (cbrt.f64 (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (exp.f64 (-.f64 z x)) -1/2) (/.f64 (pow.f64 y y) (sqrt.f64 (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 y (+.f64 y y))) (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 (exp.f64 (-.f64 z x)) (pow.f64 y y)) -2) 1/2)))) (#(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 pow.f64 (/.f64 (pow.f64 y (*.f64 y 3)) (pow.f64 (exp.f64 (-.f64 z x)) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (exp.f64 (-.f64 z x)) (pow.f64 y y)) 1) -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 (exp.f64 (-.f64 z x)) (pow.f64 y y)) -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 y (*.f64 y 3)) (pow.f64 (exp.f64 (-.f64 z x)) 3)))))) (#(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 log1p.f64 (expm1.f64 (/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (fma.f64 y (log.f64 y) (neg.f64 (-.f64 z x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (fma.f64 y (log.f64 y) (neg.f64 (-.f64 z x))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (fma.f64 y (log.f64 y) (neg.f64 (-.f64 z x)))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 1/3 (fma.f64 y (log.f64 y) (neg.f64 (-.f64 z x)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 1/2 (fma.f64 y (log.f64 y) (neg.f64 (-.f64 z x)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (-.f64 (-.f64 z x) (*.f64 y (log.f64 y))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (fma.f64 y (log.f64 y) (neg.f64 (-.f64 z x))) 1) 1))))))

simplify63.0ms (1.7%)

Algorithm
egg-herbie
Rules
483×fma-def_binary64
452×associate-*l*_binary64
449×associate-*r*_binary64
315×unsub-neg_binary64
276×unswap-sqr_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
089606
1292560
21083458
36624456
Stop Event
node limit
Counts
65 → 71
Calls
Call 1
Inputs
(/.f64 1 (exp.f64 (-.f64 z x)))
(+.f64 (/.f64 1 (exp.f64 (-.f64 z x))) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x))))
(+.f64 (/.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 y (log.f64 y)) (exp.f64 (-.f64 z x)))))
(+.f64 (/.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/6 (/.f64 (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3)) (exp.f64 (-.f64 z x)))))))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 y y) z) (exp.f64 (neg.f64 x)))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (*.f64 -1 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))))) (pow.f64 z 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 y y) z) (exp.f64 (neg.f64 x)))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (*.f64 -1 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))))) (pow.f64 z 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 y y) z) (exp.f64 (neg.f64 x)))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 z 3) (+.f64 (*.f64 -1 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (*.f64 -1 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))))) (+.f64 (*.f64 1/6 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (*.f64 -1/2 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))))))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))))))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (+.f64 (*.f64 -1 z) x))))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (+.f64 (*.f64 -1 z) x))))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (+.f64 (*.f64 -1 z) x))))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (+.f64 (*.f64 -1 z) 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 (pow.f64 y y) (exp.f64 z)) (+.f64 (/.f64 (*.f64 (pow.f64 y y) x) (exp.f64 z)) (*.f64 -1 (*.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 z))) (*.f64 -1 (/.f64 (pow.f64 y y) (exp.f64 z)))) (pow.f64 x 2)))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (+.f64 (*.f64 -1/6 (/.f64 (pow.f64 y y) (exp.f64 z))) (*.f64 -1 (/.f64 (pow.f64 y y) (exp.f64 z))))) (pow.f64 x 3))) (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (+.f64 (/.f64 (*.f64 (pow.f64 y y) x) (exp.f64 z)) (*.f64 -1 (*.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 z))) (*.f64 -1 (/.f64 (pow.f64 y y) (exp.f64 z)))) (pow.f64 x 2))))))
(/.f64 (pow.f64 y y) (exp.f64 (+.f64 (*.f64 -1 x) z)))
(/.f64 (pow.f64 y y) (exp.f64 (+.f64 (*.f64 -1 x) z)))
(/.f64 (pow.f64 y y) (exp.f64 (+.f64 (*.f64 -1 x) z)))
(/.f64 (pow.f64 y y) (exp.f64 (+.f64 (*.f64 -1 x) z)))
Outputs
(/.f64 1 (exp.f64 (-.f64 z x)))
(exp.f64 (neg.f64 (-.f64 z x)))
(exp.f64 (-.f64 x z))
(+.f64 (/.f64 1 (exp.f64 (-.f64 z x))) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x))))
(+.f64 (exp.f64 (neg.f64 (-.f64 z x))) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x))))
(fma.f64 (/.f64 y (exp.f64 (-.f64 z x))) (log.f64 y) (exp.f64 (-.f64 x z)))
(fma.f64 (*.f64 y (exp.f64 (-.f64 x z))) (log.f64 y) (exp.f64 (-.f64 x z)))
(+.f64 (/.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 y (log.f64 y)) (exp.f64 (-.f64 z x)))))
(+.f64 (exp.f64 (neg.f64 (-.f64 z x))) (fma.f64 1/2 (/.f64 (*.f64 y y) (/.f64 (exp.f64 (-.f64 z x)) (pow.f64 (log.f64 y) 2))) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x)))))
(+.f64 (exp.f64 (neg.f64 (-.f64 z x))) (fma.f64 1/2 (*.f64 (/.f64 (*.f64 y y) (exp.f64 (-.f64 z x))) (pow.f64 (log.f64 y) 2)) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x)))))
(fma.f64 1/2 (*.f64 (pow.f64 (log.f64 y) 2) (/.f64 (*.f64 y y) (exp.f64 (-.f64 z x)))) (fma.f64 (/.f64 y (exp.f64 (-.f64 z x))) (log.f64 y) (exp.f64 (-.f64 x z))))
(fma.f64 1/2 (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 (*.f64 y y) (exp.f64 (-.f64 x z)))) (fma.f64 (*.f64 y (exp.f64 (-.f64 x z))) (log.f64 y) (exp.f64 (-.f64 x z))))
(+.f64 (/.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/6 (/.f64 (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3)) (exp.f64 (-.f64 z x)))))))
(+.f64 (exp.f64 (neg.f64 (-.f64 z x))) (+.f64 (fma.f64 1/2 (/.f64 (*.f64 y y) (/.f64 (exp.f64 (-.f64 z x)) (pow.f64 (log.f64 y) 2))) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x)))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3)) (exp.f64 (-.f64 z x))))))
(+.f64 (exp.f64 (neg.f64 (-.f64 z x))) (fma.f64 1/2 (*.f64 (/.f64 (*.f64 y y) (exp.f64 (-.f64 z x))) (pow.f64 (log.f64 y) 2)) (fma.f64 1/6 (*.f64 (/.f64 (pow.f64 y 3) (exp.f64 (-.f64 z x))) (pow.f64 (log.f64 y) 3)) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (-.f64 z x))))))
(+.f64 (fma.f64 (/.f64 y (exp.f64 (-.f64 z x))) (log.f64 y) (exp.f64 (-.f64 x z))) (fma.f64 1/2 (*.f64 (pow.f64 (log.f64 y) 2) (/.f64 (*.f64 y y) (exp.f64 (-.f64 z x)))) (/.f64 1/6 (/.f64 (/.f64 (exp.f64 (-.f64 z x)) (pow.f64 (log.f64 y) 3)) (pow.f64 y 3)))))
(+.f64 (fma.f64 (*.f64 y (exp.f64 (-.f64 x z))) (log.f64 y) (exp.f64 (-.f64 x z))) (fma.f64 1/2 (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 (*.f64 y y) (exp.f64 (-.f64 x z)))) (*.f64 (*.f64 (pow.f64 y 3) (*.f64 1/6 (pow.f64 (log.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 -1 (/.f64 (*.f64 (pow.f64 y y) z) (exp.f64 (neg.f64 x)))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))))
(fma.f64 -1 (/.f64 (*.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))) (/.f64 (*.f64 z (pow.f64 y y)) (exp.f64 (neg.f64 x))))
(*.f64 (exp.f64 x) (-.f64 (pow.f64 y y) (*.f64 z (pow.f64 y y))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (*.f64 -1 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))))) (pow.f64 z 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 y y) z) (exp.f64 (neg.f64 x)))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))))
(fma.f64 -1 (*.f64 (/.f64 (*.f64 -1/2 (pow.f64 y y)) (exp.f64 (neg.f64 x))) (*.f64 z z)) (fma.f64 -1 (/.f64 (*.f64 z (pow.f64 y y)) (exp.f64 (neg.f64 x))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))))
(fma.f64 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (*.f64 z z) (-.f64 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))) (/.f64 (*.f64 z (pow.f64 y y)) (exp.f64 (neg.f64 x)))))
(-.f64 (*.f64 (pow.f64 y y) (exp.f64 x)) (*.f64 (*.f64 (pow.f64 y y) (exp.f64 x)) (+.f64 (*.f64 (*.f64 z z) -1/2) z)))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (*.f64 -1 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))))) (pow.f64 z 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 y y) z) (exp.f64 (neg.f64 x)))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 z 3) (+.f64 (*.f64 -1 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (*.f64 -1 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))))) (+.f64 (*.f64 1/6 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (*.f64 -1/2 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))))))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))))))
(fma.f64 -1 (*.f64 (/.f64 (*.f64 -1/2 (pow.f64 y y)) (exp.f64 (neg.f64 x))) (*.f64 z z)) (fma.f64 -1 (/.f64 (*.f64 z (pow.f64 y y)) (exp.f64 (neg.f64 x))) (fma.f64 -1 (*.f64 (pow.f64 z 3) (fma.f64 -1 (/.f64 (*.f64 -1/2 (pow.f64 y y)) (exp.f64 (neg.f64 x))) (*.f64 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))) -1/3))) (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))))))
(fma.f64 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))) (*.f64 z z) (-.f64 (-.f64 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))) (*.f64 (pow.f64 z 3) (fma.f64 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))) -1/3 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x))))))) (/.f64 (*.f64 z (pow.f64 y y)) (exp.f64 (neg.f64 x)))))
(-.f64 (-.f64 (*.f64 (pow.f64 y y) (exp.f64 x)) (*.f64 1/6 (*.f64 (*.f64 (pow.f64 z 3) (pow.f64 y y)) (exp.f64 x)))) (*.f64 (*.f64 (pow.f64 y y) (exp.f64 x)) (+.f64 (*.f64 (*.f64 z z) -1/2) z)))
(-.f64 (*.f64 (pow.f64 y y) (exp.f64 x)) (+.f64 (*.f64 (*.f64 (pow.f64 y y) (exp.f64 x)) (+.f64 (*.f64 (*.f64 z z) -1/2) z)) (*.f64 1/6 (*.f64 (*.f64 (pow.f64 z 3) (pow.f64 y y)) (exp.f64 x)))))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (+.f64 (*.f64 -1 z) x))))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (fma.f64 -1 z x))))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (+.f64 (*.f64 -1 z) x))))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (fma.f64 -1 z x))))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (+.f64 (*.f64 -1 z) x))))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (fma.f64 -1 z x))))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (+.f64 (*.f64 -1 z) x))))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (fma.f64 -1 z x))))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(*.f64 (exp.f64 (-.f64 x 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)))
(fma.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) x (/.f64 (pow.f64 y y) (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 (*.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 z))) (*.f64 -1 (/.f64 (pow.f64 y y) (exp.f64 z)))) (pow.f64 x 2)))))
(+.f64 (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (/.f64 (pow.f64 y y) (/.f64 (exp.f64 z) x))) (neg.f64 (*.f64 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) -1/2) (*.f64 x x))))
(+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (-.f64 (/.f64 (pow.f64 y y) (/.f64 (exp.f64 z) x)) (*.f64 x (*.f64 x (/.f64 (*.f64 (pow.f64 y y) -1/2) (exp.f64 z))))))
(+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (-.f64 x (*.f64 -1/2 (*.f64 x x)))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (+.f64 (*.f64 -1/6 (/.f64 (pow.f64 y y) (exp.f64 z))) (*.f64 -1 (/.f64 (pow.f64 y y) (exp.f64 z))))) (pow.f64 x 3))) (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (+.f64 (/.f64 (*.f64 (pow.f64 y y) x) (exp.f64 z)) (*.f64 -1 (*.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y y) (exp.f64 z))) (*.f64 -1 (/.f64 (pow.f64 y y) (exp.f64 z)))) (pow.f64 x 2))))))
(fma.f64 -1 (*.f64 (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) -7/6)) (pow.f64 x 3)) (+.f64 (+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (/.f64 (pow.f64 y y) (/.f64 (exp.f64 z) x))) (neg.f64 (*.f64 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) -1/2) (*.f64 x x)))))
(+.f64 (-.f64 (/.f64 (pow.f64 y y) (/.f64 (exp.f64 z) x)) (*.f64 x (*.f64 x (/.f64 (*.f64 (pow.f64 y y) -1/2) (exp.f64 z))))) (fma.f64 (neg.f64 (fma.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) -7/6 (/.f64 (pow.f64 y y) (exp.f64 z)))) (pow.f64 x 3) (/.f64 (pow.f64 y y) (exp.f64 z))))
(+.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (-.f64 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (-.f64 x (*.f64 -1/2 (*.f64 x x)))) (*.f64 (*.f64 (/.f64 -1/6 (exp.f64 z)) (pow.f64 y y)) (pow.f64 x 3))))
(+.f64 (*.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) (-.f64 x (*.f64 -1/2 (*.f64 x x)))) (fma.f64 (pow.f64 x 3) (/.f64 1/6 (/.f64 (exp.f64 z) (pow.f64 y y))) (/.f64 (pow.f64 y y) (exp.f64 z))))
(/.f64 (pow.f64 y y) (exp.f64 (+.f64 (*.f64 -1 x) z)))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (fma.f64 -1 z x))))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (+.f64 (*.f64 -1 x) z)))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (fma.f64 -1 z x))))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (+.f64 (*.f64 -1 x) z)))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (fma.f64 -1 z x))))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (+.f64 (*.f64 -1 x) z)))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 (fma.f64 -1 z x))))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(*.f64 (exp.f64 (-.f64 x z)) (pow.f64 y y))

eval43.0ms (1.2%)

Compiler

Compiled 2061 to 703 computations (65.9% saved)

prune46.0ms (1.2%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New1232125
Fresh000
Picked101
Done101
Total1252127
Error
0b
Counts
127 → 2
Alt Table
Click to see full alt table
StatusErrorProgram
26.8b
(/.f64 (pow.f64 y y) (exp.f64 z))
0.9b
(exp.f64 (-.f64 x z))
Compiler

Compiled 16 to 11 computations (31.3% saved)

localize9.0ms (0.2%)

Compiler

Compiled 12 to 5 computations (58.3% saved)

localize14.0ms (0.4%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.8b
(/.f64 (pow.f64 y y) (exp.f64 z))
Compiler

Compiled 16 to 6 computations (62.5% saved)

series7.0ms (0.2%)

Counts
1 → 8
Calls

6 calls:

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

rewrite79.0ms (2.1%)

Algorithm
batch-egg-rewrite
Rules
657×pow1_binary64
608×add-log-exp_binary64
608×log1p-expm1-u_binary64
608×expm1-log1p-u_binary64
592×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
069
11259
216399
Stop Event
node limit
Counts
1 → 31
Calls
Call 1
Inputs
(/.f64 (pow.f64 y y) (exp.f64 z))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (/.f64 (pow.f64 y y) (exp.f64 z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 y y) (exp.f64 (neg.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (pow.f64 y y) (exp.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 z))) (pow.f64 (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 z))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 z))) 2) (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (*.f64 y y) y)) (*.f64 (cbrt.f64 (pow.f64 y y)) (exp.f64 (neg.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (pow.f64 y y) (exp.f64 z))) (sqrt.f64 (/.f64 (pow.f64 y y) (exp.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (pow.f64 y y)) (/.f64 1 (neg.f64 (exp.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (exp.f64 (neg.f64 z)) (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 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (*.f64 y y) y)) 1) (/.f64 (cbrt.f64 (pow.f64 y y)) (exp.f64 z)))))) (#(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 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (exp.f64 z)) 2)) (/.f64 (pow.f64 y y) (cbrt.f64 (exp.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (*.f64 y y) y)) (pow.f64 (cbrt.f64 (exp.f64 z)) 2)) (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (pow.f64 y y)) (pow.f64 (cbrt.f64 (exp.f64 z)) 2)) (/.f64 (sqrt.f64 (pow.f64 y y)) (cbrt.f64 (exp.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (exp.f64 z))) (/.f64 (pow.f64 y y) (sqrt.f64 (exp.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (*.f64 y y) y)) (sqrt.f64 (exp.f64 z))) (/.f64 (cbrt.f64 (pow.f64 y y)) (sqrt.f64 (exp.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (pow.f64 y y) (exp.f64 z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (pow.f64 y y) (exp.f64 z))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (exp.f64 z) (pow.f64 y y)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (pow.f64 y y) (neg.f64 (exp.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (pow.f64 y y) (exp.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (pow.f64 y y) (exp.f64 z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (pow.f64 y y) 3) (pow.f64 (exp.f64 z) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (pow.f64 y y) (exp.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (pow.f64 y y) (exp.f64 z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 y (log.f64 y)) z))))))

simplify61.0ms (1.6%)

Algorithm
egg-herbie
Rules
372×fma-def_binary64
359×associate-/l*_binary64
351×distribute-rgt-out_binary64
321×associate-/r*_binary64
270×associate-*l*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
052223
1170210
2568186
33416178
Stop Event
node limit
Counts
39 → 46
Calls
Call 1
Inputs
(/.f64 1 (exp.f64 z))
(+.f64 (/.f64 1 (exp.f64 z)) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 z)))
(+.f64 (/.f64 1 (exp.f64 z)) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y 2) (pow.f64 (log.f64 y) 2)) (exp.f64 z))) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 z))))
(+.f64 (/.f64 1 (exp.f64 z)) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3)) (exp.f64 z))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y 2) (pow.f64 (log.f64 y) 2)) (exp.f64 z))) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 z)))))
(pow.f64 y y)
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y y) z)) (pow.f64 y y))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y y) z)) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y y)) (*.f64 1/2 (pow.f64 y y))) (pow.f64 z 2))) (pow.f64 y y)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y y) z)) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (+.f64 (*.f64 -1 (pow.f64 y y)) (*.f64 1/2 (pow.f64 y y)))) (+.f64 (*.f64 -1/2 (pow.f64 y y)) (*.f64 1/6 (pow.f64 y y)))) (pow.f64 z 3))) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y y)) (*.f64 1/2 (pow.f64 y y))) (pow.f64 z 2))) (pow.f64 y y))))
Outputs
(/.f64 1 (exp.f64 z))
(exp.f64 (neg.f64 z))
(+.f64 (/.f64 1 (exp.f64 z)) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 z)))
(+.f64 (exp.f64 (neg.f64 z)) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 z)))
(+.f64 (exp.f64 (neg.f64 z)) (*.f64 (/.f64 y (exp.f64 z)) (log.f64 y)))
(fma.f64 (/.f64 y (exp.f64 z)) (log.f64 y) (exp.f64 (neg.f64 z)))
(+.f64 (/.f64 1 (exp.f64 z)) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y 2) (pow.f64 (log.f64 y) 2)) (exp.f64 z))) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 z))))
(+.f64 (exp.f64 (neg.f64 z)) (fma.f64 1/2 (/.f64 (*.f64 (*.f64 y y) (pow.f64 (log.f64 y) 2)) (exp.f64 z)) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 z))))
(+.f64 (exp.f64 (neg.f64 z)) (fma.f64 1/2 (*.f64 (/.f64 (*.f64 y y) (exp.f64 z)) (pow.f64 (log.f64 y) 2)) (*.f64 (/.f64 y (exp.f64 z)) (log.f64 y))))
(fma.f64 1/2 (*.f64 (pow.f64 (log.f64 y) 2) (/.f64 y (/.f64 (exp.f64 z) y))) (fma.f64 (/.f64 y (exp.f64 z)) (log.f64 y) (exp.f64 (neg.f64 z))))
(fma.f64 1/2 (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 (/.f64 y (exp.f64 z)) y)) (fma.f64 (/.f64 y (exp.f64 z)) (log.f64 y) (exp.f64 (neg.f64 z))))
(+.f64 (/.f64 1 (exp.f64 z)) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3)) (exp.f64 z))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y 2) (pow.f64 (log.f64 y) 2)) (exp.f64 z))) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 z)))))
(+.f64 (exp.f64 (neg.f64 z)) (fma.f64 1/6 (/.f64 (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3)) (exp.f64 z)) (fma.f64 1/2 (/.f64 (*.f64 (*.f64 y y) (pow.f64 (log.f64 y) 2)) (exp.f64 z)) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 z)))))
(+.f64 (exp.f64 (neg.f64 z)) (fma.f64 1/6 (*.f64 (/.f64 (pow.f64 y 3) (exp.f64 z)) (pow.f64 (log.f64 y) 3)) (fma.f64 1/2 (*.f64 (/.f64 (*.f64 y y) (exp.f64 z)) (pow.f64 (log.f64 y) 2)) (*.f64 (/.f64 y (exp.f64 z)) (log.f64 y)))))
(fma.f64 1/6 (*.f64 (/.f64 (pow.f64 (log.f64 y) 3) (exp.f64 z)) (pow.f64 y 3)) (fma.f64 1/2 (*.f64 (pow.f64 (log.f64 y) 2) (/.f64 y (/.f64 (exp.f64 z) y))) (fma.f64 (/.f64 y (exp.f64 z)) (log.f64 y) (exp.f64 (neg.f64 z)))))
(fma.f64 1/6 (*.f64 (pow.f64 (log.f64 y) 3) (/.f64 (pow.f64 y 3) (exp.f64 z))) (fma.f64 1/2 (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 (/.f64 y (exp.f64 z)) y)) (fma.f64 (/.f64 y (exp.f64 z)) (log.f64 y) (exp.f64 (neg.f64 z)))))
(pow.f64 y y)
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y y) z)) (pow.f64 y y))
(fma.f64 -1 (*.f64 z (pow.f64 y y)) (pow.f64 y y))
(-.f64 (pow.f64 y y) (*.f64 z (pow.f64 y y)))
(*.f64 (+.f64 (neg.f64 z) 1) (pow.f64 y y))
(*.f64 (pow.f64 y y) (-.f64 1 z))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y y) z)) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y y)) (*.f64 1/2 (pow.f64 y y))) (pow.f64 z 2))) (pow.f64 y y)))
(fma.f64 -1 (*.f64 z (pow.f64 y y)) (fma.f64 -1 (*.f64 (*.f64 (pow.f64 y y) -1/2) (*.f64 z z)) (pow.f64 y y)))
(-.f64 (fma.f64 (*.f64 1/2 (pow.f64 y y)) (*.f64 z z) (pow.f64 y y)) (*.f64 z (pow.f64 y y)))
(-.f64 (pow.f64 y y) (*.f64 (pow.f64 y y) (+.f64 z (*.f64 z (*.f64 z -1/2)))))
(*.f64 (pow.f64 y y) (-.f64 1 (+.f64 z (*.f64 z (*.f64 z -1/2)))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 y y) z)) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (+.f64 (*.f64 -1 (pow.f64 y y)) (*.f64 1/2 (pow.f64 y y)))) (+.f64 (*.f64 -1/2 (pow.f64 y y)) (*.f64 1/6 (pow.f64 y y)))) (pow.f64 z 3))) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y y)) (*.f64 1/2 (pow.f64 y y))) (pow.f64 z 2))) (pow.f64 y y))))
(fma.f64 -1 (*.f64 z (pow.f64 y y)) (fma.f64 -1 (*.f64 (fma.f64 -1 (*.f64 (pow.f64 y y) -1/2) (*.f64 (pow.f64 y y) -1/3)) (pow.f64 z 3)) (fma.f64 -1 (*.f64 (*.f64 (pow.f64 y y) -1/2) (*.f64 z z)) (pow.f64 y y))))
(-.f64 (-.f64 (fma.f64 (*.f64 1/2 (pow.f64 y y)) (*.f64 z z) (pow.f64 y y)) (*.f64 (fma.f64 (pow.f64 y y) -1/3 (*.f64 1/2 (pow.f64 y y))) (pow.f64 z 3))) (*.f64 z (pow.f64 y y)))
(fma.f64 (pow.f64 z 3) (*.f64 (pow.f64 y y) -1/6) (-.f64 (pow.f64 y y) (*.f64 (pow.f64 y y) (+.f64 z (*.f64 z (*.f64 z -1/2))))))
(fma.f64 (pow.f64 z 3) (*.f64 (pow.f64 y y) -1/6) (*.f64 (pow.f64 y y) (-.f64 1 (+.f64 z (*.f64 z (*.f64 z -1/2))))))

eval19.0ms (0.5%)

Compiler

Compiled 658 to 243 computations (63.1% saved)

prune14.0ms (0.4%)

Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New44246
Fresh000
Picked101
Done011
Total45348
Error
0b
Counts
48 → 3
Alt Table
Click to see full alt table
StatusErrorProgram
0.9b
(exp.f64 (-.f64 x z))
44.4b
(pow.f64 y y)
18.7b
(exp.f64 (neg.f64 z))
Compiler

Compiled 19 to 14 computations (26.3% saved)

localize20.0ms (0.5%)

Compiler

Compiled 9 to 5 computations (44.4% saved)

localize8.0ms (0.2%)

Compiler

Compiled 7 to 4 computations (42.9% saved)

eval0.0ms (0%)

Compiler

Compiled 3 to 3 computations (0% saved)

prune4.0ms (0.1%)

Pruning

3 alts after pruning (0 fresh and 3 done)

PrunedKeptTotal
New000
Fresh000
Picked011
Done022
Total033
Error
0b
Counts
3 → 3
Alt Table
Click to see full alt table
StatusErrorProgram
0.9b
(exp.f64 (-.f64 x z))
44.4b
(pow.f64 y y)
18.7b
(exp.f64 (neg.f64 z))
Compiler

Compiled 19 to 14 computations (26.3% saved)

regimes73.0ms (2%)

Counts
6 → 1
Calls
Call 1
Inputs
(pow.f64 y y)
(exp.f64 (neg.f64 z))
(exp.f64 (-.f64 x z))
(/.f64 (pow.f64 y y) (exp.f64 z))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
Outputs
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
Calls

7 calls:

11.0ms
y
11.0ms
(+.f64 x (*.f64 y (log.f64 y)))
11.0ms
(-.f64 (+.f64 x (*.f64 y (log.f64 y))) z)
11.0ms
x
11.0ms
z
Results
ErrorSegmentsBranch
0b1x
0b1y
0b1z
0b1(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
0b1(-.f64 (+.f64 x (*.f64 y (log.f64 y))) z)
0b1(+.f64 x (*.f64 y (log.f64 y)))
0b1(*.f64 y (log.f64 y))
Compiler

Compiled 87 to 53 computations (39.1% saved)

regimes32.0ms (0.9%)

Counts
5 → 1
Calls
Call 1
Inputs
(pow.f64 y y)
(exp.f64 (neg.f64 z))
(exp.f64 (-.f64 x z))
(/.f64 (pow.f64 y y) (exp.f64 z))
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
Outputs
(exp.f64 (-.f64 x z))
Calls

3 calls:

10.0ms
y
10.0ms
z
9.0ms
x
Results
ErrorSegmentsBranch
0.9b1x
0.9b1y
0.9b1z
Compiler

Compiled 39 to 22 computations (43.6% saved)

regimes54.0ms (1.5%)

Accuracy

Total -26.6b remaining (-141.7%)

Threshold costs -26.6b (-141.7%)

Counts
2 → 1
Calls
Call 1
Inputs
(pow.f64 y y)
(exp.f64 (neg.f64 z))
Outputs
(exp.f64 (neg.f64 z))
Calls

3 calls:

35.0ms
z
7.0ms
y
7.0ms
x
Results
ErrorSegmentsBranch
18.7b1x
18.7b1y
18.7b1z
Compiler

Compiled 21 to 15 computations (28.6% saved)

simplify8.0ms (0.2%)

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
01429
12229
22629
32729
Stop Event
done
saturated
Calls
Call 1
Inputs
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
(exp.f64 (-.f64 x z))
(exp.f64 (neg.f64 z))
(pow.f64 y y)
Outputs
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
(exp.f64 (-.f64 x z))
(exp.f64 (neg.f64 z))
(pow.f64 y y)
Compiler

Compiled 31 to 22 computations (29% saved)

soundness0.0ms (0%)

end80.0ms (2.2%)

Compiler

Compiled 22 to 13 computations (40.9% saved)

Profiling

Loading profile data...