\frac{e^{x \cdot \log \left(\frac{x}{x + y}\right)}}{x}\begin{array}{l}
\mathbf{if}\;x \le -1.93589564103634151 \cdot 10^{37}:\\
\;\;\;\;\frac{1}{x \cdot e^{y}}\\
\mathbf{elif}\;x \le 5.82893129968314749:\\
\;\;\;\;\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}\\
\mathbf{else}:\\
\;\;\;\;\frac{e^{-1 \cdot y}}{x}\\
\end{array}double f(double x, double y) {
double r409698 = x;
double r409699 = y;
double r409700 = r409698 + r409699;
double r409701 = r409698 / r409700;
double r409702 = log(r409701);
double r409703 = r409698 * r409702;
double r409704 = exp(r409703);
double r409705 = r409704 / r409698;
return r409705;
}
double f(double x, double y) {
double r409706 = x;
double r409707 = -1.9358956410363415e+37;
bool r409708 = r409706 <= r409707;
double r409709 = 1.0;
double r409710 = y;
double r409711 = exp(r409710);
double r409712 = r409706 * r409711;
double r409713 = r409709 / r409712;
double r409714 = 5.8289312996831475;
bool r409715 = r409706 <= r409714;
double r409716 = 2.0;
double r409717 = cbrt(r409706);
double r409718 = r409706 + r409710;
double r409719 = cbrt(r409718);
double r409720 = r409717 / r409719;
double r409721 = log(r409720);
double r409722 = r409716 * r409721;
double r409723 = r409722 * r409706;
double r409724 = exp(r409723);
double r409725 = pow(r409720, r409706);
double r409726 = r409724 * r409725;
double r409727 = r409726 / r409706;
double r409728 = -1.0;
double r409729 = r409728 * r409710;
double r409730 = exp(r409729);
double r409731 = r409730 / r409706;
double r409732 = r409715 ? r409727 : r409731;
double r409733 = r409708 ? r409713 : r409732;
return r409733;
}




Bits error versus x




Bits error versus y
Results
| Original | 11.0 |
|---|---|
| Target | 8.3 |
| Herbie | 0.1 |
if x < -1.9358956410363415e+37Initial program 14.0
Simplified14.0
Taylor expanded around inf 0.0
Simplified0.0
rmApplied clear-num0.0
Simplified0.0
if -1.9358956410363415e+37 < x < 5.8289312996831475Initial program 10.4
Simplified10.4
rmApplied add-cube-cbrt12.3
Applied add-cube-cbrt10.4
Applied times-frac10.4
Applied unpow-prod-down2.2
rmApplied add-exp-log34.2
Applied add-exp-log34.2
Applied prod-exp34.2
Applied add-exp-log34.2
Applied add-exp-log34.2
Applied prod-exp34.2
Applied div-exp34.2
Applied pow-exp33.2
Simplified0.1
if 5.8289312996831475 < x Initial program 9.6
Simplified9.6
Taylor expanded around inf 0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2020056 +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))