



Bits error versus re




Bits error versus im
| Original | 37.3 |
|---|---|
| Target | 32.2 |
| Herbie | 13.4 |
Initial program 37.3
Initial simplification13.4
Final simplification13.4
herbie shell --seed 2018365 +o rules:numerics
(FPCore (re im)
:name "math.sqrt on complex, real part"
:herbie-target
(if (< re 0) (* 0.5 (* (sqrt 2) (sqrt (/ (* im im) (- (sqrt (+ (* re re) (* im im))) re))))) (* 0.5 (sqrt (* 2.0 (+ (sqrt (+ (* re re) (* im im))) re)))))
(* 0.5 (sqrt (* 2.0 (+ (sqrt (+ (* re re) (* im im))) re)))))
Time bar (total: 9.6s)Debug log
2 alts after pruning (2 fresh and 0 done)
Merged error: 15.0b
Found 2 expressions with local error:
| 0.5b | (fma (hypot re im) 2.0 (* re 2.0)) |
| 0.2b | (sqrt (fma (hypot re im) 2.0 (* re 2.0))) |
2 calls. Slowest were:
| 1.0ms | (sqrt (fma (hypot re im) 2.0 (* re 2.0))) |
| 0.0ms | (fma (hypot re im) 2.0 (* re 2.0)) |
2 calls. Slowest were:
| 121.0ms | (sqrt (fma (hypot re im) 2.0 (* re 2.0))) |
| 40.0ms | (fma (hypot re im) 2.0 (* re 2.0)) |
10 calls. Slowest were:
| 19.0ms | (sqrt (* (cbrt (fma (hypot re im) 2.0 (* re 2.0))) (cbrt (fma (hypot re im) 2.0 (* re 2.0))))) |
| 18.0ms | (sqrt (sqrt (fma (hypot re im) 2.0 (* re 2.0)))) |
| 9.0ms | (sqrt (fma (hypot re im) 2.0 (* re 2.0))) |
5 alts after pruning (4 fresh and 1 done)
Merged error: 15.0b
Found 4 expressions with local error:
| 0.6b | (cbrt (fma (hypot re im) 2.0 (* re 2.0))) |
| 0.6b | (cbrt (fma (hypot re im) 2.0 (* 2.0 re))) |
| 0.5b | (fma (hypot re im) 2.0 (* re 2.0)) |
| 0.5b | (fma (hypot re im) 2.0 (* 2.0 re)) |
4 calls. Slowest were:
| 1.0ms | (cbrt (fma (hypot re im) 2.0 (* re 2.0))) |
| 1.0ms | (cbrt (fma (hypot re im) 2.0 (* 2.0 re))) |
| 0.0ms | (fma (hypot re im) 2.0 (* re 2.0)) |
4 calls. Slowest were:
| 127.0ms | (cbrt (fma (hypot re im) 2.0 (* re 2.0))) |
| 127.0ms | (cbrt (fma (hypot re im) 2.0 (* 2.0 re))) |
| 54.0ms | (fma (hypot re im) 2.0 (* re 2.0)) |
| 52.0ms | (fma (hypot re im) 2.0 (* 2.0 re)) |
18 calls. Slowest were:
| 214.0ms | (+ (exp (* 1/3 (+ (log im) (log 2.0)))) (+ (* 0.3333333333333333 (* re (exp (* 1/3 (- (log 2.0) (* 2 (log im))))))) (* 0.05555555555555555 (* (pow re 2) (exp (* 1/3 (- (log 2.0) (* 5 (log im))))))))) |
| 157.0ms | (+ (exp (* 1/3 (+ (log im) (log 2.0)))) (+ (* 0.3333333333333333 (* re (exp (* 1/3 (- (log 2.0) (* 2 (log im))))))) (* 0.05555555555555555 (* (pow re 2) (exp (* 1/3 (- (log 2.0) (* 5 (log im))))))))) |
| 119.0ms | (exp (* 1/3 (- (+ (log (/ -1 re)) (log 1.0)) (* 2 (log (/ -1 im)))))) |
7 alts after pruning (5 fresh and 2 done)
Merged error: 15.0b
Found 4 expressions with local error:
| 3.5b | (expm1 (log1p (fma (hypot re im) 2.0 (* re 2.0)))) |
| 0.5b | (fma (hypot re im) 2.0 (* re 2.0)) |
| 0.2b | (log1p (fma (hypot re im) 2.0 (* re 2.0))) |
| 0.2b | (sqrt (expm1 (log1p (fma (hypot re im) 2.0 (* re 2.0))))) |
4 calls. Slowest were:
| 1.0ms | (sqrt (expm1 (log1p (fma (hypot re im) 2.0 (* re 2.0))))) |
| 0.0ms | (log1p (fma (hypot re im) 2.0 (* re 2.0))) |
| 0.0ms | (expm1 (log1p (fma (hypot re im) 2.0 (* re 2.0)))) |
4 calls. Slowest were:
| 205.0ms | (expm1 (log1p (fma (hypot re im) 2.0 (* re 2.0)))) |
| 204.0ms | (sqrt (expm1 (log1p (fma (hypot re im) 2.0 (* re 2.0))))) |
| 66.0ms | (log1p (fma (hypot re im) 2.0 (* re 2.0))) |
| 44.0ms | (fma (hypot re im) 2.0 (* re 2.0)) |
18 calls. Slowest were:
| 326.0ms | (- (+ (* 0.125 (* (sqrt (/ 1 (- (exp (- (log 4.0) (log (/ 1 re)))) 1))) (/ (exp (- (log 4.0) (log (/ 1 re)))) re))) (sqrt (- (exp (- (log 4.0) (log (/ 1 re)))) 1))) (* 0.0078125 (* (sqrt (/ 1 (pow (- (exp (- (log 4.0) (log (/ 1 re)))) 1) 3))) (/ (pow (exp (- (log 4.0) (log (/ 1 re)))) 2) (pow re 2))))) |
| 295.0ms | (- (+ (* 0.25 (/ 1 re)) (log 4.0)) (+ (* 0.03125 (/ 1 (pow re 2))) (log (/ 1 re)))) |
| 161.0ms | (- (+ (* 0.25 (/ (exp (- (log 4.0) (log (/ 1 re)))) re)) (exp (- (log 4.0) (log (/ 1 re))))) 1) |
7 alts after pruning (5 fresh and 2 done)
Merged error: 14.9b
Found 4 expressions with local error:
| 3.1b | (exp (log (cbrt (fma (hypot re im) 2.0 (* 2.0 re))))) |
| 0.6b | (cbrt (fma (hypot re im) 2.0 (* re 2.0))) |
| 0.6b | (cbrt (fma (hypot re im) 2.0 (* 2.0 re))) |
| 0.5b | (fma (hypot re im) 2.0 (* re 2.0)) |
4 calls. Slowest were:
| 3.0ms | (exp (log (cbrt (fma (hypot re im) 2.0 (* 2.0 re))))) |
| 1.0ms | (cbrt (fma (hypot re im) 2.0 (* re 2.0))) |
| 1.0ms | (cbrt (fma (hypot re im) 2.0 (* 2.0 re))) |
4 calls. Slowest were:
| 168.0ms | (exp (log (cbrt (fma (hypot re im) 2.0 (* 2.0 re))))) |
| 159.0ms | (cbrt (fma (hypot re im) 2.0 (* re 2.0))) |
| 133.0ms | (cbrt (fma (hypot re im) 2.0 (* 2.0 re))) |
| 52.0ms | (fma (hypot re im) 2.0 (* re 2.0)) |
30 calls. Slowest were:
| 245.0ms | (+ (exp (* 1/3 (+ (log im) (log 2.0)))) (+ (* 0.3333333333333333 (* re (exp (* 1/3 (- (log 2.0) (* 2 (log im))))))) (* 0.05555555555555555 (* (pow re 2) (exp (* 1/3 (- (log 2.0) (* 5 (log im))))))))) |
| 216.0ms | (+ (exp (* 1/3 (+ (log im) (log 2.0)))) (+ (* 0.3333333333333333 (* re (exp (* 1/3 (- (log 2.0) (* 2 (log im))))))) (* 0.05555555555555555 (* (pow re 2) (exp (* 1/3 (- (log 2.0) (* 5 (log im))))))))) |
| 177.0ms | (+ (exp (* 1/3 (+ (log im) (log 2.0)))) (+ (* 0.3333333333333333 (* re (exp (* 1/3 (- (log 2.0) (* 2 (log im))))))) (* 0.05555555555555555 (* (pow re 2) (exp (* 1/3 (- (log 2.0) (* 5 (log im))))))))) |
7 alts after pruning (5 fresh and 2 done)
Merged error: 14.9b
0% (0.0b remaining)
Error of 13.4b against oracle of 13.4b and baseline of 13.4b