


Bits error versus x
Results
Initial program 4.2
Simplified0.1
rmApplied flip3-+0.2
Final simplification0.2
herbie shell --seed 2019005 +o rules:numerics
(FPCore (x)
:name "sqrtexp (problem 3.4.4)"
(sqrt (/ (- (exp (* 2 x)) 1) (- (exp x) 1))))
Time bar (total: 2.7m)Debug log
1 calls. Slowest were:
| 146.0ms | (sqrt (/ (- (exp (* 2 x)) 1) (- (exp x) 1))) |
2 alts after pruning (2 fresh and 0 done)
Merged error: 0.3b
Found 2 expressions with local error:
| 0.3b | (sqrt (+ (exp x) 1)) |
| 0.0b | (+ (exp x) 1) |
2 calls. Slowest were:
| 12.0ms | (sqrt (+ (exp x) 1)) |
| 8.0ms | (+ (exp x) 1) |
2 calls. Slowest were:
| 95.0ms | (sqrt (+ (exp x) 1)) |
| 14.0ms | (+ (exp x) 1) |
14 calls. Slowest were:
| 188.0ms | (- (+ (sqrt 2) (+ (* 1/4 (/ (pow x 2) (sqrt 2))) (* 1/2 (/ x (sqrt 2))))) (* 1/8 (/ (pow x 2) (pow (sqrt 2) 3)))) |
| 81.0ms | (sqrt (- (* (exp x) (exp x)) (* 1 1))) |
| 56.0ms | (sqrt (+ (pow (exp x) 3) (pow 1 3))) |
3 alts after pruning (3 fresh and 0 done)
Merged error: 0.2b
Found 4 expressions with local error:
| 4.1b | (- (* 1 1) (* (exp x) 1)) |
| 0.3b | (sqrt (/ (+ (pow (exp x) 3) (pow 1 3)) (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))) |
| 0.2b | (/ (+ (pow (exp x) 3) (pow 1 3)) (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1)))) |
| 0.2b | (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))) |
4 calls. Slowest were:
| 28.0ms | (/ (+ (pow (exp x) 3) (pow 1 3)) (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1)))) |
| 16.0ms | (sqrt (/ (+ (pow (exp x) 3) (pow 1 3)) (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))) |
| 8.0ms | (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))) |
4 calls. Slowest were:
| 123.0ms | (sqrt (/ (+ (pow (exp x) 3) (pow 1 3)) (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))) |
| 78.0ms | (/ (+ (pow (exp x) 3) (pow 1 3)) (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1)))) |
| 26.0ms | (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))) |
| 20.0ms | (- (* 1 1) (* (exp x) 1)) |
98 calls. Slowest were:
| 744.0ms | (sqrt (/ (+ (pow (exp x) 3) (pow 1 3)) (- (* (* (exp x) (exp x)) (* (exp x) (exp x))) (* (- (* 1 1) (* (exp x) 1)) (- (* 1 1) (* (exp x) 1)))))) |
| 407.0ms | (sqrt (/ (+ (pow (exp x) 3) (pow 1 3)) (+ (pow (* (exp x) (exp x)) 3) (pow (- (* 1 1) (* (exp x) 1)) 3)))) |
| 377.0ms | (sqrt (/ (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))) (* (cbrt (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1)))) (cbrt (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))))) |
3 alts after pruning (2 fresh and 1 done)
Merged error: 0.2b
Found 2 expressions with local error:
| 0.3b | (sqrt (+ (exp x) 1)) |
| 0.0b | (+ (exp x) 1) |
2 calls. Slowest were:
| 6.0ms | (sqrt (+ (exp x) 1)) |
| 5.0ms | (+ (exp x) 1) |
2 calls. Slowest were:
| 28.0ms | (sqrt (+ (exp x) 1)) |
| 7.0ms | (+ (exp x) 1) |
14 calls. Slowest were:
| 140.0ms | (- (+ (sqrt 2) (+ (* 1/4 (/ (pow x 2) (sqrt 2))) (* 1/2 (/ x (sqrt 2))))) (* 1/8 (/ (pow x 2) (pow (sqrt 2) 3)))) |
| 37.0ms | (+ x (+ (* 1/2 (pow x 2)) 2)) |
| 35.0ms | (sqrt (- (* (exp x) (exp x)) (* 1 1))) |
3 alts after pruning (1 fresh and 2 done)
Merged error: 0.2b
Found 4 expressions with local error:
| 4.1b | (- (* 1 1) (* (exp x) 1)) |
| 0.3b | (sqrt (/ (/ (+ (pow (exp x) 3) (pow 1 3)) (sqrt (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))) (sqrt (fma (exp x) (expm1 x) 1)))) |
| 0.2b | (/ (/ (+ (pow (exp x) 3) (pow 1 3)) (sqrt (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))) (sqrt (fma (exp x) (expm1 x) 1))) |
| 0.2b | (/ (+ (pow (exp x) 3) (pow 1 3)) (sqrt (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))) |
4 calls. Slowest were:
| 42.0ms | (/ (/ (+ (pow (exp x) 3) (pow 1 3)) (sqrt (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))) (sqrt (fma (exp x) (expm1 x) 1))) |
| 35.0ms | (/ (+ (pow (exp x) 3) (pow 1 3)) (sqrt (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))) |
| 28.0ms | (sqrt (/ (/ (+ (pow (exp x) 3) (pow 1 3)) (sqrt (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))) (sqrt (fma (exp x) (expm1 x) 1)))) |
4 calls. Slowest were:
| 282.0ms | (sqrt (/ (/ (+ (pow (exp x) 3) (pow 1 3)) (sqrt (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))) (sqrt (fma (exp x) (expm1 x) 1)))) |
| 153.0ms | (/ (/ (+ (pow (exp x) 3) (pow 1 3)) (sqrt (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))) (sqrt (fma (exp x) (expm1 x) 1))) |
| 104.0ms | (/ (+ (pow (exp x) 3) (pow 1 3)) (sqrt (+ (* (exp x) (exp x)) (- (* 1 1) (* (exp x) 1))))) |
| 19.0ms | (- (* 1 1) (* (exp x) 1)) |
923 calls. Slowest were:
| 876.0ms | (sqrt (/ (/ (+ (pow (exp x) 3) (pow 1 3)) (sqrt (- (* (* (exp x) (exp x)) (* (exp x) (exp x))) (* (- (* 1 1) (* (exp x) 1)) (- (* 1 1) (* (exp x) 1)))))) (* (cbrt (sqrt (fma (exp x) (expm1 x) 1))) (cbrt (sqrt (fma (exp x) (expm1 x) 1)))))) |
| 808.0ms | (/ (/ (+ (pow (exp x) 3) (pow 1 3)) (sqrt (- (* (* (exp x) (exp x)) (* (exp x) (exp x))) (* (- (* 1 1) (* (exp x) 1)) (- (* 1 1) (* (exp x) 1)))))) (* (cbrt (sqrt (fma (exp x) (expm1 x) 1))) (cbrt (sqrt (fma (exp x) (expm1 x) 1))))) |
| 806.0ms | (/ (+ (pow (exp x) 3) (pow 1 3)) (sqrt (- (* (* (exp x) (exp x)) (* (exp x) (exp x))) (* (- (* 1 1) (* (exp x) 1)) (- (* 1 1) (* (exp x) 1)))))) |
3 alts after pruning (0 fresh and 3 done)
Merged error: 0.2b
0% (0.1b remaining)
Error of 0.2b against oracle of 0.1b and baseline of 0.2b