\frac{\left(x \cdot y\right) \cdot z}{\sqrt{z \cdot z - t \cdot a}}\begin{array}{l}
\mathbf{if}\;z \le -1.3632525312502413 \cdot 10^{154}:\\
\;\;\;\;-1 \cdot \left(x \cdot y\right)\\
\mathbf{elif}\;z \le 3.2105156078013753 \cdot 10^{110}:\\
\;\;\;\;x \cdot \left(\left(y \cdot \frac{\sqrt[3]{z} \cdot \sqrt[3]{z}}{\sqrt[3]{\sqrt{z \cdot z - t \cdot a}} \cdot \sqrt[3]{\sqrt{z \cdot z - t \cdot a}}}\right) \cdot \frac{\sqrt[3]{z}}{\sqrt[3]{\sqrt{z \cdot z - t \cdot a}}}\right)\\
\mathbf{else}:\\
\;\;\;\;x \cdot y\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r295288 = x;
double r295289 = y;
double r295290 = r295288 * r295289;
double r295291 = z;
double r295292 = r295290 * r295291;
double r295293 = r295291 * r295291;
double r295294 = t;
double r295295 = a;
double r295296 = r295294 * r295295;
double r295297 = r295293 - r295296;
double r295298 = sqrt(r295297);
double r295299 = r295292 / r295298;
return r295299;
}
double f(double x, double y, double z, double t, double a) {
double r295300 = z;
double r295301 = -1.3632525312502413e+154;
bool r295302 = r295300 <= r295301;
double r295303 = -1.0;
double r295304 = x;
double r295305 = y;
double r295306 = r295304 * r295305;
double r295307 = r295303 * r295306;
double r295308 = 3.210515607801375e+110;
bool r295309 = r295300 <= r295308;
double r295310 = cbrt(r295300);
double r295311 = r295310 * r295310;
double r295312 = r295300 * r295300;
double r295313 = t;
double r295314 = a;
double r295315 = r295313 * r295314;
double r295316 = r295312 - r295315;
double r295317 = sqrt(r295316);
double r295318 = cbrt(r295317);
double r295319 = r295318 * r295318;
double r295320 = r295311 / r295319;
double r295321 = r295305 * r295320;
double r295322 = r295310 / r295318;
double r295323 = r295321 * r295322;
double r295324 = r295304 * r295323;
double r295325 = r295309 ? r295324 : r295306;
double r295326 = r295302 ? r295307 : r295325;
return r295326;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 24.9 |
|---|---|
| Target | 7.9 |
| Herbie | 6.2 |
if z < -1.3632525312502413e+154Initial program 54.7
rmApplied *-un-lft-identity54.7
Applied sqrt-prod54.7
Applied times-frac54.3
Simplified54.3
rmApplied associate-*l*54.3
Taylor expanded around -inf 1.2
if -1.3632525312502413e+154 < z < 3.210515607801375e+110Initial program 11.3
rmApplied *-un-lft-identity11.3
Applied sqrt-prod11.3
Applied times-frac9.3
Simplified9.3
rmApplied associate-*l*9.2
rmApplied add-cube-cbrt10.0
Applied add-cube-cbrt9.5
Applied times-frac9.5
Applied associate-*r*8.7
if 3.210515607801375e+110 < z Initial program 44.2
rmApplied *-un-lft-identity44.2
Applied sqrt-prod44.2
Applied times-frac42.0
Simplified42.0
rmApplied associate-*l*42.0
Taylor expanded around inf 2.2
Final simplification6.2
herbie shell --seed 2020034
(FPCore (x y z t a)
:name "Statistics.Math.RootFinding:ridders from math-functions-0.1.5.2"
:precision binary64
: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)))))