\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922227999963610045597306452691555 + 78.69949241540000173245061887428164482117\right) \cdot x + 137.5194164160000127594685181975364685059\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514000013984514225739985704422\right) \cdot x + 263.5050747210000281484099105000495910645\right) \cdot x + 313.3992158940000081202015280723571777344\right) \cdot x + 47.06687660600000100430406746454536914825}\begin{array}{l}
\mathbf{if}\;x \le -1.132776625026725631349257390561686378676 \cdot 10^{70} \lor \neg \left(x \le 2.287943170826980441039975419814875490697 \cdot 10^{47}\right):\\
\;\;\;\;\left(\frac{y}{{x}^{2}} + 4.16438922227999963610045597306452691555 \cdot x\right) - 110.1139242984810948655649553984403610229\\
\mathbf{else}:\\
\;\;\;\;\frac{x - 2}{\left(\left(\left(x + 43.3400022514000013984514225739985704422\right) \cdot x + 263.5050747210000281484099105000495910645\right) \cdot x + 313.3992158940000081202015280723571777344\right) \cdot x + 47.06687660600000100430406746454536914825} \cdot \left(\left(\left(\left(x \cdot 4.16438922227999963610045597306452691555 + 78.69949241540000173245061887428164482117\right) \cdot x + 137.5194164160000127594685181975364685059\right) \cdot x + y\right) \cdot x + z\right)\\
\end{array}double f(double x, double y, double z) {
double r263818 = x;
double r263819 = 2.0;
double r263820 = r263818 - r263819;
double r263821 = 4.16438922228;
double r263822 = r263818 * r263821;
double r263823 = 78.6994924154;
double r263824 = r263822 + r263823;
double r263825 = r263824 * r263818;
double r263826 = 137.519416416;
double r263827 = r263825 + r263826;
double r263828 = r263827 * r263818;
double r263829 = y;
double r263830 = r263828 + r263829;
double r263831 = r263830 * r263818;
double r263832 = z;
double r263833 = r263831 + r263832;
double r263834 = r263820 * r263833;
double r263835 = 43.3400022514;
double r263836 = r263818 + r263835;
double r263837 = r263836 * r263818;
double r263838 = 263.505074721;
double r263839 = r263837 + r263838;
double r263840 = r263839 * r263818;
double r263841 = 313.399215894;
double r263842 = r263840 + r263841;
double r263843 = r263842 * r263818;
double r263844 = 47.066876606;
double r263845 = r263843 + r263844;
double r263846 = r263834 / r263845;
return r263846;
}
double f(double x, double y, double z) {
double r263847 = x;
double r263848 = -1.1327766250267256e+70;
bool r263849 = r263847 <= r263848;
double r263850 = 2.2879431708269804e+47;
bool r263851 = r263847 <= r263850;
double r263852 = !r263851;
bool r263853 = r263849 || r263852;
double r263854 = y;
double r263855 = 2.0;
double r263856 = pow(r263847, r263855);
double r263857 = r263854 / r263856;
double r263858 = 4.16438922228;
double r263859 = r263858 * r263847;
double r263860 = r263857 + r263859;
double r263861 = 110.1139242984811;
double r263862 = r263860 - r263861;
double r263863 = 2.0;
double r263864 = r263847 - r263863;
double r263865 = 43.3400022514;
double r263866 = r263847 + r263865;
double r263867 = r263866 * r263847;
double r263868 = 263.505074721;
double r263869 = r263867 + r263868;
double r263870 = r263869 * r263847;
double r263871 = 313.399215894;
double r263872 = r263870 + r263871;
double r263873 = r263872 * r263847;
double r263874 = 47.066876606;
double r263875 = r263873 + r263874;
double r263876 = r263864 / r263875;
double r263877 = r263847 * r263858;
double r263878 = 78.6994924154;
double r263879 = r263877 + r263878;
double r263880 = r263879 * r263847;
double r263881 = 137.519416416;
double r263882 = r263880 + r263881;
double r263883 = r263882 * r263847;
double r263884 = r263883 + r263854;
double r263885 = r263884 * r263847;
double r263886 = z;
double r263887 = r263885 + r263886;
double r263888 = r263876 * r263887;
double r263889 = r263853 ? r263862 : r263888;
return r263889;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 26.8 |
|---|---|
| Target | 0.5 |
| Herbie | 0.7 |
if x < -1.1327766250267256e+70 or 2.2879431708269804e+47 < x Initial program 62.8
Taylor expanded around inf 0.2
if -1.1327766250267256e+70 < x < 2.2879431708269804e+47Initial program 2.3
rmApplied associate-/l*0.9
rmApplied associate-/r/1.0
Final simplification0.7
herbie shell --seed 2019326
(FPCore (x y z)
:name "Numeric.SpecFunctions:logGamma from math-functions-0.1.5.2, C"
:precision binary64
:herbie-target
(if (< x -3.326128725870005e+62) (- (+ (/ y (* x x)) (* 4.16438922228 x)) 110.1139242984811) (if (< x 9.429991714554673e+55) (* (/ (- x 2) 1) (/ (+ (* (+ (* (+ (* (+ (* x 4.16438922228) 78.6994924154) x) 137.519416416) x) y) x) z) (+ (* (+ (+ (* 263.505074721 x) (+ (* 43.3400022514 (* x x)) (* x (* x x)))) 313.399215894) x) 47.066876606))) (- (+ (/ y (* x x)) (* 4.16438922228 x)) 110.1139242984811)))
(/ (* (- x 2) (+ (* (+ (* (+ (* (+ (* x 4.16438922228) 78.6994924154) x) 137.519416416) x) y) x) z)) (+ (* (+ (* (+ (* (+ x 43.3400022514) x) 263.505074721) x) 313.399215894) x) 47.066876606)))