\left(1.0 - \frac{1.0}{x \cdot 9.0}\right) - \frac{y}{3.0 \cdot \sqrt{x}}\mathsf{fma}\left(1, 1.0 - \frac{1.0}{x \cdot 9.0}, \frac{\frac{y}{\sqrt[3]{3.0}}}{\sqrt{x}} \cdot \frac{-1}{\sqrt[3]{3.0} \cdot \sqrt[3]{3.0}}\right) + \mathsf{fma}\left(-\frac{\frac{y}{\sqrt[3]{3.0}}}{\sqrt{x}}, \frac{1}{\sqrt[3]{3.0} \cdot \sqrt[3]{3.0}}, \frac{1}{\sqrt[3]{3.0} \cdot \sqrt[3]{3.0}} \cdot \frac{\frac{y}{\sqrt[3]{3.0}}}{\sqrt{x}}\right)double f(double x, double y) {
double r17460157 = 1.0;
double r17460158 = x;
double r17460159 = 9.0;
double r17460160 = r17460158 * r17460159;
double r17460161 = r17460157 / r17460160;
double r17460162 = r17460157 - r17460161;
double r17460163 = y;
double r17460164 = 3.0;
double r17460165 = sqrt(r17460158);
double r17460166 = r17460164 * r17460165;
double r17460167 = r17460163 / r17460166;
double r17460168 = r17460162 - r17460167;
return r17460168;
}
double f(double x, double y) {
double r17460169 = 1.0;
double r17460170 = 1.0;
double r17460171 = x;
double r17460172 = 9.0;
double r17460173 = r17460171 * r17460172;
double r17460174 = r17460170 / r17460173;
double r17460175 = r17460170 - r17460174;
double r17460176 = y;
double r17460177 = 3.0;
double r17460178 = cbrt(r17460177);
double r17460179 = r17460176 / r17460178;
double r17460180 = sqrt(r17460171);
double r17460181 = r17460179 / r17460180;
double r17460182 = -1.0;
double r17460183 = r17460178 * r17460178;
double r17460184 = r17460182 / r17460183;
double r17460185 = r17460181 * r17460184;
double r17460186 = fma(r17460169, r17460175, r17460185);
double r17460187 = -r17460181;
double r17460188 = r17460169 / r17460183;
double r17460189 = r17460188 * r17460181;
double r17460190 = fma(r17460187, r17460188, r17460189);
double r17460191 = r17460186 + r17460190;
return r17460191;
}




Bits error versus x




Bits error versus y
| Original | 0.2 |
|---|---|
| Target | 0.2 |
| Herbie | 0.3 |
Initial program 0.2
rmApplied associate-/r*0.2
rmApplied *-un-lft-identity0.2
Applied add-cube-cbrt0.2
Applied *-un-lft-identity0.2
Applied times-frac0.2
Applied times-frac0.3
Applied *-un-lft-identity0.3
Applied prod-diff0.3
Final simplification0.3
herbie shell --seed 2019168 +o rules:numerics
(FPCore (x y)
:name "Numeric.SpecFunctions:invIncompleteGamma from math-functions-0.1.5.2, D"
:herbie-target
(- (- 1.0 (/ (/ 1.0 x) 9.0)) (/ y (* 3.0 (sqrt x))))
(- (- 1.0 (/ 1.0 (* x 9.0))) (/ y (* 3.0 (sqrt x)))))