\left(\left(\left(x - 0.5\right) \cdot \log x - x\right) + 0.9189385332046700050057097541866824030876\right) + \frac{\left(\left(y + 7.936500793651000149400709382518925849581 \cdot 10^{-4}\right) \cdot z - 0.002777777777777800001512975569539776188321\right) \cdot z + 0.08333333333333299564049667651488562114537}{x}\begin{array}{l}
\mathbf{if}\;x \le 2.717425698450508370910792508296994577267 \cdot 10^{63}:\\
\;\;\;\;\mathsf{fma}\left(\log x, x - 0.5, \frac{\mathsf{fma}\left(\mathsf{fma}\left(y + 7.936500793651000149400709382518925849581 \cdot 10^{-4}, z, -0.002777777777777800001512975569539776188321\right), z, 0.08333333333333299564049667651488562114537\right)}{x} - \left(x - 0.9189385332046700050057097541866824030876\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{{z}^{2}}{x}, y, 7.936500793651000149400709382518925849581 \cdot 10^{-4} \cdot \frac{{z}^{2}}{x} - \mathsf{fma}\left(\log \left(\frac{1}{x}\right), x, x\right)\right)\\
\end{array}double f(double x, double y, double z) {
double r367226 = x;
double r367227 = 0.5;
double r367228 = r367226 - r367227;
double r367229 = log(r367226);
double r367230 = r367228 * r367229;
double r367231 = r367230 - r367226;
double r367232 = 0.91893853320467;
double r367233 = r367231 + r367232;
double r367234 = y;
double r367235 = 0.0007936500793651;
double r367236 = r367234 + r367235;
double r367237 = z;
double r367238 = r367236 * r367237;
double r367239 = 0.0027777777777778;
double r367240 = r367238 - r367239;
double r367241 = r367240 * r367237;
double r367242 = 0.083333333333333;
double r367243 = r367241 + r367242;
double r367244 = r367243 / r367226;
double r367245 = r367233 + r367244;
return r367245;
}
double f(double x, double y, double z) {
double r367246 = x;
double r367247 = 2.7174256984505084e+63;
bool r367248 = r367246 <= r367247;
double r367249 = log(r367246);
double r367250 = 0.5;
double r367251 = r367246 - r367250;
double r367252 = y;
double r367253 = 0.0007936500793651;
double r367254 = r367252 + r367253;
double r367255 = z;
double r367256 = 0.0027777777777778;
double r367257 = -r367256;
double r367258 = fma(r367254, r367255, r367257);
double r367259 = 0.083333333333333;
double r367260 = fma(r367258, r367255, r367259);
double r367261 = r367260 / r367246;
double r367262 = 0.91893853320467;
double r367263 = r367246 - r367262;
double r367264 = r367261 - r367263;
double r367265 = fma(r367249, r367251, r367264);
double r367266 = 2.0;
double r367267 = pow(r367255, r367266);
double r367268 = r367267 / r367246;
double r367269 = r367253 * r367268;
double r367270 = 1.0;
double r367271 = r367270 / r367246;
double r367272 = log(r367271);
double r367273 = fma(r367272, r367246, r367246);
double r367274 = r367269 - r367273;
double r367275 = fma(r367268, r367252, r367274);
double r367276 = r367248 ? r367265 : r367275;
return r367276;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 6.0 |
|---|---|
| Target | 1.1 |
| Herbie | 4.3 |
if x < 2.7174256984505084e+63Initial program 0.7
Simplified0.6
rmApplied *-un-lft-identity0.6
Applied associate-/r*0.6
Simplified0.6
rmApplied fma-neg0.6
if 2.7174256984505084e+63 < x Initial program 11.8
Simplified11.8
Taylor expanded around inf 12.0
Simplified8.2
Final simplification4.3
herbie shell --seed 2019354 +o rules:numerics
(FPCore (x y z)
:name "Numeric.SpecFunctions:$slogFactorial from math-functions-0.1.5.2, B"
:precision binary64
:herbie-target
(+ (+ (+ (* (- x 0.5) (log x)) (- 0.91893853320467 x)) (/ 0.083333333333333 x)) (* (/ z x) (- (* z (+ y 0.0007936500793651)) 0.0027777777777778)))
(+ (+ (- (* (- x 0.5) (log x)) x) 0.91893853320467) (/ (+ (* (- (* (+ y 0.0007936500793651) z) 0.0027777777777778) z) 0.083333333333333) x)))