\frac{\cosh x \cdot \frac{y}{x}}{z}\begin{array}{l}
\mathbf{if}\;z \le -3775038362858526700 \lor \neg \left(z \le 7.25860780760428 \cdot 10^{-28}\right):\\
\;\;\;\;\cosh x \cdot \frac{y}{x \cdot z}\\
\mathbf{else}:\\
\;\;\;\;\left(\cosh x \cdot \frac{y}{x}\right) \cdot \frac{1}{z}\\
\end{array}double f(double x, double y, double z) {
double r468216 = x;
double r468217 = cosh(r468216);
double r468218 = y;
double r468219 = r468218 / r468216;
double r468220 = r468217 * r468219;
double r468221 = z;
double r468222 = r468220 / r468221;
return r468222;
}
double f(double x, double y, double z) {
double r468223 = z;
double r468224 = -3.7750383628585267e+18;
bool r468225 = r468223 <= r468224;
double r468226 = 7.25860780760428e-28;
bool r468227 = r468223 <= r468226;
double r468228 = !r468227;
bool r468229 = r468225 || r468228;
double r468230 = x;
double r468231 = cosh(r468230);
double r468232 = y;
double r468233 = r468230 * r468223;
double r468234 = r468232 / r468233;
double r468235 = r468231 * r468234;
double r468236 = r468232 / r468230;
double r468237 = r468231 * r468236;
double r468238 = 1.0;
double r468239 = r468238 / r468223;
double r468240 = r468237 * r468239;
double r468241 = r468229 ? r468235 : r468240;
return r468241;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 8.0 |
|---|---|
| Target | 0.4 |
| Herbie | 0.4 |
if z < -3.7750383628585267e+18 or 7.25860780760428e-28 < z Initial program 11.9
rmApplied *-un-lft-identity11.9
Applied times-frac11.9
Simplified11.9
Simplified0.3
if -3.7750383628585267e+18 < z < 7.25860780760428e-28Initial program 0.4
rmApplied div-inv0.5
Final simplification0.4
herbie shell --seed 2020036 +o rules:numerics
(FPCore (x y z)
:name "Linear.Quaternion:$ctan from linear-1.19.1.3"
:precision binary64
:herbie-target
(if (< y -4.618902267687042e-52) (* (/ (/ y z) x) (cosh x)) (if (< y 1.0385305359351529e-39) (/ (/ (* (cosh x) y) x) z) (* (/ (/ y z) x) (cosh x))))
(/ (* (cosh x) (/ y x)) z))