\frac{1}{x} - \frac{1}{\tan x}0.02222222222222222307030925492199457949027 \cdot {x}^{3} + \left(0.002116402116402116544841005563171165704262 \cdot {x}^{5} + 0.3333333333333333148296162562473909929395 \cdot x\right)double f(double x) {
double r105692 = 1.0;
double r105693 = x;
double r105694 = r105692 / r105693;
double r105695 = tan(r105693);
double r105696 = r105692 / r105695;
double r105697 = r105694 - r105696;
return r105697;
}
double f(double x) {
double r105698 = 0.022222222222222223;
double r105699 = x;
double r105700 = 3.0;
double r105701 = pow(r105699, r105700);
double r105702 = r105698 * r105701;
double r105703 = 0.0021164021164021165;
double r105704 = 5.0;
double r105705 = pow(r105699, r105704);
double r105706 = r105703 * r105705;
double r105707 = 0.3333333333333333;
double r105708 = r105707 * r105699;
double r105709 = r105706 + r105708;
double r105710 = r105702 + r105709;
return r105710;
}




Bits error versus x
Results
| Original | 59.9 |
|---|---|
| Target | 0.1 |
| Herbie | 0.3 |
Initial program 59.9
Taylor expanded around 0 0.3
Final simplification0.3
herbie shell --seed 2019325
(FPCore (x)
:name "invcot (example 3.9)"
:precision binary64
:pre (and (< -0.026 x) (< x 0.026))
:herbie-target
(if (< (fabs x) 0.026) (* (/ x 3) (+ 1 (/ (* x x) 15))) (- (/ 1 x) (/ 1 (tan x))))
(- (/ 1 x) (/ 1 (tan x))))