x \cdot \left(\frac{y}{z} - \frac{t}{1 - z}\right)
\begin{array}{l}
t_1 := \frac{y}{z} - \frac{t}{1 - z}\\
t_2 := \frac{t \cdot x}{1 - z}\\
\mathbf{if}\;t_1 \leq -1.1584484572454943 \cdot 10^{+250}:\\
\;\;\;\;\frac{y \cdot x}{z} - t_2\\
\mathbf{elif}\;t_1 \leq 5.659525696432036 \cdot 10^{+181}:\\
\;\;\;\;t_1 \cdot x\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(y, \frac{x}{z}, -t_2\right)\\
\end{array}
(FPCore (x y z t) :precision binary64 (* x (- (/ y z) (/ t (- 1.0 z)))))
(FPCore (x y z t)
:precision binary64
(let* ((t_1 (- (/ y z) (/ t (- 1.0 z)))) (t_2 (/ (* t x) (- 1.0 z))))
(if (<= t_1 -1.1584484572454943e+250)
(- (/ (* y x) z) t_2)
(if (<= t_1 5.659525696432036e+181) (* t_1 x) (fma y (/ x z) (- t_2))))))double code(double x, double y, double z, double t) {
return x * ((y / z) - (t / (1.0 - z)));
}
double code(double x, double y, double z, double t) {
double t_1 = (y / z) - (t / (1.0 - z));
double t_2 = (t * x) / (1.0 - z);
double tmp;
if (t_1 <= -1.1584484572454943e+250) {
tmp = ((y * x) / z) - t_2;
} else if (t_1 <= 5.659525696432036e+181) {
tmp = t_1 * x;
} else {
tmp = fma(y, (x / z), -t_2);
}
return tmp;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
| Original | 4.4 |
|---|---|
| Target | 4.1 |
| Herbie | 1.4 |
if (-.f64 (/.f64 y z) (/.f64 t (-.f64 1 z))) < -1.1584484572454943e250Initial program 27.9
Taylor expanded in y around 0 0.3
if -1.1584484572454943e250 < (-.f64 (/.f64 y z) (/.f64 t (-.f64 1 z))) < 5.6595256964320361e181Initial program 1.5
Taylor expanded in y around 0 8.2
Applied add-cube-cbrt_binary648.6
Applied add-cube-cbrt_binary649.1
Applied prod-diff_binary649.1
Simplified5.2
Simplified1.5
if 5.6595256964320361e181 < (-.f64 (/.f64 y z) (/.f64 t (-.f64 1 z))) Initial program 17.1
Taylor expanded in y around 0 1.4
Applied *-un-lft-identity_binary641.4
Applied times-frac_binary641.9
Applied fma-neg_binary641.9
Final simplification1.4
herbie shell --seed 2022117
(FPCore (x y z t)
:name "Numeric.SpecFunctions:invIncompleteBetaWorker from math-functions-0.1.5.2, C"
:precision binary64
:herbie-target
(if (< (* x (- (/ y z) (/ t (- 1.0 z)))) -7.623226303312042e-196) (* x (- (/ y z) (* t (/ 1.0 (- 1.0 z))))) (if (< (* x (- (/ y z) (/ t (- 1.0 z)))) 1.4133944927702302e-211) (+ (/ (* y x) z) (- (/ (* t x) (- 1.0 z)))) (* x (- (/ y z) (* t (/ 1.0 (- 1.0 z)))))))
(* x (- (/ y z) (/ t (- 1.0 z)))))