\frac{e^{x \cdot \log \left(\frac{x}{x + y}\right)}}{x}\begin{array}{l}
\mathbf{if}\;x \le -7.0366427384808783 \cdot 10^{48} \lor \neg \left(x \le 9.41291569922092328 \cdot 10^{-13}\right):\\
\;\;\;\;\frac{e^{-1 \cdot y}}{x}\\
\mathbf{else}:\\
\;\;\;\;\frac{e^{\left(2 \cdot \log \left(\frac{\sqrt[3]{x}}{\sqrt[3]{x + y}}\right)\right) \cdot x} \cdot {\left(\frac{\sqrt[3]{x}}{\sqrt[3]{x + y}}\right)}^{x}}{x}\\
\end{array}double f(double x, double y) {
double r489656 = x;
double r489657 = y;
double r489658 = r489656 + r489657;
double r489659 = r489656 / r489658;
double r489660 = log(r489659);
double r489661 = r489656 * r489660;
double r489662 = exp(r489661);
double r489663 = r489662 / r489656;
return r489663;
}
double f(double x, double y) {
double r489664 = x;
double r489665 = -7.036642738480878e+48;
bool r489666 = r489664 <= r489665;
double r489667 = 9.412915699220923e-13;
bool r489668 = r489664 <= r489667;
double r489669 = !r489668;
bool r489670 = r489666 || r489669;
double r489671 = -1.0;
double r489672 = y;
double r489673 = r489671 * r489672;
double r489674 = exp(r489673);
double r489675 = r489674 / r489664;
double r489676 = 2.0;
double r489677 = cbrt(r489664);
double r489678 = r489664 + r489672;
double r489679 = cbrt(r489678);
double r489680 = r489677 / r489679;
double r489681 = log(r489680);
double r489682 = r489676 * r489681;
double r489683 = r489682 * r489664;
double r489684 = exp(r489683);
double r489685 = pow(r489680, r489664);
double r489686 = r489684 * r489685;
double r489687 = r489686 / r489664;
double r489688 = r489670 ? r489675 : r489687;
return r489688;
}




Bits error versus x




Bits error versus y
Results
| Original | 11.1 |
|---|---|
| Target | 8.0 |
| Herbie | 0.4 |
if x < -7.036642738480878e+48 or 9.412915699220923e-13 < x Initial program 11.4
Simplified11.4
Taylor expanded around inf 0.5
Simplified0.5
if -7.036642738480878e+48 < x < 9.412915699220923e-13Initial program 10.9
Simplified10.9
rmApplied add-cube-cbrt13.6
Applied add-cube-cbrt10.9
Applied times-frac10.9
Applied unpow-prod-down2.4
rmApplied add-exp-log36.0
Applied add-exp-log36.0
Applied prod-exp36.0
Applied add-exp-log36.0
Applied add-exp-log36.0
Applied prod-exp36.0
Applied div-exp36.0
Applied pow-exp34.9
Simplified0.2
Final simplification0.4
herbie shell --seed 2020057 +o rules:numerics
(FPCore (x y)
:name "Numeric.SpecFunctions:invIncompleteBetaWorker from math-functions-0.1.5.2, F"
:precision binary64
:herbie-target
(if (< y -3.7311844206647956e+94) (/ (exp (/ -1 y)) x) (if (< y 2.817959242728288e+37) (/ (pow (/ x (+ y x)) x) x) (if (< y 2.347387415166998e+178) (log (exp (/ (pow (/ x (+ y x)) x) x))) (/ (exp (/ -1 y)) x))))
(/ (exp (* x (log (/ x (+ x y))))) x))