


Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus t



Bits error versus a



Bits error versus b



Bits error versus c
Initial program 3.6
rmApplied add-log-exp7.8
Applied add-log-exp15.3
Applied diff-log15.3
Simplified1.5
Final simplification1.5
herbie shell --seed 2019010 +o rules:numerics
(FPCore (x y z t a b c)
:name "Numeric.SpecFunctions:invIncompleteBetaWorker from math-functions-0.1.5.2"
(/ x (+ x (* y (exp (* 2.0 (- (/ (* z (sqrt (+ t a))) t) (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0)))))))))))
Time bar (total: 48.8s)Debug log
| 268.0ms | (/ x (+ x (* y (exp (* 2.0 (- (/ (* z (sqrt (+ t a))) t) (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0)))))))))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 4.4b
Found 4 expressions with local error:
| 3.3b | (/ (* z (sqrt (+ t a))) t) |
| 3.2b | (- (/ (* z (sqrt (+ t a))) t) (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0))))) |
| 0.3b | (/ 2.0 (* t 3.0)) |
| 0.2b | (* z (sqrt (+ t a))) |
| 30× | associate--r+ |
| 28× | prod-diff |
| 22× | add-cube-cbrt |
| 22× | *-un-lft-identity |
| 22× | add-sqr-sqrt |
| 20× | frac-sub |
| 15× | distribute-lft-in |
| 15× | distribute-rgt-in |
| 10× | div-inv |
| 9× | flip-- |
| 9× | flip3-- |
| 8× | associate-*r/ |
| 8× | frac-times |
| 6× | add-log-exp |
| 6× | associate-*r* |
| 5× | flip-+ |
| 5× | flip3-+ |
| 4× | log1p-expm1-u |
| 4× | add-exp-log |
| 4× | sqrt-div |
| 4× | fma-neg |
| 4× | add-cbrt-cube |
| 4× | pow1 |
| 4× | expm1-log1p-u |
| 3× | sqrt-prod |
| 3× | sub-neg |
| 2× | associate-/l/ |
| 2× | associate--l+ |
| 2× | associate-*l/ |
| 2× | frac-2neg |
| 2× | clear-num |
| 1× | associate-/l* |
| 1× | *-commutative |
| 1× | diff-log |
| 1× | associate-/r* |
| 22.0ms | (- (/ (* z (sqrt (+ t a))) t) (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0))))) |
| 7.0ms | (/ (* z (sqrt (+ t a))) t) |
| 4.0ms | (* z (sqrt (+ t a))) |
| 1.0ms | (/ 2.0 (* t 3.0)) |
| 202.0ms | (- (/ (* z (sqrt (+ t a))) t) (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0))))) |
| 59.0ms | (* z (sqrt (+ t a))) |
| 59.0ms | (/ (* z (sqrt (+ t a))) t) |
| 13.0ms | (/ 2.0 (* t 3.0)) |
| 609.0ms | (* t (* (+ b c) (* (- a (/ 5.0 6.0)) (* t 3.0)))) |
| 594.0ms | (* (- b c) (fma (- (sqrt (/ 2.0 (* t 3.0)))) (sqrt (/ 2.0 (* t 3.0))) (* (sqrt (/ 2.0 (* t 3.0))) (sqrt (/ 2.0 (* t 3.0)))))) |
| 570.0ms | (* (fma (- (sqrt (/ 2.0 (* t 3.0)))) (sqrt (/ 2.0 (* t 3.0))) (* (sqrt (/ 2.0 (* t 3.0))) (sqrt (/ 2.0 (* t 3.0))))) (- b c)) |
| 544.0ms | (- (* (* z (sqrt (+ t a))) (* (+ (* b b) (+ (* c c) (* b c))) (+ (* (+ a (/ 5.0 6.0)) (+ a (/ 5.0 6.0))) (+ (* (/ 2.0 (* t 3.0)) (/ 2.0 (* t 3.0))) (* (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0))))))) (* t (* (- (pow b 3) (pow c 3)) (- (pow (+ a (/ 5.0 6.0)) 3) (pow (/ 2.0 (* t 3.0)) 3))))) |
| 542.0ms | (* (- b c) (- (/ 2.0 (* t 3.0)))) |
2 alts after pruning (2 fresh and 0 done)
Merged error: 0b
Found 4 expressions with local error:
| 6.6b | (/ (sqrt (+ t a)) (/ t z)) |
| 1.6b | (fma (- (- b c)) (- (+ (/ 5.0 6.0) a) (/ 2.0 (* 3.0 t))) (/ (sqrt (+ t a)) (/ t z))) |
| 1.2b | (log (exp (fma (- (- b c)) (- (+ (/ 5.0 6.0) a) (/ 2.0 (* 3.0 t))) (/ (sqrt (+ t a)) (/ t z))))) |
| 0.3b | (/ 2.0 (* 3.0 t)) |
| 24× | times-frac |
| 23× | add-cube-cbrt |
| 23× | *-un-lft-identity |
| 23× | add-sqr-sqrt |
| 15× | sqrt-prod |
| 9× | div-inv |
| 6× | associate-/l* |
| 6× | add-exp-log |
| 6× | add-cbrt-cube |
| 5× | associate-/r* |
| 5× | pow1 |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | log-pow |
| 4× | log-prod |
| 4× | expm1-log1p-u |
| 3× | exp-prod |
| 2× | associate-/l/ |
| 2× | fma-udef |
| 2× | sqrt-div |
| 2× | frac-2neg |
| 2× | clear-num |
| 1× | flip-+ |
| 1× | associate-/r/ |
| 1× | exp-sum |
| 1× | rem-log-exp |
| 1× | div-exp |
| 1× | flip3-+ |
| 1× | cbrt-undiv |
| 4.0ms | (/ (sqrt (+ t a)) (/ t z)) |
| 2.0ms | (log (exp (fma (- (- b c)) (- (+ (/ 5.0 6.0) a) (/ 2.0 (* 3.0 t))) (/ (sqrt (+ t a)) (/ t z))))) |
| 0.0ms | (/ 2.0 (* 3.0 t)) |
| 0.0ms | (fma (- (- b c)) (- (+ (/ 5.0 6.0) a) (/ 2.0 (* 3.0 t))) (/ (sqrt (+ t a)) (/ t z))) |
| 171.0ms | (fma (- (- b c)) (- (+ (/ 5.0 6.0) a) (/ 2.0 (* 3.0 t))) (/ (sqrt (+ t a)) (/ t z))) |
| 137.0ms | (log (exp (fma (- (- b c)) (- (+ (/ 5.0 6.0) a) (/ 2.0 (* 3.0 t))) (/ (sqrt (+ t a)) (/ t z))))) |
| 68.0ms | (/ (sqrt (+ t a)) (/ t z)) |
| 13.0ms | (/ 2.0 (* 3.0 t)) |
| 225.0ms | (/ (* (* (sqrt (+ t a)) (sqrt (+ t a))) (sqrt (+ t a))) (* (* (/ t z) (/ t z)) (/ t z))) |
| 224.0ms | (log (sqrt (exp (fma (- (- b c)) (- (+ (/ 5.0 6.0) a) (/ 2.0 (* 3.0 t))) (/ (sqrt (+ t a)) (/ t z)))))) |
| 191.0ms | (- (* 0.6666666666666666 (/ b t)) (+ (* 0.6666666666666666 (/ c t)) (* 0.8333333333333334 b))) |
| 182.0ms | (sqrt (fma (- (- b c)) (- (+ (/ 5.0 6.0) a) (/ 2.0 (* 3.0 t))) (/ (sqrt (+ t a)) (/ t z)))) |
| 176.0ms | (log (* (cbrt (exp (fma (- (- b c)) (- (+ (/ 5.0 6.0) a) (/ 2.0 (* 3.0 t))) (/ (sqrt (+ t a)) (/ t z))))) (cbrt (exp (fma (- (- b c)) (- (+ (/ 5.0 6.0) a) (/ 2.0 (* 3.0 t))) (/ (sqrt (+ t a)) (/ t z))))))) |
2 alts after pruning (1 fresh and 1 done)
Merged error: 0b
Found 4 expressions with local error:
| 4.2b | (fma (* z (sqrt (+ t a))) (/ 1 t) (- (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0)))))) |
| 0.3b | (/ 2.0 (* t 3.0)) |
| 0.2b | (* z (sqrt (+ t a))) |
| 0.2b | (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0)))) |
| 24× | prod-diff |
| 24× | *-un-lft-identity |
| 24× | add-sqr-sqrt |
| 22× | add-cube-cbrt |
| 15× | distribute-lft-in |
| 15× | distribute-rgt-in |
| 11× | associate-*r* |
| 8× | flip-- |
| 8× | flip3-- |
| 8× | frac-times |
| 7× | div-inv |
| 6× | frac-sub |
| 6× | add-exp-log |
| 6× | associate-*r/ |
| 6× | add-cbrt-cube |
| 6× | pow1 |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | flip-+ |
| 4× | flip3-+ |
| 4× | expm1-log1p-u |
| 3× | sqrt-prod |
| 3× | associate-*l* |
| 2× | *-commutative |
| 2× | associate--l+ |
| 2× | associate-*l/ |
| 2× | sqrt-div |
| 2× | sub-neg |
| 1× | difference-of-squares |
| 1× | distribute-lft-out-- |
| 1× | fma-udef |
| 1× | cbrt-unprod |
| 1× | prod-exp |
| 1× | pow-prod-down |
| 1× | frac-2neg |
| 1× | associate-/r* |
| 1× | clear-num |
| 12.0ms | (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0)))) |
| 2.0ms | (* z (sqrt (+ t a))) |
| 0.0ms | (/ 2.0 (* t 3.0)) |
| 0.0ms | (fma (* z (sqrt (+ t a))) (/ 1 t) (- (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0)))))) |
| 177.0ms | (fma (* z (sqrt (+ t a))) (/ 1 t) (- (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0)))))) |
| 64.0ms | (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0)))) |
| 58.0ms | (* z (sqrt (+ t a))) |
| 15.0ms | (/ 2.0 (* t 3.0)) |
| 750.0ms | (* (+ (* b b) (+ (* c c) (* b c))) (* (- a (/ 5.0 6.0)) (* t 3.0))) |
| 729.0ms | (* (+ b c) (* (+ (* a a) (- (* (/ 5.0 6.0) (/ 5.0 6.0)) (* a (/ 5.0 6.0)))) (* t 3.0))) |
| 636.0ms | (* (- b c) (fma (- (sqrt (/ 2.0 (* t 3.0)))) (sqrt (/ 2.0 (* t 3.0))) (* (sqrt (/ 2.0 (* t 3.0))) (sqrt (/ 2.0 (* t 3.0)))))) |
| 547.0ms | (* (- (pow b 3) (pow c 3)) (- (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0))) |
| 487.0ms | (* (- b c) (fma (- (sqrt (/ 2.0 (* t 3.0)))) (sqrt (/ 2.0 (* t 3.0))) (* (sqrt (/ 2.0 (* t 3.0))) (sqrt (/ 2.0 (* t 3.0)))))) |
2 alts after pruning (0 fresh and 2 done)
Merged error: 0b
0% (1.3b remaining)
Error of 1.5b against oracle of 0.2b and baseline of 1.5b