Initial program 39.5
\[\cos \left(x + \varepsilon\right) - \cos x
\]
Applied egg-rr24.5
\[\leadsto \color{blue}{\mathsf{fma}\left(\cos x, \cos \varepsilon, -\left(\sin x \cdot \sin \varepsilon - \left(-\cos x\right)\right)\right)}
\]
Taylor expanded in x around inf 24.5
\[\leadsto \color{blue}{\cos \varepsilon \cdot \cos x - \left(\cos x + \sin x \cdot \sin \varepsilon\right)}
\]
Simplified6.4
\[\leadsto \color{blue}{\cos x \cdot \left(\cos \varepsilon + -1\right) - \sin \varepsilon \cdot \sin x}
\]
Proof
(-.f64 (*.f64 (cos.f64 x) (+.f64 (cos.f64 eps) -1)) (*.f64 (sin.f64 eps) (sin.f64 x))): 0 points increase in error, 0 points decrease in error
(-.f64 (*.f64 (cos.f64 x) (+.f64 (cos.f64 eps) (Rewrite<= metadata-eval (neg.f64 1)))) (*.f64 (sin.f64 eps) (sin.f64 x))): 0 points increase in error, 0 points decrease in error
(-.f64 (*.f64 (cos.f64 x) (Rewrite<= sub-neg_binary64 (-.f64 (cos.f64 eps) 1))) (*.f64 (sin.f64 eps) (sin.f64 x))): 0 points increase in error, 0 points decrease in error
(-.f64 (Rewrite<= distribute-lft-out--_binary64 (-.f64 (*.f64 (cos.f64 x) (cos.f64 eps)) (*.f64 (cos.f64 x) 1))) (*.f64 (sin.f64 eps) (sin.f64 x))): 14 points increase in error, 13 points decrease in error
(-.f64 (-.f64 (*.f64 (cos.f64 x) (cos.f64 eps)) (Rewrite=> *-rgt-identity_binary64 (cos.f64 x))) (*.f64 (sin.f64 eps) (sin.f64 x))): 0 points increase in error, 0 points decrease in error
(-.f64 (-.f64 (Rewrite<= *-commutative_binary64 (*.f64 (cos.f64 eps) (cos.f64 x))) (cos.f64 x)) (*.f64 (sin.f64 eps) (sin.f64 x))): 0 points increase in error, 0 points decrease in error
(-.f64 (-.f64 (*.f64 (cos.f64 eps) (cos.f64 x)) (cos.f64 x)) (Rewrite<= *-commutative_binary64 (*.f64 (sin.f64 x) (sin.f64 eps)))): 0 points increase in error, 0 points decrease in error
(Rewrite<= associate--r+_binary64 (-.f64 (*.f64 (cos.f64 eps) (cos.f64 x)) (+.f64 (cos.f64 x) (*.f64 (sin.f64 x) (sin.f64 eps))))): 108 points increase in error, 14 points decrease in error
Applied egg-rr0.6
\[\leadsto \color{blue}{\frac{\left(-{\sin \varepsilon}^{2}\right) \cdot \cos x}{\cos \varepsilon + 1}} - \sin \varepsilon \cdot \sin x
\]
Simplified0.3
\[\leadsto \color{blue}{\left(\frac{\sin \varepsilon}{-1} \cdot \tan \left(\frac{\varepsilon}{2}\right)\right) \cdot \cos x} - \sin \varepsilon \cdot \sin x
\]
Proof
(*.f64 (*.f64 (/.f64 (sin.f64 eps) -1) (tan.f64 (/.f64 eps 2))) (cos.f64 x)): 0 points increase in error, 0 points decrease in error
(*.f64 (*.f64 (/.f64 (sin.f64 eps) -1) (Rewrite<= hang-0p-tan_binary64 (/.f64 (sin.f64 eps) (+.f64 1 (cos.f64 eps))))) (cos.f64 x)): 42 points increase in error, 13 points decrease in error
(*.f64 (*.f64 (/.f64 (sin.f64 eps) -1) (/.f64 (sin.f64 eps) (Rewrite<= +-commutative_binary64 (+.f64 (cos.f64 eps) 1)))) (cos.f64 x)): 0 points increase in error, 0 points decrease in error
(*.f64 (Rewrite<= times-frac_binary64 (/.f64 (*.f64 (sin.f64 eps) (sin.f64 eps)) (*.f64 -1 (+.f64 (cos.f64 eps) 1)))) (cos.f64 x)): 25 points increase in error, 25 points decrease in error
(*.f64 (/.f64 (Rewrite<= unpow2_binary64 (pow.f64 (sin.f64 eps) 2)) (*.f64 -1 (+.f64 (cos.f64 eps) 1))) (cos.f64 x)): 0 points increase in error, 0 points decrease in error
(*.f64 (/.f64 (Rewrite<= remove-double-neg_binary64 (neg.f64 (neg.f64 (pow.f64 (sin.f64 eps) 2)))) (*.f64 -1 (+.f64 (cos.f64 eps) 1))) (cos.f64 x)): 0 points increase in error, 0 points decrease in error
(*.f64 (/.f64 (neg.f64 (Rewrite=> neg-mul-1_binary64 (*.f64 -1 (pow.f64 (sin.f64 eps) 2)))) (*.f64 -1 (+.f64 (cos.f64 eps) 1))) (cos.f64 x)): 0 points increase in error, 0 points decrease in error
(*.f64 (/.f64 (Rewrite=> distribute-lft-neg-in_binary64 (*.f64 (neg.f64 -1) (pow.f64 (sin.f64 eps) 2))) (*.f64 -1 (+.f64 (cos.f64 eps) 1))) (cos.f64 x)): 0 points increase in error, 0 points decrease in error
(*.f64 (/.f64 (*.f64 (Rewrite=> metadata-eval 1) (pow.f64 (sin.f64 eps) 2)) (*.f64 -1 (+.f64 (cos.f64 eps) 1))) (cos.f64 x)): 0 points increase in error, 0 points decrease in error
(*.f64 (Rewrite=> times-frac_binary64 (*.f64 (/.f64 1 -1) (/.f64 (pow.f64 (sin.f64 eps) 2) (+.f64 (cos.f64 eps) 1)))) (cos.f64 x)): 0 points increase in error, 0 points decrease in error
(*.f64 (*.f64 (Rewrite=> metadata-eval -1) (/.f64 (pow.f64 (sin.f64 eps) 2) (+.f64 (cos.f64 eps) 1))) (cos.f64 x)): 0 points increase in error, 0 points decrease in error
(*.f64 (Rewrite<= neg-mul-1_binary64 (neg.f64 (/.f64 (pow.f64 (sin.f64 eps) 2) (+.f64 (cos.f64 eps) 1)))) (cos.f64 x)): 0 points increase in error, 0 points decrease in error
(*.f64 (Rewrite<= distribute-frac-neg_binary64 (/.f64 (neg.f64 (pow.f64 (sin.f64 eps) 2)) (+.f64 (cos.f64 eps) 1))) (cos.f64 x)): 0 points increase in error, 0 points decrease in error
(Rewrite<= associate-/r/_binary64 (/.f64 (neg.f64 (pow.f64 (sin.f64 eps) 2)) (/.f64 (+.f64 (cos.f64 eps) 1) (cos.f64 x)))): 20 points increase in error, 14 points decrease in error
(Rewrite<= associate-/l*_binary64 (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 eps) 2)) (cos.f64 x)) (+.f64 (cos.f64 eps) 1))): 15 points increase in error, 12 points decrease in error
Applied egg-rr0.3
\[\leadsto \color{blue}{\left(-\sin \varepsilon\right) \cdot \left(\tan \left(\varepsilon \cdot 0.5\right) \cdot \cos x\right) + \left(-\sin \varepsilon\right) \cdot \sin x}
\]
Simplified0.3
\[\leadsto \color{blue}{\left(-\sin \varepsilon\right) \cdot \mathsf{fma}\left(\cos x, \tan \left(\varepsilon \cdot 0.5\right), \sin x\right)}
\]
Proof
(*.f64 (neg.f64 (sin.f64 eps)) (fma.f64 (cos.f64 x) (tan.f64 (*.f64 eps 1/2)) (sin.f64 x))): 0 points increase in error, 0 points decrease in error
(*.f64 (neg.f64 (sin.f64 eps)) (Rewrite<= fma-def_binary64 (+.f64 (*.f64 (cos.f64 x) (tan.f64 (*.f64 eps 1/2))) (sin.f64 x)))): 8 points increase in error, 2 points decrease in error
(*.f64 (neg.f64 (sin.f64 eps)) (+.f64 (Rewrite<= *-commutative_binary64 (*.f64 (tan.f64 (*.f64 eps 1/2)) (cos.f64 x))) (sin.f64 x))): 0 points increase in error, 0 points decrease in error
(Rewrite<= distribute-lft-out_binary64 (+.f64 (*.f64 (neg.f64 (sin.f64 eps)) (*.f64 (tan.f64 (*.f64 eps 1/2)) (cos.f64 x))) (*.f64 (neg.f64 (sin.f64 eps)) (sin.f64 x)))): 13 points increase in error, 7 points decrease in error
Final simplification0.3
\[\leadsto \sin \varepsilon \cdot \left(-\mathsf{fma}\left(\cos x, \tan \left(\varepsilon \cdot 0.5\right), \sin x\right)\right)
\]