


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
Results
Initial program 4.1
Final simplification4.1
herbie shell --seed 2019022
(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: 2.5m)Debug log
| 79.0ms | 256× | body | 80 | valid |
| 63.0ms | 262× | body | 80 | nan |
| 216.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: 2.7b
Found 4 expressions with local error:
| 5.2b | (/ (* z (sqrt (+ t a))) t) |
| 1.9b | (- (/ (* 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))) |
| 20× | frac-sub |
| 9× | flip-- |
| 9× | flip3-- |
| 8× | associate-*r/ |
| 8× | frac-times |
| 6× | add-log-exp |
| 6× | associate--r+ |
| 6× | add-cube-cbrt |
| 6× | associate-*r* |
| 6× | *-un-lft-identity |
| 6× | add-sqr-sqrt |
| 5× | flip-+ |
| 5× | flip3-+ |
| 4× | add-exp-log |
| 4× | sqrt-div |
| 4× | add-cbrt-cube |
| 4× | pow1 |
| 3× | sqrt-prod |
| 3× | distribute-lft-in |
| 3× | sub-neg |
| 3× | distribute-rgt-in |
| 2× | associate-/l/ |
| 2× | div-inv |
| 2× | associate--l+ |
| 2× | associate-*l/ |
| 2× | frac-2neg |
| 2× | clear-num |
| 1× | associate-/l* |
| 1× | *-commutative |
| 1× | diff-log |
| 1× | associate-/r* |
| 14.0ms | (- (/ (* z (sqrt (+ t a))) t) (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0))))) |
| 4.0ms | (/ (* z (sqrt (+ t a))) t) |
| 3.0ms | (* z (sqrt (+ t a))) |
| 1.0ms | (/ 2.0 (* t 3.0)) |
| 189.0ms | (- (/ (* z (sqrt (+ t a))) t) (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0))))) |
| 61.0ms | (/ (* z (sqrt (+ t a))) t) |
| 39.0ms | (* z (sqrt (+ t a))) |
| 13.0ms | (/ 2.0 (* t 3.0)) |
| 638.0ms | (- (* (* z (sqrt (+ t a))) (* (+ (* b b) (+ (* c c) (* b c))) (+ (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0))))) (* t (* (- (pow b 3) (pow c 3)) (- (* (+ a (/ 5.0 6.0)) (+ a (/ 5.0 6.0))) (* (/ 2.0 (* t 3.0)) (/ 2.0 (* t 3.0))))))) |
| 543.0ms | (* t (* (+ b c) (* (- a (/ 5.0 6.0)) (* t 3.0)))) |
| 525.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))))) |
| 385.0ms | (- (* (* z (sqrt (+ t a))) (* (+ 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 (* (- (* b b) (* c c)) (- (pow (+ a (/ 5.0 6.0)) 3) (pow (/ 2.0 (* t 3.0)) 3))))) |
| 329.0ms | (- (* (* z (sqrt (+ t a))) (* (+ (* b b) (+ (* c c) (* b c))) (* (- a (/ 5.0 6.0)) (* t 3.0)))) (* t (* (- (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))))) |
3 alts after pruning (2 fresh and 1 done)
Merged error: 0b
Found 4 expressions with local error:
| 26.5b | (/ (- (* (* z (sqrt (+ t a))) (* (- a (/ 5.0 6.0)) (* t 3.0))) (* t (* (- b c) (- (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0))))) (* t (* (- a (/ 5.0 6.0)) (* t 3.0)))) |
| 5.6b | (- (* (* z (sqrt (+ t a))) (* (- a (/ 5.0 6.0)) (* t 3.0))) (* t (* (- b c) (- (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0))))) |
| 4.5b | (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) |
| 4.3b | (* t (* (- b c) (- (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0)))) |
| 766× | associate-*l/ |
| 764× | associate-*r/ |
| 524× | frac-sub |
| 498× | flip-- |
| 498× | flip3-- |
| 364× | frac-times |
| 240× | sqrt-div |
| 162× | associate-/l/ |
| 120× | flip-+ |
| 120× | flip3-+ |
| 16× | distribute-lft-in |
| 16× | distribute-rgt-in |
| 9× | sub-neg |
| 8× | associate--r+ |
| 8× | add-exp-log |
| 8× | add-cbrt-cube |
| 7× | add-cube-cbrt |
| 7× | *-un-lft-identity |
| 7× | add-sqr-sqrt |
| 6× | add-log-exp |
| 6× | pow1 |
| 4× | associate-*l* |
| 3× | associate-/l* |
| 3× | times-frac |
| 2× | *-commutative |
| 2× | associate-/r/ |
| 2× | associate-*r* |
| 1× | difference-of-squares |
| 1× | div-inv |
| 1× | cbrt-unprod |
| 1× | prod-exp |
| 1× | pow-prod-down |
| 1× | div-exp |
| 1× | div-sub |
| 1× | diff-log |
| 1× | frac-2neg |
| 1× | associate-/r* |
| 1× | clear-num |
| 1× | cbrt-undiv |
| 119.0ms | (/ (- (* (* z (sqrt (+ t a))) (* (- a (/ 5.0 6.0)) (* t 3.0))) (* t (* (- b c) (- (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0))))) (* t (* (- a (/ 5.0 6.0)) (* t 3.0)))) |
| 101.0ms | (- (* (* z (sqrt (+ t a))) (* (- a (/ 5.0 6.0)) (* t 3.0))) (* t (* (- b c) (- (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0))))) |
| 71.0ms | (* t (* (- b c) (- (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0)))) |
| 11.0ms | (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) |
| 671.0ms | (/ (- (* (* z (sqrt (+ t a))) (* (- a (/ 5.0 6.0)) (* t 3.0))) (* t (* (- b c) (- (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0))))) (* t (* (- a (/ 5.0 6.0)) (* t 3.0)))) |
| 449.0ms | (- (* (* z (sqrt (+ t a))) (* (- a (/ 5.0 6.0)) (* t 3.0))) (* t (* (- b c) (- (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0))))) |
| 136.0ms | (* t (* (- b c) (- (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0)))) |
| 32.0ms | (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) |
| 829.0ms | (* (* (sqrt (+ (* t t) (- (* a a) (* t a)))) (+ a (/ 5.0 6.0))) (* (+ b c) (+ (* (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0))) (+ (* (* (- a (/ 5.0 6.0)) 2.0) (* (- a (/ 5.0 6.0)) 2.0)) (* (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0)))))) |
| 726.0ms | (* (* (sqrt (+ (* t t) (- (* a a) (* t a)))) (+ (* a a) (+ (* (/ 5.0 6.0) (/ 5.0 6.0)) (* a (/ 5.0 6.0))))) (* (+ (* b b) (+ (* c c) (* b c))) (* (+ (* (* a a) (* a a)) (+ (* (* (/ 5.0 6.0) (/ 5.0 6.0)) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))))) (+ (* a a) (+ (* (/ 5.0 6.0) (/ 5.0 6.0)) (* a (/ 5.0 6.0))))))) |
| 706.0ms | (- (* (* (* z (sqrt (+ t a))) (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0))) (* (+ (* b b) (+ (* c c) (* b c))) (+ (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0)))) (* (+ a (/ 5.0 6.0)) (* t (* (- (pow b 3) (pow c 3)) (- (* (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0))) (* (* (- a (/ 5.0 6.0)) 2.0) (* (- a (/ 5.0 6.0)) 2.0))))))) |
| 671.0ms | (* (+ a (/ 5.0 6.0)) (* (+ (* b b) (+ (* c c) (* b c))) (* (+ (* (* a a) (* a a)) (+ (* (* (/ 5.0 6.0) (/ 5.0 6.0)) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))))) (+ (* a a) (+ (* (/ 5.0 6.0) (/ 5.0 6.0)) (* a (/ 5.0 6.0))))))) |
| 612.0ms | (* (+ b c) (+ (* (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0))) (+ (* (* (- a (/ 5.0 6.0)) 2.0) (* (- a (/ 5.0 6.0)) 2.0)) (* (* (- (* a a) (* (/ 5.0 6.0) (/ 5.0 6.0))) (* t 3.0)) (* (- a (/ 5.0 6.0)) 2.0))))) |
3 alts after pruning (1 fresh and 2 done)
Merged error: 0b
Found 4 expressions with local error:
| 0.0b | (exp (* 2.0 (- (* 0.8333333333333334 c) (* (- b c) a)))) |
| 0.0b | (- (* 0.8333333333333334 c) (* (- b c) a)) |
| 0.0b | (* y (exp (* 2.0 (- (* 0.8333333333333334 c) (* (- b c) a))))) |
| 0.0b | (* (- b c) a) |
| 8× | exp-sum |
| 7× | add-log-exp |
| 7× | associate-*r* |
| 6× | add-cube-cbrt |
| 6× | *-un-lft-identity |
| 6× | add-sqr-sqrt |
| 5× | sub-neg |
| 4× | add-exp-log |
| 4× | add-cbrt-cube |
| 4× | distribute-lft-in |
| 4× | pow1 |
| 4× | distribute-rgt-in |
| 3× | associate-*l* |
| 2× | flip-- |
| 2× | *-commutative |
| 2× | associate-*l/ |
| 2× | flip3-- |
| 1× | rem-exp-log |
| 1× | diff-log |
| 1× | exp-prod |
| 5.0ms | (* y (exp (* 2.0 (- (* 0.8333333333333334 c) (* (- b c) a))))) |
| 5.0ms | (* (- b c) a) |
| 4.0ms | (exp (* 2.0 (- (* 0.8333333333333334 c) (* (- b c) a)))) |
| 3.0ms | (- (* 0.8333333333333334 c) (* (- b c) a)) |
| 60.0ms | (* y (exp (* 2.0 (- (* 0.8333333333333334 c) (* (- b c) a))))) |
| 34.0ms | (exp (* 2.0 (- (* 0.8333333333333334 c) (* (- b c) a)))) |
| 29.0ms | (- (* 0.8333333333333334 c) (* (- b c) a)) |
| 24.0ms | (* (- b c) a) |
| 307.0ms | (* (- (* b b) (* c c)) a) |
| 220.0ms | (* (exp (* 2.0 (- (+ (* a c) (* 0.8333333333333334 c)) (* a b)))) y) |
| 214.0ms | (* 2.0 (- (* 0.8333333333333334 c) (* (- b c) a))) |
| 195.0ms | (exp (* 2.0 (- (+ (* a c) (* 0.8333333333333334 c)) (* a b)))) |
| 190.0ms | (* (exp (* 2.0 (- (+ (* a c) (* 0.8333333333333334 c)) (* a b)))) y) |
3 alts after pruning (0 fresh and 3 done)
Merged error: 0b
0% (3.3b remaining)
Error of 4.1b against oracle of 0.8b and baseline of 4.1b
| 2.6s | 7953× | body | 80 | nan |
| 2.3s | 8000× | body | 80 | valid |