\frac{x - y}{z - y} \cdot t\begin{array}{l}
\mathbf{if}\;y \le -2.23864684832811672 \cdot 10^{-67} \lor \neg \left(y \le 6.8251508594710119 \cdot 10^{-35}\right):\\
\;\;\;\;\left(\frac{x}{z - y} - \frac{y}{z - y}\right) \cdot t\\
\mathbf{else}:\\
\;\;\;\;\left(x - y\right) \cdot \frac{t}{z - y}\\
\end{array}double f(double x, double y, double z, double t) {
double r549036 = x;
double r549037 = y;
double r549038 = r549036 - r549037;
double r549039 = z;
double r549040 = r549039 - r549037;
double r549041 = r549038 / r549040;
double r549042 = t;
double r549043 = r549041 * r549042;
return r549043;
}
double f(double x, double y, double z, double t) {
double r549044 = y;
double r549045 = -2.2386468483281167e-67;
bool r549046 = r549044 <= r549045;
double r549047 = 6.825150859471012e-35;
bool r549048 = r549044 <= r549047;
double r549049 = !r549048;
bool r549050 = r549046 || r549049;
double r549051 = x;
double r549052 = z;
double r549053 = r549052 - r549044;
double r549054 = r549051 / r549053;
double r549055 = r549044 / r549053;
double r549056 = r549054 - r549055;
double r549057 = t;
double r549058 = r549056 * r549057;
double r549059 = r549051 - r549044;
double r549060 = r549057 / r549053;
double r549061 = r549059 * r549060;
double r549062 = r549050 ? r549058 : r549061;
return r549062;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 2.0 |
|---|---|
| Target | 1.9 |
| Herbie | 2.3 |
if y < -2.2386468483281167e-67 or 6.825150859471012e-35 < y Initial program 0.2
rmApplied div-sub0.2
if -2.2386468483281167e-67 < y < 6.825150859471012e-35Initial program 4.7
rmApplied div-inv4.8
Applied associate-*l*5.7
Simplified5.6
Final simplification2.3
herbie shell --seed 2020027
(FPCore (x y z t)
:name "Numeric.Signal.Multichannel:$cput from hsignal-0.2.7.1"
:precision binary64
:herbie-target
(/ t (/ (- z y) (- x y)))
(* (/ (- x y) (- z y)) t))