
Time bar (total: 3.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% | 99.9% | 0.1% | 0% | 0% | 0% | 4 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 5 |
| 15.4% | 12.5% | 68.6% | 0.1% | 0% | 18.7% | 0% | 6 |
| 23.1% | 18.7% | 62.4% | 0.1% | 0% | 18.7% | 0% | 7 |
| 24% | 18.7% | 59.3% | 0.1% | 0% | 21.8% | 0% | 8 |
| 41.9% | 28.1% | 39% | 0.1% | 0% | 32.8% | 0% | 9 |
| 48.8% | 32.8% | 34.3% | 0.1% | 0% | 32.8% | 0% | 10 |
| 50.6% | 32.8% | 32% | 0.1% | 0% | 35.1% | 0% | 11 |
| 64.9% | 38.2% | 20.7% | 0.1% | 0% | 41% | 0% | 12 |
Compiled 39 to 21 computations (46.2% saved)
| 52.0ms | 255× | 1 | valid |
| 4.0ms | 42× | 0 | invalid |
| 0.0ms | 5× | 0 | valid |
ival-mult: 12.0ms (25.6% of total)adjust: 11.0ms (23.5% of total)ival-cbrt: 5.0ms (10.7% of total)ival-sub: 4.0ms (8.5% of total)ival-div: 4.0ms (8.5% of total)ival-sqrt: 4.0ms (8.5% of total)ival-add: 4.0ms (8.5% of total)ival-neg: 1.0ms (2.1% 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 |
|---|---|---|---|---|---|
| 117 | 0 | - | 2 | (-1.1346380414737946e-161 -2.5368340132369182e-203 -1.8707486986993295e-198) | (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))) |
| 100 | 11 | (9.967719424543281e+262 -5.5126142305456194e-52 1.9759716291306245e-82) | 57 | (3.082475883480943e+52 -1.616698103023721e-279 -2.2230783269952288e+93) | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) |
| 98 | 11 | (-4.6046468872652445e+149 -5.519187803107191e-89 -7.529799325519623e-298) | 63 | (-2.64614896742952e-123 -1.1783696543467542e-298 4.099570224780468e+93) | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) |
| 73 | 54 | (9.967719424543281e+262 -5.5126142305456194e-52 1.9759716291306245e-82) | 0 | - | (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) |
| 62 | 67 | (-1.430473509371535e+226 -3.29217476798707e-156 1.7817730203908647e-74) | 0 | - | (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) |
| 17 | 0 | - | 17 | (-3.6635486464325236e+80 7.927319520466661e-214 2.44433718988147e-202) | (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))) |
| 15 | 0 | - | 0 | - | (-.f64 (*.f64 g g) (*.f64 h h)) |
| 12 | 0 | - | 12 | (9.186956745570371e+146 -2.1747143718920334e-138 6.538954159305266e-229) | (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))) |
| 0 | 0 | - | 0 | - | (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) |
| 0 | 0 | - | 0 | - | a |
| 0 | 0 | - | 0 | - | #s(literal 1 binary64) |
| 0 | 0 | - | 0 | - | (*.f64 #s(literal 2 binary64) a) |
| 0 | 10 | (-1.430473509371535e+226 -3.29217476798707e-156 1.7817730203908647e-74) | 0 | - | (+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) |
| 0 | 0 | - | 0 | - | (*.f64 h h) |
| 0 | 0 | - | 0 | - | (*.f64 g g) |
| 0 | 0 | - | 0 | - | (neg.f64 g) |
| 0 | 0 | - | 0 | - | #s(literal 2 binary64) |
| 0 | 0 | - | 0 | - | g |
| 0 | 0 | - | 0 | - | h |
| Operator | Subexpression | Explanation | Count | |
|---|---|---|---|---|
sqrt.f64 | (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))) | oflow-rescue | 104 | 0 |
| ↳ | (-.f64 (*.f64 g g) (*.f64 h h)) | overflow | 104 | |
| ↳ | (*.f64 g g) | overflow | 104 | |
| ↳ | (*.f64 h h) | overflow | 15 | |
+.f64 | (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) | cancellation | 76 | 0 |
-.f64 | (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) | cancellation | 69 | 0 |
cbrt.f64 | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) | oflow-rescue | 47 | 0 |
| ↳ | (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))) | overflow | 47 | |
| ↳ | (-.f64 (*.f64 g g) (*.f64 h h)) | overflow | 104 | |
| ↳ | (*.f64 g g) | overflow | 104 | |
| ↳ | (*.f64 h h) | overflow | 15 | |
| ↳ | (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) | overflow | 1 | |
cbrt.f64 | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) | oflow-rescue | 42 | 0 |
| ↳ | (-.f64 (*.f64 g g) (*.f64 h h)) | overflow | 104 | |
| ↳ | (*.f64 g g) | overflow | 104 | |
| ↳ | (*.f64 h h) | overflow | 15 | |
| ↳ | (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))) | overflow | 42 | |
-.f64 | (-.f64 (*.f64 g g) (*.f64 h h)) | nan-rescue | 15 | 0 |
| ↳ | (*.f64 g g) | overflow | 104 | |
| ↳ | (*.f64 h h) | overflow | 15 | |
sqrt.f64 | (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))) | uflow-rescue | 11 | 0 |
| ↳ | (-.f64 (*.f64 g g) (*.f64 h h)) | underflow | 11 | |
| ↳ | (*.f64 g g) | underflow | 11 | |
| ↳ | (*.f64 h h) | underflow | 111 | |
+.f64 | (+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) | cancellation | 10 | 0 |
cbrt.f64 | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) | uflow-rescue | 7 | 0 |
| ↳ | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) | underflow | 51 | |
| ↳ | (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))) | underflow | 58 | |
| ↳ | (-.f64 (*.f64 g g) (*.f64 h h)) | underflow | 11 | |
| ↳ | (*.f64 g g) | underflow | 11 | |
| ↳ | (*.f64 h h) | underflow | 111 | |
| ↳ | (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) | underflow | 51 | |
cbrt.f64 | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) | uflow-rescue | 4 | 0 |
| ↳ | (-.f64 (*.f64 g g) (*.f64 h h)) | underflow | 11 | |
| ↳ | (*.f64 h h) | underflow | 111 | |
| ↳ | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) | underflow | 60 | |
| ↳ | (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))) | underflow | 64 | |
| ↳ | (*.f64 g g) | underflow | 11 | |
| ↳ | (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) | underflow | 60 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 148 | 2 |
| - | 16 | 90 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 148 | 0 | 2 |
| - | 16 | 0 | 90 |
| number | freq |
|---|---|
| 0 | 92 |
| 1 | 46 |
| 2 | 50 |
| 3 | 35 |
| 4 | 31 |
| 5 | 2 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 414.0ms | 1 164× | 2 | valid |
| 347.0ms | 744× | 3 | valid |
| 276.0ms | 1 128× | 1 | valid |
| 4.0ms | 36× | 0 | valid |
Compiled 6 408 to 936 computations (85.4% saved)
adjust: 246.0ms (31.5% of total)ival-mult: 174.0ms (22.3% of total)ival-cbrt: 84.0ms (10.8% of total)ival-sub: 74.0ms (9.5% of total)ival-add: 70.0ms (9% of total)ival-sqrt: 67.0ms (8.6% of total)ival-div: 46.0ms (5.9% of total)ival-neg: 13.0ms (1.7% of total)exact: 3.0ms (0.4% of total)ival-true: 2.0ms (0.3% of total)ival-assert: 1.0ms (0.1% of total)| 1× | egg-herbie |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 79 | 292 |
| 1 | 272 | 287 |
| 2 | 858 | 287 |
| 3 | 2888 | 282 |
| 4 | 7209 | 282 |
| 0 | 19 | 37 |
| 0 | 33 | 33 |
| 1 | 66 | 32 |
| 2 | 158 | 32 |
| 3 | 432 | 31 |
| 4 | 1050 | 31 |
| 5 | 1923 | 31 |
| 6 | 2515 | 31 |
| 7 | 4175 | 31 |
| 8 | 5034 | 31 |
| 9 | 5709 | 31 |
| 10 | 6726 | 31 |
| 11 | 7088 | 31 |
| 12 | 7276 | 31 |
| 13 | 7516 | 31 |
| 14 | 7516 | 31 |
| 15 | 7786 | 31 |
| 0 | 8072 | 31 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) |
| Outputs |
|---|
(+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) |
(+.f64 (cbrt.f64 (*.f64 #s(literal -1/2 binary64) (/.f64 (+.f64 (sqrt.f64 (*.f64 (-.f64 g h) (+.f64 h g))) g) a))) (cbrt.f64 (*.f64 (-.f64 (sqrt.f64 (*.f64 (-.f64 g h) (+.f64 h g))) g) (/.f64 #s(literal 1/2 binary64) a)))) |
(abs h)
Compiled 37 to 19 computations (48.6% saved)
Compiled 0 to 3 computations (-∞% saved)
| Status | Accuracy | Program |
|---|---|---|
| 45.4% | (+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) |
Compiled 74 to 38 computations (48.6% saved)
| 1× | egg-herbie |
Useful iterations: 6 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 19 | 37 |
| 1 | 37 | 36 |
| 2 | 51 | 36 |
| 3 | 67 | 36 |
| 4 | 79 | 36 |
| 5 | 88 | 36 |
| 6 | 101 | 35 |
| 7 | 112 | 35 |
| 8 | 156 | 35 |
| 9 | 226 | 35 |
| 10 | 229 | 35 |
| 1× | saturated |
| Inputs |
|---|
(+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) |
| Outputs |
|---|
(+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) |
(+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal -1 binary64) (*.f64 a #s(literal 2 binary64))) (+.f64 (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))) g))) (cbrt.f64 (*.f64 (-.f64 (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))) g) (/.f64 #s(literal 1 binary64) (*.f64 a #s(literal 2 binary64)))))) |
| 1× | fuel |
Compiled 35 to 20 computations (42.9% saved)
(abs h)
Compiled 284 to 158 computations (44.4% saved)
Loading profile data...