\frac{\left(x \cdot y\right) \cdot z}{\sqrt{z \cdot z - t \cdot a}}\begin{array}{l}
\mathbf{if}\;z \le -2.10649338000724949433232669239319553399 \cdot 10^{111}:\\
\;\;\;\;\left(-x\right) \cdot y\\
\mathbf{elif}\;z \le -5.724817248923862073820996612199459744158 \cdot 10^{-277}:\\
\;\;\;\;\frac{1}{\frac{\sqrt{z \cdot z - t \cdot a}}{z \cdot \left(y \cdot x\right)}}\\
\mathbf{elif}\;z \le 5.269881922884741006979772141958737835512 \cdot 10^{-110}:\\
\;\;\;\;x \cdot \frac{y \cdot z}{\sqrt{z \cdot z - t \cdot a}}\\
\mathbf{elif}\;z \le 5.436017192620622397238815607199475065105 \cdot 10^{141}:\\
\;\;\;\;\left(y \cdot x\right) \cdot \frac{z}{\sqrt{z \cdot z - t \cdot a}}\\
\mathbf{else}:\\
\;\;\;\;y \cdot x\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r16948340 = x;
double r16948341 = y;
double r16948342 = r16948340 * r16948341;
double r16948343 = z;
double r16948344 = r16948342 * r16948343;
double r16948345 = r16948343 * r16948343;
double r16948346 = t;
double r16948347 = a;
double r16948348 = r16948346 * r16948347;
double r16948349 = r16948345 - r16948348;
double r16948350 = sqrt(r16948349);
double r16948351 = r16948344 / r16948350;
return r16948351;
}
double f(double x, double y, double z, double t, double a) {
double r16948352 = z;
double r16948353 = -2.1064933800072495e+111;
bool r16948354 = r16948352 <= r16948353;
double r16948355 = x;
double r16948356 = -r16948355;
double r16948357 = y;
double r16948358 = r16948356 * r16948357;
double r16948359 = -5.724817248923862e-277;
bool r16948360 = r16948352 <= r16948359;
double r16948361 = 1.0;
double r16948362 = r16948352 * r16948352;
double r16948363 = t;
double r16948364 = a;
double r16948365 = r16948363 * r16948364;
double r16948366 = r16948362 - r16948365;
double r16948367 = sqrt(r16948366);
double r16948368 = r16948357 * r16948355;
double r16948369 = r16948352 * r16948368;
double r16948370 = r16948367 / r16948369;
double r16948371 = r16948361 / r16948370;
double r16948372 = 5.269881922884741e-110;
bool r16948373 = r16948352 <= r16948372;
double r16948374 = r16948357 * r16948352;
double r16948375 = r16948374 / r16948367;
double r16948376 = r16948355 * r16948375;
double r16948377 = 5.4360171926206224e+141;
bool r16948378 = r16948352 <= r16948377;
double r16948379 = r16948352 / r16948367;
double r16948380 = r16948368 * r16948379;
double r16948381 = r16948378 ? r16948380 : r16948368;
double r16948382 = r16948373 ? r16948376 : r16948381;
double r16948383 = r16948360 ? r16948371 : r16948382;
double r16948384 = r16948354 ? r16948358 : r16948383;
return r16948384;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 25.2 |
|---|---|
| Target | 7.7 |
| Herbie | 6.7 |
if z < -2.1064933800072495e+111Initial program 45.9
rmApplied *-un-lft-identity45.9
Applied sqrt-prod45.9
Applied times-frac43.6
Simplified43.6
rmApplied associate-*l*43.6
Taylor expanded around -inf 1.6
Simplified1.6
if -2.1064933800072495e+111 < z < -5.724817248923862e-277Initial program 10.4
rmApplied clear-num10.7
if -5.724817248923862e-277 < z < 5.269881922884741e-110Initial program 16.3
rmApplied *-un-lft-identity16.3
Applied sqrt-prod16.3
Applied times-frac16.0
Simplified16.0
rmApplied associate-*l*15.4
rmApplied associate-*r/15.3
if 5.269881922884741e-110 < z < 5.4360171926206224e+141Initial program 8.1
rmApplied *-un-lft-identity8.1
Applied sqrt-prod8.1
Applied times-frac4.8
Simplified4.8
if 5.4360171926206224e+141 < z Initial program 51.8
Taylor expanded around inf 1.4
Final simplification6.7
herbie shell --seed 2019200 +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)))))