
Time bar (total: 2.9s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 99.8% | 0.2% | 0% | 0% | 0% | 0 |
| 0% | 0% | 99.8% | 0.2% | 0% | 0% | 0% | 1 |
| 0% | 0% | 99.8% | 0.2% | 0% | 0% | 0% | 2 |
| 0% | 0% | 99.8% | 0.2% | 0% | 0% | 0% | 3 |
| 0% | 0% | 99.8% | 0.2% | 0% | 0% | 0% | 4 |
| 25% | 25% | 74.9% | 0.2% | 0% | 0% | 0% | 5 |
| 25% | 25% | 74.9% | 0.2% | 0% | 0% | 0% | 6 |
| 25% | 25% | 74.9% | 0.2% | 0% | 0% | 0% | 7 |
| 37.5% | 37.4% | 62.4% | 0.2% | 0% | 0% | 0% | 8 |
| 56.3% | 56.1% | 43.7% | 0.2% | 0% | 0% | 0% | 9 |
| 56.3% | 56.1% | 43.7% | 0.2% | 0% | 0% | 0% | 10 |
| 56.3% | 56.1% | 43.7% | 0.2% | 0% | 0% | 0% | 11 |
| 65.6% | 65.5% | 34.3% | 0.2% | 0% | 0% | 0% | 12 |
Compiled 9 to 9 computations (0% saved)
| 703.0ms | 8 256× | 0 | valid |
ival-mult: 237.0ms (67.5% of total)ival-div: 103.0ms (29.4% of total)ival-true: 6.0ms (1.7% of total)adjust: 3.0ms (0.9% of total)ival-assert: 3.0ms (0.9% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 36 | 0 | - | 1 | (3.2569091945572376e-12 1.6313278636929646e-303 -4.857505266120179e-121 6.3449531123788964e+60) | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
| 0 | 0 | - | 0 | - | (*.f64 b1 b2) |
| 0 | 0 | - | 0 | - | (*.f64 a1 a2) |
| 0 | 0 | - | 0 | - | a1 |
| 0 | 0 | - | 0 | - | b2 |
| 0 | 0 | - | 0 | - | b1 |
| 0 | 0 | - | 0 | - | a2 |
| Operator | Subexpression | Explanation | Count | |
|---|---|---|---|---|
/.f64 | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) | n/u | 9 | 0 |
| ↳ | (*.f64 b1 b2) | underflow | 44 | |
/.f64 | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) | u/n | 7 | 0 |
| ↳ | (*.f64 a1 a2) | underflow | 38 | |
/.f64 | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) | u/u | 6 | 0 |
| ↳ | (*.f64 a1 a2) | underflow | 38 | |
| ↳ | (*.f64 b1 b2) | underflow | 44 | |
/.f64 | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) | o/n | 6 | 0 |
| ↳ | (*.f64 a1 a2) | overflow | 26 | |
/.f64 | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) | n/o | 4 | 0 |
| ↳ | (*.f64 b1 b2) | overflow | 31 | |
/.f64 | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) | o/o | 3 | 0 |
| ↳ | (*.f64 a1 a2) | overflow | 26 | |
| ↳ | (*.f64 b1 b2) | overflow | 31 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 35 | 1 |
| - | 0 | 220 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 35 | 0 | 1 |
| - | 0 | 0 | 220 |
| number | freq |
|---|---|
| 0 | 221 |
| 1 | 35 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 37.0ms | 512× | 0 | valid |
Compiled 45 to 25 computations (44.4% saved)
ival-mult: 18.0ms (83.1% of total)ival-div: 3.0ms (13.9% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 36 | 114 |
| 1 | 116 | 102 |
| 2 | 326 | 102 |
| 3 | 697 | 102 |
| 4 | 997 | 102 |
| 5 | 1879 | 102 |
| 6 | 1895 | 102 |
| 0 | 7 | 7 |
| 0 | 10 | 7 |
| 1 | 19 | 7 |
| 2 | 37 | 7 |
| 3 | 48 | 7 |
| 4 | 48 | 7 |
| 0 | 48 | 7 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| 1× | saturated |
| Inputs |
|---|
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
| Outputs |
|---|
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(negabs b2)
(negabs b1)
(negabs a2)
(negabs a1)
(sort a1 a2)
(sort b1 b2)
Compiled 7 to 7 computations (0% saved)
Compiled 0 to 4 computations (-∞% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 86.6% | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
Compiled 7 to 7 computations (0% saved)
| 1× | egg-herbie |
Found 3 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (*.f64 b1 b2) | |
| cost-diff | 0 | (*.f64 a1 a2) | |
| cost-diff | 0 | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 17 |
| 0 | 10 | 17 |
| 1 | 19 | 17 |
| 2 | 37 | 17 |
| 3 | 48 | 17 |
| 4 | 48 | 17 |
| 0 | 48 | 17 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| Inputs |
|---|
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
(*.f64 a1 a2) |
a1 |
a2 |
(*.f64 b1 b2) |
b1 |
b2 |
| Outputs |
|---|
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(*.f64 a1 a2) |
(*.f64 a2 a1) |
a1 |
a2 |
(*.f64 b1 b2) |
(*.f64 b2 b1) |
b1 |
b2 |
Found 3 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (*.f64 b1 b2) | |
| accuracy | 0.0 | (*.f64 a1 a2) | |
| accuracy | 8.47412046269286 | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
| 37.0ms | 256× | 0 | valid |
Compiled 19 to 9 computations (52.6% saved)
ival-mult: 5.0ms (76.9% of total)ival-div: 1.0ms (15.4% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| Inputs |
|---|
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
(*.f64 a1 a2) |
(*.f64 b1 b2) |
| Outputs |
|---|
(/ (* a1 a2) (* b1 b2)) |
(* a1 a2) |
(* b1 b2) |
12 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 22.0ms | b2 | @ | 0 | ((/ (* a1 a2) (* b1 b2)) (* a1 a2) (* b1 b2)) |
| 2.0ms | a2 | @ | -inf | ((/ (* a1 a2) (* b1 b2)) (* a1 a2) (* b1 b2)) |
| 1.0ms | a1 | @ | -inf | ((/ (* a1 a2) (* b1 b2)) (* a1 a2) (* b1 b2)) |
| 1.0ms | a1 | @ | 0 | ((/ (* a1 a2) (* b1 b2)) (* a1 a2) (* b1 b2)) |
| 1.0ms | b2 | @ | -inf | ((/ (* a1 a2) (* b1 b2)) (* a1 a2) (* b1 b2)) |
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 13 |
| 1 | 16 | 13 |
| 2 | 34 | 13 |
| 3 | 45 | 13 |
| 4 | 45 | 13 |
| 0 | 45 | 13 |
| 1× | iter limit |
| 1× | saturated |
| Inputs |
|---|
(/ (* a1 a2) (* b1 b2)) |
(* a1 a2) |
(* b1 b2) |
| Outputs |
|---|
(/ (* a1 a2) (* b1 b2)) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(* a1 a2) |
(*.f64 a2 a1) |
(* b1 b2) |
(*.f64 b2 b1) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 13 |
| 0 | 10 | 13 |
| 1 | 22 | 13 |
| 2 | 65 | 13 |
| 3 | 209 | 13 |
| 4 | 548 | 13 |
| 5 | 557 | 13 |
| 0 | 557 | 13 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| Inputs |
|---|
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
(*.f64 a1 a2) |
(*.f64 b1 b2) |
| Outputs |
|---|
(*.f64 (/.f64 (/.f64 (neg.f64 a1) b1) b2) (neg.f64 a2)) |
(*.f64 (/.f64 (/.f64 (neg.f64 a2) b1) b2) (neg.f64 a1)) |
(*.f64 (/.f64 (neg.f64 a1) b1) (/.f64 (neg.f64 a2) b2)) |
(*.f64 (/.f64 (neg.f64 a1) b2) (/.f64 (neg.f64 a2) b1)) |
(*.f64 (/.f64 (neg.f64 a2) b1) (/.f64 (neg.f64 a1) b2)) |
(*.f64 (/.f64 (neg.f64 a2) b2) (/.f64 (neg.f64 a1) b1)) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(*.f64 (/.f64 a2 b1) (/.f64 a1 b2)) |
(*.f64 (/.f64 a1 b2) (/.f64 a2 b1)) |
(*.f64 (neg.f64 a1) (/.f64 (/.f64 (neg.f64 a2) b1) b2)) |
(*.f64 (neg.f64 a2) (/.f64 (/.f64 (neg.f64 a1) b1) b2)) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(*.f64 (/.f64 a1 b1) (/.f64 a2 b2)) |
(*.f64 a2 (/.f64 (/.f64 a1 b2) b1)) |
(*.f64 a1 (/.f64 (/.f64 a2 b2) b1)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a1) b2) a2) (neg.f64 b1)) |
(/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
(/.f64 (*.f64 (/.f64 (neg.f64 a1) b1) a2) (neg.f64 b2)) |
(/.f64 (*.f64 a2 a1) (*.f64 b2 b1)) |
(/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
(/.f64 (*.f64 (neg.f64 a1) a2) (*.f64 (neg.f64 b2) b1)) |
(neg.f64 (*.f64 (/.f64 (/.f64 (neg.f64 a1) b1) b2) a2)) |
(*.f64 (neg.f64 a1) (neg.f64 a2)) |
(*.f64 (neg.f64 a2) (neg.f64 a1)) |
(*.f64 a2 a1) |
(*.f64 a1 a2) |
(neg.f64 (*.f64 (neg.f64 a1) a2)) |
(*.f64 (neg.f64 b2) (neg.f64 b1)) |
(*.f64 (neg.f64 b1) (neg.f64 b2)) |
(*.f64 b2 b1) |
(*.f64 b1 b2) |
(neg.f64 (*.f64 (neg.f64 b2) b1)) |
Compiled 304 to 77 computations (74.7% saved)
8 alts after pruning (7 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 29 | 7 | 36 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 29 | 8 | 37 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 81.3% | (/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
| ▶ | 92.3% | (/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
| ✓ | 86.6% | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
| 81.3% | (*.f64 (/.f64 (/.f64 (neg.f64 a2) b1) b2) (neg.f64 a1)) | |
| 93.9% | (*.f64 (/.f64 (/.f64 (neg.f64 a1) b1) b2) (neg.f64 a2)) | |
| ▶ | 91.7% | (*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
| ▶ | 81.2% | (*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
| ▶ | 98.0% | (*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
Compiled 113 to 113 computations (0% saved)
| 1× | egg-herbie |
Found 15 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (/.f64 a1 b2) | |
| cost-diff | 0 | (*.f64 (/.f64 a1 b2) a2) | |
| cost-diff | 0 | (/.f64 (*.f64 (/.f64 a1 b2) a2) b1) | |
| cost-diff | 0 | (/.f64 a1 b1) | |
| cost-diff | 0 | (*.f64 (/.f64 a1 b1) a2) | |
| cost-diff | 0 | (/.f64 (*.f64 (/.f64 a1 b1) a2) b2) | |
| cost-diff | 0 | (/.f64 a2 b2) | |
| cost-diff | 0 | (/.f64 (/.f64 a2 b2) b1) | |
| cost-diff | 0 | (*.f64 (/.f64 (/.f64 a2 b2) b1) a1) | |
| cost-diff | 0 | (/.f64 a1 b2) | |
| cost-diff | 0 | (/.f64 (/.f64 a1 b2) b1) | |
| cost-diff | 0 | (*.f64 (/.f64 (/.f64 a1 b2) b1) a2) | |
| cost-diff | 0 | (/.f64 a1 b1) | |
| cost-diff | 0 | (/.f64 a2 b2) | |
| cost-diff | 0 | (*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 16 | 93 |
| 0 | 28 | 93 |
| 1 | 44 | 93 |
| 2 | 58 | 93 |
| 3 | 61 | 93 |
| 0 | 61 | 93 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| Inputs |
|---|
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(/.f64 a2 b2) |
a2 |
b2 |
(/.f64 a1 b1) |
a1 |
b1 |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(/.f64 (/.f64 a1 b2) b1) |
(/.f64 a1 b2) |
a1 |
b2 |
b1 |
a2 |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(/.f64 (/.f64 a2 b2) b1) |
(/.f64 a2 b2) |
a2 |
b2 |
b1 |
a1 |
(/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
(*.f64 (/.f64 a1 b1) a2) |
(/.f64 a1 b1) |
a1 |
b1 |
a2 |
b2 |
(/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
(*.f64 (/.f64 a1 b2) a2) |
(/.f64 a1 b2) |
a1 |
b2 |
a2 |
b1 |
| Outputs |
|---|
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(/.f64 a2 b2) |
a2 |
b2 |
(/.f64 a1 b1) |
a1 |
b1 |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(/.f64 (/.f64 a1 b2) b1) |
(/.f64 a1 b2) |
a1 |
b2 |
b1 |
a2 |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(/.f64 (/.f64 a2 b2) b1) |
(/.f64 a2 b2) |
a2 |
b2 |
b1 |
a1 |
(/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(*.f64 (/.f64 a1 b1) a2) |
(/.f64 a1 b1) |
a1 |
b1 |
a2 |
b2 |
(/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(*.f64 (/.f64 a1 b2) a2) |
(/.f64 a1 b2) |
a1 |
b2 |
a2 |
b1 |
Found 15 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (/.f64 a1 b2) | |
| accuracy | 5.532961496348599 | (/.f64 (*.f64 (/.f64 a1 b2) a2) b1) | |
| accuracy | 7.63010464659265 | (*.f64 (/.f64 a1 b2) a2) | |
| accuracy | 0.0 | (/.f64 a1 b1) | |
| accuracy | 1.156337642792202 | (*.f64 (/.f64 a1 b1) a2) | |
| accuracy | 4.857119901938315 | (/.f64 (*.f64 (/.f64 a1 b1) a2) b2) | |
| accuracy | 0.0 | (/.f64 a2 b2) | |
| accuracy | 1.522570274268911 | (/.f64 (/.f64 a2 b2) b1) | |
| accuracy | 4.816452630922271 | (*.f64 (/.f64 (/.f64 a2 b2) b1) a1) | |
| accuracy | 0.0 | (/.f64 a1 b2) | |
| accuracy | 3.889983436795268 | (*.f64 (/.f64 (/.f64 a1 b2) b1) a2) | |
| accuracy | 8.99049116637464 | (/.f64 (/.f64 a1 b2) b1) | |
| accuracy | 0.0 | (/.f64 a2 b2) | |
| accuracy | 0.0 | (/.f64 a1 b1) | |
| accuracy | 1.3097361419113178 | (*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
| 76.0ms | 256× | 0 | valid |
Compiled 95 to 18 computations (81.1% saved)
ival-div: 32.0ms (52.4% of total)ival-mult: 29.0ms (47.5% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| Inputs |
|---|
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(/.f64 a2 b2) |
(/.f64 a1 b1) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(/.f64 (/.f64 a1 b2) b1) |
(/.f64 a1 b2) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(/.f64 (/.f64 a2 b2) b1) |
(/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
(*.f64 (/.f64 a1 b1) a2) |
(/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
(*.f64 (/.f64 a1 b2) a2) |
| Outputs |
|---|
(/ (* a1 a2) (* b1 b2)) |
(/ a1 b1) |
(/ a1 (* b1 b2)) |
(/ a1 b2) |
(/ (* a1 a2) b1) |
(/ (* a1 a2) b2) |
(/ a2 b2) |
(/ a2 (* b1 b2)) |
12 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 21.0ms | a1 | @ | 0 | ((* (/ a2 b2) (/ a1 b1)) (/ a2 b2) (/ a1 b1) (* (/ (/ a1 b2) b1) a2) (/ (/ a1 b2) b1) (/ a1 b2) (* (/ (/ a2 b2) b1) a1) (/ (/ a2 b2) b1) (/ (* (/ a1 b1) a2) b2) (* (/ a1 b1) a2) (/ (* (/ a1 b2) a2) b1) (* (/ a1 b2) a2)) |
| 3.0ms | a1 | @ | -inf | ((* (/ a2 b2) (/ a1 b1)) (/ a2 b2) (/ a1 b1) (* (/ (/ a1 b2) b1) a2) (/ (/ a1 b2) b1) (/ a1 b2) (* (/ (/ a2 b2) b1) a1) (/ (/ a2 b2) b1) (/ (* (/ a1 b1) a2) b2) (* (/ a1 b1) a2) (/ (* (/ a1 b2) a2) b1) (* (/ a1 b2) a2)) |
| 2.0ms | a2 | @ | -inf | ((* (/ a2 b2) (/ a1 b1)) (/ a2 b2) (/ a1 b1) (* (/ (/ a1 b2) b1) a2) (/ (/ a1 b2) b1) (/ a1 b2) (* (/ (/ a2 b2) b1) a1) (/ (/ a2 b2) b1) (/ (* (/ a1 b1) a2) b2) (* (/ a1 b1) a2) (/ (* (/ a1 b2) a2) b1) (* (/ a1 b2) a2)) |
| 2.0ms | a1 | @ | inf | ((* (/ a2 b2) (/ a1 b1)) (/ a2 b2) (/ a1 b1) (* (/ (/ a1 b2) b1) a2) (/ (/ a1 b2) b1) (/ a1 b2) (* (/ (/ a2 b2) b1) a1) (/ (/ a2 b2) b1) (/ (* (/ a1 b1) a2) b2) (* (/ a1 b1) a2) (/ (* (/ a1 b2) a2) b1) (* (/ a1 b2) a2)) |
| 2.0ms | b1 | @ | -inf | ((* (/ a2 b2) (/ a1 b1)) (/ a2 b2) (/ a1 b1) (* (/ (/ a1 b2) b1) a2) (/ (/ a1 b2) b1) (/ a1 b2) (* (/ (/ a2 b2) b1) a1) (/ (/ a2 b2) b1) (/ (* (/ a1 b1) a2) b2) (* (/ a1 b1) a2) (/ (* (/ a1 b2) a2) b1) (* (/ a1 b2) a2)) |
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 14 | 36 |
| 1 | 24 | 36 |
| 2 | 38 | 36 |
| 3 | 41 | 36 |
| 0 | 41 | 36 |
| 1× | iter limit |
| 1× | saturated |
| Inputs |
|---|
(/ (* a1 a2) (* b1 b2)) |
(/ a1 b1) |
(/ a1 (* b1 b2)) |
(/ a1 b2) |
(/ (* a1 a2) b1) |
(/ (* a1 a2) b2) |
(/ a2 b2) |
(/ a2 (* b1 b2)) |
| Outputs |
|---|
(/ (* a1 a2) (* b1 b2)) |
(*.f64 (/.f64 a2 b1) (/.f64 a1 b2)) |
(/ a1 b1) |
(/.f64 a1 b1) |
(/ a1 (* b1 b2)) |
(/.f64 (/.f64 a1 b1) b2) |
(/ a1 b2) |
(/.f64 a1 b2) |
(/ (* a1 a2) b1) |
(*.f64 (/.f64 a2 b1) a1) |
(/ (* a1 a2) b2) |
(*.f64 (/.f64 a1 b2) a2) |
(/ a2 b2) |
(/.f64 a2 b2) |
(/ a2 (* b1 b2)) |
(/.f64 (/.f64 a2 b2) b1) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 16 | 64 |
| 0 | 28 | 64 |
| 1 | 61 | 64 |
| 2 | 183 | 64 |
| 3 | 495 | 64 |
| 4 | 543 | 64 |
| 0 | 543 | 64 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| Inputs |
|---|
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(/.f64 a2 b2) |
(/.f64 a1 b1) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(/.f64 (/.f64 a1 b2) b1) |
(/.f64 a1 b2) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(/.f64 (/.f64 a2 b2) b1) |
(/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
(*.f64 (/.f64 a1 b1) a2) |
(/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
(*.f64 (/.f64 a1 b2) a2) |
| Outputs |
|---|
(*.f64 (/.f64 (neg.f64 a2) b1) (/.f64 (neg.f64 a1) b2)) |
(*.f64 (/.f64 (neg.f64 a1) b1) (/.f64 (neg.f64 a2) b2)) |
(*.f64 (/.f64 a1 (*.f64 b1 (neg.f64 b2))) (neg.f64 a2)) |
(*.f64 (/.f64 (/.f64 (neg.f64 a2) b2) b1) (neg.f64 a1)) |
(*.f64 (/.f64 a2 b1) (/.f64 a1 b2)) |
(*.f64 (/.f64 (neg.f64 a2) b2) (/.f64 (neg.f64 a1) b1)) |
(*.f64 (neg.f64 a2) (/.f64 a1 (*.f64 b1 (neg.f64 b2)))) |
(*.f64 (neg.f64 a1) (/.f64 (/.f64 (neg.f64 a2) b2) b1)) |
(*.f64 (/.f64 (neg.f64 a1) b2) (/.f64 (neg.f64 a2) b1)) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(*.f64 (/.f64 a1 b2) (/.f64 a2 b1)) |
(*.f64 (/.f64 a1 b1) (/.f64 a2 b2)) |
(*.f64 a1 (/.f64 (/.f64 a2 b2) b1)) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(*.f64 a2 (/.f64 (/.f64 a1 b2) b1)) |
(/.f64 (*.f64 (neg.f64 a2) a1) (*.f64 b1 (neg.f64 b2))) |
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a2) b2) a1) (neg.f64 b1)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a2) b1) a1) (neg.f64 b2)) |
(/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
(/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
(neg.f64 (*.f64 (/.f64 a1 (*.f64 b1 (neg.f64 b2))) a2)) |
(/.f64 (neg.f64 a2) (neg.f64 b2)) |
(/.f64 a2 b2) |
(neg.f64 (/.f64 (neg.f64 a2) b2)) |
(/.f64 (neg.f64 a1) (neg.f64 b1)) |
(/.f64 a1 b1) |
(neg.f64 (/.f64 (neg.f64 a1) b1)) |
(*.f64 (/.f64 (neg.f64 a2) b1) (/.f64 (neg.f64 a1) b2)) |
(*.f64 (/.f64 (neg.f64 a1) b1) (/.f64 (neg.f64 a2) b2)) |
(*.f64 (/.f64 a1 (*.f64 b1 (neg.f64 b2))) (neg.f64 a2)) |
(*.f64 (/.f64 (/.f64 (neg.f64 a2) b2) b1) (neg.f64 a1)) |
(*.f64 (/.f64 a2 b1) (/.f64 a1 b2)) |
(*.f64 (/.f64 (neg.f64 a2) b2) (/.f64 (neg.f64 a1) b1)) |
(*.f64 (neg.f64 a2) (/.f64 a1 (*.f64 b1 (neg.f64 b2)))) |
(*.f64 (neg.f64 a1) (/.f64 (/.f64 (neg.f64 a2) b2) b1)) |
(*.f64 (/.f64 (neg.f64 a1) b2) (/.f64 (neg.f64 a2) b1)) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(*.f64 (/.f64 a1 b2) (/.f64 a2 b1)) |
(*.f64 (/.f64 a1 b1) (/.f64 a2 b2)) |
(*.f64 a1 (/.f64 (/.f64 a2 b2) b1)) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(*.f64 a2 (/.f64 (/.f64 a1 b2) b1)) |
(/.f64 (*.f64 (neg.f64 a2) a1) (*.f64 b1 (neg.f64 b2))) |
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a2) b2) a1) (neg.f64 b1)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a2) b1) a1) (neg.f64 b2)) |
(/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
(/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
(neg.f64 (*.f64 (/.f64 a1 (*.f64 b1 (neg.f64 b2))) a2)) |
(/.f64 (/.f64 (neg.f64 a1) b1) (neg.f64 b2)) |
(/.f64 (neg.f64 a1) (*.f64 b1 (neg.f64 b2))) |
(/.f64 (/.f64 (neg.f64 a1) b2) (neg.f64 b1)) |
(/.f64 (/.f64 a1 b2) b1) |
(/.f64 (/.f64 a1 b1) b2) |
(/.f64 a1 (*.f64 b1 b2)) |
(neg.f64 (/.f64 a1 (*.f64 b1 (neg.f64 b2)))) |
(/.f64 (neg.f64 a1) (neg.f64 b2)) |
(/.f64 a1 b2) |
(neg.f64 (/.f64 (neg.f64 a1) b2)) |
(*.f64 (/.f64 (neg.f64 a2) b1) (/.f64 (neg.f64 a1) b2)) |
(*.f64 (/.f64 (neg.f64 a1) b1) (/.f64 (neg.f64 a2) b2)) |
(*.f64 (/.f64 a1 (*.f64 b1 (neg.f64 b2))) (neg.f64 a2)) |
(*.f64 (/.f64 (/.f64 (neg.f64 a2) b2) b1) (neg.f64 a1)) |
(*.f64 (/.f64 a2 b1) (/.f64 a1 b2)) |
(*.f64 (/.f64 (neg.f64 a2) b2) (/.f64 (neg.f64 a1) b1)) |
(*.f64 (neg.f64 a2) (/.f64 a1 (*.f64 b1 (neg.f64 b2)))) |
(*.f64 (neg.f64 a1) (/.f64 (/.f64 (neg.f64 a2) b2) b1)) |
(*.f64 (/.f64 (neg.f64 a1) b2) (/.f64 (neg.f64 a2) b1)) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(*.f64 (/.f64 a1 b2) (/.f64 a2 b1)) |
(*.f64 (/.f64 a1 b1) (/.f64 a2 b2)) |
(*.f64 a1 (/.f64 (/.f64 a2 b2) b1)) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(*.f64 a2 (/.f64 (/.f64 a1 b2) b1)) |
(/.f64 (*.f64 (neg.f64 a2) a1) (*.f64 b1 (neg.f64 b2))) |
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a2) b2) a1) (neg.f64 b1)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a2) b1) a1) (neg.f64 b2)) |
(/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
(/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
(neg.f64 (*.f64 (/.f64 a1 (*.f64 b1 (neg.f64 b2))) a2)) |
(/.f64 (/.f64 (neg.f64 a2) b1) (neg.f64 b2)) |
(/.f64 (/.f64 a2 b1) b2) |
(/.f64 (/.f64 (neg.f64 a2) b2) (neg.f64 b1)) |
(/.f64 (neg.f64 a2) (*.f64 b1 (neg.f64 b2))) |
(/.f64 (/.f64 a2 b2) b1) |
(/.f64 a2 (*.f64 b1 b2)) |
(neg.f64 (/.f64 (/.f64 (neg.f64 a2) b2) b1)) |
(*.f64 (/.f64 (neg.f64 a2) b1) (/.f64 (neg.f64 a1) b2)) |
(*.f64 (/.f64 (neg.f64 a1) b1) (/.f64 (neg.f64 a2) b2)) |
(*.f64 (/.f64 a1 (*.f64 b1 (neg.f64 b2))) (neg.f64 a2)) |
(*.f64 (/.f64 (/.f64 (neg.f64 a2) b2) b1) (neg.f64 a1)) |
(*.f64 (/.f64 a2 b1) (/.f64 a1 b2)) |
(*.f64 (/.f64 (neg.f64 a2) b2) (/.f64 (neg.f64 a1) b1)) |
(*.f64 (neg.f64 a2) (/.f64 a1 (*.f64 b1 (neg.f64 b2)))) |
(*.f64 (neg.f64 a1) (/.f64 (/.f64 (neg.f64 a2) b2) b1)) |
(*.f64 (/.f64 (neg.f64 a1) b2) (/.f64 (neg.f64 a2) b1)) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(*.f64 (/.f64 a1 b2) (/.f64 a2 b1)) |
(*.f64 (/.f64 a1 b1) (/.f64 a2 b2)) |
(*.f64 a1 (/.f64 (/.f64 a2 b2) b1)) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(*.f64 a2 (/.f64 (/.f64 a1 b2) b1)) |
(/.f64 (*.f64 (neg.f64 a2) a1) (*.f64 b1 (neg.f64 b2))) |
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a2) b2) a1) (neg.f64 b1)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a2) b1) a1) (neg.f64 b2)) |
(/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
(/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
(neg.f64 (*.f64 (/.f64 a1 (*.f64 b1 (neg.f64 b2))) a2)) |
(*.f64 (/.f64 (neg.f64 a2) b1) (neg.f64 a1)) |
(*.f64 (/.f64 (neg.f64 a1) b1) (neg.f64 a2)) |
(*.f64 (/.f64 a2 b1) a1) |
(*.f64 (neg.f64 a2) (/.f64 (neg.f64 a1) b1)) |
(*.f64 (neg.f64 a1) (/.f64 (neg.f64 a2) b1)) |
(*.f64 (/.f64 a1 b1) a2) |
(*.f64 a1 (/.f64 a2 b1)) |
(*.f64 a2 (/.f64 a1 b1)) |
(/.f64 (*.f64 (neg.f64 a2) a1) (neg.f64 b1)) |
(/.f64 (*.f64 a1 a2) b1) |
(neg.f64 (*.f64 (/.f64 (neg.f64 a2) b1) a1)) |
(*.f64 (/.f64 (neg.f64 a2) b1) (/.f64 (neg.f64 a1) b2)) |
(*.f64 (/.f64 (neg.f64 a1) b1) (/.f64 (neg.f64 a2) b2)) |
(*.f64 (/.f64 a1 (*.f64 b1 (neg.f64 b2))) (neg.f64 a2)) |
(*.f64 (/.f64 (/.f64 (neg.f64 a2) b2) b1) (neg.f64 a1)) |
(*.f64 (/.f64 a2 b1) (/.f64 a1 b2)) |
(*.f64 (/.f64 (neg.f64 a2) b2) (/.f64 (neg.f64 a1) b1)) |
(*.f64 (neg.f64 a2) (/.f64 a1 (*.f64 b1 (neg.f64 b2)))) |
(*.f64 (neg.f64 a1) (/.f64 (/.f64 (neg.f64 a2) b2) b1)) |
(*.f64 (/.f64 (neg.f64 a1) b2) (/.f64 (neg.f64 a2) b1)) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(*.f64 (/.f64 a1 b2) (/.f64 a2 b1)) |
(*.f64 (/.f64 a1 b1) (/.f64 a2 b2)) |
(*.f64 a1 (/.f64 (/.f64 a2 b2) b1)) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(*.f64 a2 (/.f64 (/.f64 a1 b2) b1)) |
(/.f64 (*.f64 (neg.f64 a2) a1) (*.f64 b1 (neg.f64 b2))) |
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a2) b2) a1) (neg.f64 b1)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a2) b1) a1) (neg.f64 b2)) |
(/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
(/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
(neg.f64 (*.f64 (/.f64 a1 (*.f64 b1 (neg.f64 b2))) a2)) |
(*.f64 (/.f64 (neg.f64 a2) b2) (neg.f64 a1)) |
(*.f64 (neg.f64 a2) (/.f64 (neg.f64 a1) b2)) |
(*.f64 (neg.f64 a1) (/.f64 (neg.f64 a2) b2)) |
(*.f64 (/.f64 (neg.f64 a1) b2) (neg.f64 a2)) |
(*.f64 (/.f64 a1 b2) a2) |
(*.f64 a1 (/.f64 a2 b2)) |
(*.f64 (/.f64 a2 b2) a1) |
(*.f64 a2 (/.f64 a1 b2)) |
(/.f64 (*.f64 (neg.f64 a2) a1) (neg.f64 b2)) |
(/.f64 (*.f64 a1 a2) b2) |
(neg.f64 (*.f64 (/.f64 (neg.f64 a2) b2) a1)) |
Compiled 760 to 172 computations (77.4% saved)
7 alts after pruning (2 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 86 | 2 | 88 |
| Fresh | 2 | 0 | 2 |
| Picked | 1 | 4 | 5 |
| Done | 0 | 1 | 1 |
| Total | 89 | 7 | 96 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 81.3% | (/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
| ✓ | 92.3% | (/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
| ✓ | 86.6% | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
| ✓ | 91.7% | (*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
| ▶ | 86.5% | (*.f64 (/.f64 a2 (*.f64 b1 b2)) a1) |
| ✓ | 98.0% | (*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
| ▶ | 87.6% | (*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
Compiled 49 to 49 computations (0% saved)
| 1× | egg-herbie |
Found 6 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (*.f64 b1 b2) | |
| cost-diff | 0 | (/.f64 a2 (*.f64 b1 b2)) | |
| cost-diff | 0 | (*.f64 (/.f64 a2 (*.f64 b1 b2)) a1) | |
| cost-diff | 0 | (*.f64 b1 b2) | |
| cost-diff | 0 | (/.f64 a1 (*.f64 b1 b2)) | |
| cost-diff | 0 | (*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 38 |
| 0 | 14 | 38 |
| 1 | 25 | 38 |
| 2 | 49 | 38 |
| 3 | 57 | 38 |
| 4 | 57 | 38 |
| 0 | 57 | 38 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| Inputs |
|---|
(*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
(/.f64 a1 (*.f64 b1 b2)) |
a1 |
(*.f64 b1 b2) |
b1 |
b2 |
a2 |
(*.f64 (/.f64 a2 (*.f64 b1 b2)) a1) |
(/.f64 a2 (*.f64 b1 b2)) |
a2 |
(*.f64 b1 b2) |
b1 |
b2 |
a1 |
| Outputs |
|---|
(*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
(*.f64 (/.f64 a2 (*.f64 b2 b1)) a1) |
(/.f64 a1 (*.f64 b1 b2)) |
(/.f64 a1 (*.f64 b2 b1)) |
a1 |
(*.f64 b1 b2) |
(*.f64 b2 b1) |
b1 |
b2 |
a2 |
(*.f64 (/.f64 a2 (*.f64 b1 b2)) a1) |
(*.f64 (/.f64 a2 (*.f64 b2 b1)) a1) |
(/.f64 a2 (*.f64 b1 b2)) |
(/.f64 a2 (*.f64 b2 b1)) |
a2 |
(*.f64 b1 b2) |
(*.f64 b2 b1) |
b1 |
b2 |
a1 |
Found 6 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (*.f64 b1 b2) | |
| accuracy | 4.816452630922271 | (*.f64 (/.f64 a2 (*.f64 b1 b2)) a1) | |
| accuracy | 5.046624096756292 | (/.f64 a2 (*.f64 b1 b2)) | |
| accuracy | 0.0 | (*.f64 b1 b2) | |
| accuracy | 3.889983436795268 | (*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) | |
| accuracy | 6.080728515056149 | (/.f64 a1 (*.f64 b1 b2)) |
| 42.0ms | 256× | 0 | valid |
Compiled 40 to 11 computations (72.5% saved)
ival-mult: 29.0ms (89.9% of total)ival-div: 3.0ms (9.3% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| Inputs |
|---|
(*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
(/.f64 a1 (*.f64 b1 b2)) |
(*.f64 b1 b2) |
(*.f64 (/.f64 a2 (*.f64 b1 b2)) a1) |
(/.f64 a2 (*.f64 b1 b2)) |
| Outputs |
|---|
(/ (* a1 a2) (* b1 b2)) |
(/ a1 (* b1 b2)) |
(/ a2 (* b1 b2)) |
(* b1 b2) |
12 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 2.0ms | b1 | @ | -inf | ((* (/ a1 (* b1 b2)) a2) (/ a1 (* b1 b2)) (* b1 b2) (* (/ a2 (* b1 b2)) a1) (/ a2 (* b1 b2))) |
| 1.0ms | b2 | @ | -inf | ((* (/ a1 (* b1 b2)) a2) (/ a1 (* b1 b2)) (* b1 b2) (* (/ a2 (* b1 b2)) a1) (/ a2 (* b1 b2))) |
| 1.0ms | b1 | @ | inf | ((* (/ a1 (* b1 b2)) a2) (/ a1 (* b1 b2)) (* b1 b2) (* (/ a2 (* b1 b2)) a1) (/ a2 (* b1 b2))) |
| 1.0ms | b2 | @ | inf | ((* (/ a1 (* b1 b2)) a2) (/ a1 (* b1 b2)) (* b1 b2) (* (/ a2 (* b1 b2)) a1) (/ a2 (* b1 b2))) |
| 1.0ms | a1 | @ | -inf | ((* (/ a1 (* b1 b2)) a2) (/ a1 (* b1 b2)) (* b1 b2) (* (/ a2 (* b1 b2)) a1) (/ a2 (* b1 b2))) |
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 20 |
| 1 | 20 | 20 |
| 2 | 37 | 20 |
| 3 | 46 | 20 |
| 4 | 46 | 20 |
| 0 | 46 | 20 |
| 1× | iter limit |
| 1× | saturated |
| Inputs |
|---|
(/ (* a1 a2) (* b1 b2)) |
(/ a1 (* b1 b2)) |
(/ a2 (* b1 b2)) |
(* b1 b2) |
| Outputs |
|---|
(/ (* a1 a2) (* b1 b2)) |
(*.f64 (/.f64 a1 b2) (/.f64 a2 b1)) |
(/ a1 (* b1 b2)) |
(/.f64 a1 (*.f64 b2 b1)) |
(/ a2 (* b1 b2)) |
(/.f64 a2 (*.f64 b2 b1)) |
(* b1 b2) |
(*.f64 b2 b1) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 9 | 27 |
| 0 | 14 | 27 |
| 1 | 30 | 27 |
| 2 | 91 | 27 |
| 3 | 258 | 27 |
| 4 | 425 | 27 |
| 5 | 437 | 27 |
| 0 | 437 | 27 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| Inputs |
|---|
(*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
(/.f64 a1 (*.f64 b1 b2)) |
(*.f64 b1 b2) |
(*.f64 (/.f64 a2 (*.f64 b1 b2)) a1) |
(/.f64 a2 (*.f64 b1 b2)) |
| Outputs |
|---|
(*.f64 (/.f64 (neg.f64 a1) b2) (/.f64 (neg.f64 a2) b1)) |
(*.f64 (/.f64 (neg.f64 a2) b2) (/.f64 (neg.f64 a1) b1)) |
(*.f64 (/.f64 (/.f64 (neg.f64 a1) b1) b2) (neg.f64 a2)) |
(*.f64 (/.f64 (/.f64 (neg.f64 a2) b1) b2) (neg.f64 a1)) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(*.f64 (/.f64 a1 b2) (/.f64 a2 b1)) |
(*.f64 (/.f64 (neg.f64 a1) b1) (/.f64 (neg.f64 a2) b2)) |
(*.f64 (/.f64 (neg.f64 a2) b1) (/.f64 (neg.f64 a1) b2)) |
(*.f64 (/.f64 a2 b1) (/.f64 a1 b2)) |
(*.f64 (/.f64 a1 b1) (/.f64 a2 b2)) |
(*.f64 (neg.f64 a2) (/.f64 (/.f64 (neg.f64 a1) b1) b2)) |
(*.f64 (neg.f64 a1) (/.f64 (/.f64 (neg.f64 a2) b1) b2)) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(*.f64 a2 (/.f64 (/.f64 a1 b2) b1)) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(*.f64 a1 (/.f64 (/.f64 a2 b2) b1)) |
(/.f64 (/.f64 (*.f64 (neg.f64 a2) a1) b2) (neg.f64 b1)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a1) b1) a2) (neg.f64 b2)) |
(/.f64 (*.f64 a2 a1) (*.f64 b2 b1)) |
(/.f64 (*.f64 (/.f64 a2 b2) a1) b1) |
(/.f64 (*.f64 (/.f64 a2 b1) a1) b2) |
(/.f64 (*.f64 (neg.f64 a2) a1) (*.f64 (neg.f64 b2) b1)) |
(neg.f64 (*.f64 (/.f64 (/.f64 (neg.f64 a1) b1) b2) a2)) |
(/.f64 (/.f64 (neg.f64 a1) b2) (neg.f64 b1)) |
(/.f64 (/.f64 a1 b2) b1) |
(/.f64 (/.f64 (neg.f64 a1) b1) (neg.f64 b2)) |
(/.f64 (/.f64 a1 b1) b2) |
(/.f64 (neg.f64 a1) (*.f64 (neg.f64 b2) b1)) |
(/.f64 a1 (*.f64 b2 b1)) |
(neg.f64 (/.f64 (/.f64 (neg.f64 a1) b1) b2)) |
(*.f64 (neg.f64 b2) (neg.f64 b1)) |
(*.f64 (neg.f64 b1) (neg.f64 b2)) |
(*.f64 b2 b1) |
(*.f64 b1 b2) |
(neg.f64 (*.f64 (neg.f64 b2) b1)) |
(*.f64 (/.f64 (neg.f64 a1) b2) (/.f64 (neg.f64 a2) b1)) |
(*.f64 (/.f64 (neg.f64 a2) b2) (/.f64 (neg.f64 a1) b1)) |
(*.f64 (/.f64 (/.f64 (neg.f64 a1) b1) b2) (neg.f64 a2)) |
(*.f64 (/.f64 (/.f64 (neg.f64 a2) b1) b2) (neg.f64 a1)) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(*.f64 (/.f64 a1 b2) (/.f64 a2 b1)) |
(*.f64 (/.f64 (neg.f64 a1) b1) (/.f64 (neg.f64 a2) b2)) |
(*.f64 (/.f64 (neg.f64 a2) b1) (/.f64 (neg.f64 a1) b2)) |
(*.f64 (/.f64 a2 b1) (/.f64 a1 b2)) |
(*.f64 (/.f64 a1 b1) (/.f64 a2 b2)) |
(*.f64 (neg.f64 a2) (/.f64 (/.f64 (neg.f64 a1) b1) b2)) |
(*.f64 (neg.f64 a1) (/.f64 (/.f64 (neg.f64 a2) b1) b2)) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(*.f64 a2 (/.f64 (/.f64 a1 b2) b1)) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(*.f64 a1 (/.f64 (/.f64 a2 b2) b1)) |
(/.f64 (/.f64 (*.f64 (neg.f64 a2) a1) b2) (neg.f64 b1)) |
(/.f64 (*.f64 (/.f64 (neg.f64 a1) b1) a2) (neg.f64 b2)) |
(/.f64 (*.f64 a2 a1) (*.f64 b2 b1)) |
(/.f64 (*.f64 (/.f64 a2 b2) a1) b1) |
(/.f64 (*.f64 (/.f64 a2 b1) a1) b2) |
(/.f64 (*.f64 (neg.f64 a2) a1) (*.f64 (neg.f64 b2) b1)) |
(neg.f64 (*.f64 (/.f64 (/.f64 (neg.f64 a1) b1) b2) a2)) |
(/.f64 (/.f64 (neg.f64 a2) b2) (neg.f64 b1)) |
(/.f64 (/.f64 a2 b2) b1) |
(/.f64 (/.f64 (neg.f64 a2) b1) (neg.f64 b2)) |
(/.f64 (/.f64 a2 b1) b2) |
(/.f64 (neg.f64 a2) (*.f64 (neg.f64 b2) b1)) |
(/.f64 a2 (*.f64 b2 b1)) |
(neg.f64 (/.f64 (/.f64 (neg.f64 a2) b1) b2)) |
Compiled 444 to 110 computations (75.2% saved)
7 alts after pruning (0 fresh and 7 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 52 | 0 | 52 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 2 | 2 |
| Done | 0 | 5 | 5 |
| Total | 52 | 7 | 59 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 81.3% | (/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
| ✓ | 92.3% | (/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
| ✓ | 86.6% | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
| ✓ | 91.7% | (*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
| ✓ | 86.5% | (*.f64 (/.f64 a2 (*.f64 b1 b2)) a1) |
| ✓ | 98.0% | (*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
| ✓ | 87.6% | (*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
Compiled 123 to 80 computations (35% saved)
| Inputs |
|---|
(*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
(*.f64 (/.f64 a2 (*.f64 b1 b2)) a1) |
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
(/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
(/.f64 (*.f64 (/.f64 a1 b2) a2) b1) |
(*.f64 (/.f64 (/.f64 (neg.f64 a1) b1) b2) (neg.f64 a2)) |
(*.f64 (/.f64 (/.f64 (neg.f64 a2) b1) b2) (neg.f64 a1)) |
| Outputs |
|---|
(/.f64 (*.f64 (/.f64 a1 b1) a2) b2) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
7 calls:
| 25.0ms | (*.f64 b1 b2) |
| 3.0ms | a2 |
| 3.0ms | b2 |
| 3.0ms | b1 |
| 3.0ms | a1 |
| Accuracy | Segments | Branch |
|---|---|---|
| 98.0% | 1 | (*.f64 b1 b2) |
| 99.7% | 2 | (*.f64 a1 a2) |
| 98.0% | 1 | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
| 98.0% | 1 | a1 |
| 98.0% | 1 | a2 |
| 98.0% | 1 | b1 |
| 98.0% | 1 | b2 |
Compiled 17 to 33 computations (-94.1% saved)
| Inputs |
|---|
(*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
(*.f64 (/.f64 a2 (*.f64 b1 b2)) a1) |
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(*.f64 (/.f64 (/.f64 a1 b2) b1) a2) |
(*.f64 (/.f64 (/.f64 a2 b2) b1) a1) |
| Outputs |
|---|
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
4 calls:
| 2.0ms | a1 |
| 2.0ms | b2 |
| 2.0ms | (*.f64 a1 a2) |
| 2.0ms | (*.f64 b1 b2) |
| Accuracy | Segments | Branch |
|---|---|---|
| 98.0% | 1 | (*.f64 b1 b2) |
| 98.0% | 1 | a1 |
| 98.0% | 1 | b2 |
| 98.0% | 1 | (*.f64 a1 a2) |
Compiled 8 to 18 computations (-125% saved)
| Inputs |
|---|
(*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
(*.f64 (/.f64 a2 (*.f64 b1 b2)) a1) |
(/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
| Outputs |
|---|
(*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
(*.f64 (/.f64 a2 (*.f64 b1 b2)) a1) |
7 calls:
| 20.0ms | b1 |
| 2.0ms | a2 |
| 2.0ms | b2 |
| 2.0ms | a1 |
| 1.0ms | (*.f64 a1 a2) |
| Accuracy | Segments | Branch |
|---|---|---|
| 91.6% | 3 | (*.f64 a1 a2) |
| 91.6% | 2 | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
| 91.2% | 3 | a2 |
| 90.8% | 2 | b1 |
| 91.6% | 2 | (*.f64 b1 b2) |
| 87.6% | 1 | a1 |
| 89.9% | 2 | b2 |
Compiled 17 to 33 computations (-94.1% saved)
Total -0.0b remaining (-0%)
Threshold costs -0b (-0%)
| Inputs |
|---|
(*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
| Outputs |
|---|
(*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
6 calls:
| 1.0ms | b2 |
| 1.0ms | b1 |
| 1.0ms | a2 |
| 1.0ms | (*.f64 a1 a2) |
| 1.0ms | (*.f64 b1 b2) |
| Accuracy | Segments | Branch |
|---|---|---|
| 87.6% | 1 | a2 |
| 87.6% | 1 | b2 |
| 87.6% | 1 | (*.f64 a1 a2) |
| 87.6% | 1 | b1 |
| 87.6% | 1 | (/.f64 (*.f64 a1 a2) (*.f64 b1 b2)) |
| 87.6% | 1 | (*.f64 b1 b2) |
Compiled 16 to 29 computations (-81.3% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | 1671261167675.5005 | 40126734691647740.0 |
Compiled 10 to 14 computations (-40% saved)
| 1× | binary-search |
| 1× | predicate-same |
| Time | Left | Right |
|---|---|---|
| 13.0ms | 1.447608472118146e-22 | 2.825937171403732e-19 |
| 5.0ms | 128× | 0 | valid |
Compiled 90 to 126 computations (-40% saved)
ival-div: 1.0ms (48.5% of total)ival-mult: 1.0ms (48.5% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 21 | 54 |
| 1× | saturated |
| Inputs |
|---|
(if (<=.f64 (*.f64 a1 a2) #s(literal 2000000000000 binary64)) (/.f64 (*.f64 (/.f64 a1 b1) a2) b2) (*.f64 (/.f64 a2 b2) (/.f64 a1 b1))) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(if (<=.f64 (*.f64 b1 b2) #s(literal 5815372481559007/20769187434139310514121985316880384 binary64)) (*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) (*.f64 (/.f64 a2 (*.f64 b1 b2)) a1)) |
(*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
| Outputs |
|---|
(if (<=.f64 (*.f64 a1 a2) #s(literal 2000000000000 binary64)) (/.f64 (*.f64 (/.f64 a1 b1) a2) b2) (*.f64 (/.f64 a2 b2) (/.f64 a1 b1))) |
(*.f64 (/.f64 a2 b2) (/.f64 a1 b1)) |
(if (<=.f64 (*.f64 b1 b2) #s(literal 5815372481559007/20769187434139310514121985316880384 binary64)) (*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) (*.f64 (/.f64 a2 (*.f64 b1 b2)) a1)) |
(*.f64 (/.f64 a1 (*.f64 b1 b2)) a2) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 16 | 64 |
| 0 | 28 | 64 |
| 1 | 61 | 64 |
| 2 | 183 | 64 |
| 3 | 495 | 64 |
| 4 | 543 | 64 |
| 0 | 543 | 64 |
| 0 | 7 | 13 |
| 0 | 10 | 13 |
| 1 | 22 | 13 |
| 2 | 65 | 13 |
| 3 | 209 | 13 |
| 4 | 548 | 13 |
| 5 | 557 | 13 |
| 0 | 557 | 13 |
| 1× | done |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
Compiled 54 to 21 computations (61.1% saved)
Compiled 376 to 226 computations (39.9% saved)
Loading profile data...