\frac{\left(x \cdot y\right) \cdot z}{\sqrt{z \cdot z - t \cdot a}}\begin{array}{l}
\mathbf{if}\;z \le -1.696983515699775782779959954264589471041 \cdot 10^{105}:\\
\;\;\;\;x \cdot \left(-y\right)\\
\mathbf{elif}\;z \le 7.016332579849616821378684143943451656749 \cdot 10^{58}:\\
\;\;\;\;\frac{x}{\sqrt{z \cdot z - t \cdot a}} \cdot \frac{1}{\frac{\frac{1}{z}}{y}}\\
\mathbf{else}:\\
\;\;\;\;\frac{x \cdot y}{\mathsf{fma}\left(t \cdot \frac{a}{z \cdot z}, \frac{-1}{2}, 1\right)}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r10692440 = x;
double r10692441 = y;
double r10692442 = r10692440 * r10692441;
double r10692443 = z;
double r10692444 = r10692442 * r10692443;
double r10692445 = r10692443 * r10692443;
double r10692446 = t;
double r10692447 = a;
double r10692448 = r10692446 * r10692447;
double r10692449 = r10692445 - r10692448;
double r10692450 = sqrt(r10692449);
double r10692451 = r10692444 / r10692450;
return r10692451;
}
double f(double x, double y, double z, double t, double a) {
double r10692452 = z;
double r10692453 = -1.6969835156997758e+105;
bool r10692454 = r10692452 <= r10692453;
double r10692455 = x;
double r10692456 = y;
double r10692457 = -r10692456;
double r10692458 = r10692455 * r10692457;
double r10692459 = 7.016332579849617e+58;
bool r10692460 = r10692452 <= r10692459;
double r10692461 = r10692452 * r10692452;
double r10692462 = t;
double r10692463 = a;
double r10692464 = r10692462 * r10692463;
double r10692465 = r10692461 - r10692464;
double r10692466 = sqrt(r10692465);
double r10692467 = r10692455 / r10692466;
double r10692468 = 1.0;
double r10692469 = r10692468 / r10692452;
double r10692470 = r10692469 / r10692456;
double r10692471 = r10692468 / r10692470;
double r10692472 = r10692467 * r10692471;
double r10692473 = r10692455 * r10692456;
double r10692474 = r10692463 / r10692461;
double r10692475 = r10692462 * r10692474;
double r10692476 = -0.5;
double r10692477 = fma(r10692475, r10692476, r10692468);
double r10692478 = r10692473 / r10692477;
double r10692479 = r10692460 ? r10692472 : r10692478;
double r10692480 = r10692454 ? r10692458 : r10692479;
return r10692480;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
| Original | 25.2 |
|---|---|
| Target | 8.0 |
| Herbie | 8.1 |
if z < -1.6969835156997758e+105Initial program 44.1
rmApplied associate-/l*42.0
rmApplied *-un-lft-identity42.0
Applied *-un-lft-identity42.0
Applied sqrt-prod42.0
Applied times-frac42.0
Applied times-frac42.0
Simplified42.0
Taylor expanded around -inf 1.6
Simplified1.6
if -1.6969835156997758e+105 < z < 7.016332579849617e+58Initial program 12.2
rmApplied associate-/l*10.9
rmApplied *-un-lft-identity10.9
Applied *-un-lft-identity10.9
Applied sqrt-prod10.9
Applied times-frac10.9
Applied times-frac10.5
Simplified10.5
rmApplied clear-num10.7
rmApplied *-un-lft-identity10.7
Applied div-inv10.7
Applied times-frac11.4
Applied *-un-lft-identity11.4
Applied times-frac11.4
Applied associate-*r*12.8
Simplified12.8
if 7.016332579849617e+58 < z Initial program 39.0
rmApplied associate-/l*36.5
Taylor expanded around inf 7.3
Simplified2.8
Final simplification8.1
herbie shell --seed 2019168 +o rules:numerics
(FPCore (x y z t a)
:name "Statistics.Math.RootFinding:ridders from math-functions-0.1.5.2"
:herbie-target
(if (< z -3.1921305903852764e+46) (- (* y x)) (if (< z 5.976268120920894e+90) (/ (* x z) (/ (sqrt (- (* z z) (* a t))) y)) (* y x)))
(/ (* (* x y) z) (sqrt (- (* z z) (* t a)))))