\frac{\left(x \cdot y\right) \cdot z}{\sqrt{z \cdot z - t \cdot a}}\begin{array}{l}
\mathbf{if}\;z \le -2.099203142812841057267611063629875049796 \cdot 10^{122}:\\
\;\;\;\;\left(-x\right) \cdot y\\
\mathbf{elif}\;z \le 8.801249261765559740247641081984816423417 \cdot 10^{98}:\\
\;\;\;\;\frac{\sqrt[3]{z}}{\sqrt{\sqrt[3]{z \cdot z - a \cdot t}}} \cdot \left(y \cdot \left(\frac{\sqrt[3]{z} \cdot \sqrt[3]{z}}{\left|\sqrt[3]{\sqrt{z \cdot z - a \cdot t}} \cdot \sqrt[3]{\sqrt{z \cdot z - a \cdot t}}\right|} \cdot x\right)\right)\\
\mathbf{else}:\\
\;\;\;\;x \cdot y\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r11242066 = x;
double r11242067 = y;
double r11242068 = r11242066 * r11242067;
double r11242069 = z;
double r11242070 = r11242068 * r11242069;
double r11242071 = r11242069 * r11242069;
double r11242072 = t;
double r11242073 = a;
double r11242074 = r11242072 * r11242073;
double r11242075 = r11242071 - r11242074;
double r11242076 = sqrt(r11242075);
double r11242077 = r11242070 / r11242076;
return r11242077;
}
double f(double x, double y, double z, double t, double a) {
double r11242078 = z;
double r11242079 = -2.099203142812841e+122;
bool r11242080 = r11242078 <= r11242079;
double r11242081 = x;
double r11242082 = -r11242081;
double r11242083 = y;
double r11242084 = r11242082 * r11242083;
double r11242085 = 8.80124926176556e+98;
bool r11242086 = r11242078 <= r11242085;
double r11242087 = cbrt(r11242078);
double r11242088 = r11242078 * r11242078;
double r11242089 = a;
double r11242090 = t;
double r11242091 = r11242089 * r11242090;
double r11242092 = r11242088 - r11242091;
double r11242093 = cbrt(r11242092);
double r11242094 = sqrt(r11242093);
double r11242095 = r11242087 / r11242094;
double r11242096 = r11242087 * r11242087;
double r11242097 = sqrt(r11242092);
double r11242098 = cbrt(r11242097);
double r11242099 = r11242098 * r11242098;
double r11242100 = fabs(r11242099);
double r11242101 = r11242096 / r11242100;
double r11242102 = r11242101 * r11242081;
double r11242103 = r11242083 * r11242102;
double r11242104 = r11242095 * r11242103;
double r11242105 = r11242081 * r11242083;
double r11242106 = r11242086 ? r11242104 : r11242105;
double r11242107 = r11242080 ? r11242084 : r11242106;
return r11242107;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 24.7 |
|---|---|
| Target | 7.6 |
| Herbie | 5.8 |
if z < -2.099203142812841e+122Initial program 48.1
Taylor expanded around -inf 1.6
Simplified1.6
if -2.099203142812841e+122 < z < 8.80124926176556e+98Initial program 11.0
rmApplied *-un-lft-identity11.0
Applied sqrt-prod11.0
Applied times-frac9.6
Simplified9.6
rmApplied add-cube-cbrt10.0
Applied sqrt-prod10.0
Applied add-cube-cbrt10.3
Applied times-frac10.3
Applied associate-*r*9.5
Simplified8.4
rmApplied add-sqr-sqrt8.4
Applied cbrt-prod8.2
if 8.80124926176556e+98 < z Initial program 43.5
Taylor expanded around inf 2.4
Final simplification5.8
herbie shell --seed 2019172 +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)))))