


Bits error versus v



Bits error versus w



Bits error versus r
Initial program 12.4
Simplified0.3
rmApplied *-un-lft-identity0.3
Applied add-sqr-sqrt0.9
Applied prod-diff0.9
Simplified0.3
Simplified0.3
rmApplied expm1-log1p-u0.4
Final simplification0.4
herbie shell --seed 2019016 +o rules:numerics
(FPCore (v w r)
:name "Rosa's TurbineBenchmark"
(- (- (+ 3 (/ 2 (* r r))) (/ (* (* 0.125 (- 3 (* 2 v))) (* (* (* w w) r) r)) (- 1 v))) 4.5))
Time bar (total: 26.9s)Debug log
| 555× | (pre true 80) |
| 555× | (body real 80) |
| 94.0ms | (- (- (+ 3 (/ 2 (* r r))) (/ (* (* 0.125 (- 3 (* 2 v))) (* (* (* w w) r) r)) (- 1 v))) 4.5) |
2 alts after pruning (2 fresh and 0 done)
Merged error: 0.2b
Found 4 expressions with local error:
| 0.5b | (/ 2 (* r r)) |
| 0.4b | (* (* w r) (* w r)) |
| 0.0b | (fma (/ (fma -2 v 3) (/ (- 1 v) 0.125)) (* (* w r) (* w r)) 4.5) |
| 0.0b | (- (+ 3 (/ 2 (* r r))) (fma (/ (fma -2 v 3) (/ (- 1 v) 0.125)) (* (* w r) (* w r)) 4.5)) |
| 13× | *-un-lft-identity |
| 13× | add-sqr-sqrt |
| 11× | add-cube-cbrt |
| 9× | prod-diff |
| 9× | pow1 |
| 6× | add-log-exp |
| 6× | add-exp-log |
| 6× | add-cbrt-cube |
| 4× | log1p-expm1-u |
| 4× | expm1-log1p-u |
| 3× | fma-neg |
| 2× | fma-udef |
| 1× | difference-of-squares |
| 1× | distribute-lft-out-- |
| 1× | associate--r+ |
| 1× | flip-- |
| 1× | div-inv |
| 1× | cbrt-unprod |
| 1× | pow-prod-up |
| 1× | *-commutative |
| 1× | associate--l+ |
| 1× | prod-exp |
| 1× | pow-prod-down |
| 1× | associate-*l* |
| 1× | associate-*r* |
| 1× | diff-log |
| 1× | flip3-- |
| 1× | pow-plus |
| 1× | frac-2neg |
| 1× | sub-neg |
| 1× | associate-/r* |
| 1× | clear-num |
| 1× | pow2 |
| 26.0ms | (- (+ 3 (/ 2 (* r r))) (fma (/ (fma -2 v 3) (/ (- 1 v) 0.125)) (* (* w r) (* w r)) 4.5)) |
| 8.0ms | (* (* w r) (* w r)) |
| 3.0ms | (/ 2 (* r r)) |
| 0.0ms | (fma (/ (fma -2 v 3) (/ (- 1 v) 0.125)) (* (* w r) (* w r)) 4.5) |
| 84.0ms | (fma (/ (fma -2 v 3) (/ (- 1 v) 0.125)) (* (* w r) (* w r)) 4.5) |
| 82.0ms | (- (+ 3 (/ 2 (* r r))) (fma (/ (fma -2 v 3) (/ (- 1 v) 0.125)) (* (* w r) (* w r)) 4.5)) |
| 18.0ms | (* (* w r) (* w r)) |
| 18.0ms | (/ 2 (* r r)) |
| 1.0s | (* (* (* (* w r) (* w r)) (* w r)) (* (* (* w r) (* w r)) (* w r))) |
| 422.0ms | (- (+ (* 0.125 (/ (* (pow r 2) (pow w 2)) v)) (* 0.125 (/ (* (pow r 2) (pow w 2)) (pow v 2)))) (* 0.25 (* (pow r 2) (pow w 2)))) |
| 421.0ms | (+ (sqrt (+ 3 (/ 2 (* r r)))) (sqrt (fma (/ (fma -2 v 3) (/ (- 1 v) 0.125)) (* (* w r) (* w r)) 4.5))) |
| 393.0ms | (- (sqrt (+ 3 (/ 2 (* r r)))) (sqrt (fma (/ (fma -2 v 3) (/ (- 1 v) 0.125)) (* (* w r) (* w r)) 4.5))) |
| 353.0ms | (- (+ (* 0.125 (/ (* (pow r 2) (pow w 2)) v)) (* 0.125 (/ (* (pow r 2) (pow w 2)) (pow v 2)))) (* 0.25 (* (pow r 2) (pow w 2)))) |
9 alts after pruning (9 fresh and 0 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 0.4b | (* (* w r) (* w r)) |
| 0.2b | (/ (/ 2 r) r) |
| 0.0b | (fma (/ (fma v -2 3) (- 1 v)) (* (* (* w r) (* w r)) (- 0.125)) (+ (+ (- 4.5) 3) (/ (/ 2 r) r))) |
| 0.0b | (/ (fma v -2 3) (- 1 v)) |
| 13× | add-cube-cbrt |
| 13× | *-un-lft-identity |
| 13× | add-sqr-sqrt |
| 9× | times-frac |
| 9× | pow1 |
| 8× | add-exp-log |
| 8× | add-cbrt-cube |
| 7× | associate-/l* |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | expm1-log1p-u |
| 3× | div-inv |
| 3× | associate-/r* |
| 2× | associate-/r/ |
| 2× | frac-2neg |
| 2× | clear-num |
| 1× | associate-/l/ |
| 1× | flip-- |
| 1× | fma-udef |
| 1× | cbrt-unprod |
| 1× | pow-prod-up |
| 1× | *-commutative |
| 1× | prod-exp |
| 1× | pow-prod-down |
| 1× | associate-*l* |
| 1× | associate-*r* |
| 1× | div-exp |
| 1× | flip3-- |
| 1× | pow-plus |
| 1× | cbrt-undiv |
| 1× | pow2 |
| 7.0ms | (* (* w r) (* w r)) |
| 4.0ms | (/ (/ 2 r) r) |
| 3.0ms | (/ (fma v -2 3) (- 1 v)) |
| 0.0ms | (fma (/ (fma v -2 3) (- 1 v)) (* (* (* w r) (* w r)) (- 0.125)) (+ (+ (- 4.5) 3) (/ (/ 2 r) r))) |
| 133.0ms | (fma (/ (fma v -2 3) (- 1 v)) (* (* (* w r) (* w r)) (- 0.125)) (+ (+ (- 4.5) 3) (/ (/ 2 r) r))) |
| 22.0ms | (/ (/ 2 r) r) |
| 16.0ms | (* (* w r) (* w r)) |
| 13.0ms | (/ (fma v -2 3) (- 1 v)) |
| 576.0ms | (* (* (* (* w r) (* w r)) (* w r)) (* (* (* w r) (* w r)) (* w r))) |
| 379.0ms | (- (+ (* 0.125 (/ (* (pow r 2) (pow w 2)) v)) (* 0.125 (/ (* (pow r 2) (pow w 2)) (pow v 2)))) (* 0.25 (* (pow r 2) (pow w 2)))) |
| 293.0ms | (- (+ (* 0.125 (/ (* (pow r 2) (pow w 2)) v)) (* 0.125 (/ (* (pow r 2) (pow w 2)) (pow v 2)))) (* 0.25 (* (pow r 2) (pow w 2)))) |
| 189.0ms | (/ (* (* (fma v -2 3) (fma v -2 3)) (fma v -2 3)) (* (* (- 1 v) (- 1 v)) (- 1 v))) |
| 61.0ms | (- 2 (+ (/ 1 v) (/ 1 (pow v 2)))) |
10 alts after pruning (10 fresh and 0 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 0.5b | (log1p (/ (fma v -2 3) (- 1 v))) |
| 0.4b | (* (* w r) (* w r)) |
| 0.2b | (/ (/ 2 r) r) |
| 0.0b | (fma (expm1 (log1p (/ (fma v -2 3) (- 1 v)))) (* (* (* w r) (* w r)) (- 0.125)) (+ (+ (- 4.5) 3) (/ (/ 2 r) r))) |
| 9× | pow1 |
| 6× | add-exp-log |
| 6× | add-cbrt-cube |
| 5× | add-cube-cbrt |
| 5× | *-un-lft-identity |
| 5× | expm1-log1p-u |
| 5× | add-sqr-sqrt |
| 4× | add-log-exp |
| 4× | associate-/l* |
| 4× | log1p-expm1-u |
| 2× | div-inv |
| 1× | associate-/l/ |
| 1× | fma-udef |
| 1× | cbrt-unprod |
| 1× | pow-prod-up |
| 1× | *-commutative |
| 1× | log1p-expm1 |
| 1× | prod-exp |
| 1× | pow-prod-down |
| 1× | associate-*l* |
| 1× | associate-*r* |
| 1× | pow-plus |
| 1× | frac-2neg |
| 1× | clear-num |
| 1× | log1p-udef |
| 1× | pow2 |
| 7.0ms | (* (* w r) (* w r)) |
| 3.0ms | (/ (/ 2 r) r) |
| 0.0ms | (log1p (/ (fma v -2 3) (- 1 v))) |
| 0.0ms | (fma (expm1 (log1p (/ (fma v -2 3) (- 1 v)))) (* (* (* w r) (* w r)) (- 0.125)) (+ (+ (- 4.5) 3) (/ (/ 2 r) r))) |
| 196.0ms | (fma (expm1 (log1p (/ (fma v -2 3) (- 1 v)))) (* (* (* w r) (* w r)) (- 0.125)) (+ (+ (- 4.5) 3) (/ (/ 2 r) r))) |
| 39.0ms | (log1p (/ (fma v -2 3) (- 1 v))) |
| 27.0ms | (* (* w r) (* w r)) |
| 13.0ms | (/ (/ 2 r) r) |
| 604.0ms | (* (* (* (* w r) (* w r)) (* w r)) (* (* (* w r) (* w r)) (* w r))) |
| 339.0ms | (- (+ (* 0.125 (/ (* (pow r 2) (pow w 2)) v)) (* 0.125 (/ (* (pow r 2) (pow w 2)) (pow v 2)))) (* 0.25 (* (pow r 2) (pow w 2)))) |
| 278.0ms | (- (+ (* 0.125 (/ (* (pow r 2) (pow w 2)) v)) (* 0.125 (/ (* (pow r 2) (pow w 2)) (pow v 2)))) (* 0.25 (* (pow r 2) (pow w 2)))) |
| 260.0ms | (- (log 3) (+ (* 1/3 (/ 1 v)) (* 7/18 (/ 1 (pow v 2))))) |
| 188.0ms | (- (log 3) (+ (* 1/3 (/ 1 v)) (* 7/18 (/ 1 (pow v 2))))) |
11 alts after pruning (10 fresh and 1 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 0.4b | (* (* w r) (* w r)) |
| 0.3b | (cbrt (fma v -2 3)) |
| 0.3b | (cbrt (fma -2 v 3)) |
| 0.3b | (cbrt (fma -2 v 3)) |
| 9× | pow1 |
| 9× | cbrt-prod |
| 7× | add-cube-cbrt |
| 7× | *-un-lft-identity |
| 7× | add-sqr-sqrt |
| 6× | add-exp-log |
| 6× | add-cbrt-cube |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | expm1-log1p-u |
| 3× | pow1/3 |
| 1× | cbrt-unprod |
| 1× | pow-prod-up |
| 1× | *-commutative |
| 1× | prod-exp |
| 1× | pow-prod-down |
| 1× | associate-*l* |
| 1× | associate-*r* |
| 1× | pow-plus |
| 1× | pow2 |
| 4.0ms | (* (* w r) (* w r)) |
| 1.0ms | (cbrt (fma v -2 3)) |
| 1.0ms | (cbrt (fma -2 v 3)) |
| 1.0ms | (cbrt (fma -2 v 3)) |
| 67.0ms | (cbrt (fma -2 v 3)) |
| 60.0ms | (cbrt (fma v -2 3)) |
| 59.0ms | (cbrt (fma -2 v 3)) |
| 23.0ms | (* (* w r) (* w r)) |
| 618.0ms | (* (* (* (* w r) (* w r)) (* w r)) (* (* (* w r) (* w r)) (* w r))) |
| 285.0ms | (- (pow 3 1/3) (+ (* 2/9 (* v (pow 3 1/3))) (* 4/81 (* (pow v 2) (pow 3 1/3))))) |
| 262.0ms | (- (pow 3 1/3) (+ (* 2/9 (* v (pow 3 1/3))) (* 4/81 (* (pow v 2) (pow 3 1/3))))) |
| 261.0ms | (- (exp (* 1/3 (- (log 2) (log (/ -1 v))))) (+ (* 1/2 (/ (exp (* 1/3 (- (log 2) (log (/ -1 v))))) v)) (* 1/4 (/ (exp (* 1/3 (- (log 2) (log (/ -1 v))))) (pow v 2))))) |
| 259.0ms | (- (exp (* 1/3 (- (log 2) (log (/ -1 v))))) (+ (* 1/2 (/ (exp (* 1/3 (- (log 2) (log (/ -1 v))))) v)) (* 1/4 (/ (exp (* 1/3 (- (log 2) (log (/ -1 v))))) (pow v 2))))) |
11 alts after pruning (9 fresh and 2 done)
Merged error: 0.0b
0% (0.3b remaining)
Error of 0.4b against oracle of 0.1b and baseline of 0.4b
| 17261× | (pre true 80) |
| 17261× | (body real 80) |