



Bits error versus a




Bits error versus b




Bits error versus c
| Original | 33.6 |
|---|---|
| Target | 20.6 |
| Herbie | 7.1 |
if b < -1.7665482787645588e+108Initial program 59.6
Simplified59.6
Taylor expanded around -inf 2.4
Simplified2.4
if -1.7665482787645588e+108 < b < 2.566361082313029e-307Initial program 33.1
Simplified33.1
rmApplied flip--33.2
Applied associate-/l/37.5
Simplified21.1
rmApplied times-frac15.9
Simplified9.4
Simplified9.4
if 2.566361082313029e-307 < b < 8.095749828230367e+95Initial program 9.6
Simplified9.6
rmApplied div-inv9.8
if 8.095749828230367e+95 < b Initial program 42.9
Simplified42.8
rmApplied flip--61.1
Applied associate-/l/61.4
Simplified61.6
rmApplied times-frac61.4
Simplified61.3
Simplified61.3
rmApplied add-sqr-sqrt61.2
Applied fma-neg61.2
Taylor expanded around 0 3.9
Simplified3.9
Final simplification7.1
herbie shell --seed 2019005 +o rules:numerics
(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: 24.3s)Debug log
1 calls. Slowest were:
| 67.0ms | (/ (- (- b) (sqrt (- (* b b) (* 4 (* a c))))) (* 2 a)) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 34.4b
Found 4 expressions with local error:
| 24.3b | (sqrt (fma (* -4 a) c (* b b))) |
| 1.1b | (- (- b) (sqrt (fma (* -4 a) c (* b b)))) |
| 0.1b | (/ (- (- b) (sqrt (fma (* -4 a) c (* b b)))) (* 2 a)) |
| 0.0b | (fma (* -4 a) c (* b b)) |
4 calls. Slowest were:
| 15.0ms | (/ (- (- b) (sqrt (fma (* -4 a) c (* b b)))) (* 2 a)) |
| 5.0ms | (- (- b) (sqrt (fma (* -4 a) c (* b b)))) |
| 1.0ms | (sqrt (fma (* -4 a) c (* b b))) |
4 calls. Slowest were:
| 89.0ms | (/ (- (- b) (sqrt (fma (* -4 a) c (* b b)))) (* 2 a)) |
| 51.0ms | (- (- b) (sqrt (fma (* -4 a) c (* b b)))) |
| 49.0ms | (sqrt (fma (* -4 a) c (* b b))) |
| 47.0ms | (fma (* -4 a) c (* b b)) |
93 calls. Slowest were:
| 262.0ms | (- (* (- b) (- b)) (* (sqrt (fma (* -4 a) c (* b b))) (sqrt (fma (* -4 a) c (* b b))))) |
| 168.0ms | (- (pow (- b) 3) (pow (sqrt (fma (* -4 a) c (* b b))) 3)) |
| 103.0ms | (/ (* (* (- (- b) (sqrt (fma (* -4 a) c (* b b)))) (- (- b) (sqrt (fma (* -4 a) c (* b b))))) (- (- b) (sqrt (fma (* -4 a) c (* b b))))) (* (* (* 2 a) (* 2 a)) (* 2 a))) |
10 alts after pruning (10 fresh and 0 done)
Merged error: 6.4b
Found 4 expressions with local error:
| 24.3b | (sqrt (fma (* -4 a) c (* b b))) |
| 16.9b | (/ (* (* c a) 4) (* (* 2 a) (+ (- b) (sqrt (fma (* -4 a) c (* b b)))))) |
| 1.1b | (+ (- b) (sqrt (fma (* -4 a) c (* b b)))) |
| 0.1b | (* (* 2 a) (+ (- b) (sqrt (fma (* -4 a) c (* b b))))) |
4 calls. Slowest were:
| 19.0ms | (/ (* (* c a) 4) (* (* 2 a) (+ (- b) (sqrt (fma (* -4 a) c (* b b)))))) |
| 16.0ms | (* (* 2 a) (+ (- b) (sqrt (fma (* -4 a) c (* b b))))) |
| 9.0ms | (+ (- b) (sqrt (fma (* -4 a) c (* b b)))) |
4 calls. Slowest were:
| 158.0ms | (/ (* (* c a) 4) (* (* 2 a) (+ (- b) (sqrt (fma (* -4 a) c (* b b)))))) |
| 73.0ms | (+ (- b) (sqrt (fma (* -4 a) c (* b b)))) |
| 72.0ms | (sqrt (fma (* -4 a) c (* b b))) |
| 70.0ms | (* (* 2 a) (+ (- b) (sqrt (fma (* -4 a) c (* b b))))) |
41 calls. Slowest were:
| 1.2s | (/ (* (* (* (* c a) 4) (* (* c a) 4)) (* (* c a) 4)) (* (* (* (* 2 a) (* 2 a)) (* 2 a)) (* (* (+ (- b) (sqrt (fma (* -4 a) c (* b b)))) (+ (- b) (sqrt (fma (* -4 a) c (* b b))))) (+ (- b) (sqrt (fma (* -4 a) c (* b b))))))) |
| 890.0ms | (/ (* (* (* (* c a) 4) (* (* c a) 4)) (* (* c a) 4)) (* (* (* (* 2 a) (+ (- b) (sqrt (fma (* -4 a) c (* b b))))) (* (* 2 a) (+ (- b) (sqrt (fma (* -4 a) c (* b b)))))) (* (* 2 a) (+ (- b) (sqrt (fma (* -4 a) c (* b b))))))) |
| 672.0ms | (- (log (* (* c a) 4)) (+ (log (* 2 a)) (log (+ (- b) (sqrt (fma (* -4 a) c (* b b))))))) |
8 alts after pruning (7 fresh and 1 done)
Merged error: 6.4b
Found 4 expressions with local error:
| 24.3b | (sqrt (fma (* -4 a) c (* b b))) |
| 1.1b | (- (sqrt (fma (* -4 a) c (* b b))) b) |
| 0.2b | (* (/ c 2) (/ 4 (- (sqrt (fma (* -4 a) c (* b b))) b))) |
| 0.1b | (/ 4 (- (sqrt (fma (* -4 a) c (* b b))) b)) |
4 calls. Slowest were:
| 5.0ms | (- (sqrt (fma (* -4 a) c (* b b))) b) |
| 4.0ms | (* (/ c 2) (/ 4 (- (sqrt (fma (* -4 a) c (* b b))) b))) |
| 3.0ms | (/ 4 (- (sqrt (fma (* -4 a) c (* b b))) b)) |
4 calls. Slowest were:
| 172.0ms | (* (/ c 2) (/ 4 (- (sqrt (fma (* -4 a) c (* b b))) b))) |
| 121.0ms | (/ 4 (- (sqrt (fma (* -4 a) c (* b b))) b)) |
| 58.0ms | (sqrt (fma (* -4 a) c (* b b))) |
| 55.0ms | (- (sqrt (fma (* -4 a) c (* b b))) b) |
41 calls. Slowest were:
| 488.0ms | (* (* (* (/ c 2) (/ c 2)) (/ c 2)) (* (* (/ 4 (- (sqrt (fma (* -4 a) c (* b b))) b)) (/ 4 (- (sqrt (fma (* -4 a) c (* b b))) b))) (/ 4 (- (sqrt (fma (* -4 a) c (* b b))) b)))) |
| 208.0ms | (+ (log (/ c 2)) (log (/ 4 (- (sqrt (fma (* -4 a) c (* b b))) b)))) |
| 87.0ms | (* (/ c 2) (/ 4 (- (sqrt (fma (* -4 a) c (* b b))) b))) |
8 alts after pruning (6 fresh and 2 done)
Merged error: 6.4b
Found 4 expressions with local error:
| 24.3b | (sqrt (fma (* -4 a) c (* b b))) |
| 24.3b | (sqrt (fma (* -4 a) c (* b b))) |
| 14.1b | (fma (sqrt (sqrt (fma (* -4 a) c (* b b)))) (sqrt (sqrt (fma (* -4 a) c (* b b)))) (- b)) |
| 0.2b | (* (/ c 2) (/ 4 (fma (sqrt (sqrt (fma (* -4 a) c (* b b)))) (sqrt (sqrt (fma (* -4 a) c (* b b)))) (- b)))) |
4 calls. Slowest were:
| 3.0ms | (* (/ c 2) (/ 4 (fma (sqrt (sqrt (fma (* -4 a) c (* b b)))) (sqrt (sqrt (fma (* -4 a) c (* b b)))) (- b)))) |
| 1.0ms | (sqrt (fma (* -4 a) c (* b b))) |
| 1.0ms | (sqrt (fma (* -4 a) c (* b b))) |
4 calls. Slowest were:
| 314.0ms | (* (/ c 2) (/ 4 (fma (sqrt (sqrt (fma (* -4 a) c (* b b)))) (sqrt (sqrt (fma (* -4 a) c (* b b)))) (- b)))) |
| 308.0ms | (fma (sqrt (sqrt (fma (* -4 a) c (* b b)))) (sqrt (sqrt (fma (* -4 a) c (* b b)))) (- b)) |
| 55.0ms | (sqrt (fma (* -4 a) c (* b b))) |
| 43.0ms | (sqrt (fma (* -4 a) c (* b b))) |
33 calls. Slowest were:
| 490.0ms | (* (* (* (/ c 2) (/ c 2)) (/ c 2)) (* (* (/ 4 (fma (sqrt (sqrt (fma (* -4 a) c (* b b)))) (sqrt (sqrt (fma (* -4 a) c (* b b)))) (- b))) (/ 4 (fma (sqrt (sqrt (fma (* -4 a) c (* b b)))) (sqrt (sqrt (fma (* -4 a) c (* b b)))) (- b)))) (/ 4 (fma (sqrt (sqrt (fma (* -4 a) c (* b b)))) (sqrt (sqrt (fma (* -4 a) c (* b b)))) (- b))))) |
| 364.0ms | (- (* 1/2 (/ (pow (exp (* 1/4 (- (log -4) (+ (log (/ -1 c)) (log (/ -1 a)))))) 4) (* a b))) (+ (* 2 (/ c b)) (* 2 (/ (* c (pow (exp (* 1/4 (- (log -4) (+ (log (/ -1 c)) (log (/ -1 a)))))) 2)) (pow b 2))))) |
| 319.0ms | (- (* 1/2 (/ (pow (exp (* 1/4 (- (log -4) (+ (log (/ 1 a)) (log (/ 1 c)))))) 4) (* a b))) (+ (* 2 (/ c b)) (* 2 (/ (* (pow (exp (* 1/4 (- (log -4) (+ (log (/ 1 a)) (log (/ 1 c)))))) 2) c) (pow b 2))))) |
8 alts after pruning (5 fresh and 3 done)
Merged error: 6.4b
95.2% (1.1b remaining)
Error of 7.1b against oracle of 6.0b and baseline of 29.3b