
Time bar (total: 2.3s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 100% | 0% | 0% | 0% | 0% | 0 |
| 0% | 0% | 100% | 0% | 0% | 0% | 0% | 1 |
| 100% | 100% | 0% | 0% | 0% | 0% | 0% | 2 |
Compiled 10 to 8 computations (20% saved)
ival-div, time spent: 0.0ms, 0.0% of total-timeival-exp, time spent: 0.0ms, 0.0% of total-timeival-add, time spent: 0.0ms, 0.0% of total-timeconst, time spent: 0.0ms, 0.0% of total-timeival-neg, time spent: 0.0ms, 0.0% of total-time| 936.0ms | 8255× | 256 | valid |
| 0.0ms | 1× | 256 | valid |
ival-exp, time spent: 146.0ms, 37.0% of total-timeival-div, time spent: 100.0ms, 26.0% of total-timeival-add, time spent: 68.0ms, 17.0% of total-timeival-neg, time spent: 61.0ms, 16.0% of total-timeconst, time spent: 14.0ms, 4.0% of total-time| 1× | egg-herbie |
| 40× | fma-neg |
| 40× | fma-define |
| 24× | sub-neg |
| 14× | distribute-lft-neg-in |
| 14× | cancel-sign-sub-inv |
| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 0 | 0 | - | 0 | - | x |
| 0 | 1 | (162.9266817265824) | 0 | - | (exp.f64 (neg.f64 x)) |
| 0 | 0 | - | 0 | - | (neg.f64 x) |
| 0 | 0 | - | 0 | - | (exp.f64 x) |
| 0 | 0 | - | 0 | - | (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x))) |
| 0 | 0 | - | 0 | - | #s(literal 2 binary64) |
| 0 | 0 | - | 0 | - | (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 124 |
| 1 | 35 | 124 |
| 2 | 67 | 124 |
| 3 | 113 | 124 |
| 4 | 170 | 124 |
| 5 | 231 | 124 |
| 6 | 286 | 124 |
| 7 | 302 | 124 |
| 8 | 309 | 124 |
| 9 | 320 | 124 |
| 10 | 332 | 124 |
| 11 | 334 | 124 |
| 1× | saturated |
| Inputs |
|---|
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 (neg.f64 x)) (exp.f64 (neg.f64 (neg.f64 x))))) |
(neg.f64 (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 (neg.f64 x)) (exp.f64 (neg.f64 (neg.f64 x)))))) |
| Outputs |
|---|
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 (neg.f64 x)) (exp.f64 (neg.f64 (neg.f64 x))))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
(neg.f64 (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 (neg.f64 x)) (exp.f64 (neg.f64 (neg.f64 x)))))) |
(/.f64 #s(literal -2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
(abs x)
Compiled 59 to 25 computations (57.6% saved)
ival-exp, time spent: 9.0ms, 38.0% of total-timeival-add, time spent: 7.0ms, 30.0% of total-timeival-div, time spent: 4.0ms, 17.0% of total-timeival-neg, time spent: 2.0ms, 8.0% of total-timeconst, time spent: 1.0ms, 4.0% of total-timeCompiled 1 to 1 computations (0% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
Compiled 9 to 7 computations (22.2% saved)
Found 1 expressions with local error:
| New | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
Compiled 25 to 9 computations (64% saved)
ival-exp, time spent: 4.0ms, 40.0% of total-timeival-div, time spent: 2.0ms, 20.0% of total-timeival-add, time spent: 2.0ms, 20.0% of total-timeival-neg, time spent: 2.0ms, 20.0% of total-timeconst, time spent: 1.0ms, 10.0% of total-time| Inputs |
|---|
#<alt (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x))))> |
| Outputs |
|---|
#<alt #s(literal 1 binary64)> |
#<alt (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))))> |
#<alt (+.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal 5/24 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1/2 binary64))))> |
#<alt (+.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 5/24 binary64) (*.f64 #s(literal -61/720 binary64) (pow.f64 x #s(literal 2 binary64))))) #s(literal 1/2 binary64))))> |
#<alt (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (*.f64 #s(literal -1 binary64) x))))> |
#<alt (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (*.f64 #s(literal -1 binary64) x))))> |
#<alt (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (*.f64 #s(literal -1 binary64) x))))> |
#<alt (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (*.f64 #s(literal -1 binary64) x))))> |
3 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | -inf | (/ 2 (+ (exp x) (exp (neg x)))) |
| 1.0ms | x | @ | inf | (/ 2 (+ (exp x) (exp (neg x)))) |
| 1.0ms | x | @ | 0 | (/ 2 (+ (exp x) (exp (neg x)))) |
| 1× | batch-egg-rewrite |
| 62× | add-exp-log |
| 62× | add-log-exp |
| 62× | log1p-expm1-u |
| 62× | expm1-log1p-u |
| 60× | add-cube-cbrt |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 12 | 20 |
| 1 | 144 | 20 |
| 2 | 2343 | 20 |
| 1× | unsound |
| Inputs |
|---|
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
| Outputs |
|---|
#s(literal -4 binary64) |
#s(literal -2 binary64) |
#s(literal -1 binary64) |
#s(literal 0 binary64) |
#s(literal 1/2 binary64) |
#s(literal 1 binary64) |
#s(literal 3/2 binary64) |
#s(literal 2 binary64) |
#s(literal 3 binary64) |
#s(literal 4 binary64) |
| 1× | egg-herbie |
| 2386× | fma-define |
| 584× | fma-neg |
| 386× | distribute-lft-in |
| 264× | associate-+l- |
| 250× | distribute-rgt-in |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 37 | 256 |
| 1 | 68 | 240 |
| 2 | 136 | 240 |
| 3 | 294 | 240 |
| 4 | 582 | 240 |
| 5 | 929 | 240 |
| 6 | 1108 | 240 |
| 7 | 1587 | 240 |
| 8 | 2418 | 240 |
| 9 | 3827 | 240 |
| 10 | 4702 | 240 |
| 11 | 5157 | 240 |
| 12 | 5232 | 240 |
| 13 | 5240 | 240 |
| 14 | 5240 | 240 |
| 15 | 5372 | 240 |
| 16 | 5428 | 240 |
| 17 | 5428 | 240 |
| 18 | 7311 | 240 |
| 19 | 7311 | 240 |
| 20 | 7311 | 240 |
| 21 | 7311 | 240 |
| 22 | 7311 | 240 |
| 23 | 7313 | 240 |
| 1× | saturated |
| Inputs |
|---|
#s(literal 1 binary64) |
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
(+.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal 5/24 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1/2 binary64)))) |
(+.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 5/24 binary64) (*.f64 #s(literal -61/720 binary64) (pow.f64 x #s(literal 2 binary64))))) #s(literal 1/2 binary64)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (*.f64 #s(literal -1 binary64) x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (*.f64 #s(literal -1 binary64) x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (*.f64 #s(literal -1 binary64) x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (*.f64 #s(literal -1 binary64) x)))) |
#s(literal -4 binary64) |
#s(literal -2 binary64) |
#s(literal -1 binary64) |
#s(literal 0 binary64) |
#s(literal 1/2 binary64) |
#s(literal 1 binary64) |
#s(literal 3/2 binary64) |
#s(literal 2 binary64) |
#s(literal 3 binary64) |
#s(literal 4 binary64) |
| Outputs |
|---|
#s(literal 1 binary64) |
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
(fma.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)) #s(literal 1 binary64)) |
(+.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal 5/24 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1/2 binary64)))) |
(+.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 #s(literal 5/24 binary64) (pow.f64 x #s(literal 2 binary64)) #s(literal -1/2 binary64)))) |
(fma.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal 5/24 binary64) #s(literal -1/2 binary64)) #s(literal 1 binary64)) |
(fma.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)) (fma.f64 #s(literal 5/24 binary64) (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64))) |
(+.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 5/24 binary64) (*.f64 #s(literal -61/720 binary64) (pow.f64 x #s(literal 2 binary64))))) #s(literal 1/2 binary64)))) |
(+.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 5/24 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal -61/720 binary64))) #s(literal -1/2 binary64)))) |
(fma.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal -61/720 binary64) #s(literal 5/24 binary64)) #s(literal -1/2 binary64)) #s(literal 1 binary64)) |
(fma.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal 5/24 binary64) (fma.f64 #s(literal -61/720 binary64) (pow.f64 x #s(literal 4 binary64)) #s(literal -1/2 binary64))) #s(literal 1 binary64)) |
(fma.f64 #s(literal -61/720 binary64) (pow.f64 x #s(literal 6 binary64)) (fma.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)) (fma.f64 #s(literal 5/24 binary64) (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (*.f64 #s(literal -1 binary64) x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (*.f64 #s(literal -1 binary64) x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (*.f64 #s(literal -1 binary64) x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (*.f64 #s(literal -1 binary64) x)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
#s(literal -4 binary64) |
#s(literal -2 binary64) |
#s(literal -1 binary64) |
#s(literal 0 binary64) |
#s(literal 1/2 binary64) |
#s(literal 1 binary64) |
#s(literal 3/2 binary64) |
#s(literal 2 binary64) |
#s(literal 3 binary64) |
#s(literal 4 binary64) |
Compiled 173 to 143 computations (17.3% saved)
5 alts after pruning (4 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 19 | 4 | 23 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 19 | 5 | 24 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
| ▶ | 49.0% | (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
| ▶ | 49.7% | #s(literal 1 binary64) |
| ▶ | 10.7% | #s(literal 1/2 binary64) |
| ▶ | 52.7% | #s(literal 0 binary64) |
Compiled 23 to 20 computations (13% saved)
Found 1 expressions with local error:
| New | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
Compiled 24 to 20 computations (16.7% saved)
ival-pow, time spent: 8.0ms, 53.0% of total-timeival-mult, time spent: 4.0ms, 27.0% of total-timeival-add, time spent: 2.0ms, 13.0% of total-timeconst, time spent: 2.0ms, 13.0% of total-time| Inputs |
|---|
#<alt (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))> |
| Outputs |
|---|
3 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | x | @ | 0 | (* -1/2 (pow x 2)) |
| 0.0ms | x | @ | inf | (* -1/2 (pow x 2)) |
| 0.0ms | x | @ | -inf | (* -1/2 (pow x 2)) |
| 1× | batch-egg-rewrite |
| 421× | associate-*r* |
| 397× | log1p-expm1-u |
| 371× | associate-*l* |
| 245× | unpow-prod-down |
| 229× | expm1-log1p-u |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 16 |
| 1 | 69 | 16 |
| 2 | 713 | 16 |
| 3 | 7802 | 16 |
| 1× | node limit |
| Inputs |
|---|
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
| Outputs |
|---|
(+.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) #s(literal -1 binary64)) |
(+.f64 #s(literal 0 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
(+.f64 (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1 binary64)))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1/2 binary64))))) |
(+.f64 (log.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1/4 binary64))) (log.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1/4 binary64)))) |
(-.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) #s(literal 1 binary64)) |
(/.f64 (-.f64 (pow.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) #s(literal 3 binary64)) #s(literal 1 binary64)) (+.f64 (*.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64))) (+.f64 #s(literal 1 binary64) (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64))))) |
(/.f64 (-.f64 (*.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64))) #s(literal 1 binary64)) (+.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) #s(literal 1 binary64))) |
(pow.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) |
(pow.f64 (cbrt.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) #s(literal 3 binary64)) |
(pow.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1/4 binary64)) #s(literal 1/2 binary64)) |
(pow.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1/8 binary64)) #s(literal 1/3 binary64)) |
(pow.f64 (*.f64 x (sqrt.f64 #s(literal -1/2 binary64))) #s(literal 2 binary64)) |
(pow.f64 (E.f64) (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64)))) |
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64)))) #s(literal 2 binary64))) (cbrt.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64))))) |
(pow.f64 (exp.f64 (sqrt.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64))))) (sqrt.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64))))) |
(sqrt.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1/4 binary64))) |
(fabs.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
(log.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1/2 binary64))) |
(cbrt.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1/8 binary64))) |
(expm1.f64 (log1p.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))))) |
(log1p.f64 (expm1.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))))) |
(exp.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64)))) |
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))))) #s(literal 3 binary64))) |
(exp.f64 (*.f64 (log.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1/8 binary64))) #s(literal 1/3 binary64))) |
(exp.f64 (*.f64 (log.f64 (*.f64 x (sqrt.f64 #s(literal -1/2 binary64)))) #s(literal 2 binary64))) |
| 1× | egg-herbie |
| 1121× | fma-neg |
| 315× | distribute-lft-out |
| 270× | associate-+l- |
| 266× | associate-+r- |
| 222× | associate--l+ |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 88 | 512 |
| 1 | 164 | 512 |
| 2 | 410 | 512 |
| 3 | 1721 | 227 |
| 4 | 5158 | 227 |
| 5 | 5983 | 227 |
| 6 | 7472 | 227 |
| 1× | node limit |
| Inputs |
|---|
(+.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) #s(literal -1 binary64)) |
(+.f64 #s(literal 0 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
(+.f64 (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1 binary64)))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1/2 binary64))))) |
(+.f64 (log.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1/4 binary64))) (log.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1/4 binary64)))) |
(-.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) #s(literal 1 binary64)) |
(/.f64 (-.f64 (pow.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) #s(literal 3 binary64)) #s(literal 1 binary64)) (+.f64 (*.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64))) (+.f64 #s(literal 1 binary64) (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64))))) |
(/.f64 (-.f64 (*.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64))) #s(literal 1 binary64)) (+.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) #s(literal 1 binary64))) |
(pow.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) |
(pow.f64 (cbrt.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) #s(literal 3 binary64)) |
(pow.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1/4 binary64)) #s(literal 1/2 binary64)) |
(pow.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1/8 binary64)) #s(literal 1/3 binary64)) |
(pow.f64 (*.f64 x (sqrt.f64 #s(literal -1/2 binary64))) #s(literal 2 binary64)) |
(pow.f64 (E.f64) (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64)))) |
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64)))) #s(literal 2 binary64))) (cbrt.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64))))) |
(pow.f64 (exp.f64 (sqrt.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64))))) (sqrt.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64))))) |
(sqrt.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1/4 binary64))) |
(fabs.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
(log.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1/2 binary64))) |
(cbrt.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1/8 binary64))) |
(expm1.f64 (log1p.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))))) |
(log1p.f64 (expm1.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))))) |
(exp.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64)))) |
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))))) #s(literal 3 binary64))) |
(exp.f64 (*.f64 (log.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1/8 binary64))) #s(literal 1/3 binary64))) |
(exp.f64 (*.f64 (log.f64 (*.f64 x (sqrt.f64 #s(literal -1/2 binary64)))) #s(literal 2 binary64))) |
| Outputs |
|---|
(+.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) #s(literal -1 binary64)) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(+.f64 #s(literal 0 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(+.f64 (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1 binary64)))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1/2 binary64))))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(+.f64 (log.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1/4 binary64))) (log.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1/4 binary64)))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(-.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) #s(literal 1 binary64)) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(/.f64 (-.f64 (pow.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) #s(literal 3 binary64)) #s(literal 1 binary64)) (+.f64 (*.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64))) (+.f64 #s(literal 1 binary64) (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64))))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(/.f64 (-.f64 (*.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64))) #s(literal 1 binary64)) (+.f64 (+.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) #s(literal 1 binary64))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(pow.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64)) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(pow.f64 (cbrt.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) #s(literal 3 binary64)) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(pow.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1/4 binary64)) #s(literal 1/2 binary64)) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(pow.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1/8 binary64)) #s(literal 1/3 binary64)) |
(cbrt.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1/8 binary64))) |
(pow.f64 (*.f64 x (sqrt.f64 #s(literal -1/2 binary64))) #s(literal 2 binary64)) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(pow.f64 (E.f64) (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64)))) |
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64)))) #s(literal 2 binary64))) (cbrt.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64))))) |
(pow.f64 (exp.f64 (sqrt.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64))))) (sqrt.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64))))) |
(sqrt.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1/4 binary64))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(fabs.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(log.f64 (pow.f64 (exp.f64 (pow.f64 x #s(literal 2 binary64))) #s(literal -1/2 binary64))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(cbrt.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1/8 binary64))) |
(expm1.f64 (log1p.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(log1p.f64 (expm1.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(exp.f64 (fma.f64 #s(literal 2 binary64) (log.f64 x) (log.f64 #s(literal -1/2 binary64)))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))))) #s(literal 3 binary64))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
(exp.f64 (*.f64 (log.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1/8 binary64))) #s(literal 1/3 binary64))) |
(cbrt.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1/8 binary64))) |
(exp.f64 (*.f64 (log.f64 (*.f64 x (sqrt.f64 #s(literal -1/2 binary64)))) #s(literal 2 binary64))) |
(*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64))) |
#s(literal 0 binary64) |
Compiled 332 to 292 computations (12% saved)
5 alts after pruning (0 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 27 | 0 | 27 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 4 | 4 |
| Done | 0 | 1 | 1 |
| Total | 27 | 5 | 32 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
| ✓ | 49.0% | (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
| ✓ | 49.7% | #s(literal 1 binary64) |
| ✓ | 10.7% | #s(literal 1/2 binary64) |
| ✓ | 52.7% | #s(literal 0 binary64) |
Compiled 42 to 36 computations (14.3% saved)
| Inputs |
|---|
#s(literal 0 binary64) |
#s(literal 1/2 binary64) |
#s(literal 1 binary64) |
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
| Outputs |
|---|
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
3 calls:
| 5.0ms | x |
| 1.0ms | (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
| 1.0ms | (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | x |
| 100.0% | 1 | (/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
| 100.0% | 1 | (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x))) |
Compiled 18 to 13 computations (27.8% saved)
| Inputs |
|---|
#s(literal 0 binary64) |
#s(literal 1/2 binary64) |
#s(literal 1 binary64) |
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
| Outputs |
|---|
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) |
#s(literal 0 binary64) |
1 calls:
| 3.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.2% | 2 | x |
Compiled 2 to 1 computations (50% saved)
| Inputs |
|---|
#s(literal 0 binary64) |
#s(literal 1/2 binary64) |
#s(literal 1 binary64) |
| Outputs |
|---|
#s(literal 1 binary64) |
#s(literal 0 binary64) |
1 calls:
| 3.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.2% | 2 | x |
Compiled 2 to 1 computations (50% saved)
| Inputs |
|---|
#s(literal 0 binary64) |
#s(literal 1/2 binary64) |
| Outputs |
|---|
#s(literal 1/2 binary64) |
#s(literal 0 binary64) |
1 calls:
| 2.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 60.2% | 2 | x |
Compiled 2 to 1 computations (50% saved)
Total 0.0b remaining (0%)
Threshold costs 0b (0%)
| Inputs |
|---|
#s(literal 0 binary64) |
| Outputs |
|---|
#s(literal 0 binary64) |
1 calls:
| 1.0ms | x |
| Accuracy | Segments | Branch |
|---|---|---|
| 52.7% | 1 | x |
Compiled 2 to 1 computations (50% saved)
| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 30.0ms | 2.877160388191083e-7 | 80.95770458946294 |
| 27.0ms | 143× | 256 | valid |
| 0.0ms | 1× | 256 | valid |
Compiled 121 to 109 computations (9.9% saved)
ival-neg, time spent: 7.0ms, 55.0% of total-timeival-exp, time spent: 4.0ms, 31.0% of total-timeival-div, time spent: 1.0ms, 8.0% of total-timeival-add, time spent: 1.0ms, 8.0% of total-timeconst, time spent: 0.0ms, 0.0% of total-time| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 21.0ms | 162.9266817265824 | 124905.84645181167 |
| 18.0ms | 127× | 256 | valid |
| 0.0ms | 1× | 256 | valid |
Compiled 61 to 58 computations (4.9% saved)
ival-exp, time spent: 3.0ms, 53.0% of total-timeival-div, time spent: 1.0ms, 18.0% of total-timeival-add, time spent: 1.0ms, 18.0% of total-timeival-neg, time spent: 1.0ms, 18.0% of total-timeconst, time spent: 0.0ms, 0.0% of total-time| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 18.0ms | 162.9266817265824 | 124905.84645181167 |
| 16.0ms | 127× | 256 | valid |
| 0.0ms | 1× | 256 | valid |
Compiled 61 to 58 computations (4.9% saved)
ival-exp, time spent: 3.0ms, 52.0% of total-timeival-div, time spent: 1.0ms, 17.0% of total-timeival-add, time spent: 1.0ms, 17.0% of total-timeival-neg, time spent: 1.0ms, 17.0% of total-timeconst, time spent: 0.0ms, 0.0% of total-time| 1× | egg-herbie |
| 3× | 1-exp |
| 3× | +-commutative |
| 2× | *-commutative |
| 1× | sub-neg |
| 1× | neg-sub0 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 29 | 95 |
| 1 | 39 | 95 |
| 2 | 41 | 95 |
| 3 | 42 | 95 |
| 1× | done |
| 1× | saturated |
| Inputs |
|---|
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
(if (<=.f64 x #s(literal 6530219459687219/4503599627370496 binary64)) (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) #s(literal 0 binary64)) |
(if (<=.f64 x #s(literal 350 binary64)) #s(literal 1 binary64) #s(literal 0 binary64)) |
(if (<=.f64 x #s(literal 350 binary64)) #s(literal 1/2 binary64) #s(literal 0 binary64)) |
#s(literal 0 binary64) |
| Outputs |
|---|
(/.f64 #s(literal 2 binary64) (+.f64 (exp.f64 x) (exp.f64 (neg.f64 x)))) |
(if (<=.f64 x #s(literal 6530219459687219/4503599627370496 binary64)) (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 2 binary64)))) #s(literal 0 binary64)) |
(if (<=.f64 x #s(literal 350 binary64)) #s(literal 1 binary64) #s(literal 0 binary64)) |
(if (<=.f64 x #s(literal 350 binary64)) #s(literal 1/2 binary64) #s(literal 0 binary64)) |
#s(literal 0 binary64) |
Compiled 38 to 32 computations (15.8% saved)
| 62× | add-exp-log |
| 62× | add-log-exp |
| 62× | log1p-expm1-u |
| 62× | expm1-log1p-u |
| 60× | add-cube-cbrt |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 12 | 20 |
| 1 | 144 | 20 |
| 2 | 2343 | 20 |
| 1× | unsound |
(abs x)
Compiled 140 to 112 computations (20% saved)
Loading profile data...