



Bits error versus a




Bits error versus b




Bits error versus c
Results
| Original | 33.5 |
|---|---|
| Target | 20.9 |
| Herbie | 7.9 |
if b < -1.8990148416878514e+29Initial program 56.5
Initial simplification56.5
Taylor expanded around -inf 4.6
Simplified4.6
if -1.8990148416878514e+29 < b < -7.496249327445511e-189Initial program 32.6
Initial simplification32.6
rmApplied *-un-lft-identity32.6
Applied *-un-lft-identity32.6
Applied distribute-lft-out--32.6
Applied associate-/l*32.6
rmApplied div-inv32.7
Applied associate-/r*32.7
rmApplied flip--32.8
Applied associate-/r/32.8
Applied add-cube-cbrt33.2
Applied times-frac33.2
Simplified17.7
Simplified17.7
Taylor expanded around -inf 38.4
Simplified10.7
if -7.496249327445511e-189 < b < 1.0994587633517505e+108Initial program 10.8
Initial simplification10.8
rmApplied *-un-lft-identity10.8
Applied *-un-lft-identity10.8
Applied distribute-lft-out--10.8
Applied associate-/l*10.9
if 1.0994587633517505e+108 < b Initial program 46.2
Initial simplification46.2
Taylor expanded around inf 3.5
Final simplification7.9
herbie shell --seed 2018365
(FPCore (a b c)
:name "The quadratic formula (r2)"
:herbie-target
(if (< b 0) (/ c (* a (/ (+ (- b) (sqrt (- (* b b) (* 4 (* a c))))) (* 2 a)))) (/ (- (- b) (sqrt (- (* b b) (* 4 (* a c))))) (* 2 a)))
(/ (- (- b) (sqrt (- (* b b) (* 4 (* a c))))) (* 2 a)))
Time bar (total: 28.6s)Debug log
1 alts after pruning (1 fresh and 0 done)
Merged error: 34.4b
Found 4 expressions with local error:
| 24.1b | (sqrt (+ (* b b) (* -4 (* a c)))) |
| 1.2b | (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))) |
| 0.8b | (+ (* b b) (* -4 (* a c))) |
| 0.1b | (/ (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))) (* 2 a)) |
4 calls. Slowest were:
| 15.0ms | (/ (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))) (* 2 a)) |
| 6.0ms | (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))) |
| 3.0ms | (sqrt (+ (* b b) (* -4 (* a c)))) |
4 calls. Slowest were:
| 88.0ms | (/ (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))) (* 2 a)) |
| 69.0ms | (sqrt (+ (* b b) (* -4 (* a c)))) |
| 63.0ms | (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))) |
| 26.0ms | (+ (* b b) (* -4 (* a c))) |
46 calls. Slowest were:
| 298.0ms | (- (pow (- b) 3) (pow (sqrt (+ (* b b) (* -4 (* a c)))) 3)) |
| 191.0ms | (sqrt (- (* (* b b) (* b b)) (* (* -4 (* a c)) (* -4 (* a c))))) |
| 174.0ms | (- (* (- b) (- b)) (* (sqrt (+ (* b b) (* -4 (* a c)))) (sqrt (+ (* b b) (* -4 (* a c)))))) |
7 alts after pruning (7 fresh and 0 done)
Merged error: 5.9b
Found 4 expressions with local error:
| 24.1b | (sqrt (+ (* b b) (* -4 (* a c)))) |
| 1.2b | (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))) |
| 0.8b | (+ (* b b) (* -4 (* a c))) |
| 0.2b | (/ 1 (/ (* 2 a) (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))))) |
4 calls. Slowest were:
| 8.0ms | (/ 1 (/ (* 2 a) (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))))) |
| 6.0ms | (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))) |
| 3.0ms | (+ (* b b) (* -4 (* a c))) |
4 calls. Slowest were:
| 109.0ms | (/ 1 (/ (* 2 a) (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))))) |
| 58.0ms | (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))) |
| 50.0ms | (sqrt (+ (* b b) (* -4 (* a c)))) |
| 31.0ms | (+ (* b b) (* -4 (* a c))) |
39 calls. Slowest were:
| 265.0ms | (+ (* (- b) (- b)) (+ (* (sqrt (+ (* b b) (* -4 (* a c)))) (sqrt (+ (* b b) (* -4 (* a c))))) (* (- b) (sqrt (+ (* b b) (* -4 (* a c))))))) |
| 148.0ms | (sqrt (+ (pow (* b b) 3) (pow (* -4 (* a c)) 3))) |
| 146.0ms | (sqrt (- (* (* b b) (* b b)) (* (* -4 (* a c)) (* -4 (* a c))))) |
7 alts after pruning (6 fresh and 1 done)
Merged error: 5.9b
Found 4 expressions with local error:
| 24.1b | (sqrt (+ (* b b) (* -4 (* a c)))) |
| 1.2b | (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))) |
| 0.8b | (+ (* b b) (* -4 (* a c))) |
| 0.3b | (/ (/ 1 (* 2 a)) (/ 1 (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))))) |
4 calls. Slowest were:
| 6.0ms | (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))) |
| 5.0ms | (/ (/ 1 (* 2 a)) (/ 1 (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))))) |
| 3.0ms | (+ (* b b) (* -4 (* a c))) |
4 calls. Slowest were:
| 93.0ms | (/ (/ 1 (* 2 a)) (/ 1 (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))))) |
| 65.0ms | (- (- b) (sqrt (+ (* b b) (* -4 (* a c))))) |
| 44.0ms | (+ (* b b) (* -4 (* a c))) |
| 42.0ms | (sqrt (+ (* b b) (* -4 (* a c)))) |
87 calls. Slowest were:
| 664.0ms | (/ (sqrt (/ 1 (* 2 a))) (/ 1 (- (pow (- b) 3) (pow (sqrt (+ (* b b) (* -4 (* a c)))) 3)))) |
| 487.0ms | (/ 1 (/ 1 (- (* (- b) (- b)) (* (sqrt (+ (* b b) (* -4 (* a c)))) (sqrt (+ (* b b) (* -4 (* a c)))))))) |
| 470.0ms | (/ 1 (/ 1 (- (* (- b) (- b)) (* (sqrt (+ (* b b) (* -4 (* a c)))) (sqrt (+ (* b b) (* -4 (* a c)))))))) |
9 alts after pruning (7 fresh and 2 done)
Merged error: 5.9b
Found 4 expressions with local error:
| 24.1b | (sqrt (+ (* (* a c) -4) (* b b))) |
| 11.6b | (* (* c (* a 4)) (* (cbrt (/ 1/2 a)) (cbrt (/ 1/2 a)))) |
| 3.3b | (* (* (* c (* a 4)) (* (cbrt (/ 1/2 a)) (cbrt (/ 1/2 a)))) (/ (cbrt (/ 1/2 a)) (- (sqrt (+ (* (* a c) -4) (* b b))) b))) |
| 1.2b | (- (sqrt (+ (* (* a c) -4) (* b b))) b) |
4 calls. Slowest were:
| 43.0ms | (* (* (* c (* a 4)) (* (cbrt (/ 1/2 a)) (cbrt (/ 1/2 a)))) (/ (cbrt (/ 1/2 a)) (- (sqrt (+ (* (* a c) -4) (* b b))) b))) |
| 16.0ms | (- (sqrt (+ (* (* a c) -4) (* b b))) b) |
| 11.0ms | (* (* c (* a 4)) (* (cbrt (/ 1/2 a)) (cbrt (/ 1/2 a)))) |
4 calls. Slowest were:
| 247.0ms | (* (* (* c (* a 4)) (* (cbrt (/ 1/2 a)) (cbrt (/ 1/2 a)))) (/ (cbrt (/ 1/2 a)) (- (sqrt (+ (* (* a c) -4) (* b b))) b))) |
| 156.0ms | (* (* c (* a 4)) (* (cbrt (/ 1/2 a)) (cbrt (/ 1/2 a)))) |
| 63.0ms | (- (sqrt (+ (* (* a c) -4) (* b b))) b) |
| 43.0ms | (sqrt (+ (* (* a c) -4) (* b b))) |
81 calls. Slowest were:
| 450.0ms | (* (* (* c (* a 4)) (* (cbrt (/ 1/2 a)) (cbrt 1/2))) (/ (cbrt (/ 1/2 a)) (- (sqrt (+ (* (* a c) -4) (* b b))) b))) |
| 364.0ms | (* (* (* c (* a 4)) (* (cbrt 1/2) (cbrt (/ 1/2 a)))) (/ (cbrt (/ 1/2 a)) (- (sqrt (+ (* (* a c) -4) (* b b))) b))) |
| 320.0ms | (* (* (* (* (* c (* a 4)) (* c (* a 4))) (* c (* a 4))) (* (* (* (cbrt (/ 1/2 a)) (cbrt (/ 1/2 a))) (* (cbrt (/ 1/2 a)) (cbrt (/ 1/2 a)))) (* (cbrt (/ 1/2 a)) (cbrt (/ 1/2 a))))) (/ (/ 1/2 a) (* (* (- (sqrt (+ (* (* a c) -4) (* b b))) b) (- (sqrt (+ (* (* a c) -4) (* b b))) b)) (- (sqrt (+ (* (* a c) -4) (* b b))) b)))) |
8 alts after pruning (6 fresh and 2 done)
Merged error: 5.9b
91% (2.2b remaining)
Error of 7.9b against oracle of 5.6b and baseline of 30.2b