Details

Time bar (total: 27.9s)

analyze1.1s (3.9%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.7%0.3%0
0%99.7%0.3%1
0%99.7%0.3%2
0%99.7%0.3%3
0%99.7%0.3%4
0%99.7%0.3%5
0%99.7%0.3%6
0%99.7%0.3%7
0%99.7%0.3%8
0%90.4%9.6%9
0%45.2%54.8%10
0%45.2%54.8%11
0%45.2%54.8%12
0%45.2%54.8%13
0%44.4%55.6%14
Compiler

Compiled 25 to 18 computations (28% saved)

sample5.2s (18.6%)

Results
3.1s16240×body128invalid
1.4s7560×body128valid
171.0ms307×body512valid
108.0ms126×body512invalid
98.0ms272×body256valid
97.0ms117×body1024valid
37.0ms107×body256invalid
32.0ms39×body1024invalid
Compiler

Compiled 74 to 53 computations (28.4% saved)

simplify51.0ms (0.2%)

Algorithm
egg-herbie
Rules
784×fma-def_binary64
557×associate-/l*_binary64
456×unswap-sqr_binary64
365×*-commutative_binary64
332×fma-neg_binary64
Counts
1 → 2
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01826
13425
27325
315825
440525
5125225
6277125
7452725
8511725

prune4.0ms (0%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New112
Fresh101
Picked000
Done000
Total213
Error
0.0b
Counts
3 → 1
Alt Table
StatusErrorProgram
0.0b
(*.f64 x (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
Compiler

Compiled 84 to 54 computations (35.7% saved)

localize13.0ms (0%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(*.f64 x (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
0.0b
(*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))
0.0b
(exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))
0.1b
(fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))

series1.2s (4.4%)

Counts
4 → 164
Calls

4 calls:

502.0ms
(*.f64 x (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
360.0ms
(fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))
322.0ms
(*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))
40.0ms
(exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))

rewrite18.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
29×add-sqr-sqrt_binary64
25×*-un-lft-identity_binary64
23×add-cube-cbrt_binary64
18×prod-diff_binary64
13×distribute-lft-in_binary64
Counts
4 → 95
Calls

4 calls:

5.0ms
(*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))
4.0ms
(*.f64 x (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
1.0ms
(exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))
0.0ms
(fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))

simplify204.0ms (0.7%)

Algorithm
egg-herbie
Rules
789×fma-def_binary64
292×*-commutative_binary64
185×sub-neg_binary64
182×times-frac_binary64
175×associate-*r*_binary64
Counts
259 → 297
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
071311258
1218910188
2484310188
3498910188

prune252.0ms (0.9%)

Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New2952297
Fresh000
Picked011
Done000
Total2953298
Error
0.0b
Counts
298 → 3
Alt Table
StatusErrorProgram
0.1b
(*.f64 (*.f64 x (*.f64 (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))))) (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))))
15.0b
(*.f64 x (/.f64 (pow.f64 z y) (exp.f64 (fma.f64 a b (*.f64 y t)))))
0.0b
(*.f64 x (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
Compiler

Compiled 13815 to 5194 computations (62.4% saved)

localize16.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
0.0b
(*.f64 (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))))
0.0b
(exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))
0.1b
(fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))

series2.8s (10.2%)

Counts
2 → 120
Calls

2 calls:

1.6s
(*.f64 (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))))
1.3s
(cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))

rewrite16.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
24×cbrt-prod_binary64
19×add-sqr-sqrt_binary64
11×*-un-lft-identity_binary64
11×add-cube-cbrt_binary64
pow1_binary64
Counts
2 → 59
Calls

2 calls:

6.0ms
(*.f64 (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))))
1.0ms
(cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))

simplify164.0ms (0.6%)

Algorithm
egg-herbie
Rules
667×associate-*l*_binary64
582×fma-def_binary64
244×*-commutative_binary64
187×cancel-sign-sub-inv_binary64
180×associate--l+_binary64
Counts
179 → 182
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
054211928
1178410472
2505310472

prune1.0s (3.7%)

Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New7131714
Fresh011
Picked101
Done011
Total7143717
Error
0.0b
Counts
717 → 3
Alt Table
StatusErrorProgram
0.1b
(*.f64 (*.f64 x (*.f64 (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))))) (cbrt.f64 (exp.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))))))
15.0b
(*.f64 x (/.f64 (pow.f64 z y) (exp.f64 (fma.f64 a b (*.f64 y t)))))
0.0b
(*.f64 x (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
Compiler

Compiled 63083 to 18238 computations (71.1% saved)

localize23.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))
0.3b
(*.f64 (*.f64 (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
0.5b
(*.f64 (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
13.8b
(cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))

series7.5s (26.8%)

Counts
3 → 180
Calls

3 calls:

6.7s
(*.f64 (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
413.0ms
(cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))
370.0ms
(*.f64 (*.f64 (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))

rewrite24.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
29×pow1_binary64
24×add-sqr-sqrt_binary64
23×cbrt-prod_binary64
16×pow1/3_binary64
14×*-un-lft-identity_binary64
Counts
3 → 93
Calls

3 calls:

6.0ms
(*.f64 (*.f64 (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
4.0ms
(*.f64 (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
1.0ms
(cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))

simplify574.0ms (2.1%)

Algorithm
egg-herbie
Counts
273 → 225
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0529285412

prune1.9s (6.6%)

Pruning

3 alts after pruning (1 fresh and 2 done)

PrunedKeptTotal
New6460646
Fresh011
Picked011
Done011
Total6463649
Error
0.0b
Counts
649 → 3
Alt Table
StatusErrorProgram
0.1b
(*.f64 (*.f64 x (*.f64 (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))))) (cbrt.f64 (exp.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))))))
15.0b
(*.f64 x (/.f64 (pow.f64 z y) (exp.f64 (fma.f64 a b (*.f64 y t)))))
0.0b
(*.f64 x (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
Compiler

Compiled 118720 to 52176 computations (56.1% saved)

localize11.0ms (0%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(exp.f64 (fma.f64 a b (*.f64 y t)))
0.0b
(*.f64 x (/.f64 (pow.f64 z y) (exp.f64 (fma.f64 a b (*.f64 y t)))))
0.5b
(/.f64 (pow.f64 z y) (exp.f64 (fma.f64 a b (*.f64 y t))))
0.8b
(fma.f64 a b (*.f64 y t))

series1.1s (3.9%)

Counts
4 → 196
Calls

4 calls:

648.0ms
(*.f64 x (/.f64 (pow.f64 z y) (exp.f64 (fma.f64 a b (*.f64 y t)))))
427.0ms
(/.f64 (pow.f64 z y) (exp.f64 (fma.f64 a b (*.f64 y t))))
11.0ms
(exp.f64 (fma.f64 a b (*.f64 y t)))
9.0ms
(fma.f64 a b (*.f64 y t))

rewrite28.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
59×times-frac_binary64
50×add-sqr-sqrt_binary64
40×*-un-lft-identity_binary64
40×add-cube-cbrt_binary64
32×associate-*r*_binary64
Counts
4 → 136
Calls

4 calls:

9.0ms
(*.f64 x (/.f64 (pow.f64 z y) (exp.f64 (fma.f64 a b (*.f64 y t)))))
5.0ms
(/.f64 (pow.f64 z y) (exp.f64 (fma.f64 a b (*.f64 y t))))
1.0ms
(exp.f64 (fma.f64 a b (*.f64 y t)))
0.0ms
(fma.f64 a b (*.f64 y t))

simplify196.0ms (0.7%)

Algorithm
egg-herbie
Rules
697×fma-def_binary64
457×associate-*r*_binary64
358×associate-*l*_binary64
259×associate-/l*_binary64
217×*-commutative_binary64
Counts
332 → 299
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
04038024
110427709
239997664
348757664
450167664

prune336.0ms (1.2%)

Pruning

4 alts after pruning (2 fresh and 2 done)

PrunedKeptTotal
New2972299
Fresh000
Picked101
Done022
Total2984302
Error
0b
Counts
302 → 4
Alt Table
StatusErrorProgram
0.1b
(*.f64 (*.f64 x (*.f64 (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))))) (cbrt.f64 (exp.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))) (cbrt.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b))))))))
15.4b
(*.f64 (*.f64 (cbrt.f64 x) (cbrt.f64 x)) (*.f64 (cbrt.f64 x) (/.f64 (pow.f64 z y) (exp.f64 (fma.f64 a b (*.f64 y t))))))
15.0b
(/.f64 (*.f64 x (pow.f64 z y)) (exp.f64 (fma.f64 a b (*.f64 y t))))
0.0b
(*.f64 x (exp.f64 (fma.f64 y (-.f64 (log.f64 z) t) (*.f64 a (-.f64 (log1p.f64 (neg.f64 z)) b)))))
Compiler

Compiled 8303 to 1708 computations (79.4% saved)

regimes4.1s (14.6%)

Accuracy

Total 0.1b remaining (46.4%)

Threshold costs 0.1b (46.4%)

Counts
337 → 1
Compiler

Compiled 170264 to 69513 computations (59.2% saved)

simplify3.0ms (0%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01523
12923
24523
35823
46423
56523
66523

end82.0ms (0.3%)

Compiler

Compiled 195 to 93 computations (52.3% saved)

Profiling

Loading profile data...