\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)\left(\left(\sqrt{\sqrt[3]{3}} \cdot \left(\left(\left(\frac{1}{x \cdot 9} + y\right) - 1\right) \cdot \sqrt{x}\right)\right) \cdot \sqrt{\sqrt[3]{3}}\right) \cdot \left(\sqrt[3]{3} \cdot \sqrt[3]{3}\right)double f(double x, double y) {
double r22994104 = 3.0;
double r22994105 = x;
double r22994106 = sqrt(r22994105);
double r22994107 = r22994104 * r22994106;
double r22994108 = y;
double r22994109 = 1.0;
double r22994110 = 9.0;
double r22994111 = r22994105 * r22994110;
double r22994112 = r22994109 / r22994111;
double r22994113 = r22994108 + r22994112;
double r22994114 = r22994113 - r22994109;
double r22994115 = r22994107 * r22994114;
return r22994115;
}
double f(double x, double y) {
double r22994116 = 3.0;
double r22994117 = cbrt(r22994116);
double r22994118 = sqrt(r22994117);
double r22994119 = 1.0;
double r22994120 = x;
double r22994121 = 9.0;
double r22994122 = r22994120 * r22994121;
double r22994123 = r22994119 / r22994122;
double r22994124 = y;
double r22994125 = r22994123 + r22994124;
double r22994126 = r22994125 - r22994119;
double r22994127 = sqrt(r22994120);
double r22994128 = r22994126 * r22994127;
double r22994129 = r22994118 * r22994128;
double r22994130 = r22994129 * r22994118;
double r22994131 = r22994117 * r22994117;
double r22994132 = r22994130 * r22994131;
return r22994132;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.4 |
|---|---|
| Target | 0.4 |
| Herbie | 0.5 |
Initial program 0.4
rmApplied associate-*l*0.4
rmApplied add-cube-cbrt0.4
Applied associate-*l*0.6
rmApplied add-sqr-sqrt0.6
Applied associate-*l*0.5
Final simplification0.5
herbie shell --seed 2019169
(FPCore (x y)
:name "Numeric.SpecFunctions:incompleteGamma from math-functions-0.1.5.2, B"
:herbie-target
(* 3.0 (+ (* y (sqrt x)) (* (- (/ 1.0 (* x 9.0)) 1.0) (sqrt x))))
(* (* 3.0 (sqrt x)) (- (+ y (/ 1.0 (* x 9.0))) 1.0)))