1 - \log \left(1 - \frac{x - y}{1 - y}\right)\begin{array}{l}
\mathbf{if}\;\frac{x - y}{1 - y} \le 0.9679400613876859571504951418319251388311:\\
\;\;\;\;\log \left(\frac{e^{1}}{1 - \frac{x - y}{1 - y}}\right)\\
\mathbf{else}:\\
\;\;\;\;\log \left(\frac{e^{1}}{\left(1 + \frac{1}{y}\right) \cdot \frac{x}{y} - \frac{1}{y}}\right)\\
\end{array}double f(double x, double y) {
double r269193 = 1.0;
double r269194 = x;
double r269195 = y;
double r269196 = r269194 - r269195;
double r269197 = r269193 - r269195;
double r269198 = r269196 / r269197;
double r269199 = r269193 - r269198;
double r269200 = log(r269199);
double r269201 = r269193 - r269200;
return r269201;
}
double f(double x, double y) {
double r269202 = x;
double r269203 = y;
double r269204 = r269202 - r269203;
double r269205 = 1.0;
double r269206 = r269205 - r269203;
double r269207 = r269204 / r269206;
double r269208 = 0.967940061387686;
bool r269209 = r269207 <= r269208;
double r269210 = exp(r269205);
double r269211 = r269205 - r269207;
double r269212 = r269210 / r269211;
double r269213 = log(r269212);
double r269214 = 1.0;
double r269215 = r269205 / r269203;
double r269216 = r269214 + r269215;
double r269217 = r269202 / r269203;
double r269218 = r269216 * r269217;
double r269219 = r269218 - r269215;
double r269220 = r269210 / r269219;
double r269221 = log(r269220);
double r269222 = r269209 ? r269213 : r269221;
return r269222;
}




Bits error versus x




Bits error versus y
Results
| Original | 18.8 |
|---|---|
| Target | 0.1 |
| Herbie | 0.2 |
if (/ (- x y) (- 1.0 y)) < 0.967940061387686Initial program 0.0
rmApplied add-log-exp0.0
Applied diff-log0.0
if 0.967940061387686 < (/ (- x y) (- 1.0 y)) Initial program 61.9
rmApplied add-log-exp61.9
Applied diff-log61.9
Taylor expanded around inf 0.6
Simplified0.6
Final simplification0.2
herbie shell --seed 2019325
(FPCore (x y)
:name "Numeric.SpecFunctions:invIncompleteGamma from math-functions-0.1.5.2, B"
:precision binary64
:herbie-target
(if (< y -81284752.61947241) (- 1 (log (- (/ x (* y y)) (- (/ 1 y) (/ x y))))) (if (< y 3.0094271212461764e+25) (log (/ (exp 1) (- 1 (/ (- x y) (- 1 y))))) (- 1 (log (- (/ x (* y y)) (- (/ 1 y) (/ x y)))))))
(- 1 (log (- 1 (/ (- x y) (- 1 y))))))