Average Error: 39.6 → 1.3
Time: 5.5s
Precision: binary64
\[\cos \left(x + \varepsilon\right) - \cos x\]
\[-2 \cdot \left(\left(\sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)} \cdot \sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)}\right) \cdot \left(\sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)} \cdot \left(\sin x \cdot \cos \left(\varepsilon \cdot 0.5\right) + \cos x \cdot \sin \left(\varepsilon \cdot 0.5\right)\right)\right)\right)\]
\cos \left(x + \varepsilon\right) - \cos x
-2 \cdot \left(\left(\sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)} \cdot \sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)}\right) \cdot \left(\sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)} \cdot \left(\sin x \cdot \cos \left(\varepsilon \cdot 0.5\right) + \cos x \cdot \sin \left(\varepsilon \cdot 0.5\right)\right)\right)\right)
(FPCore (x eps) :precision binary64 (- (cos (+ x eps)) (cos x)))
(FPCore (x eps)
 :precision binary64
 (*
  -2.0
  (*
   (* (cbrt (sin (/ eps 2.0))) (cbrt (sin (/ eps 2.0))))
   (*
    (cbrt (sin (/ eps 2.0)))
    (+ (* (sin x) (cos (* eps 0.5))) (* (cos x) (sin (* eps 0.5))))))))
double code(double x, double eps) {
	return cos(x + eps) - cos(x);
}
double code(double x, double eps) {
	return -2.0 * ((cbrt(sin(eps / 2.0)) * cbrt(sin(eps / 2.0))) * (cbrt(sin(eps / 2.0)) * ((sin(x) * cos(eps * 0.5)) + (cos(x) * sin(eps * 0.5)))));
}

Error

Bits error versus x

Bits error versus eps

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Derivation

  1. Initial program 39.6

    \[\cos \left(x + \varepsilon\right) - \cos x\]
  2. Using strategy rm
  3. Applied diff-cos_binary6434.0

    \[\leadsto \color{blue}{-2 \cdot \left(\sin \left(\frac{\left(x + \varepsilon\right) - x}{2}\right) \cdot \sin \left(\frac{\left(x + \varepsilon\right) + x}{2}\right)\right)}\]
  4. Simplified14.9

    \[\leadsto -2 \cdot \color{blue}{\left(\sin \left(\frac{\varepsilon}{2}\right) \cdot \sin \left(\frac{x + \left(x + \varepsilon\right)}{2}\right)\right)}\]
  5. Using strategy rm
  6. Applied add-cube-cbrt_binary6415.6

    \[\leadsto -2 \cdot \left(\color{blue}{\left(\left(\sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)} \cdot \sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)}\right) \cdot \sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)}\right)} \cdot \sin \left(\frac{x + \left(x + \varepsilon\right)}{2}\right)\right)\]
  7. Applied associate-*l*_binary6415.6

    \[\leadsto -2 \cdot \color{blue}{\left(\left(\sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)} \cdot \sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)}\right) \cdot \left(\sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)} \cdot \sin \left(\frac{x + \left(x + \varepsilon\right)}{2}\right)\right)\right)}\]
  8. Simplified15.6

    \[\leadsto -2 \cdot \left(\left(\sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)} \cdot \sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)}\right) \cdot \color{blue}{\left(\sin \left(x + \varepsilon \cdot 0.5\right) \cdot \sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)}\right)}\right)\]
  9. Using strategy rm
  10. Applied sin-sum_binary641.3

    \[\leadsto -2 \cdot \left(\left(\sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)} \cdot \sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)}\right) \cdot \left(\color{blue}{\left(\sin x \cdot \cos \left(\varepsilon \cdot 0.5\right) + \cos x \cdot \sin \left(\varepsilon \cdot 0.5\right)\right)} \cdot \sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)}\right)\right)\]
  11. Final simplification1.3

    \[\leadsto -2 \cdot \left(\left(\sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)} \cdot \sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)}\right) \cdot \left(\sqrt[3]{\sin \left(\frac{\varepsilon}{2}\right)} \cdot \left(\sin x \cdot \cos \left(\varepsilon \cdot 0.5\right) + \cos x \cdot \sin \left(\varepsilon \cdot 0.5\right)\right)\right)\right)\]

Reproduce

herbie shell --seed 2020232 
(FPCore (x eps)
  :name "2cos (problem 3.3.5)"
  :precision binary64
  (- (cos (+ x eps)) (cos x)))