
Time bar (total: 3.0s)
| 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)
| 803.0ms | 8 256× | 0 | valid |
ival-log: 245.0ms (54.7% of total)ival-exp: 138.0ms (30.8% of total)ival-add: 54.0ms (12.1% of total)ival-true: 7.0ms (1.6% of total)ival-assert: 4.0ms (0.9% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 152 | 17 | (2.1562067810705892e-277 6.0674697560783896e+231) | 10 | (8.233829816533966e+20 32573157080867708.0) | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 5 | 0 | - | 4 | (1.4783146045675505e+213 1.5881520936472487e-211) | (+.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 | 159 | 28 |
+.f64 | (+.f64 (log.f64 a) (log.f64 b)) | cancellation | 1 | 2 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 149 | 37 |
| - | 11 | 59 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 149 | 27 | 10 |
| - | 11 | 3 | 56 |
| number | freq |
|---|---|
| 0 | 96 |
| 1 | 160 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 40.0ms | 512× | 0 | valid |
Compiled 44 to 22 computations (50% saved)
ival-log: 14.0ms (60.8% of total)ival-exp: 6.0ms (26.1% of total)ival-add: 3.0ms (13% of total)ival-true: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | egg-herbie |
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 |
|---|---|---|
| ▶ | 91.8% | (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))) |
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.668877408478088 | (+.f64 (log.f64 a) (log.f64 b)) | |
| accuracy | 4.254779406464763 | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 21.0ms | 256× | 0 | valid |
Compiled 19 to 8 computations (57.9% saved)
ival-log: 7.0ms (51.2% of total)ival-add: 4.0ms (29.2% of total)ival-exp: 3.0ms (21.9% 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 | |
|---|---|---|---|---|
| 58.0ms | b | @ | 0 | ((exp (+ (log a) (log b))) (+ (log a) (log b)) (log a) (log b)) |
| 36.0ms | a | @ | 0 | ((exp (+ (log a) (log b))) (+ (log a) (log b)) (log a) (log b)) |
| 25.0ms | a | @ | -inf | ((exp (+ (log a) (log b))) (+ (log a) (log b)) (log a) (log b)) |
| 24.0ms | b | @ | -inf | ((exp (+ (log a) (log b))) (+ (log a) (log b)) (log a) (log b)) |
| 20.0ms | a | @ | inf | ((exp (+ (log a) (log b))) (+ (log a) (log b)) (log a) (log b)) |
| 1× | egg-herbie |
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) |
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) |
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) |
| 192.0ms | 256× | 0 | valid |
Compiled 7 to 5 computations (28.6% saved)
ival-mult: 2.0ms (77.2% 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 | a | @ | 0 | ((* b a)) |
| 0.0ms | b | @ | inf | ((* b a)) |
| 0.0ms | b | @ | 0 | ((* b a)) |
| 1× | egg-herbie |
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) |
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.3b remaining (-∞%)
Threshold costs -5.3b (-∞%)
| Inputs |
|---|
(*.f64 b a) |
(exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| Outputs |
|---|
(*.f64 b a) |
6 calls:
| 3.0ms | a |
| 2.0ms | (log.f64 b) |
| 2.0ms | (+.f64 (log.f64 a) (log.f64 b)) |
| 2.0ms | (log.f64 a) |
| 2.0ms | (exp.f64 (+.f64 (log.f64 a) (log.f64 b))) |
| 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 |
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) |
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...