\frac{\tan \left(\frac{x}{y \cdot 2}\right)}{\sin \left(\frac{x}{y \cdot 2}\right)}\begin{array}{l}
\mathbf{if}\;\frac{\tan \left(\frac{x}{y \cdot 2}\right)}{\sin \left(\frac{x}{y \cdot 2}\right)} \le 2.1006546564861388:\\
\;\;\;\;\frac{\sqrt[3]{\tan \left(\frac{x}{y \cdot 2}\right)} \cdot \sqrt[3]{\tan \left(\frac{x}{y \cdot 2}\right)}}{\sqrt[3]{\sin \left(\frac{x}{y \cdot 2}\right)} \cdot \sqrt[3]{\sin \left(\frac{x}{y \cdot 2}\right)}} \cdot \frac{\sqrt[3]{\tan \left(\frac{x}{y \cdot 2}\right)}}{\sqrt[3]{\sin \left(\frac{x}{y \cdot 2}\right)}}\\
\mathbf{else}:\\
\;\;\;\;1\\
\end{array}double f(double x, double y) {
double r771467 = x;
double r771468 = y;
double r771469 = 2.0;
double r771470 = r771468 * r771469;
double r771471 = r771467 / r771470;
double r771472 = tan(r771471);
double r771473 = sin(r771471);
double r771474 = r771472 / r771473;
return r771474;
}
double f(double x, double y) {
double r771475 = x;
double r771476 = y;
double r771477 = 2.0;
double r771478 = r771476 * r771477;
double r771479 = r771475 / r771478;
double r771480 = tan(r771479);
double r771481 = sin(r771479);
double r771482 = r771480 / r771481;
double r771483 = 2.100654656486139;
bool r771484 = r771482 <= r771483;
double r771485 = cbrt(r771480);
double r771486 = r771485 * r771485;
double r771487 = cbrt(r771481);
double r771488 = r771487 * r771487;
double r771489 = r771486 / r771488;
double r771490 = r771485 / r771487;
double r771491 = r771489 * r771490;
double r771492 = 1.0;
double r771493 = r771484 ? r771491 : r771492;
return r771493;
}




Bits error versus x




Bits error versus y
Results
| Original | 35.6 |
|---|---|
| Target | 28.8 |
| Herbie | 27.4 |
if (/ (tan (/ x (* y 2.0))) (sin (/ x (* y 2.0)))) < 2.100654656486139Initial program 24.2
rmApplied add-cube-cbrt24.9
Applied add-cube-cbrt24.2
Applied times-frac24.2
if 2.100654656486139 < (/ (tan (/ x (* y 2.0))) (sin (/ x (* y 2.0)))) Initial program 62.3
Taylor expanded around 0 34.8
Final simplification27.4
herbie shell --seed 2020083
(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)))))