Details

Time bar (total: 3.3s)

analyze128.0ms (3.8%)

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.1s (64.2%)

Results
1.4s8256×body256valid
751.0ms5545×body256invalid

preprocess108.0ms (3.2%)

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)

simplify80.0ms (2.4%)

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

Compiled 23 to 15 computations (34.8% saved)

localize12.0ms (0.4%)

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)

series78.0ms (2.3%)

Counts
1 → 8
Calls

3 calls:

TimeVariablePointExpression
47.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))

rewrite69.0ms (2.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))))))

simplify208.0ms (6.2%)

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.3%)

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)

series36.0ms (1.1%)

Counts
1 → 20
Calls

9 calls:

TimeVariablePointExpression
13.0ms
z
@inf
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
11.0ms
x
@inf
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))
6.0ms
y
@-inf
(/.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
x
@0
(/.f64 (pow.f64 y y) (exp.f64 (-.f64 z x)))

rewrite88.0ms (2.6%)

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

simplify64.0ms (1.9%)

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

eval22.0ms (0.7%)

Compiler

Compiled 1647 to 562 computations (65.9% saved)

prune29.0ms (0.9%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New95297
Fresh000
Picked101
Done101
Total97299
Error
0b
Counts
99 → 2
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(exp.f64 (-.f64 x z))
28.8b
(/.f64 (pow.f64 y y) (exp.f64 z))
Compiler

Compiled 16 to 11 computations (31.3% saved)

localize5.0ms (0.1%)

Compiler

Compiled 12 to 5 computations (58.3% saved)

localize9.0ms (0.3%)

Local error

Found 1 expressions with local error:

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

Compiled 16 to 6 computations (62.5% saved)

series5.0ms (0.1%)

Counts
1 → 8
Calls

6 calls:

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

rewrite59.0ms (1.8%)

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

simplify51.0ms (1.5%)

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

eval9.0ms (0.3%)

Compiler

Compiled 658 to 243 computations (63.1% saved)

prune9.0ms (0.3%)

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.1b
(exp.f64 (-.f64 x z))
44.1b
(pow.f64 y y)
19.4b
(exp.f64 (neg.f64 z))
Compiler

Compiled 19 to 14 computations (26.3% saved)

localize4.0ms (0.1%)

Compiler

Compiled 9 to 5 computations (44.4% saved)

localize4.0ms (0.1%)

Compiler

Compiled 7 to 4 computations (42.9% saved)

eval0.0ms (0%)

Compiler

Compiled 3 to 3 computations (0% saved)

prune1.0ms (0%)

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.1b
(exp.f64 (-.f64 x z))
44.1b
(pow.f64 y y)
19.4b
(exp.f64 (neg.f64 z))
Compiler

Compiled 19 to 14 computations (26.3% saved)

regimes46.0ms (1.4%)

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:

15.0ms
y
6.0ms
(+.f64 x (*.f64 y (log.f64 y)))
5.0ms
x
5.0ms
(*.f64 y (log.f64 y))
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 87 to 53 computations (39.1% saved)

regimes17.0ms (0.5%)

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:

6.0ms
x
5.0ms
y
4.0ms
z
Results
ErrorSegmentsBranch
0.1b1x
0.1b1y
0.1b1z
Compiler

Compiled 39 to 22 computations (43.6% saved)

regimes11.0ms (0.3%)

Accuracy

Total -24.8b remaining (-127.4%)

Threshold costs -24.8b (-127.4%)

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:

3.0ms
y
3.0ms
z
3.0ms
x
Results
ErrorSegmentsBranch
19.4b1x
19.4b1y
19.4b1z
Compiler

Compiled 21 to 15 computations (28.6% saved)

simplify6.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%)

end25.0ms (0.7%)

Compiler

Compiled 22 to 13 computations (40.9% saved)

Profiling

Loading profile data...