\frac{x}{y - z \cdot t}\begin{array}{l}
\mathbf{if}\;y - z \cdot t \le -2.066141103408040992318038433191118152835 \cdot 10^{236}:\\
\;\;\;\;\frac{1}{\frac{y}{x} - \frac{t}{\frac{x}{z}}}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{y - z \cdot t}\\
\end{array}double f(double x, double y, double z, double t) {
double r593550 = x;
double r593551 = y;
double r593552 = z;
double r593553 = t;
double r593554 = r593552 * r593553;
double r593555 = r593551 - r593554;
double r593556 = r593550 / r593555;
return r593556;
}
double f(double x, double y, double z, double t) {
double r593557 = y;
double r593558 = z;
double r593559 = t;
double r593560 = r593558 * r593559;
double r593561 = r593557 - r593560;
double r593562 = -2.066141103408041e+236;
bool r593563 = r593561 <= r593562;
double r593564 = 1.0;
double r593565 = x;
double r593566 = r593557 / r593565;
double r593567 = r593565 / r593558;
double r593568 = r593559 / r593567;
double r593569 = r593566 - r593568;
double r593570 = r593564 / r593569;
double r593571 = r593565 / r593561;
double r593572 = r593563 ? r593570 : r593571;
return r593572;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 2.9 |
|---|---|
| Target | 1.8 |
| Herbie | 2.1 |
if (- y (* z t)) < -2.066141103408041e+236Initial program 9.9
rmApplied clear-num10.2
rmApplied div-sub13.5
Simplified4.8
if -2.066141103408041e+236 < (- y (* z t)) Initial program 1.7
Final simplification2.1
herbie shell --seed 2019208
(FPCore (x y z t)
:name "Diagrams.Solve.Tridiagonal:solveTriDiagonal from diagrams-solve-0.1, B"
:precision binary64
:herbie-target
(if (< x -1.618195973607049e50) (/ 1 (- (/ y x) (* (/ z x) t))) (if (< x 2.13783064348764444e131) (/ x (- y (* z t))) (/ 1 (- (/ y x) (* (/ z x) t)))))
(/ x (- y (* z t))))