\frac{\tan \left(\frac{x}{y \cdot 2}\right)}{\sin \left(\frac{x}{y \cdot 2}\right)}\frac{1}{\cos \left(\left(0.5 \cdot \frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\sqrt[3]{y} \cdot \sqrt[3]{y}}\right) \cdot \frac{\sqrt[3]{\sqrt[3]{x} \cdot \sqrt[3]{x}} \cdot \sqrt[3]{\sqrt[3]{x}}}{\sqrt[3]{y}}\right)}(FPCore (x y) :precision binary64 (/ (tan (/ x (* y 2.0))) (sin (/ x (* y 2.0)))))
(FPCore (x y)
:precision binary64
(/
1.0
(cos
(*
(* 0.5 (/ (* (cbrt x) (cbrt x)) (* (cbrt y) (cbrt y))))
(/ (* (cbrt (* (cbrt x) (cbrt x))) (cbrt (cbrt x))) (cbrt y))))))double code(double x, double y) {
return tan(x / (y * 2.0)) / sin(x / (y * 2.0));
}
double code(double x, double y) {
return 1.0 / cos((0.5 * ((cbrt(x) * cbrt(x)) / (cbrt(y) * cbrt(y)))) * ((cbrt(cbrt(x) * cbrt(x)) * cbrt(cbrt(x))) / cbrt(y)));
}




Bits error versus x




Bits error versus y
Results
| Original | 36.1 |
|---|---|
| Target | 29.4 |
| Herbie | 29.0 |
Initial program 36.1
Taylor expanded around inf 28.9
rmApplied add-cube-cbrt_binary64_2125529.0
Applied add-cube-cbrt_binary64_2125529.0
Applied times-frac_binary64_2122629.0
Applied associate-*r*_binary64_2116029.0
rmApplied add-cube-cbrt_binary64_2125528.9
Applied cbrt-prod_binary64_2125129.0
Final simplification29.0
herbie shell --seed 2021090
(FPCore (x y)
:name "Diagrams.TwoD.Layout.CirclePacking:approxRadius from diagrams-contrib-1.3.0.5"
:precision binary64
:herbie-target
(if (< y -1.2303690911306994e+114) 1.0 (if (< y -9.102852406811914e-222) (/ (sin (/ x (* y 2.0))) (* (sin (/ x (* y 2.0))) (log (exp (cos (/ x (* y 2.0))))))) 1.0))
(/ (tan (/ x (* y 2.0))) (sin (/ x (* y 2.0)))))