\frac{\left(x \cdot y\right) \cdot z}{\sqrt{z \cdot z - t \cdot a}}\begin{array}{l}
\mathbf{if}\;z \le -6.506706062111452568496513260808126439647 \cdot 10^{153}:\\
\;\;\;\;-x \cdot y\\
\mathbf{elif}\;z \le 3.243528684537981667725101402901133521761 \cdot 10^{132}:\\
\;\;\;\;\frac{x}{\frac{\sqrt[3]{\sqrt{z \cdot z - t \cdot a}} \cdot \sqrt[3]{\sqrt{z \cdot z - t \cdot a}}}{\sqrt[3]{z} \cdot \sqrt[3]{z}}} \cdot \frac{y}{\frac{\sqrt[3]{\sqrt{z \cdot z - t \cdot a}}}{\sqrt[3]{z}}}\\
\mathbf{else}:\\
\;\;\;\;x \cdot y\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r244530 = x;
double r244531 = y;
double r244532 = r244530 * r244531;
double r244533 = z;
double r244534 = r244532 * r244533;
double r244535 = r244533 * r244533;
double r244536 = t;
double r244537 = a;
double r244538 = r244536 * r244537;
double r244539 = r244535 - r244538;
double r244540 = sqrt(r244539);
double r244541 = r244534 / r244540;
return r244541;
}
double f(double x, double y, double z, double t, double a) {
double r244542 = z;
double r244543 = -6.5067060621114526e+153;
bool r244544 = r244542 <= r244543;
double r244545 = x;
double r244546 = y;
double r244547 = r244545 * r244546;
double r244548 = -r244547;
double r244549 = 3.2435286845379817e+132;
bool r244550 = r244542 <= r244549;
double r244551 = r244542 * r244542;
double r244552 = t;
double r244553 = a;
double r244554 = r244552 * r244553;
double r244555 = r244551 - r244554;
double r244556 = sqrt(r244555);
double r244557 = cbrt(r244556);
double r244558 = r244557 * r244557;
double r244559 = cbrt(r244542);
double r244560 = r244559 * r244559;
double r244561 = r244558 / r244560;
double r244562 = r244545 / r244561;
double r244563 = r244557 / r244559;
double r244564 = r244546 / r244563;
double r244565 = r244562 * r244564;
double r244566 = r244550 ? r244565 : r244547;
double r244567 = r244544 ? r244548 : r244566;
return r244567;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 24.5 |
|---|---|
| Target | 7.8 |
| Herbie | 5.4 |
if z < -6.5067060621114526e+153Initial program 53.4
Taylor expanded around -inf 0.9
Simplified0.9
if -6.5067060621114526e+153 < z < 3.2435286845379817e+132Initial program 11.4
rmApplied associate-/l*9.2
rmApplied add-cube-cbrt9.9
Applied add-cube-cbrt9.4
Applied times-frac9.4
Applied times-frac7.6
if 3.2435286845379817e+132 < z Initial program 48.8
Taylor expanded around inf 1.4
Final simplification5.4
herbie shell --seed 2019326
(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)))))