\left(\frac{1}{x + 1} - \frac{2}{x}\right) + \frac{1}{x - 1}\begin{array}{l}
\mathbf{if}\;x \le -107.120037393270436609782336745411157608:\\
\;\;\;\;\left(\frac{\sqrt[3]{\sqrt{2}}}{\frac{x}{\sqrt{\sqrt{2}}}} \cdot \frac{\sqrt[3]{\sqrt{2}} \cdot \sqrt[3]{\sqrt{2}}}{\frac{x \cdot x}{\sqrt{\sqrt{2}}}} + \frac{2}{{x}^{7}}\right) + \frac{2}{{x}^{5}}\\
\mathbf{elif}\;x \le 139.9956438464524808296118862926959991455:\\
\;\;\;\;\left(\frac{1}{1 + x} - \frac{2}{x}\right) + \frac{1}{x - 1}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{{x}^{5}} + \left(\frac{2}{{x}^{7}} + \frac{2}{{x}^{3}}\right)\\
\end{array}double f(double x) {
double r146010 = 1.0;
double r146011 = x;
double r146012 = r146011 + r146010;
double r146013 = r146010 / r146012;
double r146014 = 2.0;
double r146015 = r146014 / r146011;
double r146016 = r146013 - r146015;
double r146017 = r146011 - r146010;
double r146018 = r146010 / r146017;
double r146019 = r146016 + r146018;
return r146019;
}
double f(double x) {
double r146020 = x;
double r146021 = -107.12003739327044;
bool r146022 = r146020 <= r146021;
double r146023 = 2.0;
double r146024 = sqrt(r146023);
double r146025 = cbrt(r146024);
double r146026 = sqrt(r146024);
double r146027 = r146020 / r146026;
double r146028 = r146025 / r146027;
double r146029 = r146025 * r146025;
double r146030 = r146020 * r146020;
double r146031 = r146030 / r146026;
double r146032 = r146029 / r146031;
double r146033 = r146028 * r146032;
double r146034 = 7.0;
double r146035 = pow(r146020, r146034);
double r146036 = r146023 / r146035;
double r146037 = r146033 + r146036;
double r146038 = 5.0;
double r146039 = pow(r146020, r146038);
double r146040 = r146023 / r146039;
double r146041 = r146037 + r146040;
double r146042 = 139.99564384645248;
bool r146043 = r146020 <= r146042;
double r146044 = 1.0;
double r146045 = r146044 + r146020;
double r146046 = r146044 / r146045;
double r146047 = r146023 / r146020;
double r146048 = r146046 - r146047;
double r146049 = r146020 - r146044;
double r146050 = r146044 / r146049;
double r146051 = r146048 + r146050;
double r146052 = 3.0;
double r146053 = pow(r146020, r146052);
double r146054 = r146023 / r146053;
double r146055 = r146036 + r146054;
double r146056 = r146040 + r146055;
double r146057 = r146043 ? r146051 : r146056;
double r146058 = r146022 ? r146041 : r146057;
return r146058;
}




Bits error versus x
Results
| Original | 10.0 |
|---|---|
| Target | 0.3 |
| Herbie | 0.2 |
if x < -107.12003739327044Initial program 19.6
Taylor expanded around inf 0.5
Simplified0.5
rmApplied add-sqr-sqrt0.8
Applied associate-/l*0.7
rmApplied add-sqr-sqrt0.7
Applied sqrt-prod0.5
Applied add-cube-cbrt1.2
Applied unpow-prod-down1.2
Applied times-frac1.1
Applied add-cube-cbrt1.1
Applied times-frac0.8
Simplified0.4
Simplified0.2
if -107.12003739327044 < x < 139.99564384645248Initial program 0.0
if 139.99564384645248 < x Initial program 20.1
Taylor expanded around inf 0.6
Simplified0.6
Final simplification0.2
herbie shell --seed 2019196 +o rules:numerics
(FPCore (x)
:name "3frac (problem 3.3.3)"
:herbie-target
(/ 2.0 (* x (- (* x x) 1.0)))
(+ (- (/ 1.0 (+ x 1.0)) (/ 2.0 x)) (/ 1.0 (- x 1.0))))