\frac{x}{y - z \cdot t}\begin{array}{l}
\mathbf{if}\;z \cdot t = -\infty:\\
\;\;\;\;\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\frac{y}{\sqrt[3]{x}} - \frac{\frac{\frac{z}{\sqrt[3]{\sqrt[3]{x}}}}{\sqrt[3]{\sqrt[3]{x}}}}{\sqrt[3]{\sqrt[3]{\sqrt[3]{x}} \cdot \sqrt[3]{\sqrt[3]{x}}}} \cdot \frac{t}{\sqrt[3]{\sqrt[3]{\sqrt[3]{x}}}}}\\
\mathbf{elif}\;z \cdot t \le 3.982214551187210407512533577328782205679 \cdot 10^{305}:\\
\;\;\;\;\frac{x}{y - z \cdot t}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\frac{y}{\sqrt[3]{x}} - \frac{\sqrt[3]{z} \cdot \sqrt[3]{z}}{\sqrt[3]{\sqrt[3]{x}}} \cdot \left(\frac{\sqrt[3]{z}}{\sqrt[3]{\sqrt[3]{x}}} \cdot \frac{t}{\sqrt[3]{\sqrt[3]{x}}}\right)}\\
\end{array}double f(double x, double y, double z, double t) {
double r383389 = x;
double r383390 = y;
double r383391 = z;
double r383392 = t;
double r383393 = r383391 * r383392;
double r383394 = r383390 - r383393;
double r383395 = r383389 / r383394;
return r383395;
}
double f(double x, double y, double z, double t) {
double r383396 = z;
double r383397 = t;
double r383398 = r383396 * r383397;
double r383399 = -inf.0;
bool r383400 = r383398 <= r383399;
double r383401 = x;
double r383402 = cbrt(r383401);
double r383403 = r383402 * r383402;
double r383404 = y;
double r383405 = r383404 / r383402;
double r383406 = cbrt(r383402);
double r383407 = r383396 / r383406;
double r383408 = r383407 / r383406;
double r383409 = r383406 * r383406;
double r383410 = cbrt(r383409);
double r383411 = r383408 / r383410;
double r383412 = cbrt(r383406);
double r383413 = r383397 / r383412;
double r383414 = r383411 * r383413;
double r383415 = r383405 - r383414;
double r383416 = r383403 / r383415;
double r383417 = 3.9822145511872104e+305;
bool r383418 = r383398 <= r383417;
double r383419 = r383404 - r383398;
double r383420 = r383401 / r383419;
double r383421 = cbrt(r383396);
double r383422 = r383421 * r383421;
double r383423 = r383422 / r383406;
double r383424 = r383421 / r383406;
double r383425 = r383397 / r383406;
double r383426 = r383424 * r383425;
double r383427 = r383423 * r383426;
double r383428 = r383405 - r383427;
double r383429 = r383403 / r383428;
double r383430 = r383418 ? r383420 : r383429;
double r383431 = r383400 ? r383416 : r383430;
return r383431;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 2.7 |
|---|---|
| Target | 1.9 |
| Herbie | 1.8 |
if (* z t) < -inf.0Initial program 18.0
rmApplied add-cube-cbrt18.0
Applied associate-/l*18.0
rmApplied div-sub19.5
rmApplied add-cube-cbrt19.5
Applied times-frac11.5
rmApplied add-cube-cbrt11.5
Applied cbrt-prod11.5
Applied *-un-lft-identity11.5
Applied times-frac11.5
Applied associate-*r*11.5
Simplified11.5
if -inf.0 < (* z t) < 3.9822145511872104e+305Initial program 0.1
if 3.9822145511872104e+305 < (* z t) Initial program 21.7
rmApplied add-cube-cbrt21.7
Applied associate-/l*21.7
rmApplied div-sub23.2
rmApplied add-cube-cbrt23.2
Applied times-frac14.5
rmApplied add-cube-cbrt14.5
Applied times-frac14.5
Applied associate-*l*14.5
Final simplification1.8
herbie shell --seed 2019325 +o rules:numerics
(FPCore (x y z t)
:name "Diagrams.Solve.Tridiagonal:solveTriDiagonal from diagrams-solve-0.1, B"
:precision binary64
:herbie-target
(if (< x -1.618195973607049e+50) (/ 1 (- (/ y x) (* (/ z x) t))) (if (< x 2.1378306434876444e+131) (/ x (- y (* z t))) (/ 1 (- (/ y x) (* (/ z x) t)))))
(/ x (- y (* z t))))