\frac{\tan \left(\frac{x}{y \cdot 2}\right)}{\sin \left(\frac{x}{y \cdot 2}\right)}\begin{array}{l}
\mathbf{if}\;\frac{x}{y \cdot 2} \le -0.0:\\
\;\;\;\;1\\
\mathbf{elif}\;\frac{x}{y \cdot 2} \le 5.25966741260588092 \cdot 10^{125}:\\
\;\;\;\;\left(\sqrt[3]{\frac{\frac{\sin \left(\frac{x}{y \cdot 2}\right)}{\cos \left(\frac{x}{y \cdot 2}\right)}}{\sin \left(\frac{x}{y \cdot 2}\right)}} \cdot \sqrt[3]{\frac{\frac{\sin \left(\frac{x}{y \cdot 2}\right)}{\cos \left(\frac{x}{y \cdot 2}\right)}}{\sin \left(\frac{x}{y \cdot 2}\right)}}\right) \cdot \sqrt[3]{\frac{\tan \left(\frac{x}{y \cdot 2}\right)}{\sin \left(\frac{x}{y \cdot 2}\right)}}\\
\mathbf{else}:\\
\;\;\;\;1\\
\end{array}double f(double x, double y) {
double r602893 = x;
double r602894 = y;
double r602895 = 2.0;
double r602896 = r602894 * r602895;
double r602897 = r602893 / r602896;
double r602898 = tan(r602897);
double r602899 = sin(r602897);
double r602900 = r602898 / r602899;
return r602900;
}
double f(double x, double y) {
double r602901 = x;
double r602902 = y;
double r602903 = 2.0;
double r602904 = r602902 * r602903;
double r602905 = r602901 / r602904;
double r602906 = -0.0;
bool r602907 = r602905 <= r602906;
double r602908 = 1.0;
double r602909 = 5.259667412605881e+125;
bool r602910 = r602905 <= r602909;
double r602911 = sin(r602905);
double r602912 = cos(r602905);
double r602913 = r602911 / r602912;
double r602914 = r602913 / r602911;
double r602915 = cbrt(r602914);
double r602916 = r602915 * r602915;
double r602917 = tan(r602905);
double r602918 = r602917 / r602911;
double r602919 = cbrt(r602918);
double r602920 = r602916 * r602919;
double r602921 = r602910 ? r602920 : r602908;
double r602922 = r602907 ? r602908 : r602921;
return r602922;
}




Bits error versus x




Bits error versus y
Results
| Original | 35.9 |
|---|---|
| Target | 29.1 |
| Herbie | 28.1 |
if (/ x (* y 2.0)) < -0.0 or 5.259667412605881e+125 < (/ x (* y 2.0)) Initial program 43.5
Taylor expanded around 0 32.5
if -0.0 < (/ x (* y 2.0)) < 5.259667412605881e+125Initial program 17.1
rmApplied add-cube-cbrt17.1
rmApplied tan-quot17.1
rmApplied tan-quot17.1
Final simplification28.1
herbie shell --seed 2020062 +o rules:numerics
(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 (if (< y -9.102852406811914e-222) (/ (sin (/ x (* y 2))) (* (sin (/ x (* y 2))) (log (exp (cos (/ x (* y 2))))))) 1))
(/ (tan (/ x (* y 2))) (sin (/ x (* y 2)))))