\frac{e^{x \cdot \log \left(\frac{x}{x + y}\right)}}{x}\begin{array}{l}
\mathbf{if}\;x \le -1.81817434923962274 \cdot 10^{140} \lor \neg \left(x \le 5.23835627656106507 \cdot 10^{-4}\right):\\
\;\;\;\;\frac{e^{-1 \cdot y}}{x}\\
\mathbf{else}:\\
\;\;\;\;\frac{e^{\left(x \cdot 2\right) \cdot \log \left(\frac{\sqrt[3]{x}}{\sqrt[3]{x + y}}\right)} \cdot {\left(\frac{\sqrt[3]{x}}{\sqrt[3]{x + y}}\right)}^{x}}{x}\\
\end{array}double f(double x, double y) {
double r228396 = x;
double r228397 = y;
double r228398 = r228396 + r228397;
double r228399 = r228396 / r228398;
double r228400 = log(r228399);
double r228401 = r228396 * r228400;
double r228402 = exp(r228401);
double r228403 = r228402 / r228396;
return r228403;
}
double f(double x, double y) {
double r228404 = x;
double r228405 = -1.8181743492396227e+140;
bool r228406 = r228404 <= r228405;
double r228407 = 0.0005238356276561065;
bool r228408 = r228404 <= r228407;
double r228409 = !r228408;
bool r228410 = r228406 || r228409;
double r228411 = -1.0;
double r228412 = y;
double r228413 = r228411 * r228412;
double r228414 = exp(r228413);
double r228415 = r228414 / r228404;
double r228416 = 2.0;
double r228417 = r228404 * r228416;
double r228418 = cbrt(r228404);
double r228419 = r228404 + r228412;
double r228420 = cbrt(r228419);
double r228421 = r228418 / r228420;
double r228422 = log(r228421);
double r228423 = r228417 * r228422;
double r228424 = exp(r228423);
double r228425 = pow(r228421, r228404);
double r228426 = r228424 * r228425;
double r228427 = r228426 / r228404;
double r228428 = r228410 ? r228415 : r228427;
return r228428;
}




Bits error versus x




Bits error versus y
Results
| Original | 11.2 |
|---|---|
| Target | 7.6 |
| Herbie | 0.7 |
if x < -1.8181743492396227e+140 or 0.0005238356276561065 < x Initial program 12.0
Simplified12.0
Taylor expanded around inf 0.2
Simplified0.2
if -1.8181743492396227e+140 < x < 0.0005238356276561065Initial program 10.5
Simplified10.5
rmApplied add-cube-cbrt17.5
Applied add-cube-cbrt10.5
Applied times-frac10.5
Applied unpow-prod-down3.0
rmApplied add-exp-log38.2
Applied add-exp-log38.2
Applied prod-exp38.2
Applied add-exp-log38.2
Applied add-exp-log38.2
Applied prod-exp38.2
Applied div-exp38.2
Applied pow-exp37.3
Simplified1.0
Final simplification0.7
herbie shell --seed 2020046
(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))