Average Error: 0.2 → 0
Time: 3.6s
Precision: binary64
\[\frac{\left(\frac{\sin \varepsilon}{\cos x \cdot \cos \varepsilon} \cdot \cos x\right) \cdot \cos \varepsilon}{\sin \varepsilon}\]
\[1\]
\frac{\left(\frac{\sin \varepsilon}{\cos x \cdot \cos \varepsilon} \cdot \cos x\right) \cdot \cos \varepsilon}{\sin \varepsilon}
1
double code(double eps, double x) {
	return ((double) (((double) (((double) (((double) (((double) sin(eps)) / ((double) (((double) cos(x)) * ((double) cos(eps)))))) * ((double) cos(x)))) * ((double) cos(eps)))) / ((double) sin(eps))));
}
double code(double eps, double x) {
	return 1.0;
}

Error

Bits error versus eps

Bits error versus x

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Derivation

  1. Initial program 0.2

    \[\frac{\left(\frac{\sin \varepsilon}{\cos x \cdot \cos \varepsilon} \cdot \cos x\right) \cdot \cos \varepsilon}{\sin \varepsilon}\]
  2. Simplified0

    \[\leadsto \color{blue}{1}\]
  3. Final simplification0

    \[\leadsto 1\]

Reproduce

herbie shell --seed 2020152 
(FPCore (eps x)
  :name "(/ (* (* (/ (sin eps) (* (cos x) (cos eps))) (cos x)) (cos eps)) (sin eps))"
  :precision binary64
  (/ (* (* (/ (sin eps) (* (cos x) (cos eps))) (cos x)) (cos eps)) (sin eps)))