Details

Time bar (total: 13.6s)

analyze440.0ms (3.2%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.8%0.2%0
0%99.8%0.2%1
0%99.8%0.2%2
0%74.9%25.1%3
0%74.9%25.1%4
0%74.9%25.1%5
0%62.4%37.6%6
0%31.2%68.8%7
0%31.2%68.8%8
0%31.2%68.8%9
0%28.1%71.9%10
4.7%21.8%73.5%11
4.7%21.8%73.5%12
7%19.5%73.5%13
8.2%17.5%74.3%14
Compiler

Compiled 18 to 13 computations (27.8% saved)

sample2.9s (21.1%)

Results
1.3s6066×body128valid
575.0ms680×body1024valid
415.0ms825×body512valid
289.0ms670×body256valid
46.0ms275×body128invalid
14.0ms15×body2048valid
Compiler

Compiled 53 to 38 computations (28.3% saved)

simplify59.0ms (0.4%)

Algorithm
egg-herbie
Rules
821×fma-neg_binary64
326×fma-def_binary64
173×distribute-rgt-in_binary64
134×unsub-neg_binary64
124×associate--r+_binary64
Counts
1 → 2
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01318
12517
24617
37117
411217
517317
629317
743717
868117
9108017
10131217
11152317
12153917
13153917
14149217

prune3.0ms (0%)

Pruning

1 alts after pruning (1 fresh and 0 done)

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

Compiled 58 to 37 computations (36.2% saved)

localize9.0ms (0.1%)

Local error

Found 3 expressions with local error:

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

series709.0ms (5.2%)

Counts
3 → 108
Calls

3 calls:

282.0ms
(*.f64 z (log1p.f64 (neg.f64 y)))
252.0ms
(-.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) t)
174.0ms
(fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))

rewrite17.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
17×add-sqr-sqrt_binary64
15×*-un-lft-identity_binary64
13×add-cube-cbrt_binary64
prod-diff_binary64
add-cbrt-cube_binary64
Counts
3 → 61
Calls

3 calls:

3.0ms
(-.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) t)
3.0ms
(*.f64 z (log1p.f64 (neg.f64 y)))
0.0ms
(fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))

simplify137.0ms (1%)

Algorithm
egg-herbie
Rules
368×distribute-neg-in_binary64
341×distribute-rgt-in_binary64
316×fma-neg_binary64
292×times-frac_binary64
259×sub-neg_binary64
Counts
169 → 169
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02353071
16342835
220732748
345552748
449882748
549212748

prune113.0ms (0.8%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New1645169
Fresh000
Picked011
Done000
Total1646170
Error
0.1b
Counts
170 → 6
Alt Table
StatusErrorProgram
44.1b
(/.f64 (-.f64 (pow.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) 3) (pow.f64 t 3)) (+.f64 (*.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (+.f64 (*.f64 t t) (*.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) t))))
0.1b
(-.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) t)
32.3b
(-.f64 (fma.f64 x (log.f64 y) (*.f64 (sqrt.f64 z) (*.f64 (sqrt.f64 z) (log1p.f64 (neg.f64 y))))) t)
33.9b
(-.f64 (*.f64 (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
0.7b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
30.0b
(-.f64 (cbrt.f64 (pow.f64 (fma.f64 (log1p.f64 (neg.f64 y)) z (*.f64 (log.f64 y) x)) 3)) t)
Compiler

Compiled 3802 to 1353 computations (64.4% saved)

localize15.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))
0.3b
(*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))
0.5b
(cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))
0.5b
(*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))

series1.1s (8%)

Counts
3 → 108
Calls

3 calls:

785.0ms
(*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))
203.0ms
(*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))
103.0ms
(cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))

rewrite21.0ms (0.2%)

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 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))
4.0ms
(*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))
1.0ms
(cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))

simplify234.0ms (1.7%)

Algorithm
egg-herbie
Rules
949×fma-def_binary64
421×*-commutative_binary64
200×associate-*r*_binary64
184×cancel-sign-sub-inv_binary64
179×+-commutative_binary64
Counts
201 → 298
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
098014983
1336014318
2501814318

prune923.0ms (6.8%)

Pruning

13 alts after pruning (11 fresh and 2 done)

PrunedKeptTotal
New6077614
Fresh044
Picked011
Done011
Total60713620
Error
0.0b
Counts
620 → 13
Alt Table
StatusErrorProgram
1.0b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (*.f64 (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) t)
32.3b
(-.f64 (fma.f64 x (log.f64 y) (*.f64 (sqrt.f64 z) (*.f64 (sqrt.f64 z) (log1p.f64 (neg.f64 y))))) t)
27.5b
(-.f64 (*.f64 (cbrt.f64 (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 x x))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
44.1b
(/.f64 (-.f64 (pow.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) 3) (pow.f64 t 3)) (+.f64 (*.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (+.f64 (*.f64 t t) (*.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) t))))
0.1b
(-.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) t)
0.8b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
1.3b
(-.f64 (*.f64 (*.f64 (*.f64 (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
33.9b
(-.f64 (*.f64 (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
0.7b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
30.0b
(-.f64 (cbrt.f64 (pow.f64 (fma.f64 (log1p.f64 (neg.f64 y)) z (*.f64 (log.f64 y) x)) 3)) t)
0.9b
(-.f64 (*.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) (cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
34.1b
(-.f64 (*.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) t)
0.8b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) (cbrt.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) t)
Compiler

Compiled 45124 to 19598 computations (56.6% saved)

localize17.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.5b
(cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))
0.5b
(*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))
0.6b
(cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))
0.6b
(cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))

series1.1s (7.7%)

Counts
2 → 72
Calls

2 calls:

756.0ms
(cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))
296.0ms
(cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))

rewrite6.0ms (0%)

Algorithm
rewrite-expression-head
Rules
10×cbrt-prod_binary64
*-un-lft-identity_binary64
add-sqr-sqrt_binary64
add-cube-cbrt_binary64
add-cbrt-cube_binary64
Counts
2 → 27
Calls

2 calls:

3.0ms
(cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))
1.0ms
(cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))

simplify535.0ms (3.9%)

Algorithm
egg-herbie
Rules
897×fma-def_binary64
409×*-commutative_binary64
191×associate-*r*_binary64
173×sqr-pow_binary64
162×cancel-sign-sub-inv_binary64
Counts
99 → 184
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
093713010
1318812515
2499712515
3495512515

prune1.9s (13.6%)

Pruning

15 alts after pruning (13 fresh and 2 done)

PrunedKeptTotal
New7724776
Fresh1910
Picked101
Done022
Total77415789
Error
0.0b
Counts
789 → 15
Alt Table
StatusErrorProgram
34.6b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (*.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 1/3) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
27.5b
(-.f64 (*.f64 (cbrt.f64 (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 x x))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
32.3b
(-.f64 (fma.f64 x (log.f64 y) (*.f64 (sqrt.f64 z) (*.f64 (sqrt.f64 z) (log1p.f64 (neg.f64 y))))) t)
0.8b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2)) (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
1.0b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (*.f64 (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) t)
34.5b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (*.f64 (cbrt.f64 (exp.f64 (log.f64 (cbrt.f64 (fma.f64 (log1p.f64 (neg.f64 y)) z (*.f64 (log.f64 y) x)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
0.7b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
44.1b
(/.f64 (-.f64 (pow.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) 3) (pow.f64 t 3)) (+.f64 (*.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (+.f64 (*.f64 t t) (*.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) t))))
0.1b
(-.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) t)
1.0b
(-.f64 (*.f64 (*.f64 (*.f64 (*.f64 (cbrt.f64 (cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) (cbrt.f64 (cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))))) (cbrt.f64 (cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))))) (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
33.9b
(-.f64 (*.f64 (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
30.0b
(-.f64 (cbrt.f64 (pow.f64 (fma.f64 (log1p.f64 (neg.f64 y)) z (*.f64 (log.f64 y) x)) 3)) t)
0.9b
(-.f64 (*.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) (cbrt.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
34.1b
(-.f64 (*.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) t)
0.8b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) (cbrt.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) t)
Compiler

Compiled 90591 to 36861 computations (59.3% saved)

localize19.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.5b
(cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))
0.5b
(pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2)
0.6b
(cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2))
0.6b
(cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))

series912.0ms (6.7%)

Counts
2 → 72
Calls

2 calls:

736.0ms
(cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2))
175.0ms
(pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2)

rewrite8.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
17×cbrt-prod_binary64
12×unpow-prod-down_binary64
*-un-lft-identity_binary64
add-sqr-sqrt_binary64
add-cube-cbrt_binary64
Counts
2 → 45
Calls

2 calls:

2.0ms
(cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2))
2.0ms
(pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2)

simplify259.0ms (1.9%)

Algorithm
egg-herbie
Rules
928×fma-def_binary64
399×*-commutative_binary64
189×associate-*r*_binary64
181×sqr-pow_binary64
173×cancel-sign-sub-inv_binary64
Counts
117 → 214
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
093613448
1319412912
2497812912
3496512912

prune1.5s (10.9%)

Pruning

15 alts after pruning (12 fresh and 3 done)

PrunedKeptTotal
New6734677
Fresh4812
Picked011
Done022
Total67715692
Error
0.0b
Counts
692 → 15
Alt Table
StatusErrorProgram
27.5b
(-.f64 (*.f64 (cbrt.f64 (*.f64 (pow.f64 (log.f64 y) 2) (*.f64 x x))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
34.6b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2)) (*.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 1/3) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
44.1b
(/.f64 (-.f64 (pow.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) 3) (pow.f64 t 3)) (+.f64 (*.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (+.f64 (*.f64 t t) (*.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) t))))
1.0b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2)) (*.f64 (*.f64 (*.f64 (cbrt.f64 (cbrt.f64 (cbrt.f64 (fma.f64 (log.f64 y) x (*.f64 (log1p.f64 (neg.f64 y)) z))))) (cbrt.f64 (cbrt.f64 (cbrt.f64 (fma.f64 (log.f64 y) x (*.f64 (log1p.f64 (neg.f64 y)) z)))))) (cbrt.f64 (cbrt.f64 (cbrt.f64 (fma.f64 (log.f64 y) x (*.f64 (log1p.f64 (neg.f64 y)) z)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
32.3b
(-.f64 (fma.f64 x (log.f64 y) (*.f64 (sqrt.f64 z) (*.f64 (sqrt.f64 z) (log1p.f64 (neg.f64 y))))) t)
0.8b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2)) (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
1.0b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (*.f64 (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) t)
34.5b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2)) (*.f64 (cbrt.f64 (exp.f64 (log.f64 (cbrt.f64 (fma.f64 (log1p.f64 (neg.f64 y)) z (*.f64 (log.f64 y) x)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
0.1b
(-.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))) t)
33.9b
(-.f64 (*.f64 (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
0.7b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
30.0b
(-.f64 (cbrt.f64 (pow.f64 (fma.f64 (log1p.f64 (neg.f64 y)) z (*.f64 (log.f64 y) x)) 3)) t)
1.0b
(-.f64 (*.f64 (*.f64 (*.f64 (*.f64 (cbrt.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2))) (cbrt.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2)))) (cbrt.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) 2)))) (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) t)
34.1b
(-.f64 (*.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (sqrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) t)
0.8b
(-.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))))) (cbrt.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) (cbrt.f64 (*.f64 (*.f64 (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))) (cbrt.f64 (fma.f64 x (log.f64 y) (*.f64 z (log1p.f64 (neg.f64 y)))))))) t)
Compiler

Compiled 68381 to 29940 computations (56.2% saved)

regimes580.0ms (4.3%)

Accuracy

Total 0.1b remaining (60.5%)

Threshold costs 0.1b (60.5%)

Counts
79 → 1
Compiler

Compiled 22328 to 8169 computations (63.4% 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
01117
11817
22317
32617
42717
52717

end234.0ms (1.7%)

Compiler

Compiled 775 to 278 computations (64.1% saved)

Profiling

Loading profile data...