Initial program 39.9
\[\cos \left(x + \varepsilon\right) - \cos x
\]
Applied egg-rr24.2
\[\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.2
\[\leadsto \color{blue}{\cos \varepsilon \cdot \cos x - \left(\cos x + \sin x \cdot \sin \varepsilon\right)}
\]
Simplified6.6
\[\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))): 13 points increase in error, 5 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))))): 102 points increase in error, 20 points decrease in error
Applied egg-rr0.7
\[\leadsto \cos x \cdot \color{blue}{\left(\left(-{\sin \varepsilon}^{2}\right) \cdot \frac{1}{\cos \varepsilon + 1}\right)} - \sin \varepsilon \cdot \sin x
\]
Simplified0.3
\[\leadsto \cos x \cdot \color{blue}{\left(-\tan \left(\frac{\varepsilon}{2}\right) \cdot \sin \varepsilon\right)} - \sin \varepsilon \cdot \sin x
\]
Proof
(neg.f64 (*.f64 (tan.f64 (/.f64 eps 2)) (sin.f64 eps))): 0 points increase in error, 0 points decrease in error
(neg.f64 (*.f64 (Rewrite<= hang-0p-tan_binary64 (/.f64 (sin.f64 eps) (+.f64 1 (cos.f64 eps)))) (sin.f64 eps))): 38 points increase in error, 21 points decrease in error
(neg.f64 (*.f64 (/.f64 (sin.f64 eps) (Rewrite<= +-commutative_binary64 (+.f64 (cos.f64 eps) 1))) (sin.f64 eps))): 0 points increase in error, 0 points decrease in error
(neg.f64 (Rewrite<= associate-/r/_binary64 (/.f64 (sin.f64 eps) (/.f64 (+.f64 (cos.f64 eps) 1) (sin.f64 eps))))): 43 points increase in error, 36 points decrease in error
(neg.f64 (Rewrite<= associate-/l*_binary64 (/.f64 (*.f64 (sin.f64 eps) (sin.f64 eps)) (+.f64 (cos.f64 eps) 1)))): 31 points increase in error, 42 points decrease in error
(neg.f64 (/.f64 (Rewrite<= unpow2_binary64 (pow.f64 (sin.f64 eps) 2)) (+.f64 (cos.f64 eps) 1))): 0 points increase in error, 0 points decrease in error
(Rewrite<= distribute-frac-neg_binary64 (/.f64 (neg.f64 (pow.f64 (sin.f64 eps) 2)) (+.f64 (cos.f64 eps) 1))): 0 points increase in error, 0 points decrease in error
(/.f64 (Rewrite<= *-rgt-identity_binary64 (*.f64 (neg.f64 (pow.f64 (sin.f64 eps) 2)) 1)) (+.f64 (cos.f64 eps) 1)): 0 points increase in error, 0 points decrease in error
(Rewrite<= associate-*r/_binary64 (*.f64 (neg.f64 (pow.f64 (sin.f64 eps) 2)) (/.f64 1 (+.f64 (cos.f64 eps) 1)))): 19 points increase in error, 23 points decrease in error
Applied egg-rr0.3
\[\leadsto \color{blue}{\left(-\mathsf{fma}\left(\cos x, \tan \left(\varepsilon \cdot 0.5\right) \cdot \sin \varepsilon, \sin \varepsilon \cdot \sin x\right)\right) + \mathsf{fma}\left(\sin \varepsilon, -\sin x, \sin \varepsilon \cdot \sin x\right)}
\]
Simplified0.3
\[\leadsto \color{blue}{\left(-\sin \varepsilon\right) \cdot \left(\cos x \cdot \tan \left(0.5 \cdot \varepsilon\right) + \sin x\right)}
\]
Proof
(*.f64 (neg.f64 (sin.f64 eps)) (+.f64 (*.f64 (cos.f64 x) (tan.f64 (*.f64 1/2 eps))) (sin.f64 x))): 0 points increase in error, 0 points decrease in error
(*.f64 (neg.f64 (sin.f64 eps)) (+.f64 (*.f64 (cos.f64 x) (tan.f64 (Rewrite=> *-commutative_binary64 (*.f64 eps 1/2)))) (sin.f64 x))): 0 points increase in error, 0 points decrease in error
(Rewrite<= distribute-rgt-out_binary64 (+.f64 (*.f64 (*.f64 (cos.f64 x) (tan.f64 (*.f64 eps 1/2))) (neg.f64 (sin.f64 eps))) (*.f64 (sin.f64 x) (neg.f64 (sin.f64 eps))))): 17 points increase in error, 15 points decrease in error
(+.f64 (Rewrite=> distribute-rgt-neg-out_binary64 (neg.f64 (*.f64 (*.f64 (cos.f64 x) (tan.f64 (*.f64 eps 1/2))) (sin.f64 eps)))) (*.f64 (sin.f64 x) (neg.f64 (sin.f64 eps)))): 0 points increase in error, 0 points decrease in error
(+.f64 (neg.f64 (Rewrite<= associate-*r*_binary64 (*.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps))))) (*.f64 (sin.f64 x) (neg.f64 (sin.f64 eps)))): 6 points increase in error, 6 points decrease in error
(+.f64 (neg.f64 (*.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)))) (Rewrite=> distribute-rgt-neg-out_binary64 (neg.f64 (*.f64 (sin.f64 x) (sin.f64 eps))))): 0 points increase in error, 0 points decrease in error
(+.f64 (neg.f64 (*.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)))) (neg.f64 (Rewrite<= *-commutative_binary64 (*.f64 (sin.f64 eps) (sin.f64 x))))): 0 points increase in error, 0 points decrease in error
(Rewrite=> distribute-neg-out_binary64 (neg.f64 (+.f64 (*.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps))) (*.f64 (sin.f64 eps) (sin.f64 x))))): 0 points increase in error, 0 points decrease in error
(neg.f64 (Rewrite<= fma-udef_binary64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x))))): 7 points increase in error, 8 points decrease in error
(Rewrite<= +-rgt-identity_binary64 (+.f64 (neg.f64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x)))) 0)): 0 points increase in error, 0 points decrease in error
(+.f64 (neg.f64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x)))) (Rewrite<= metadata-eval (log.f64 1))): 0 points increase in error, 0 points decrease in error
(+.f64 (neg.f64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x)))) (log.f64 (Rewrite<= lft-mult-inverse_binary64 (*.f64 (/.f64 1 (pow.f64 (exp.f64 (sin.f64 x)) (sin.f64 eps))) (pow.f64 (exp.f64 (sin.f64 x)) (sin.f64 eps)))))): 12 points increase in error, 2 points decrease in error
(+.f64 (neg.f64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x)))) (log.f64 (*.f64 (/.f64 1 (Rewrite<= exp-prod_binary64 (exp.f64 (*.f64 (sin.f64 x) (sin.f64 eps))))) (pow.f64 (exp.f64 (sin.f64 x)) (sin.f64 eps))))): 13 points increase in error, 1 points decrease in error
(+.f64 (neg.f64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x)))) (log.f64 (*.f64 (/.f64 1 (exp.f64 (Rewrite<= *-commutative_binary64 (*.f64 (sin.f64 eps) (sin.f64 x))))) (pow.f64 (exp.f64 (sin.f64 x)) (sin.f64 eps))))): 0 points increase in error, 0 points decrease in error
(+.f64 (neg.f64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x)))) (log.f64 (*.f64 (Rewrite<= exp-neg_binary64 (exp.f64 (neg.f64 (*.f64 (sin.f64 eps) (sin.f64 x))))) (pow.f64 (exp.f64 (sin.f64 x)) (sin.f64 eps))))): 10 points increase in error, 9 points decrease in error
(+.f64 (neg.f64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x)))) (log.f64 (*.f64 (exp.f64 (Rewrite<= distribute-rgt-neg-out_binary64 (*.f64 (sin.f64 eps) (neg.f64 (sin.f64 x))))) (pow.f64 (exp.f64 (sin.f64 x)) (sin.f64 eps))))): 0 points increase in error, 0 points decrease in error
(+.f64 (neg.f64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x)))) (log.f64 (*.f64 (exp.f64 (*.f64 (sin.f64 eps) (neg.f64 (sin.f64 x)))) (Rewrite<= exp-prod_binary64 (exp.f64 (*.f64 (sin.f64 x) (sin.f64 eps))))))): 4 points increase in error, 10 points decrease in error
(+.f64 (neg.f64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x)))) (log.f64 (*.f64 (exp.f64 (*.f64 (sin.f64 eps) (neg.f64 (sin.f64 x)))) (exp.f64 (Rewrite<= *-commutative_binary64 (*.f64 (sin.f64 eps) (sin.f64 x))))))): 0 points increase in error, 0 points decrease in error
(+.f64 (neg.f64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x)))) (log.f64 (Rewrite<= exp-sum_binary64 (exp.f64 (+.f64 (*.f64 (sin.f64 eps) (neg.f64 (sin.f64 x))) (*.f64 (sin.f64 eps) (sin.f64 x))))))): 1 points increase in error, 18 points decrease in error
(+.f64 (neg.f64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x)))) (log.f64 (exp.f64 (Rewrite<= fma-udef_binary64 (fma.f64 (sin.f64 eps) (neg.f64 (sin.f64 x)) (*.f64 (sin.f64 eps) (sin.f64 x))))))): 0 points increase in error, 0 points decrease in error
(+.f64 (neg.f64 (fma.f64 (cos.f64 x) (*.f64 (tan.f64 (*.f64 eps 1/2)) (sin.f64 eps)) (*.f64 (sin.f64 eps) (sin.f64 x)))) (Rewrite=> rem-log-exp_binary64 (fma.f64 (sin.f64 eps) (neg.f64 (sin.f64 x)) (*.f64 (sin.f64 eps) (sin.f64 x))))): 8 points increase in error, 4 points decrease in error
Final simplification0.3
\[\leadsto \sin \varepsilon \cdot \left(\left(-\sin x\right) - \cos x \cdot \tan \left(\varepsilon \cdot 0.5\right)\right)
\]