
Time bar (total: 2.1s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 0 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 1 |
| 0% | 0% | 50% | 0.1% | 0% | 50% | 0% | 2 |
| 100% | 25% | 0% | 0.1% | 0% | 74.9% | 0% | 3 |
Compiled 8 to 8 computations (0% saved)
| 836.0ms | 8 256× | 0 | valid |
ival-log: 322.0ms (60.6% of total)ival-exp: 129.0ms (24.3% of total)ival-add: 71.0ms (13.4% of total)ival-true: 6.0ms (1.1% of total)ival-assert: 3.0ms (0.6% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 144 | 27 | (2.7907128978464024e+128 7.794055686579583e-31) | 10 | (6.232272722759654e+189 5.10392252040929e-151) | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 3 | 0 | - | 1 | (3.579439270015884e-31 4.856068745547002e+31) | (+.f64 (log.f64 a) (log.f64 b)) |
| 0 | 0 | - | 0 | - | a |
| 0 | 0 | - | 0 | - | b |
| 0 | 0 | - | 0 | - | (log.f64 a) |
| 0 | 0 | - | 0 | - | (log.f64 b) |
| Operator | Subexpression | Explanation | Count | |
|---|---|---|---|---|
exp.f64 | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) | sensitivity | 161 | 24 |
+.f64 | (+.f64 (log.f64 a) (log.f64 b)) | cancellation | 2 | 3 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 143 | 32 |
| - | 20 | 61 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 143 | 24 | 8 |
| - | 20 | 3 | 58 |
| number | freq |
|---|---|
| 0 | 93 |
| 1 | 163 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 34.0ms | 512× | 0 | valid |
Compiled 44 to 22 computations (50% saved)
ival-log: 13.0ms (61.3% of total)ival-exp: 5.0ms (23.6% of total)ival-add: 3.0ms (14.1% of total)ival-true: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | egg-herbie |
| 28× | distribute-lft-neg-in |
| 18× | neg-sub0 |
| 16× | neg-mul-1 |
| 14× | distribute-neg-in |
| 14× | +-commutative |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 16 | 38 |
| 1 | 36 | 23 |
| 2 | 70 | 17 |
| 3 | 111 | 17 |
| 4 | 164 | 17 |
| 5 | 170 | 17 |
| 0 | 6 | 6 |
| 0 | 10 | 6 |
| 1 | 14 | 3 |
| 2 | 19 | 3 |
| 0 | 19 | 3 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| 1× | saturated |
| Inputs |
|---|
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| Outputs |
|---|
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(*.f64 b a) |
(negabs b)
(negabs a)
(sort a b)
Compiled 6 to 6 computations (0% saved)
Compiled 0 to 2 computations (-∞% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 92.1% | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
Compiled 6 to 6 computations (0% saved)
| 1× | egg-herbie |
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (log.f64 b) | |
| cost-diff | 0 | (log.f64 a) | |
| cost-diff | 0 | (+.f64 (log.f64 a) (log.f64 b)) | |
| cost-diff | 19072 | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 6× | lower-exp.f32 |
| 4× | lower-*.f64 |
| 4× | lower-exp.f64 |
| 4× | lower-*.f32 |
| 4× | lift-log.f64 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 17 |
| 0 | 10 | 17 |
| 1 | 14 | 14 |
| 2 | 19 | 14 |
| 0 | 19 | 14 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| Inputs |
|---|
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(+.f64 (log.f64 a) (log.f64 b)) |
(log.f64 a) |
a |
(log.f64 b) |
b |
| Outputs |
|---|
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(*.f64 b a) |
(+.f64 (log.f64 a) (log.f64 b)) |
(+.f64 (log.f64 b) (log.f64 a)) |
(log.f64 a) |
a |
(log.f64 b) |
b |
Found 4 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0 | (log.f64 b) | |
| accuracy | 0 | (log.f64 a) | |
| accuracy | 0.6337178704067646 | (+.f64 (log.f64 a) (log.f64 b)) | |
| accuracy | 4.131906110443771 | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 18.0ms | 256× | 0 | valid |
Compiled 19 to 8 computations (57.9% saved)
ival-log: 6.0ms (56.5% of total)ival-exp: 3.0ms (28.3% of total)ival-add: 1.0ms (9.4% of total)ival-true: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| Inputs |
|---|
#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ()) |
#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ()) |
#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ()) |
#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ()) |
| Outputs |
|---|
#s(alt (exp (+ (log a) (log b))) (taylor 0 b) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log a) (log b))) (taylor 0 b) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log a) (log b))) (taylor 0 b) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log a) (log b))) (taylor 0 b) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (+ (log a) (log b)) (taylor 0 b) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log a) (log b)) (taylor 0 b) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log a) (log b)) (taylor 0 b) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log a) (log b)) (taylor 0 b) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (log b) (taylor 0 b) (#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ())) ()) |
#s(alt (log b) (taylor 0 b) (#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ())) ()) |
#s(alt (log b) (taylor 0 b) (#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ())) ()) |
#s(alt (log b) (taylor 0 b) (#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log a) (* -1 (log (/ 1 b))))) (taylor inf b) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log a) (* -1 (log (/ 1 b))))) (taylor inf b) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log a) (* -1 (log (/ 1 b))))) (taylor inf b) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log a) (* -1 (log (/ 1 b))))) (taylor inf b) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (+ (log a) (* -1 (log (/ 1 b)))) (taylor inf b) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log a) (* -1 (log (/ 1 b)))) (taylor inf b) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log a) (* -1 (log (/ 1 b)))) (taylor inf b) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log a) (* -1 (log (/ 1 b)))) (taylor inf b) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (* -1 (log (/ 1 b))) (taylor inf b) (#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ())) ()) |
#s(alt (* -1 (log (/ 1 b))) (taylor inf b) (#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ())) ()) |
#s(alt (* -1 (log (/ 1 b))) (taylor inf b) (#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ())) ()) |
#s(alt (* -1 (log (/ 1 b))) (taylor inf b) (#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log -1) (+ (log a) (* -1 (log (/ -1 b)))))) (taylor -inf b) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log -1) (+ (log a) (* -1 (log (/ -1 b)))))) (taylor -inf b) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log -1) (+ (log a) (* -1 (log (/ -1 b)))))) (taylor -inf b) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log -1) (+ (log a) (* -1 (log (/ -1 b)))))) (taylor -inf b) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (+ (log a) (* -1 (log (/ -1 b))))) (taylor -inf b) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (+ (log a) (* -1 (log (/ -1 b))))) (taylor -inf b) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (+ (log a) (* -1 (log (/ -1 b))))) (taylor -inf b) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (+ (log a) (* -1 (log (/ -1 b))))) (taylor -inf b) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (* -1 (log (/ -1 b)))) (taylor -inf b) (#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (* -1 (log (/ -1 b)))) (taylor -inf b) (#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (* -1 (log (/ -1 b)))) (taylor -inf b) (#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (* -1 (log (/ -1 b)))) (taylor -inf b) (#s(alt (log.f64 b) (patch (log.f64 b) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log a) (log b))) (taylor 0 a) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log a) (log b))) (taylor 0 a) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log a) (log b))) (taylor 0 a) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log a) (log b))) (taylor 0 a) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (+ (log a) (log b)) (taylor 0 a) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log a) (log b)) (taylor 0 a) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log a) (log b)) (taylor 0 a) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log a) (log b)) (taylor 0 a) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (log a) (taylor 0 a) (#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ())) ()) |
#s(alt (log a) (taylor 0 a) (#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ())) ()) |
#s(alt (log a) (taylor 0 a) (#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ())) ()) |
#s(alt (log a) (taylor 0 a) (#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log b) (* -1 (log (/ 1 a))))) (taylor inf a) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log b) (* -1 (log (/ 1 a))))) (taylor inf a) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log b) (* -1 (log (/ 1 a))))) (taylor inf a) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log b) (* -1 (log (/ 1 a))))) (taylor inf a) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (+ (log b) (* -1 (log (/ 1 a)))) (taylor inf a) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log b) (* -1 (log (/ 1 a)))) (taylor inf a) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log b) (* -1 (log (/ 1 a)))) (taylor inf a) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log b) (* -1 (log (/ 1 a)))) (taylor inf a) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (* -1 (log (/ 1 a))) (taylor inf a) (#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ())) ()) |
#s(alt (* -1 (log (/ 1 a))) (taylor inf a) (#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ())) ()) |
#s(alt (* -1 (log (/ 1 a))) (taylor inf a) (#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ())) ()) |
#s(alt (* -1 (log (/ 1 a))) (taylor inf a) (#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log -1) (+ (log b) (* -1 (log (/ -1 a)))))) (taylor -inf a) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log -1) (+ (log b) (* -1 (log (/ -1 a)))))) (taylor -inf a) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log -1) (+ (log b) (* -1 (log (/ -1 a)))))) (taylor -inf a) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (exp (+ (log -1) (+ (log b) (* -1 (log (/ -1 a)))))) (taylor -inf a) (#s(alt (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) (patch (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (+ (log b) (* -1 (log (/ -1 a))))) (taylor -inf a) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (+ (log b) (* -1 (log (/ -1 a))))) (taylor -inf a) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (+ (log b) (* -1 (log (/ -1 a))))) (taylor -inf a) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (+ (log b) (* -1 (log (/ -1 a))))) (taylor -inf a) (#s(alt (+.f64 (log.f64 a) (log.f64 b)) (patch (+.f64 (log.f64 a) (log.f64 b)) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (* -1 (log (/ -1 a)))) (taylor -inf a) (#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (* -1 (log (/ -1 a)))) (taylor -inf a) (#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (* -1 (log (/ -1 a)))) (taylor -inf a) (#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ())) ()) |
#s(alt (+ (log -1) (* -1 (log (/ -1 a)))) (taylor -inf a) (#s(alt (log.f64 a) (patch (log.f64 a) #<representation binary64>) () ())) ()) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 49.0ms | b | @ | 0 | ((exp (+ (log a) (log b))) (+ (log a) (log b)) (log a) (log b)) |
| 25.0ms | b | @ | -inf | ((exp (+ (log a) (log b))) (+ (log a) (log b)) (log a) (log b)) |
| 21.0ms | a | @ | 0 | ((exp (+ (log a) (log b))) (+ (log a) (log b)) (log a) (log b)) |
| 16.0ms | a | @ | inf | ((exp (+ (log a) (log b))) (+ (log a) (log b)) (log a) (log b)) |
| 15.0ms | a | @ | -inf | ((exp (+ (log a) (log b))) (+ (log a) (log b)) (log a) (log b)) |
| 1× | egg-herbie |
| 8 608× | lower-fma.f64 |
| 8 608× | lower-fma.f32 |
| 1 984× | lower--.f64 |
| 1 984× | lower--.f32 |
| 1 856× | lower-+.f64 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 33 | 312 |
| 1 | 70 | 240 |
| 2 | 136 | 240 |
| 3 | 332 | 240 |
| 4 | 715 | 240 |
| 5 | 1114 | 240 |
| 6 | 1425 | 240 |
| 7 | 1672 | 240 |
| 8 | 2149 | 240 |
| 9 | 2854 | 240 |
| 10 | 3182 | 240 |
| 11 | 3188 | 240 |
| 12 | 3930 | 240 |
| 13 | 4978 | 240 |
| 14 | 5074 | 240 |
| 15 | 5082 | 240 |
| 16 | 5090 | 240 |
| 17 | 5090 | 240 |
| 18 | 5158 | 240 |
| 19 | 5166 | 240 |
| 20 | 5170 | 240 |
| 21 | 7832 | 240 |
| 22 | 7925 | 240 |
| 0 | 8053 | 240 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(exp (+ (log a) (log b))) |
(exp (+ (log a) (log b))) |
(exp (+ (log a) (log b))) |
(exp (+ (log a) (log b))) |
(+ (log a) (log b)) |
(+ (log a) (log b)) |
(+ (log a) (log b)) |
(+ (log a) (log b)) |
(log b) |
(log b) |
(log b) |
(log b) |
(exp (+ (log a) (* -1 (log (/ 1 b))))) |
(exp (+ (log a) (* -1 (log (/ 1 b))))) |
(exp (+ (log a) (* -1 (log (/ 1 b))))) |
(exp (+ (log a) (* -1 (log (/ 1 b))))) |
(+ (log a) (* -1 (log (/ 1 b)))) |
(+ (log a) (* -1 (log (/ 1 b)))) |
(+ (log a) (* -1 (log (/ 1 b)))) |
(+ (log a) (* -1 (log (/ 1 b)))) |
(* -1 (log (/ 1 b))) |
(* -1 (log (/ 1 b))) |
(* -1 (log (/ 1 b))) |
(* -1 (log (/ 1 b))) |
(exp (+ (log -1) (+ (log a) (* -1 (log (/ -1 b)))))) |
(exp (+ (log -1) (+ (log a) (* -1 (log (/ -1 b)))))) |
(exp (+ (log -1) (+ (log a) (* -1 (log (/ -1 b)))))) |
(exp (+ (log -1) (+ (log a) (* -1 (log (/ -1 b)))))) |
(+ (log -1) (+ (log a) (* -1 (log (/ -1 b))))) |
(+ (log -1) (+ (log a) (* -1 (log (/ -1 b))))) |
(+ (log -1) (+ (log a) (* -1 (log (/ -1 b))))) |
(+ (log -1) (+ (log a) (* -1 (log (/ -1 b))))) |
(+ (log -1) (* -1 (log (/ -1 b)))) |
(+ (log -1) (* -1 (log (/ -1 b)))) |
(+ (log -1) (* -1 (log (/ -1 b)))) |
(+ (log -1) (* -1 (log (/ -1 b)))) |
(exp (+ (log a) (log b))) |
(exp (+ (log a) (log b))) |
(exp (+ (log a) (log b))) |
(exp (+ (log a) (log b))) |
(+ (log a) (log b)) |
(+ (log a) (log b)) |
(+ (log a) (log b)) |
(+ (log a) (log b)) |
(log a) |
(log a) |
(log a) |
(log a) |
(exp (+ (log b) (* -1 (log (/ 1 a))))) |
(exp (+ (log b) (* -1 (log (/ 1 a))))) |
(exp (+ (log b) (* -1 (log (/ 1 a))))) |
(exp (+ (log b) (* -1 (log (/ 1 a))))) |
(+ (log b) (* -1 (log (/ 1 a)))) |
(+ (log b) (* -1 (log (/ 1 a)))) |
(+ (log b) (* -1 (log (/ 1 a)))) |
(+ (log b) (* -1 (log (/ 1 a)))) |
(* -1 (log (/ 1 a))) |
(* -1 (log (/ 1 a))) |
(* -1 (log (/ 1 a))) |
(* -1 (log (/ 1 a))) |
(exp (+ (log -1) (+ (log b) (* -1 (log (/ -1 a)))))) |
(exp (+ (log -1) (+ (log b) (* -1 (log (/ -1 a)))))) |
(exp (+ (log -1) (+ (log b) (* -1 (log (/ -1 a)))))) |
(exp (+ (log -1) (+ (log b) (* -1 (log (/ -1 a)))))) |
(+ (log -1) (+ (log b) (* -1 (log (/ -1 a))))) |
(+ (log -1) (+ (log b) (* -1 (log (/ -1 a))))) |
(+ (log -1) (+ (log b) (* -1 (log (/ -1 a))))) |
(+ (log -1) (+ (log b) (* -1 (log (/ -1 a))))) |
(+ (log -1) (* -1 (log (/ -1 a)))) |
(+ (log -1) (* -1 (log (/ -1 a)))) |
(+ (log -1) (* -1 (log (/ -1 a)))) |
(+ (log -1) (* -1 (log (/ -1 a)))) |
| Outputs |
|---|
(exp (+ (log a) (log b))) |
(*.f64 b a) |
(exp (+ (log a) (log b))) |
(*.f64 b a) |
(exp (+ (log a) (log b))) |
(*.f64 b a) |
(exp (+ (log a) (log b))) |
(*.f64 b a) |
(+ (log a) (log b)) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log a) (log b)) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log a) (log b)) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log a) (log b)) |
(+.f64 (log.f64 b) (log.f64 a)) |
(log b) |
(log.f64 b) |
(log b) |
(log.f64 b) |
(log b) |
(log.f64 b) |
(log b) |
(log.f64 b) |
(exp (+ (log a) (* -1 (log (/ 1 b))))) |
(*.f64 b a) |
(exp (+ (log a) (* -1 (log (/ 1 b))))) |
(*.f64 b a) |
(exp (+ (log a) (* -1 (log (/ 1 b))))) |
(*.f64 b a) |
(exp (+ (log a) (* -1 (log (/ 1 b))))) |
(*.f64 b a) |
(+ (log a) (* -1 (log (/ 1 b)))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log a) (* -1 (log (/ 1 b)))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log a) (* -1 (log (/ 1 b)))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log a) (* -1 (log (/ 1 b)))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(* -1 (log (/ 1 b))) |
(log.f64 b) |
(* -1 (log (/ 1 b))) |
(log.f64 b) |
(* -1 (log (/ 1 b))) |
(log.f64 b) |
(* -1 (log (/ 1 b))) |
(log.f64 b) |
(exp (+ (log -1) (+ (log a) (* -1 (log (/ -1 b)))))) |
(*.f64 b a) |
(exp (+ (log -1) (+ (log a) (* -1 (log (/ -1 b)))))) |
(*.f64 b a) |
(exp (+ (log -1) (+ (log a) (* -1 (log (/ -1 b)))))) |
(*.f64 b a) |
(exp (+ (log -1) (+ (log a) (* -1 (log (/ -1 b)))))) |
(*.f64 b a) |
(+ (log -1) (+ (log a) (* -1 (log (/ -1 b))))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log -1) (+ (log a) (* -1 (log (/ -1 b))))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log -1) (+ (log a) (* -1 (log (/ -1 b))))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log -1) (+ (log a) (* -1 (log (/ -1 b))))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log -1) (* -1 (log (/ -1 b)))) |
(log.f64 b) |
(+ (log -1) (* -1 (log (/ -1 b)))) |
(log.f64 b) |
(+ (log -1) (* -1 (log (/ -1 b)))) |
(log.f64 b) |
(+ (log -1) (* -1 (log (/ -1 b)))) |
(log.f64 b) |
(exp (+ (log a) (log b))) |
(*.f64 b a) |
(exp (+ (log a) (log b))) |
(*.f64 b a) |
(exp (+ (log a) (log b))) |
(*.f64 b a) |
(exp (+ (log a) (log b))) |
(*.f64 b a) |
(+ (log a) (log b)) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log a) (log b)) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log a) (log b)) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log a) (log b)) |
(+.f64 (log.f64 b) (log.f64 a)) |
(log a) |
(log.f64 a) |
(log a) |
(log.f64 a) |
(log a) |
(log.f64 a) |
(log a) |
(log.f64 a) |
(exp (+ (log b) (* -1 (log (/ 1 a))))) |
(*.f64 b a) |
(exp (+ (log b) (* -1 (log (/ 1 a))))) |
(*.f64 b a) |
(exp (+ (log b) (* -1 (log (/ 1 a))))) |
(*.f64 b a) |
(exp (+ (log b) (* -1 (log (/ 1 a))))) |
(*.f64 b a) |
(+ (log b) (* -1 (log (/ 1 a)))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log b) (* -1 (log (/ 1 a)))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log b) (* -1 (log (/ 1 a)))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log b) (* -1 (log (/ 1 a)))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(* -1 (log (/ 1 a))) |
(log.f64 a) |
(* -1 (log (/ 1 a))) |
(log.f64 a) |
(* -1 (log (/ 1 a))) |
(log.f64 a) |
(* -1 (log (/ 1 a))) |
(log.f64 a) |
(exp (+ (log -1) (+ (log b) (* -1 (log (/ -1 a)))))) |
(*.f64 b a) |
(exp (+ (log -1) (+ (log b) (* -1 (log (/ -1 a)))))) |
(*.f64 b a) |
(exp (+ (log -1) (+ (log b) (* -1 (log (/ -1 a)))))) |
(*.f64 b a) |
(exp (+ (log -1) (+ (log b) (* -1 (log (/ -1 a)))))) |
(*.f64 b a) |
(+ (log -1) (+ (log b) (* -1 (log (/ -1 a))))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log -1) (+ (log b) (* -1 (log (/ -1 a))))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log -1) (+ (log b) (* -1 (log (/ -1 a))))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log -1) (+ (log b) (* -1 (log (/ -1 a))))) |
(+.f64 (log.f64 b) (log.f64 a)) |
(+ (log -1) (* -1 (log (/ -1 a)))) |
(log.f64 a) |
(+ (log -1) (* -1 (log (/ -1 a)))) |
(log.f64 a) |
(+ (log -1) (* -1 (log (/ -1 a)))) |
(log.f64 a) |
(+ (log -1) (* -1 (log (/ -1 a)))) |
(log.f64 a) |
| 7 112× | lower-fma.f64 |
| 7 112× | lower-fma.f32 |
| 4 202× | lower-*.f64 |
| 4 202× | lower-*.f32 |
| 4 178× | lower-/.f64 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 15 |
| 0 | 10 | 13 |
| 1 | 29 | 11 |
| 2 | 144 | 11 |
| 3 | 1268 | 11 |
| 0 | 8970 | 11 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
(+.f64 (log.f64 a) (log.f64 b)) |
(log.f64 a) |
(log.f64 b) |
| Outputs |
|---|
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
#<batchref> |
Compiled 7 825 to 801 computations (89.8% saved)
1 alts after pruning (1 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 310 | 1 | 311 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 311 | 1 | 312 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (*.f64 b a) |
Compiled 3 to 3 computations (0% saved)
| 1× | egg-herbie |
Found 1 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (*.f64 b a) |
| 4× | lower-*.f32 |
| 2× | *-commutative |
| 2× | lower-*.f64 |
| 2× | lift-*.f64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 3 | 5 |
| 0 | 4 | 5 |
| 1 | 5 | 5 |
| 0 | 5 | 5 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| Inputs |
|---|
(*.f64 b a) |
b |
a |
| Outputs |
|---|
(*.f64 b a) |
(*.f64 a b) |
b |
a |
Found 1 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0 | (*.f64 b a) |
| 6.0ms | 256× | 0 | valid |
Compiled 7 to 5 computations (28.6% saved)
ival-mult: 2.0ms (103.9% of total)ival-true: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| Inputs |
|---|
#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ()) |
| Outputs |
|---|
#s(alt (* a b) (taylor 0 b) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor 0 b) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor 0 b) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor 0 b) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor inf b) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor inf b) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor inf b) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor inf b) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor -inf b) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor -inf b) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor -inf b) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor -inf b) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor 0 a) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor 0 a) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor 0 a) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor 0 a) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor inf a) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor inf a) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor inf a) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor inf a) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor -inf a) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor -inf a) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor -inf a) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
#s(alt (* a b) (taylor -inf a) (#s(alt (*.f64 b a) (patch (*.f64 b a) #<representation binary64>) () ())) ()) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | b | @ | -inf | ((* b a)) |
| 0.0ms | a | @ | -inf | ((* b a)) |
| 0.0ms | b | @ | 0 | ((* b a)) |
| 0.0ms | a | @ | inf | ((* b a)) |
| 0.0ms | b | @ | inf | ((* b a)) |
| 1× | egg-herbie |
| 4× | lower-*.f64 |
| 4× | lower-*.f32 |
| 2× | *-commutative |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 3 | 72 |
| 1 | 4 | 72 |
| 0 | 4 | 72 |
| 1× | iter limit |
| 1× | saturated |
| Inputs |
|---|
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
(* a b) |
| Outputs |
|---|
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
(* a b) |
(*.f64 b a) |
| 4× | lower-*.f32 |
| 2× | lower-*.f64 |
| 2× | *-commutative |
| 2× | lift-*.f64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 3 | 3 |
| 0 | 4 | 3 |
| 1 | 5 | 3 |
| 0 | 5 | 3 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| Inputs |
|---|
(*.f64 b a) |
| Outputs |
|---|
#<batchref> |
#<batchref> |
Compiled 102 to 5 computations (95.1% saved)
1 alts after pruning (0 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 26 | 0 | 26 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 26 | 1 | 27 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 b a) |
Compiled 12 to 10 computations (16.7% saved)
Total -5.1b remaining (-∞%)
Threshold costs -5.1b (-∞%)
| Inputs |
|---|
(*.f64 b a) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| Outputs |
|---|
(*.f64 b a) |
6 calls:
| 20.0ms | (+.f64 (log.f64 a) (log.f64 b)) |
| 1.0ms | (log.f64 b) |
| 1.0ms | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 1.0ms | (log.f64 a) |
| 1.0ms | a |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | a |
| 100.0% | 1 | b |
| 100.0% | 1 | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 100.0% | 1 | (+.f64 (log.f64 a) (log.f64 b)) |
| 100.0% | 1 | (log.f64 a) |
| 100.0% | 1 | (log.f64 b) |
Compiled 17 to 21 computations (-23.5% saved)
| 1× | egg-herbie |
| 2× | *-commutative-binary64-*.f64 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 3 | 3 |
| 1 | 4 | 3 |
| 1× | saturated |
| Inputs |
|---|
(*.f64 b a) |
| Outputs |
|---|
(*.f64 b a) |
(*.f64 a b) |
| 7 112× | lower-fma.f64 |
| 7 112× | lower-fma.f32 |
| 4 202× | lower-*.f64 |
| 4 202× | lower-*.f32 |
| 4 178× | lower-/.f64 |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 6 | 15 |
| 0 | 10 | 13 |
| 1 | 29 | 11 |
| 2 | 144 | 11 |
| 3 | 1268 | 11 |
| 0 | 8970 | 11 |
| 1× | done |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
Compiled 12 to 10 computations (16.7% saved)
(sort a b)
(negabs a)
(negabs b)
Compiled 60 to 60 computations (0% saved)
Loading profile data...