\left(1 - \frac{1}{x \cdot 9}\right) - \frac{y}{3 \cdot \sqrt{x}}\left(1 - \frac{0.1111111111111111049432054187491303309798}{x}\right) - \frac{y}{3 \cdot \sqrt{x}}double f(double x, double y) {
double r317810 = 1.0;
double r317811 = x;
double r317812 = 9.0;
double r317813 = r317811 * r317812;
double r317814 = r317810 / r317813;
double r317815 = r317810 - r317814;
double r317816 = y;
double r317817 = 3.0;
double r317818 = sqrt(r317811);
double r317819 = r317817 * r317818;
double r317820 = r317816 / r317819;
double r317821 = r317815 - r317820;
return r317821;
}
double f(double x, double y) {
double r317822 = 1.0;
double r317823 = 0.1111111111111111;
double r317824 = x;
double r317825 = r317823 / r317824;
double r317826 = r317822 - r317825;
double r317827 = y;
double r317828 = 3.0;
double r317829 = sqrt(r317824);
double r317830 = r317828 * r317829;
double r317831 = r317827 / r317830;
double r317832 = r317826 - r317831;
return r317832;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.2 |
|---|---|
| Target | 0.3 |
| Herbie | 0.3 |
Initial program 0.2
Taylor expanded around 0 0.3
Final simplification0.3
herbie shell --seed 2020001 +o rules:numerics
(FPCore (x y)
:name "Numeric.SpecFunctions:invIncompleteGamma from math-functions-0.1.5.2, D"
:precision binary64
:herbie-target
(- (- 1 (/ (/ 1 x) 9)) (/ y (* 3 (sqrt x))))
(- (- 1 (/ 1 (* x 9))) (/ y (* 3 (sqrt x)))))