\frac{1 - \tan x \cdot \tan x}{1 + \tan x \cdot \tan x}\left(\tan x + \sqrt{1}\right) \cdot \frac{\frac{1 - \tan x \cdot \tan x}{\mathsf{fma}\left(\tan x, \tan x, 1\right)}}{\sqrt{1} + \tan x}double f(double x) {
double r14029 = 1.0;
double r14030 = x;
double r14031 = tan(r14030);
double r14032 = r14031 * r14031;
double r14033 = r14029 - r14032;
double r14034 = r14029 + r14032;
double r14035 = r14033 / r14034;
return r14035;
}
double f(double x) {
double r14036 = x;
double r14037 = tan(r14036);
double r14038 = 1.0;
double r14039 = sqrt(r14038);
double r14040 = r14037 + r14039;
double r14041 = r14037 * r14037;
double r14042 = r14038 - r14041;
double r14043 = fma(r14037, r14037, r14038);
double r14044 = r14042 / r14043;
double r14045 = r14039 + r14037;
double r14046 = r14044 / r14045;
double r14047 = r14040 * r14046;
return r14047;
}



Bits error versus x
Initial program 0.3
rmApplied clear-num0.4
Simplified0.4
rmApplied add-sqr-sqrt0.4
Applied difference-of-squares0.4
Applied *-un-lft-identity0.4
Applied times-frac0.4
Applied add-cube-cbrt0.4
Applied times-frac0.4
Simplified0.4
Simplified0.4
rmApplied flip--0.4
Applied associate-/r/0.4
Applied associate-/r*0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2020047 +o rules:numerics
(FPCore (x)
:name "Trigonometry B"
:precision binary64
(/ (- 1 (* (tan x) (tan x))) (+ 1 (* (tan x) (tan x)))))