\frac{x}{y - z \cdot t}\begin{array}{l}
\mathbf{if}\;x \le 3.500414053322566554674071078271460628078 \cdot 10^{149} \lor \neg \left(x \le 3.253127234732810282842347103578009613163 \cdot 10^{245}\right):\\
\;\;\;\;\frac{x}{y - z \cdot t}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{\frac{y}{x} - \frac{t}{x} \cdot z}\\
\end{array}double f(double x, double y, double z, double t) {
double r458179 = x;
double r458180 = y;
double r458181 = z;
double r458182 = t;
double r458183 = r458181 * r458182;
double r458184 = r458180 - r458183;
double r458185 = r458179 / r458184;
return r458185;
}
double f(double x, double y, double z, double t) {
double r458186 = x;
double r458187 = 3.5004140533225666e+149;
bool r458188 = r458186 <= r458187;
double r458189 = 3.2531272347328103e+245;
bool r458190 = r458186 <= r458189;
double r458191 = !r458190;
bool r458192 = r458188 || r458191;
double r458193 = y;
double r458194 = z;
double r458195 = t;
double r458196 = r458194 * r458195;
double r458197 = r458193 - r458196;
double r458198 = r458186 / r458197;
double r458199 = 1.0;
double r458200 = r458193 / r458186;
double r458201 = r458195 / r458186;
double r458202 = r458201 * r458194;
double r458203 = r458200 - r458202;
double r458204 = r458199 / r458203;
double r458205 = r458192 ? r458198 : r458204;
return r458205;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 2.9 |
|---|---|
| Target | 1.6 |
| Herbie | 2.6 |
if x < 3.5004140533225666e+149 or 3.2531272347328103e+245 < x Initial program 2.4
if 3.5004140533225666e+149 < x < 3.2531272347328103e+245Initial program 8.4
rmApplied clear-num8.6
Simplified8.6
rmApplied div-sub8.6
Simplified4.5
Final simplification2.6
herbie shell --seed 2019235
(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))))