



Bits error versus a




Bits error versus b




Bits error versus c
| Original | 33.2 |
|---|---|
| Target | 20.6 |
| Herbie | 13.7 |
if b < -5.4415579011733295e-244Initial program 21.7
Simplified21.7
Taylor expanded around -inf 21.7
Simplified21.8
if -5.4415579011733295e-244 < b < 2.0251889522263652e+136Initial program 31.2
Simplified31.2
rmApplied div-inv31.3
rmApplied flip--31.4
Applied associate-*l/31.4
Simplified14.6
Taylor expanded around inf 8.6
if 2.0251889522263652e+136 < b Initial program 61.0
Simplified61.0
rmApplied div-inv61.0
rmApplied flip--61.1
Applied associate-*l/61.1
Simplified36.1
Taylor expanded around 0 6.8
Final simplification13.7
herbie shell --seed 2019010 +o rules:numerics
(FPCore (a b c)
:name "quadp (p42, positive)"
:herbie-target
(if (< b 0) (/ (+ (- b) (sqrt (- (* b b) (* 4 (* a c))))) (* 2 a)) (/ c (* a (/ (- (- b) (sqrt (- (* b b) (* 4 (* a c))))) (* 2 a)))))
(/ (+ (- b) (sqrt (- (* b b) (* 4 (* a c))))) (* 2 a)))
Time bar (total: 15.7s)Debug log
| 55.0ms | (/ (+ (- b) (sqrt (- (* b b) (* 4 (* a c))))) (* 2 a)) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 32.9b
Found 4 expressions with local error:
| 22.0b | (sqrt (fma (* a c) -4 (* b b))) |
| 1.7b | (- (sqrt (fma (* a c) -4 (* b b))) b) |
| 0.2b | (fma (* a c) -4 (* b b)) |
| 0.1b | (/ (- (sqrt (fma (* a c) -4 (* b b))) b) (* 2 a)) |
| 10× | add-sqr-sqrt |
| 9× | add-cube-cbrt |
| 9× | *-un-lft-identity |
| 6× | sqrt-prod |
| 6× | add-exp-log |
| 6× | fma-neg |
| 6× | add-cbrt-cube |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | pow1 |
| 4× | expm1-log1p-u |
| 3× | associate-/l* |
| 3× | times-frac |
| 2× | associate-/l/ |
| 2× | flip-- |
| 2× | flip3-- |
| 1× | div-inv |
| 1× | fma-udef |
| 1× | div-exp |
| 1× | div-sub |
| 1× | pow1/2 |
| 1× | frac-2neg |
| 1× | sub-neg |
| 1× | associate-/r* |
| 1× | clear-num |
| 1× | rem-sqrt-square |
| 1× | cbrt-undiv |
| 19.0ms | (/ (- (sqrt (fma (* a c) -4 (* b b))) b) (* 2 a)) |
| 10.0ms | (- (sqrt (fma (* a c) -4 (* b b))) b) |
| 2.0ms | (sqrt (fma (* a c) -4 (* b b))) |
| 0.0ms | (fma (* a c) -4 (* b b)) |
| 85.0ms | (sqrt (fma (* a c) -4 (* b b))) |
| 71.0ms | (/ (- (sqrt (fma (* a c) -4 (* b b))) b) (* 2 a)) |
| 69.0ms | (- (sqrt (fma (* a c) -4 (* b b))) b) |
| 29.0ms | (fma (* a c) -4 (* b b)) |
| 703.0ms | (- (* (sqrt (fma (* a c) -4 (* b b))) (sqrt (fma (* a c) -4 (* b b)))) (* b b)) |
| 142.0ms | (- (pow (sqrt (fma (* a c) -4 (* b b))) 3) (pow b 3)) |
| 98.0ms | (/ (* (* (- (sqrt (fma (* a c) -4 (* b b))) b) (- (sqrt (fma (* a c) -4 (* b b))) b)) (- (sqrt (fma (* a c) -4 (* b b))) b)) (* (* (* 2 a) (* 2 a)) (* 2 a))) |
| 58.0ms | (- (log (- (sqrt (fma (* a c) -4 (* b b))) b)) (log (* 2 a))) |
| 40.0ms | (/ (* (cbrt (- (sqrt (fma (* a c) -4 (* b b))) b)) (cbrt (- (sqrt (fma (* a c) -4 (* b b))) b))) 2) |
10 alts after pruning (10 fresh and 0 done)
Merged error: 21.0b
Found 4 expressions with local error:
| 22.0b | (sqrt (fma (* a -4) c (* b b))) |
| 1.7b | (- (sqrt (fma (* a -4) c (* b b))) b) |
| 0.1b | (/ (- (sqrt (fma (* a -4) c (* b b))) b) (* 2 a)) |
| 0.0b | (fma (* a -4) c (* b b)) |
| 10× | add-sqr-sqrt |
| 9× | add-cube-cbrt |
| 9× | *-un-lft-identity |
| 6× | sqrt-prod |
| 6× | add-exp-log |
| 6× | fma-neg |
| 6× | add-cbrt-cube |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | pow1 |
| 4× | expm1-log1p-u |
| 3× | associate-/l* |
| 3× | times-frac |
| 2× | associate-/l/ |
| 2× | flip-- |
| 2× | flip3-- |
| 1× | div-inv |
| 1× | fma-udef |
| 1× | div-exp |
| 1× | div-sub |
| 1× | pow1/2 |
| 1× | frac-2neg |
| 1× | sub-neg |
| 1× | associate-/r* |
| 1× | clear-num |
| 1× | rem-sqrt-square |
| 1× | cbrt-undiv |
| 17.0ms | (/ (- (sqrt (fma (* a -4) c (* b b))) b) (* 2 a)) |
| 10.0ms | (- (sqrt (fma (* a -4) c (* b b))) b) |
| 2.0ms | (sqrt (fma (* a -4) c (* b b))) |
| 0.0ms | (fma (* a -4) c (* b b)) |
| 69.0ms | (/ (- (sqrt (fma (* a -4) c (* b b))) b) (* 2 a)) |
| 56.0ms | (- (sqrt (fma (* a -4) c (* b b))) b) |
| 41.0ms | (sqrt (fma (* a -4) c (* b b))) |
| 31.0ms | (fma (* a -4) c (* b b)) |
| 566.0ms | (- (* (sqrt (fma (* a -4) c (* b b))) (sqrt (fma (* a -4) c (* b b)))) (* b b)) |
| 105.0ms | (- (pow (sqrt (fma (* a -4) c (* b b))) 3) (pow b 3)) |
| 94.0ms | (/ (* (* (- (sqrt (fma (* a -4) c (* b b))) b) (- (sqrt (fma (* a -4) c (* b b))) b)) (- (sqrt (fma (* a -4) c (* b b))) b)) (* (* (* 2 a) (* 2 a)) (* 2 a))) |
| 80.0ms | (- (log (- (sqrt (fma (* a -4) c (* b b))) b)) (log (* 2 a))) |
| 52.0ms | (- (pow b 2) (* 4 (* a c))) |
10 alts after pruning (9 fresh and 1 done)
Merged error: 21.0b
Found 4 expressions with local error:
| 22.0b | (sqrt (fma (* a c) -4 (* b b))) |
| 1.7b | (- (sqrt (fma (* a c) -4 (* b b))) b) |
| 0.2b | (* (- (sqrt (fma (* a c) -4 (* b b))) b) (/ 1 (* 2 a))) |
| 0.2b | (fma (* a c) -4 (* b b)) |
| 10× | add-sqr-sqrt |
| 9× | add-cube-cbrt |
| 9× | *-un-lft-identity |
| 8× | add-exp-log |
| 6× | sqrt-prod |
| 6× | fma-neg |
| 6× | add-cbrt-cube |
| 6× | pow1 |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | associate-*r* |
| 4× | expm1-log1p-u |
| 3× | flip-- |
| 3× | associate-*l* |
| 3× | flip3-- |
| 2× | prod-exp |
| 2× | associate-*l/ |
| 2× | frac-times |
| 1× | div-inv |
| 1× | fma-udef |
| 1× | cbrt-unprod |
| 1× | *-commutative |
| 1× | un-div-inv |
| 1× | associate-*r/ |
| 1× | pow-prod-down |
| 1× | pow1/2 |
| 1× | sub-neg |
| 1× | rec-exp |
| 1× | rem-sqrt-square |
| 12.0ms | (* (- (sqrt (fma (* a c) -4 (* b b))) b) (/ 1 (* 2 a))) |
| 5.0ms | (- (sqrt (fma (* a c) -4 (* b b))) b) |
| 1.0ms | (sqrt (fma (* a c) -4 (* b b))) |
| 0.0ms | (fma (* a c) -4 (* b b)) |
| 90.0ms | (* (- (sqrt (fma (* a c) -4 (* b b))) b) (/ 1 (* 2 a))) |
| 56.0ms | (- (sqrt (fma (* a c) -4 (* b b))) b) |
| 53.0ms | (sqrt (fma (* a c) -4 (* b b))) |
| 46.0ms | (fma (* a c) -4 (* b b)) |
| 293.0ms | (* (- (* (sqrt (fma (* a c) -4 (* b b))) (sqrt (fma (* a c) -4 (* b b)))) (* b b)) 1) |
| 261.0ms | (* (- (pow (sqrt (fma (* a c) -4 (* b b))) 3) (pow b 3)) 1) |
| 236.0ms | (* (- (sqrt (fma (* a c) -4 (* b b))) b) (/ 1 (* 2 a))) |
| 200.0ms | (* (- (* (sqrt (fma (* a c) -4 (* b b))) (sqrt (fma (* a c) -4 (* b b)))) (* b b)) (/ 1 (* 2 a))) |
| 173.0ms | (* (+ (* (sqrt (fma (* a c) -4 (* b b))) (sqrt (fma (* a c) -4 (* b b)))) (+ (* b b) (* (sqrt (fma (* a c) -4 (* b b))) b))) (* 2 a)) |
9 alts after pruning (7 fresh and 2 done)
Merged error: 20.1b
Found 4 expressions with local error:
| 22.0b | (sqrt (fma (* a c) -4 (* b b))) |
| 14.3b | (* (* a (* -4 c)) (/ 1/2 a)) |
| 0.3b | (+ (sqrt (fma (* a c) -4 (* b b))) b) |
| 0.2b | (fma (* a c) -4 (* b b)) |
| 9× | add-sqr-sqrt |
| 8× | add-cube-cbrt |
| 8× | *-un-lft-identity |
| 6× | sqrt-prod |
| 6× | add-exp-log |
| 6× | add-cbrt-cube |
| 6× | fma-def |
| 6× | pow1 |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | associate-*r* |
| 4× | expm1-log1p-u |
| 1× | div-inv |
| 1× | fma-udef |
| 1× | flip-+ |
| 1× | cbrt-unprod |
| 1× | *-commutative |
| 1× | associate-*r/ |
| 1× | prod-exp |
| 1× | pow-prod-down |
| 1× | associate-*l* |
| 1× | pow1/2 |
| 1× | flip3-+ |
| 1× | rem-sqrt-square |
| 1× | +-commutative |
| 4.0ms | (* (* a (* -4 c)) (/ 1/2 a)) |
| 4.0ms | (+ (sqrt (fma (* a c) -4 (* b b))) b) |
| 1.0ms | (sqrt (fma (* a c) -4 (* b b))) |
| 0.0ms | (fma (* a c) -4 (* b b)) |
| 80.0ms | (+ (sqrt (fma (* a c) -4 (* b b))) b) |
| 59.0ms | (sqrt (fma (* a c) -4 (* b b))) |
| 32.0ms | (fma (* a c) -4 (* b b)) |
| 9.0ms | (* (* a (* -4 c)) (/ 1/2 a)) |
| 247.0ms | (* (* a (* -4 c)) (/ 1/2 a)) |
| 150.0ms | (+ (log (* a (* -4 c))) (log (/ 1/2 a))) |
| 149.0ms | (* (* (* (* a (* -4 c)) (* a (* -4 c))) (* a (* -4 c))) (* (* (/ 1/2 a) (/ 1/2 a)) (/ 1/2 a))) |
| 49.0ms | (- (pow b 2) (* 4 (* a c))) |
| 48.0ms | (- (pow b 2) (* 4 (* a c))) |
9 alts after pruning (6 fresh and 3 done)
Merged error: 12.7b
98.4% (0.3b remaining)
Error of 13.7b against oracle of 13.5b and baseline of 29.4b