\frac{6 \cdot \left(x - 1\right)}{\left(x + 1\right) + 4 \cdot \sqrt{x}}6 \cdot \frac{x - 1}{\mathsf{fma}\left(\sqrt{x}, 4, x + 1\right)}double f(double x) {
double r606386 = 6.0;
double r606387 = x;
double r606388 = 1.0;
double r606389 = r606387 - r606388;
double r606390 = r606386 * r606389;
double r606391 = r606387 + r606388;
double r606392 = 4.0;
double r606393 = sqrt(r606387);
double r606394 = r606392 * r606393;
double r606395 = r606391 + r606394;
double r606396 = r606390 / r606395;
return r606396;
}
double f(double x) {
double r606397 = 6.0;
double r606398 = x;
double r606399 = 1.0;
double r606400 = r606398 - r606399;
double r606401 = sqrt(r606398);
double r606402 = 4.0;
double r606403 = r606398 + r606399;
double r606404 = fma(r606401, r606402, r606403);
double r606405 = r606400 / r606404;
double r606406 = r606397 * r606405;
return r606406;
}




Bits error versus x
| Original | 0.2 |
|---|---|
| Target | 0.0 |
| Herbie | 0.0 |
Initial program 0.2
Simplified0.0
rmApplied div-inv0.1
Simplified0.0
Final simplification0.0
herbie shell --seed 2019323 +o rules:numerics
(FPCore (x)
:name "Data.Approximate.Numerics:blog from approximate-0.2.2.1"
:precision binary64
:herbie-target
(/ 6 (/ (+ (+ x 1) (* 4 (sqrt x))) (- x 1)))
(/ (* 6 (- x 1)) (+ (+ x 1) (* 4 (sqrt x)))))