\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{\tan \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{\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)}}\\
\mathbf{else}:\\
\;\;\;\;1\\
\end{array}double f(double x, double y) {
double r728819 = x;
double r728820 = y;
double r728821 = 2.0;
double r728822 = r728820 * r728821;
double r728823 = r728819 / r728822;
double r728824 = tan(r728823);
double r728825 = sin(r728823);
double r728826 = r728824 / r728825;
return r728826;
}
double f(double x, double y) {
double r728827 = x;
double r728828 = y;
double r728829 = 2.0;
double r728830 = r728828 * r728829;
double r728831 = r728827 / r728830;
double r728832 = -0.0;
bool r728833 = r728831 <= r728832;
double r728834 = 1.0;
double r728835 = 5.259667412605881e+125;
bool r728836 = r728831 <= r728835;
double r728837 = tan(r728831);
double r728838 = sin(r728831);
double r728839 = r728837 / r728838;
double r728840 = cbrt(r728839);
double r728841 = cos(r728831);
double r728842 = r728838 / r728841;
double r728843 = r728842 / r728838;
double r728844 = cbrt(r728843);
double r728845 = r728840 * r728844;
double r728846 = r728845 * r728844;
double r728847 = r728836 ? r728846 : r728834;
double r728848 = r728833 ? r728834 : r728847;
return r728848;
}




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
(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)))))