x \cdot \left(\frac{y}{z} - \frac{t}{1 - z}\right)\begin{array}{l}
\mathbf{if}\;t \le -1.77373656942475791 \cdot 10^{-180} \lor \neg \left(t \le 6.2185368398920625 \cdot 10^{-38}\right):\\
\;\;\;\;\left(x \cdot y\right) \cdot \frac{1}{z} + x \cdot \left(-\frac{t}{1 - z}\right)\\
\mathbf{else}:\\
\;\;\;\;x \cdot \frac{y}{z} + \left(x \cdot \left(-t\right)\right) \cdot \frac{1}{1 - z}\\
\end{array}double f(double x, double y, double z, double t) {
double r396075 = x;
double r396076 = y;
double r396077 = z;
double r396078 = r396076 / r396077;
double r396079 = t;
double r396080 = 1.0;
double r396081 = r396080 - r396077;
double r396082 = r396079 / r396081;
double r396083 = r396078 - r396082;
double r396084 = r396075 * r396083;
return r396084;
}
double f(double x, double y, double z, double t) {
double r396085 = t;
double r396086 = -1.773736569424758e-180;
bool r396087 = r396085 <= r396086;
double r396088 = 6.218536839892062e-38;
bool r396089 = r396085 <= r396088;
double r396090 = !r396089;
bool r396091 = r396087 || r396090;
double r396092 = x;
double r396093 = y;
double r396094 = r396092 * r396093;
double r396095 = 1.0;
double r396096 = z;
double r396097 = r396095 / r396096;
double r396098 = r396094 * r396097;
double r396099 = 1.0;
double r396100 = r396099 - r396096;
double r396101 = r396085 / r396100;
double r396102 = -r396101;
double r396103 = r396092 * r396102;
double r396104 = r396098 + r396103;
double r396105 = r396093 / r396096;
double r396106 = r396092 * r396105;
double r396107 = -r396085;
double r396108 = r396092 * r396107;
double r396109 = r396095 / r396100;
double r396110 = r396108 * r396109;
double r396111 = r396106 + r396110;
double r396112 = r396091 ? r396104 : r396111;
return r396112;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 4.4 |
|---|---|
| Target | 4.1 |
| Herbie | 4.4 |
if t < -1.773736569424758e-180 or 6.218536839892062e-38 < t Initial program 3.7
rmApplied sub-neg3.7
Applied distribute-lft-in3.7
rmApplied div-inv3.8
Applied associate-*r*4.4
if -1.773736569424758e-180 < t < 6.218536839892062e-38Initial program 5.7
rmApplied sub-neg5.7
Applied distribute-lft-in5.7
rmApplied div-inv5.7
Applied distribute-lft-neg-in5.7
Applied associate-*r*4.5
Final simplification4.4
herbie shell --seed 2020056 +o rules:numerics
(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 z)))) -7.623226303312042e-196) (* x (- (/ y z) (* t (/ 1 (- 1 z))))) (if (< (* x (- (/ y z) (/ t (- 1 z)))) 1.4133944927702302e-211) (+ (/ (* y x) z) (- (/ (* t x) (- 1 z)))) (* x (- (/ y z) (* t (/ 1 (- 1 z)))))))
(* x (- (/ y z) (/ t (- 1 z)))))