\frac{\cos \left(2 \cdot x\right)}{{cos}^{2} \cdot \left(\left(x \cdot {sin}^{2}\right) \cdot x\right)}\frac{1}{\left|{cos}^{\left(\frac{2}{2}\right)} \cdot \left(x \cdot {sin}^{\left(\frac{2}{2}\right)}\right)\right|} \cdot \frac{\frac{\cos \left(2 \cdot x\right)}{\sqrt{\left|{cos}^{\left(\frac{2}{2}\right)} \cdot \left(x \cdot {sin}^{\left(\frac{2}{2}\right)}\right)\right|}}}{\sqrt{\left|{cos}^{\left(\frac{2}{2}\right)} \cdot \left(x \cdot {sin}^{\left(\frac{2}{2}\right)}\right)\right|}}double f(double x, double cos, double sin) {
double r58575 = 2.0;
double r58576 = x;
double r58577 = r58575 * r58576;
double r58578 = cos(r58577);
double r58579 = cos;
double r58580 = pow(r58579, r58575);
double r58581 = sin;
double r58582 = pow(r58581, r58575);
double r58583 = r58576 * r58582;
double r58584 = r58583 * r58576;
double r58585 = r58580 * r58584;
double r58586 = r58578 / r58585;
return r58586;
}
double f(double x, double cos, double sin) {
double r58587 = 1.0;
double r58588 = cos;
double r58589 = 2.0;
double r58590 = 2.0;
double r58591 = r58589 / r58590;
double r58592 = pow(r58588, r58591);
double r58593 = x;
double r58594 = sin;
double r58595 = pow(r58594, r58591);
double r58596 = r58593 * r58595;
double r58597 = r58592 * r58596;
double r58598 = fabs(r58597);
double r58599 = r58587 / r58598;
double r58600 = r58589 * r58593;
double r58601 = cos(r58600);
double r58602 = sqrt(r58598);
double r58603 = r58601 / r58602;
double r58604 = r58603 / r58602;
double r58605 = r58599 * r58604;
return r58605;
}



Bits error versus x



Bits error versus cos



Bits error versus sin
Results
Initial program 28.3
rmApplied sqr-pow28.3
Applied associate-*r*22.2
rmApplied add-sqr-sqrt22.3
Simplified22.2
Simplified2.9
rmApplied *-un-lft-identity2.9
Applied times-frac2.7
rmApplied add-sqr-sqrt2.7
Applied associate-/r*2.7
Final simplification2.7
herbie shell --seed 2020060
(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))))