



Bits error versus a1




Bits error versus a2




Bits error versus b1




Bits error versus b2
Results
| Original | 11.3 |
|---|---|
| Target | 10.7 |
| Herbie | 2.2 |
if (/ (* a1 a2) (* b1 b2)) < -inf.0 or -2.2845054729502e-312 < (/ (* a1 a2) (* b1 b2)) < 4.506587229492748e-292Initial program 17.6
rmApplied times-frac3.2
if -inf.0 < (/ (* a1 a2) (* b1 b2)) < -2.2845054729502e-312 or 4.506587229492748e-292 < (/ (* a1 a2) (* b1 b2)) < 4.736445781412451e+290Initial program 0.7
Taylor expanded around inf 0.7
if 4.736445781412451e+290 < (/ (* a1 a2) (* b1 b2)) Initial program 56.4
Taylor expanded around inf 56.4
rmApplied times-frac7.7
Final simplification2.2
herbie shell --seed 2019022 +o rules:numerics
(FPCore (a1 a2 b1 b2)
:name "Quotient of products"
:herbie-target
(* (/ a1 b1) (/ a2 b2))
(/ (* a1 a2) (* b1 b2)))
Time bar (total: 4.1s)Debug log
| 20.0ms | 313× | body | 80 | valid |
| 38.0ms | (/ (* a1 a2) (* b1 b2)) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 10.5b
Found 1 expressions with local error:
| 10.5b | (/ (* a1 a2) (* b1 b2)) |
| 3× | add-exp-log |
| 3× | add-cbrt-cube |
| 1× | add-log-exp |
| 1× | associate-/l* |
| 1× | div-inv |
| 1× | log1p-expm1-u |
| 1× | add-cube-cbrt |
| 1× | div-exp |
| 1× | times-frac |
| 1× | *-un-lft-identity |
| 1× | frac-2neg |
| 1× | associate-/r* |
| 1× | clear-num |
| 1× | cbrt-undiv |
| 1× | pow1 |
| 1× | expm1-log1p-u |
| 1× | add-sqr-sqrt |
| 3.0ms | (/ (* a1 a2) (* b1 b2)) |
| 21.0ms | (/ (* a1 a2) (* b1 b2)) |
| 136.0ms | (/ (* (* (* a1 a2) (* a1 a2)) (* a1 a2)) (* (* (* b1 b2) (* b1 b2)) (* b1 b2))) |
| 60.0ms | (- (log (* a1 a2)) (log (* b1 b2))) |
| 27.0ms | (/ (* a1 a2) (* b2 b1)) |
| 18.0ms | (/ (* a1 a2) (* b2 b1)) |
| 17.0ms | (/ (* a1 a2) (* b2 b1)) |
7 alts after pruning (7 fresh and 0 done)
Merged error: 0.1b
Found 1 expressions with local error:
| 10.5b | (/ (* a1 a2) (* b2 b1)) |
| 3× | add-exp-log |
| 3× | add-cbrt-cube |
| 1× | add-log-exp |
| 1× | associate-/l* |
| 1× | div-inv |
| 1× | log1p-expm1-u |
| 1× | add-cube-cbrt |
| 1× | div-exp |
| 1× | times-frac |
| 1× | *-un-lft-identity |
| 1× | frac-2neg |
| 1× | associate-/r* |
| 1× | clear-num |
| 1× | cbrt-undiv |
| 1× | pow1 |
| 1× | expm1-log1p-u |
| 1× | add-sqr-sqrt |
| 5.0ms | (/ (* a1 a2) (* b2 b1)) |
| 25.0ms | (/ (* a1 a2) (* b2 b1)) |
| 167.0ms | (/ (* (* (* a1 a2) (* a1 a2)) (* a1 a2)) (* (* (* b2 b1) (* b2 b1)) (* b2 b1))) |
| 46.0ms | (- (log (* a1 a2)) (log (* b2 b1))) |
| 36.0ms | (/ (* a1 a2) (* b2 b1)) |
| 34.0ms | (/ (* a1 a2) (* b2 b1)) |
| 33.0ms | (/ (* a1 a2) (* b2 b1)) |
8 alts after pruning (7 fresh and 1 done)
Merged error: 0.0b
Found 2 expressions with local error:
| 6.5b | (/ (/ (* a1 a2) b1) b2) |
| 4.7b | (/ (* a1 a2) b1) |
| 5× | associate-/l* |
| 3× | div-inv |
| 3× | add-cube-cbrt |
| 3× | *-un-lft-identity |
| 3× | add-sqr-sqrt |
| 2× | add-log-exp |
| 2× | log1p-expm1-u |
| 2× | add-exp-log |
| 2× | add-cbrt-cube |
| 2× | frac-2neg |
| 2× | clear-num |
| 2× | pow1 |
| 2× | expm1-log1p-u |
| 1× | associate-/l/ |
| 4.0ms | (/ (/ (* a1 a2) b1) b2) |
| 2.0ms | (/ (* a1 a2) b1) |
| 22.0ms | (/ (* a1 a2) b1) |
| 19.0ms | (/ (/ (* a1 a2) b1) b2) |
| 35.0ms | (/ (* a1 a2) (* b2 b1)) |
| 26.0ms | (/ (* a1 a2) (* b2 b1)) |
| 22.0ms | (* (cbrt (/ (* a1 a2) b1)) (cbrt (/ (* a1 a2) b1))) |
| 17.0ms | (/ (* a1 a2) (* b2 b1)) |
| 15.0ms | (sqrt (/ (* a1 a2) b1)) |
9 alts after pruning (7 fresh and 2 done)
Merged error: 0.0b
Found 2 expressions with local error:
| 7.4b | (/ (/ (* a1 a2) b2) b1) |
| 5.5b | (/ (* a1 a2) b2) |
| 5× | associate-/l* |
| 3× | div-inv |
| 3× | add-cube-cbrt |
| 3× | *-un-lft-identity |
| 3× | add-sqr-sqrt |
| 2× | add-log-exp |
| 2× | log1p-expm1-u |
| 2× | add-exp-log |
| 2× | add-cbrt-cube |
| 2× | frac-2neg |
| 2× | clear-num |
| 2× | pow1 |
| 2× | expm1-log1p-u |
| 1× | associate-/l/ |
| 8.0ms | (/ (/ (* a1 a2) b2) b1) |
| 4.0ms | (/ (* a1 a2) b2) |
| 27.0ms | (/ (/ (* a1 a2) b2) b1) |
| 12.0ms | (/ (* a1 a2) b2) |
| 23.0ms | (/ (* a1 a2) (* b2 b1)) |
| 21.0ms | (/ (* a1 a2) (* b2 b1)) |
| 17.0ms | (/ (* a1 a2) (* b2 b1)) |
| 14.0ms | (* (cbrt (/ (* a1 a2) b2)) (cbrt (/ (* a1 a2) b2))) |
| 11.0ms | (sqrt (/ (* a1 a2) b2)) |
9 alts after pruning (6 fresh and 3 done)
Merged error: 0.0b
80.8% (2.2b remaining)
Error of 2.2b against oracle of 0.0b and baseline of 11.3b
| 865.0ms | 10005× | body | 80 | valid |