\frac{1 - \cos x}{\sin x}\begin{array}{l}
\mathbf{if}\;\frac{1 - \cos x}{\sin x} \le -0.01419821707705988360348481336359327542596:\\
\;\;\;\;\frac{e^{\log \left(\frac{{1}^{3} - \cos x \cdot \left(\cos x \cdot \cos x\right)}{\cos x \cdot \left(1 + \cos x\right) + 1 \cdot 1}\right)}}{\sin x}\\
\mathbf{elif}\;\frac{1 - \cos x}{\sin x} \le 2.589932435073376851492402139776061176235 \cdot 10^{-5}:\\
\;\;\;\;\left(x \cdot \left(x \cdot \frac{1}{24}\right) + \frac{1}{2}\right) \cdot x + {x}^{5} \cdot \frac{1}{240}\\
\mathbf{else}:\\
\;\;\;\;\frac{e^{\log \left(\frac{{1}^{3} - \log \left(e^{{\left(\cos x\right)}^{3}}\right)}{\cos x \cdot \left(1 + \cos x\right) + 1 \cdot 1}\right)}}{\sin x}\\
\end{array}double f(double x) {
double r48296 = 1.0;
double r48297 = x;
double r48298 = cos(r48297);
double r48299 = r48296 - r48298;
double r48300 = sin(r48297);
double r48301 = r48299 / r48300;
return r48301;
}
double f(double x) {
double r48302 = 1.0;
double r48303 = x;
double r48304 = cos(r48303);
double r48305 = r48302 - r48304;
double r48306 = sin(r48303);
double r48307 = r48305 / r48306;
double r48308 = -0.014198217077059884;
bool r48309 = r48307 <= r48308;
double r48310 = 3.0;
double r48311 = pow(r48302, r48310);
double r48312 = r48304 * r48304;
double r48313 = r48304 * r48312;
double r48314 = r48311 - r48313;
double r48315 = r48302 + r48304;
double r48316 = r48304 * r48315;
double r48317 = r48302 * r48302;
double r48318 = r48316 + r48317;
double r48319 = r48314 / r48318;
double r48320 = log(r48319);
double r48321 = exp(r48320);
double r48322 = r48321 / r48306;
double r48323 = 2.589932435073377e-05;
bool r48324 = r48307 <= r48323;
double r48325 = 0.041666666666666664;
double r48326 = r48303 * r48325;
double r48327 = r48303 * r48326;
double r48328 = 0.5;
double r48329 = r48327 + r48328;
double r48330 = r48329 * r48303;
double r48331 = 5.0;
double r48332 = pow(r48303, r48331);
double r48333 = 0.004166666666666667;
double r48334 = r48332 * r48333;
double r48335 = r48330 + r48334;
double r48336 = pow(r48304, r48310);
double r48337 = exp(r48336);
double r48338 = log(r48337);
double r48339 = r48311 - r48338;
double r48340 = r48339 / r48318;
double r48341 = log(r48340);
double r48342 = exp(r48341);
double r48343 = r48342 / r48306;
double r48344 = r48324 ? r48335 : r48343;
double r48345 = r48309 ? r48322 : r48344;
return r48345;
}




Bits error versus x
Results
| Original | 30.2 |
|---|---|
| Target | 0.0 |
| Herbie | 0.7 |
if (/ (- 1.0 (cos x)) (sin x)) < -0.014198217077059884Initial program 0.8
rmApplied flip3--0.9
Simplified0.9
rmApplied add-exp-log0.9
Applied add-exp-log0.9
Applied div-exp1.0
Simplified0.9
rmApplied add-cbrt-cube1.2
Applied rem-cube-cbrt0.9
if -0.014198217077059884 < (/ (- 1.0 (cos x)) (sin x)) < 2.589932435073377e-05Initial program 59.8
Taylor expanded around 0 0.3
Simplified0.3
if 2.589932435073377e-05 < (/ (- 1.0 (cos x)) (sin x)) Initial program 1.1
rmApplied flip3--1.2
Simplified1.2
rmApplied add-exp-log1.2
Applied add-exp-log1.2
Applied div-exp1.2
Simplified1.2
rmApplied add-log-exp1.3
Final simplification0.7
herbie shell --seed 2019174
(FPCore (x)
:name "tanhf (example 3.4)"
:herbie-expected 2
:herbie-target
(tan (/ x 2.0))
(/ (- 1.0 (cos x)) (sin x)))