\frac{\cos \left(2 \cdot x\right)}{{cos}^{2} \cdot \left(\left(x \cdot {sin}^{2}\right) \cdot x\right)}\begin{array}{l}
\mathbf{if}\;cos \le 4.24708257629406067 \cdot 10^{-274}:\\
\;\;\;\;\cos \left(2 \cdot x\right) \cdot \frac{1}{{\left(\left|{\left({cos}^{1} \cdot {sin}^{1}\right)}^{1} \cdot x\right|\right)}^{2}}\\
\mathbf{elif}\;cos \le 6.4244675320823765 \cdot 10^{214}:\\
\;\;\;\;\frac{\sqrt[3]{\cos \left(2 \cdot x\right)} \cdot \sqrt[3]{\cos \left(2 \cdot x\right)}}{\left|{cos}^{\left(\frac{2}{2}\right)} \cdot \left(x \cdot {sin}^{\left(\frac{2}{2}\right)}\right)\right|} \cdot \frac{\sqrt[3]{\cos \left(2 \cdot x\right)}}{\left|{cos}^{\left(\frac{2}{2}\right)} \cdot \left(x \cdot {sin}^{\left(\frac{2}{2}\right)}\right)\right|}\\
\mathbf{else}:\\
\;\;\;\;\frac{\cos \left(2 \cdot x\right)}{{\left(\left|sin \cdot \left(x \cdot cos\right)\right|\right)}^{2}}\\
\end{array}double f(double x, double cos, double sin) {
double r69545 = 2.0;
double r69546 = x;
double r69547 = r69545 * r69546;
double r69548 = cos(r69547);
double r69549 = cos;
double r69550 = pow(r69549, r69545);
double r69551 = sin;
double r69552 = pow(r69551, r69545);
double r69553 = r69546 * r69552;
double r69554 = r69553 * r69546;
double r69555 = r69550 * r69554;
double r69556 = r69548 / r69555;
return r69556;
}
double f(double x, double cos, double sin) {
double r69557 = cos;
double r69558 = 4.2470825762940607e-274;
bool r69559 = r69557 <= r69558;
double r69560 = 2.0;
double r69561 = x;
double r69562 = r69560 * r69561;
double r69563 = cos(r69562);
double r69564 = 1.0;
double r69565 = 1.0;
double r69566 = pow(r69557, r69565);
double r69567 = sin;
double r69568 = pow(r69567, r69565);
double r69569 = r69566 * r69568;
double r69570 = pow(r69569, r69565);
double r69571 = r69570 * r69561;
double r69572 = fabs(r69571);
double r69573 = 2.0;
double r69574 = pow(r69572, r69573);
double r69575 = r69564 / r69574;
double r69576 = r69563 * r69575;
double r69577 = 6.4244675320823765e+214;
bool r69578 = r69557 <= r69577;
double r69579 = cbrt(r69563);
double r69580 = r69579 * r69579;
double r69581 = r69560 / r69573;
double r69582 = pow(r69557, r69581);
double r69583 = pow(r69567, r69581);
double r69584 = r69561 * r69583;
double r69585 = r69582 * r69584;
double r69586 = fabs(r69585);
double r69587 = r69580 / r69586;
double r69588 = r69579 / r69586;
double r69589 = r69587 * r69588;
double r69590 = r69561 * r69557;
double r69591 = r69567 * r69590;
double r69592 = fabs(r69591);
double r69593 = pow(r69592, r69573);
double r69594 = r69563 / r69593;
double r69595 = r69578 ? r69589 : r69594;
double r69596 = r69559 ? r69576 : r69595;
return r69596;
}



Bits error versus x



Bits error versus cos



Bits error versus sin
Results
if cos < 4.2470825762940607e-274Initial program 28.9
rmApplied sqr-pow28.9
Applied associate-*r*23.2
rmApplied add-sqr-sqrt23.3
Simplified23.2
Simplified3.2
Taylor expanded around inf 2.8
rmApplied div-inv2.8
if 4.2470825762940607e-274 < cos < 6.4244675320823765e+214Initial program 28.2
rmApplied sqr-pow28.2
Applied associate-*r*20.9
rmApplied add-sqr-sqrt20.9
Simplified20.9
Simplified1.9
rmApplied add-cube-cbrt2.1
Applied times-frac1.8
if 6.4244675320823765e+214 < cos Initial program 24.4
rmApplied sqr-pow24.4
Applied associate-*r*21.2
rmApplied add-sqr-sqrt21.2
Simplified21.2
Simplified4.5
Taylor expanded around inf 2.2
Taylor expanded around 0 2.6
Final simplification2.4
herbie shell --seed 2020035
(FPCore (x cos sin)
:name "cos(2*x)/(cos^2(x)*sin^2(x))"
:precision binary64
(/ (cos (* 2 x)) (* (pow cos 2) (* (* x (pow sin 2)) x))))