Details

Time bar (total: 5.0s)

analyze179.0ms (3.6%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
0%0%99.9%0.1%0%0%0%3
0%0%99.9%0.1%0%0%0%4
0%0%99.9%0.1%0%0%0%5
12.5%9.4%65.5%0.1%0%25%0%6
18.8%14%60.8%0.1%0%25%0%7
20%14%56.2%0.1%4.7%25%0%8
27.7%14%36.7%0.1%11.7%37.4%0%9
32.8%14.8%30.4%0.1%17.2%37.4%0%10
35.4%15.5%28.3%0.1%18.6%37.4%0%11
47.3%16.4%18.3%0.1%21.4%43.7%0%12
Compiler

Compiled 13 to 9 computations (30.8% saved)

sample3.6s (71.7%)

Results
2.2s8256×body256valid
691.0ms2515×body256invalid
626.0ms3112×body256infinite
Bogosity

preprocess64.0ms (1.3%)

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)

simplify90.0ms (1.8%)

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)

prune1.0ms (0%)

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
16.8b
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
0b
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
Compiler

Compiled 23 to 15 computations (34.8% saved)

localize13.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.3b
(*.f64 y (log.f64 y))
Compiler

Compiled 35 to 8 computations (77.1% saved)

series59.0ms (1.2%)

Counts
1 → 8
Calls

3 calls:

TimeVariablePointExpression
28.0ms
y
@0
(*.f64 y (log.f64 y))
23.0ms
y
@-inf
(*.f64 y (log.f64 y))
8.0ms
y
@inf
(*.f64 y (log.f64 y))

rewrite52.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
348×pow1_binary64
332×add-sqr-sqrt_binary64
327×*-un-lft-identity_binary64
319×add-log-exp_binary64
319×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
046
1766
28876
Stop Event
node limit
Counts
1 → 23
Calls
Call 1
Inputs
(*.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 (cbrt.f64 (pow.f64 y (+.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 (+.f64 1 (*.f64 y (log.f64 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 1 (*.f64 y (log.f64 y))) 3) 1) (+.f64 (*.f64 (+.f64 1 (*.f64 y (log.f64 y))) (+.f64 1 (*.f64 y (log.f64 y)))) (+.f64 1 (*.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 (pow.f64 (*.f64 y (log.f64 y)) 2) 1/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 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 (E.f64) (log.f64 (*.f64 y (log.f64 y))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (*.f64 y (log.f64 y))))) (sqrt.f64 (log.f64 (*.f64 y (log.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (cbrt.f64 (pow.f64 (log.f64 (*.f64 y (log.f64 y))) 2))) (cbrt.f64 (log.f64 (*.f64 y (log.f64 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 y (log.f64 y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 y (log.f64 y)))))) (#(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 exp.f64 (*.f64 (*.f64 3 (log.f64 (*.f64 y (log.f64 y)))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 y (log.f64 y)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 y (log.f64 y)))) 2))))))

simplify214.0ms (4.3%)

Algorithm
egg-herbie
Rules
812×distribute-rgt-in_binary64
775×unsub-neg_binary64
633×fma-def_binary64
625×distribute-neg-in_binary64
524×distribute-lft-in_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01480
13180
26348
313848
426348
564848
6209748
7341048
8456648
9493048
10501448
11504348
12505548
13505548
14602548
15706648
16750248
17768048
18781848
19784248
20784248
21784248
Stop Event
node limit
Counts
31 → 26
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)
Outputs
(*.f64 -1 (*.f64 y (log.f64 (/.f64 1 y))))
(neg.f64 (*.f64 y (neg.f64 (log.f64 y))))
(neg.f64 (*.f64 (neg.f64 y) (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))))
(neg.f64 (*.f64 (neg.f64 y) (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))))
(neg.f64 (*.f64 (neg.f64 y) (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))))
(neg.f64 (*.f64 (neg.f64 y) (log.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))))
(neg.f64 (*.f64 (neg.f64 y) (log.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))))
(neg.f64 (*.f64 (neg.f64 y) (log.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))))
(neg.f64 (*.f64 (neg.f64 y) (log.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))))
(neg.f64 (*.f64 (neg.f64 y) (log.f64 y)))
(*.f64 y (log.f64 y))

localize11.0ms (0.2%)

Local error

Found 1 expressions with local error:

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

Compiled 24 to 7 computations (70.8% saved)

series38.0ms (0.8%)

Counts
1 → 20
Calls

9 calls:

TimeVariablePointExpression
24.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)))
1.0ms
x
@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)))
1.0ms
y
@0
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))

rewrite66.0ms (1.3%)

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))))))

simplify66.0ms (1.3%)

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))

eval59.0ms (1.2%)

Compiler

Compiled 1647 to 562 computations (65.9% saved)

prune16.0ms (0.3%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New94397
Fresh000
Picked101
Done101
Total96399
Error
0b
Counts
99 → 3
Alt Table
Click to see full alt table
StatusErrorProgram
27.7b
(*.f64 (pow.f64 y y) (exp.f64 x))
27.7b
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))
0.9b
(exp.f64 (-.f64 x z))
Compiler

Compiled 26 to 18 computations (30.8% saved)

localize7.0ms (0.1%)

Compiler

Compiled 12 to 5 computations (58.3% saved)

localize8.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (pow.f64 y y) (exp.f64 x))
Compiler

Compiled 16 to 6 computations (62.5% saved)

series3.0ms (0.1%)

Counts
1 → 8
Calls

6 calls:

TimeVariablePointExpression
1.0ms
y
@0
(*.f64 (pow.f64 y y) (exp.f64 x))
1.0ms
y
@inf
(*.f64 (pow.f64 y y) (exp.f64 x))
1.0ms
y
@-inf
(*.f64 (pow.f64 y y) (exp.f64 x))
1.0ms
x
@-inf
(*.f64 (pow.f64 y y) (exp.f64 x))
0.0ms
x
@0
(*.f64 (pow.f64 y y) (exp.f64 x))

rewrite60.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
564×pow1_binary64
518×add-log-exp_binary64
518×log1p-expm1-u_binary64
518×expm1-log1p-u_binary64
504×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify67.0ms (1.3%)

Algorithm
egg-herbie
Rules
778×unswap-sqr_binary64
553×distribute-rgt-in_binary64
549×distribute-lft-in_binary64
532×*-commutative_binary64
349×distribute-rgt-out_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
036187
1114182
2361168
31584155
43207148
57714148
Stop Event
node limit
Counts
19 → 25
Calls
Call 1
Inputs
(exp.f64 x)
(+.f64 (*.f64 y (*.f64 (exp.f64 x) (log.f64 y))) (exp.f64 x))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) (*.f64 (exp.f64 x) (pow.f64 (log.f64 y) 2)))) (+.f64 (*.f64 y (*.f64 (exp.f64 x) (log.f64 y))) (exp.f64 x)))
(+.f64 (*.f64 1/6 (*.f64 (pow.f64 y 3) (*.f64 (exp.f64 x) (pow.f64 (log.f64 y) 3)))) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) (*.f64 (exp.f64 x) (pow.f64 (log.f64 y) 2)))) (+.f64 (*.f64 y (*.f64 (exp.f64 x) (log.f64 y))) (exp.f64 x))))
(pow.f64 y y)
(+.f64 (pow.f64 y y) (*.f64 (pow.f64 y y) x))
(+.f64 (pow.f64 y y) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y y) (pow.f64 x 2))) (*.f64 (pow.f64 y y) x)))
(+.f64 (*.f64 1/6 (*.f64 (pow.f64 y y) (pow.f64 x 3))) (+.f64 (pow.f64 y y) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y y) (pow.f64 x 2))) (*.f64 (pow.f64 y y) x))))
Outputs
(exp.f64 x)
(+.f64 (*.f64 y (*.f64 (exp.f64 x) (log.f64 y))) (exp.f64 x))
(fma.f64 y (*.f64 (exp.f64 x) (log.f64 y)) (exp.f64 x))
(fma.f64 (exp.f64 x) (*.f64 y (log.f64 y)) (exp.f64 x))
(*.f64 (exp.f64 x) (+.f64 1 (*.f64 y (log.f64 y))))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) (*.f64 (exp.f64 x) (pow.f64 (log.f64 y) 2)))) (+.f64 (*.f64 y (*.f64 (exp.f64 x) (log.f64 y))) (exp.f64 x)))
(fma.f64 1/2 (*.f64 (*.f64 y y) (*.f64 (exp.f64 x) (pow.f64 (log.f64 y) 2))) (fma.f64 y (*.f64 (exp.f64 x) (log.f64 y)) (exp.f64 x)))
(fma.f64 1/2 (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 (exp.f64 x) (*.f64 y y))) (fma.f64 y (*.f64 (exp.f64 x) (log.f64 y)) (exp.f64 x)))
(+.f64 (exp.f64 x) (*.f64 (exp.f64 x) (+.f64 (*.f64 y (log.f64 y)) (*.f64 (*.f64 y y) (*.f64 1/2 (pow.f64 (log.f64 y) 2))))))
(+.f64 (exp.f64 x) (*.f64 (exp.f64 x) (*.f64 (log.f64 y) (+.f64 y (*.f64 (log.f64 y) (*.f64 y (*.f64 y 1/2)))))))
(*.f64 (exp.f64 x) (+.f64 1 (*.f64 (log.f64 y) (+.f64 y (*.f64 (log.f64 y) (*.f64 y (*.f64 y 1/2)))))))
(+.f64 (*.f64 1/6 (*.f64 (pow.f64 y 3) (*.f64 (exp.f64 x) (pow.f64 (log.f64 y) 3)))) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) (*.f64 (exp.f64 x) (pow.f64 (log.f64 y) 2)))) (+.f64 (*.f64 y (*.f64 (exp.f64 x) (log.f64 y))) (exp.f64 x))))
(fma.f64 1/6 (*.f64 (pow.f64 y 3) (*.f64 (exp.f64 x) (pow.f64 (log.f64 y) 3))) (fma.f64 1/2 (*.f64 (*.f64 y y) (*.f64 (exp.f64 x) (pow.f64 (log.f64 y) 2))) (fma.f64 y (*.f64 (exp.f64 x) (log.f64 y)) (exp.f64 x))))
(fma.f64 1/6 (*.f64 (exp.f64 x) (*.f64 (pow.f64 (log.f64 y) 3) (pow.f64 y 3))) (fma.f64 1/2 (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 (exp.f64 x) (*.f64 y y))) (fma.f64 y (*.f64 (exp.f64 x) (log.f64 y)) (exp.f64 x))))
(+.f64 (exp.f64 x) (fma.f64 1/6 (*.f64 (exp.f64 x) (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3))) (*.f64 (exp.f64 x) (+.f64 (*.f64 y (log.f64 y)) (*.f64 (*.f64 y y) (*.f64 1/2 (pow.f64 (log.f64 y) 2)))))))
(+.f64 (exp.f64 x) (*.f64 (exp.f64 x) (+.f64 (*.f64 y (log.f64 y)) (*.f64 (pow.f64 (log.f64 y) 2) (+.f64 (*.f64 y (*.f64 y 1/2)) (*.f64 (log.f64 y) (*.f64 1/6 (pow.f64 y 3))))))))
(*.f64 (exp.f64 x) (+.f64 (*.f64 (log.f64 y) (+.f64 y (*.f64 (log.f64 y) (*.f64 y (*.f64 y 1/2))))) (+.f64 1 (*.f64 1/6 (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3))))))
(pow.f64 y y)
(+.f64 (pow.f64 y y) (*.f64 (pow.f64 y y) x))
(+.f64 (pow.f64 y y) (*.f64 x (pow.f64 y y)))
(*.f64 (+.f64 x 1) (pow.f64 y y))
(*.f64 (pow.f64 y y) (+.f64 x 1))
(+.f64 (pow.f64 y y) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y y) (pow.f64 x 2))) (*.f64 (pow.f64 y y) x)))
(+.f64 (pow.f64 y y) (fma.f64 1/2 (*.f64 (pow.f64 y y) (*.f64 x x)) (*.f64 x (pow.f64 y y))))
(+.f64 (*.f64 (+.f64 x 1) (pow.f64 y y)) (*.f64 1/2 (*.f64 (pow.f64 y y) (*.f64 x x))))
(*.f64 (pow.f64 y y) (+.f64 (+.f64 x 1) (*.f64 x (*.f64 x 1/2))))
(*.f64 (pow.f64 y y) (+.f64 x (+.f64 1 (*.f64 x (*.f64 x 1/2)))))
(*.f64 (pow.f64 y y) (+.f64 1 (+.f64 x (*.f64 x (*.f64 x 1/2)))))
(+.f64 (*.f64 1/6 (*.f64 (pow.f64 y y) (pow.f64 x 3))) (+.f64 (pow.f64 y y) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y y) (pow.f64 x 2))) (*.f64 (pow.f64 y y) x))))
(fma.f64 1/6 (*.f64 (pow.f64 y y) (pow.f64 x 3)) (+.f64 (pow.f64 y y) (fma.f64 1/2 (*.f64 (pow.f64 y y) (*.f64 x x)) (*.f64 x (pow.f64 y y)))))
(fma.f64 1/6 (*.f64 (pow.f64 y y) (pow.f64 x 3)) (+.f64 (*.f64 (+.f64 x 1) (pow.f64 y y)) (*.f64 1/2 (*.f64 (pow.f64 y y) (*.f64 x x)))))
(fma.f64 1/6 (*.f64 (pow.f64 y y) (pow.f64 x 3)) (*.f64 (pow.f64 y y) (+.f64 (+.f64 x 1) (*.f64 x (*.f64 x 1/2)))))
(*.f64 (pow.f64 y y) (+.f64 (+.f64 x (+.f64 1 (*.f64 x (*.f64 x 1/2)))) (*.f64 1/6 (pow.f64 x 3))))
(*.f64 (pow.f64 y y) (+.f64 x (+.f64 1 (*.f64 (*.f64 x x) (+.f64 1/2 (*.f64 x 1/6))))))

localize10.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))
Compiler

Compiled 20 to 7 computations (65% saved)

series4.0ms (0.1%)

Counts
1 → 12
Calls

6 calls:

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

rewrite70.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
676×pow1_binary64
626×add-log-exp_binary64
625×log1p-expm1-u_binary64
625×expm1-log1p-u_binary64
611×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify58.0ms (1.2%)

Algorithm
egg-herbie
Rules
496×associate-/l/_binary64
484×distribute-rgt-in_binary64
482×fma-neg_binary64
428×distribute-lft-in_binary64
281×associate-*r*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
053281
1158246
2527210
33171190
Stop Event
node limit
Counts
44 → 48
Calls
Call 1
Inputs
(/.f64 1 (exp.f64 (neg.f64 x)))
(+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (neg.f64 x))) (/.f64 1 (exp.f64 (neg.f64 x))))
(+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (neg.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y 2) (pow.f64 (log.f64 y) 2)) (exp.f64 (neg.f64 x)))) (/.f64 1 (exp.f64 (neg.f64 x)))))
(+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (neg.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y 2) (pow.f64 (log.f64 y) 2)) (exp.f64 (neg.f64 x)))) (+.f64 (/.f64 1 (exp.f64 (neg.f64 x))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3)) (exp.f64 (neg.f64 x)))))))
(pow.f64 y y)
(+.f64 (pow.f64 y y) (*.f64 (pow.f64 y y) x))
(+.f64 (pow.f64 y y) (+.f64 (*.f64 (pow.f64 y y) x) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y y)) (*.f64 1/2 (pow.f64 y y))) (pow.f64 x 2)))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y y)) (+.f64 (pow.f64 y y) (*.f64 -1/6 (pow.f64 y y)))) (pow.f64 x 3))) (+.f64 (pow.f64 y y) (+.f64 (*.f64 (pow.f64 y y) x) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y y)) (*.f64 1/2 (pow.f64 y y))) (pow.f64 x 2))))))
(/.f64 (pow.f64 y y) (exp.f64 (*.f64 -1 x)))
(/.f64 (pow.f64 y y) (exp.f64 (*.f64 -1 x)))
(/.f64 (pow.f64 y y) (exp.f64 (*.f64 -1 x)))
(/.f64 (pow.f64 y y) (exp.f64 (*.f64 -1 x)))
Outputs
(/.f64 1 (exp.f64 (neg.f64 x)))
(exp.f64 (neg.f64 (neg.f64 x)))
(exp.f64 x)
(+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (neg.f64 x))) (/.f64 1 (exp.f64 (neg.f64 x))))
(+.f64 (exp.f64 (neg.f64 (neg.f64 x))) (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (neg.f64 x))))
(+.f64 (exp.f64 x) (*.f64 (/.f64 y (exp.f64 (neg.f64 x))) (log.f64 y)))
(*.f64 (exp.f64 x) (+.f64 1 (*.f64 y (log.f64 y))))
(+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (neg.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y 2) (pow.f64 (log.f64 y) 2)) (exp.f64 (neg.f64 x)))) (/.f64 1 (exp.f64 (neg.f64 x)))))
(+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (neg.f64 x))) (fma.f64 1/2 (/.f64 (*.f64 (*.f64 y y) (pow.f64 (log.f64 y) 2)) (exp.f64 (neg.f64 x))) (exp.f64 (neg.f64 (neg.f64 x)))))
(+.f64 (*.f64 (/.f64 y (exp.f64 (neg.f64 x))) (log.f64 y)) (fma.f64 1/2 (/.f64 (*.f64 y y) (/.f64 (exp.f64 (neg.f64 x)) (pow.f64 (log.f64 y) 2))) (exp.f64 x)))
(+.f64 (exp.f64 x) (*.f64 (exp.f64 x) (+.f64 (*.f64 y (log.f64 y)) (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 1/2 (*.f64 y y))))))
(*.f64 (exp.f64 x) (+.f64 1 (*.f64 (log.f64 y) (+.f64 y (*.f64 1/2 (*.f64 (log.f64 y) (*.f64 y y)))))))
(+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (neg.f64 x))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (pow.f64 y 2) (pow.f64 (log.f64 y) 2)) (exp.f64 (neg.f64 x)))) (+.f64 (/.f64 1 (exp.f64 (neg.f64 x))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3)) (exp.f64 (neg.f64 x)))))))
(+.f64 (/.f64 (*.f64 y (log.f64 y)) (exp.f64 (neg.f64 x))) (+.f64 (fma.f64 1/2 (/.f64 (*.f64 (*.f64 y y) (pow.f64 (log.f64 y) 2)) (exp.f64 (neg.f64 x))) (exp.f64 (neg.f64 (neg.f64 x)))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 y 3) (pow.f64 (log.f64 y) 3)) (exp.f64 (neg.f64 x))))))
(+.f64 (*.f64 (/.f64 y (exp.f64 (neg.f64 x))) (log.f64 y)) (fma.f64 1/2 (/.f64 (*.f64 y y) (/.f64 (exp.f64 (neg.f64 x)) (pow.f64 (log.f64 y) 2))) (fma.f64 1/6 (*.f64 (/.f64 (pow.f64 y 3) (exp.f64 (neg.f64 x))) (pow.f64 (log.f64 y) 3)) (exp.f64 x))))
(+.f64 (*.f64 (exp.f64 x) (+.f64 1 (*.f64 y (log.f64 y)))) (*.f64 (exp.f64 x) (+.f64 (*.f64 (pow.f64 (log.f64 y) 3) (*.f64 1/6 (pow.f64 y 3))) (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 1/2 (*.f64 y y))))))
(*.f64 (exp.f64 x) (+.f64 (+.f64 (*.f64 y (log.f64 y)) 1) (*.f64 (pow.f64 (log.f64 y) 2) (+.f64 (*.f64 y (*.f64 y 1/2)) (*.f64 1/6 (*.f64 (log.f64 y) (pow.f64 y 3)))))))
(pow.f64 y y)
(+.f64 (pow.f64 y y) (*.f64 (pow.f64 y y) x))
(+.f64 (pow.f64 y y) (*.f64 x (pow.f64 y y)))
(*.f64 (+.f64 x 1) (pow.f64 y y))
(*.f64 (pow.f64 y y) (+.f64 1 x))
(+.f64 (pow.f64 y y) (+.f64 (*.f64 (pow.f64 y y) x) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y y)) (*.f64 1/2 (pow.f64 y y))) (pow.f64 x 2)))))
(+.f64 (pow.f64 y y) (fma.f64 (pow.f64 y y) x (neg.f64 (*.f64 (*.f64 (pow.f64 y y) -1/2) (*.f64 x x)))))
(-.f64 (*.f64 (+.f64 x 1) (pow.f64 y y)) (*.f64 (pow.f64 y y) (*.f64 -1/2 (*.f64 x x))))
(+.f64 (pow.f64 y y) (*.f64 (pow.f64 y y) (-.f64 x (*.f64 (*.f64 x x) -1/2))))
(*.f64 (pow.f64 y y) (-.f64 (+.f64 1 x) (*.f64 (*.f64 x x) -1/2)))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y y)) (+.f64 (pow.f64 y y) (*.f64 -1/6 (pow.f64 y y)))) (pow.f64 x 3))) (+.f64 (pow.f64 y y) (+.f64 (*.f64 (pow.f64 y y) x) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (pow.f64 y y)) (*.f64 1/2 (pow.f64 y y))) (pow.f64 x 2))))))
(fma.f64 -1 (*.f64 (fma.f64 -1 (pow.f64 y y) (*.f64 5/6 (pow.f64 y y))) (pow.f64 x 3)) (+.f64 (pow.f64 y y) (fma.f64 (pow.f64 y y) x (neg.f64 (*.f64 (*.f64 (pow.f64 y y) -1/2) (*.f64 x x))))))
(-.f64 (-.f64 (*.f64 (+.f64 x 1) (pow.f64 y y)) (*.f64 (pow.f64 y y) (*.f64 -1/2 (*.f64 x x)))) (*.f64 (*.f64 (pow.f64 y y) -1/6) (pow.f64 x 3)))
(+.f64 (*.f64 (pow.f64 y y) (-.f64 x (*.f64 (*.f64 x x) -1/2))) (fma.f64 (pow.f64 x 3) (*.f64 1/6 (pow.f64 y y)) (pow.f64 y y)))
(+.f64 (pow.f64 y y) (*.f64 (pow.f64 y y) (-.f64 (+.f64 x (*.f64 1/2 (*.f64 x x))) (*.f64 -1/6 (pow.f64 x 3)))))
(/.f64 (pow.f64 y y) (exp.f64 (*.f64 -1 x)))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))
(*.f64 (exp.f64 x) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (*.f64 -1 x)))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))
(*.f64 (exp.f64 x) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (*.f64 -1 x)))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))
(*.f64 (exp.f64 x) (pow.f64 y y))
(/.f64 (pow.f64 y y) (exp.f64 (*.f64 -1 x)))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))
(*.f64 (exp.f64 x) (pow.f64 y y))

eval14.0ms (0.3%)

Compiler

Compiled 969 to 365 computations (62.3% saved)

prune15.0ms (0.3%)

Pruning

5 alts after pruning (3 fresh and 2 done)

PrunedKeptTotal
New70373
Fresh000
Picked011
Done112
Total71576
Error
0b
Counts
76 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
27.7b
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))
44.2b
(*.f64 (pow.f64 y y) (+.f64 x 1))
44.2b
(pow.f64 y y)
0.9b
(exp.f64 (-.f64 x z))
19.2b
(exp.f64 x)
Compiler

Compiled 38 to 27 computations (28.9% saved)

localize3.0ms (0.1%)

Compiler

Compiled 6 to 4 computations (33.3% saved)

localize9.0ms (0.2%)

Compiler

Compiled 19 to 10 computations (47.4% saved)

localize18.0ms (0.4%)

Compiler

Compiled 7 to 4 computations (42.9% saved)

eval0.0ms (0%)

Compiler

Compiled 3 to 3 computations (0% saved)

prune2.0ms (0%)

Pruning

5 alts after pruning (0 fresh and 5 done)

PrunedKeptTotal
New000
Fresh000
Picked011
Done044
Total055
Error
0b
Counts
5 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
27.7b
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))
44.2b
(*.f64 (pow.f64 y y) (+.f64 x 1))
44.2b
(pow.f64 y y)
0.9b
(exp.f64 (-.f64 x z))
19.2b
(exp.f64 x)
Compiler

Compiled 38 to 27 computations (28.9% saved)

regimes40.0ms (0.8%)

Counts
8 → 1
Calls
Call 1
Inputs
(exp.f64 x)
(pow.f64 y y)
(exp.f64 (-.f64 x z))
(*.f64 (pow.f64 y y) (+.f64 x 1))
(*.f64 (pow.f64 y y) (exp.f64 x))
(/.f64 (pow.f64 y y) (exp.f64 (neg.f64 x)))
(/.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:

7.0ms
y
6.0ms
(*.f64 y (log.f64 y))
6.0ms
(+.f64 x (*.f64 y (log.f64 y)))
5.0ms
(-.f64 (+.f64 x (*.f64 y (log.f64 y))) z)
5.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 100 to 57 computations (43% saved)

regimes20.0ms (0.4%)

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

3 calls:

8.0ms
y
5.0ms
z
5.0ms
x
Results
ErrorSegmentsBranch
0.9b1x
0.9b1y
0.9b1z
Compiler

Compiled 52 to 26 computations (50% saved)

regimes16.0ms (0.3%)

Accuracy

Total -25.9b remaining (-134.6%)

Threshold costs -25.9b (-134.6%)

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

3 calls:

9.0ms
x
3.0ms
y
3.0ms
z
Results
ErrorSegmentsBranch
19.2b1x
19.2b1y
19.2b1z
Compiler

Compiled 20 to 14 computations (30% 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
01223
11723
22323
32523
42623
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 x)
Outputs
(exp.f64 (-.f64 (+.f64 x (*.f64 y (log.f64 y))) z))
(exp.f64 (-.f64 x z))
(exp.f64 x)
Compiler

Compiled 24 to 17 computations (29.2% saved)

soundness0.0ms (0%)

end42.0ms (0.8%)

Compiler

Compiled 18 to 11 computations (38.9% saved)

Profiling

Loading profile data...