\frac{x - \sin x}{x - \tan x}
\begin{array}{l}
t_0 := x - \tan x\\
t_1 := \frac{-1}{t_0}\\
t_2 := \mathsf{fma}\left(1, \frac{x}{t_0}, \sin x \cdot t_1\right)\\
\mathbf{if}\;x \leq -0.004881470445787531:\\
\;\;\;\;t_2 + \mathsf{fma}\left(t_1, \sin x, \frac{1}{t_0} \cdot \sin x\right)\\
\mathbf{elif}\;x \leq 0.005566771948535619:\\
\;\;\;\;\mathsf{fma}\left(0.225, x \cdot x, 0.00024107142857142857 \cdot {x}^{6}\right) - 0.5\\
\mathbf{else}:\\
\;\;\;\;t_2 + \mathsf{expm1}\left(\mathsf{log1p}\left(0\right)\right)\\
\end{array}
(FPCore (x) :precision binary64 (/ (- x (sin x)) (- x (tan x))))
(FPCore (x)
:precision binary64
(let* ((t_0 (- x (tan x)))
(t_1 (/ -1.0 t_0))
(t_2 (fma 1.0 (/ x t_0) (* (sin x) t_1))))
(if (<= x -0.004881470445787531)
(+ t_2 (fma t_1 (sin x) (* (/ 1.0 t_0) (sin x))))
(if (<= x 0.005566771948535619)
(- (fma 0.225 (* x x) (* 0.00024107142857142857 (pow x 6.0))) 0.5)
(+ t_2 (expm1 (log1p 0.0)))))))double code(double x) {
return (x - sin(x)) / (x - tan(x));
}
double code(double x) {
double t_0 = x - tan(x);
double t_1 = -1.0 / t_0;
double t_2 = fma(1.0, (x / t_0), (sin(x) * t_1));
double tmp;
if (x <= -0.004881470445787531) {
tmp = t_2 + fma(t_1, sin(x), ((1.0 / t_0) * sin(x)));
} else if (x <= 0.005566771948535619) {
tmp = fma(0.225, (x * x), (0.00024107142857142857 * pow(x, 6.0))) - 0.5;
} else {
tmp = t_2 + expm1(log1p(0.0));
}
return tmp;
}



Bits error versus x
if x < -0.0048814704457875308Initial program 0.1
Applied div-sub_binary640.1
Applied div-inv_binary640.1
Applied *-un-lft-identity_binary640.1
Applied prod-diff_binary640.1
if -0.0048814704457875308 < x < 0.00556677194853561885Initial program 63.3
Taylor expanded in x around 0 0.0
Simplified0.0
Taylor expanded in x around 0 0.1
if 0.00556677194853561885 < x Initial program 0.1
Applied div-sub_binary640.1
Applied div-inv_binary640.1
Applied *-un-lft-identity_binary640.1
Applied prod-diff_binary640.1
Applied expm1-log1p-u_binary640.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2022076
(FPCore (x)
:name "sintan (problem 3.4.5)"
:precision binary64
(/ (- x (sin x)) (- x (tan x))))