
Time bar (total: 2.2s)
| 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% | 99.9% | 0.1% | 0% | 0% | 0% | 2 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 3 |
| 0% | 0% | 49.9% | 0.1% | 0% | 49.9% | 0% | 4 |
| 0% | 0% | 49.9% | 0.1% | 0% | 49.9% | 0% | 5 |
| 0% | 0% | 49.9% | 0.1% | 0% | 49.9% | 0% | 6 |
| 9.4% | 4.7% | 45.2% | 0.1% | 0% | 49.9% | 0% | 7 |
| 17.2% | 8.6% | 41.3% | 0.1% | 0% | 49.9% | 0% | 8 |
| 27.3% | 13.7% | 36.3% | 0.1% | 0% | 49.9% | 0% | 9 |
| 41% | 20.5% | 29.4% | 0.1% | 0% | 49.9% | 0% | 10 |
| 48.6% | 24.3% | 25.6% | 0.1% | 0% | 49.9% | 0% | 11 |
| 57.1% | 28.5% | 21.4% | 0.1% | 0% | 49.9% | 0% | 12 |
Compiled 30 to 17 computations (43.3% saved)
| 25.0ms | 260× | 0 | valid |
ival-log: 5.0ms (26.6% of total)ival-mult: 4.0ms (21.3% of total)ival-hypot: 4.0ms (21.3% of total)ival-atan2: 2.0ms (10.6% of total)ival-div: 1.0ms (5.3% of total)ival-add: 1.0ms (5.3% of total)ival-sub: 1.0ms (5.3% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)exact: 0.0ms (0% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 124 | 0 | - | 1 | (-1.7661539953148527e-292 2.8720067512787035e-156 2.120718426398233e-173) | (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) |
| 1 | 0 | - | 1 | (3.065502923853557e+81 -3.5221713443525926e-232 9.747101380911904e+249) | (*.f64 (atan2.f64 im re) (log.f64 base)) |
| 0 | 0 | - | 0 | - | (log.f64 base) |
| 0 | 0 | - | 0 | - | (/.f64 (-.f64 (*.f64 (atan2.f64 im re) (log.f64 base)) (*.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) #s(literal 0 binary64))) (+.f64 (*.f64 (log.f64 base) (log.f64 base)) (*.f64 #s(literal 0 binary64) #s(literal 0 binary64)))) |
| 0 | 0 | - | 0 | - | (*.f64 re re) |
| 0 | 0 | - | 0 | - | (atan2.f64 im re) |
| 0 | 0 | - | 0 | - | im |
| 0 | 0 | - | 0 | - | (+.f64 (*.f64 re re) (*.f64 im im)) |
| 0 | 0 | - | 0 | - | re |
| 0 | 0 | - | 0 | - | (-.f64 (*.f64 (atan2.f64 im re) (log.f64 base)) (*.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) #s(literal 0 binary64))) |
| 0 | 0 | - | 0 | - | (+.f64 (*.f64 (log.f64 base) (log.f64 base)) (*.f64 #s(literal 0 binary64) #s(literal 0 binary64))) |
| 0 | 0 | - | 0 | - | (*.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) #s(literal 0 binary64)) |
| 0 | 0 | - | 0 | - | #s(literal 0 binary64) |
| 0 | 0 | - | 0 | - | (*.f64 #s(literal 0 binary64) #s(literal 0 binary64)) |
| 0 | 0 | - | 0 | - | (*.f64 (log.f64 base) (log.f64 base)) |
| 0 | 0 | - | 0 | - | (*.f64 im im) |
| 0 | 0 | - | 0 | - | base |
| 0 | 0 | - | 0 | - | (log.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) |
| Operator | Subexpression | Explanation | Count | |
|---|---|---|---|---|
sqrt.f64 | (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) | oflow-rescue | 111 | 0 |
| ↳ | (+.f64 (*.f64 re re) (*.f64 im im)) | overflow | 111 | |
| ↳ | (*.f64 re re) | overflow | 68 | |
| ↳ | (*.f64 im im) | overflow | 62 | |
sqrt.f64 | (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) | uflow-rescue | 12 | 0 |
| ↳ | (+.f64 (*.f64 re re) (*.f64 im im)) | underflow | 12 | |
| ↳ | (*.f64 re re) | underflow | 57 | |
| ↳ | (*.f64 im im) | underflow | 53 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 123 | 0 |
| - | 0 | 133 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 123 | 0 | 0 |
| - | 0 | 0 | 133 |
| number | freq |
|---|---|
| 0 | 133 |
| 1 | 123 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 388.0ms | 3 072× | 0 | valid |
Compiled 4 644 to 888 computations (80.9% saved)
ival-mult: 81.0ms (30.2% of total)ival-log: 56.0ms (20.9% of total)ival-hypot: 46.0ms (17.1% of total)ival-atan2: 25.0ms (9.3% of total)ival-add: 23.0ms (8.6% of total)ival-div: 16.0ms (6% of total)ival-sub: 14.0ms (5.2% of total)ival-true: 2.0ms (0.7% of total)exact: 2.0ms (0.7% of total)adjust: 1.0ms (0.4% of total)ival-assert: 1.0ms (0.4% of total)| 1× | egg-herbie |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 76 | 139 |
| 1 | 205 | 121 |
| 2 | 438 | 78 |
| 3 | 851 | 63 |
| 4 | 1417 | 63 |
| 5 | 2461 | 63 |
| 6 | 3273 | 63 |
| 7 | 3944 | 63 |
| 8 | 6097 | 63 |
| 9 | 7919 | 63 |
| 0 | 18 | 26 |
| 0 | 34 | 14 |
| 1 | 53 | 12 |
| 2 | 76 | 8 |
| 3 | 95 | 6 |
| 4 | 113 | 6 |
| 5 | 184 | 6 |
| 6 | 398 | 6 |
| 7 | 1265 | 6 |
| 8 | 1939 | 6 |
| 9 | 2420 | 6 |
| 10 | 2992 | 6 |
| 11 | 3887 | 6 |
| 12 | 4668 | 6 |
| 13 | 5681 | 6 |
| 14 | 6840 | 6 |
| 15 | 7178 | 6 |
| 16 | 7385 | 6 |
| 17 | 7580 | 6 |
| 18 | 7787 | 6 |
| 0 | 8595 | 6 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (-.f64 (*.f64 (atan2.f64 im re) (log.f64 base)) (*.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) #s(literal 0 binary64))) (+.f64 (*.f64 (log.f64 base) (log.f64 base)) (*.f64 #s(literal 0 binary64) #s(literal 0 binary64)))) |
| Outputs |
|---|
(/.f64 (-.f64 (*.f64 (atan2.f64 im re) (log.f64 base)) (*.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) #s(literal 0 binary64))) (+.f64 (*.f64 (log.f64 base) (log.f64 base)) (*.f64 #s(literal 0 binary64) #s(literal 0 binary64)))) |
(/.f64 (atan2.f64 im re) (log.f64 base)) |
Compiled 28 to 18 computations (35.7% saved)
Compiled 0 to 3 computations (-∞% saved)
| Status | Accuracy | Program |
|---|---|---|
| 51.6% | (/.f64 (-.f64 (*.f64 (atan2.f64 im re) (log.f64 base)) (*.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) #s(literal 0 binary64))) (+.f64 (*.f64 (log.f64 base) (log.f64 base)) (*.f64 #s(literal 0 binary64) #s(literal 0 binary64)))) |
Compiled 56 to 36 computations (35.7% saved)
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 18 | 28 |
| 1 | 27 | 28 |
| 2 | 38 | 28 |
| 3 | 44 | 28 |
| 4 | 54 | 28 |
| 5 | 64 | 28 |
| 6 | 78 | 28 |
| 7 | 86 | 28 |
| 8 | 90 | 28 |
| 9 | 91 | 28 |
| 1× | saturated |
| Inputs |
|---|
(/.f64 (-.f64 (*.f64 (atan2.f64 im re) (log.f64 base)) (*.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) #s(literal 0 binary64))) (+.f64 (*.f64 (log.f64 base) (log.f64 base)) (*.f64 #s(literal 0 binary64) #s(literal 0 binary64)))) |
| Outputs |
|---|
(/.f64 (-.f64 (*.f64 (atan2.f64 im re) (log.f64 base)) (*.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) #s(literal 0 binary64))) (+.f64 (*.f64 (log.f64 base) (log.f64 base)) (*.f64 #s(literal 0 binary64) #s(literal 0 binary64)))) |
(/.f64 (-.f64 (*.f64 (log.f64 base) (atan2.f64 im re)) (*.f64 #s(literal 0 binary64) (log.f64 (sqrt.f64 (+.f64 (*.f64 im im) (*.f64 re re)))))) (+.f64 (*.f64 #s(literal 0 binary64) #s(literal 0 binary64)) (*.f64 (log.f64 base) (log.f64 base)))) |
| 1× | fuel |
Compiled 28 to 18 computations (35.7% saved)
Compiled 112 to 72 computations (35.7% saved)
Loading profile data...