\frac{x - y}{z - y} \cdot t\begin{array}{l}
\mathbf{if}\;\frac{x - y}{z - y} \le -1.477269956526729882709689256541591977713 \cdot 10^{-242}:\\
\;\;\;\;1 \cdot \frac{t}{\frac{z - y}{x - y}}\\
\mathbf{elif}\;\frac{x - y}{z - y} \le -0.0:\\
\;\;\;\;\left(x - y\right) \cdot \frac{t}{z - y}\\
\mathbf{else}:\\
\;\;\;\;\frac{x - y}{z - y} \cdot t\\
\end{array}double f(double x, double y, double z, double t) {
double r423000 = x;
double r423001 = y;
double r423002 = r423000 - r423001;
double r423003 = z;
double r423004 = r423003 - r423001;
double r423005 = r423002 / r423004;
double r423006 = t;
double r423007 = r423005 * r423006;
return r423007;
}
double f(double x, double y, double z, double t) {
double r423008 = x;
double r423009 = y;
double r423010 = r423008 - r423009;
double r423011 = z;
double r423012 = r423011 - r423009;
double r423013 = r423010 / r423012;
double r423014 = -1.4772699565267299e-242;
bool r423015 = r423013 <= r423014;
double r423016 = 1.0;
double r423017 = t;
double r423018 = r423012 / r423010;
double r423019 = r423017 / r423018;
double r423020 = r423016 * r423019;
double r423021 = -0.0;
bool r423022 = r423013 <= r423021;
double r423023 = r423017 / r423012;
double r423024 = r423010 * r423023;
double r423025 = r423013 * r423017;
double r423026 = r423022 ? r423024 : r423025;
double r423027 = r423015 ? r423020 : r423026;
return r423027;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 2.4 |
|---|---|
| Target | 2.4 |
| Herbie | 1.4 |
if (/ (- x y) (- z y)) < -1.4772699565267299e-242Initial program 2.7
rmApplied clear-num2.8
rmApplied *-un-lft-identity2.8
Applied associate-*l*2.8
Simplified2.5
if -1.4772699565267299e-242 < (/ (- x y) (- z y)) < -0.0Initial program 13.3
rmApplied div-inv13.3
Applied associate-*l*0.2
Simplified0.2
if -0.0 < (/ (- x y) (- z y)) Initial program 1.6
Final simplification1.4
herbie shell --seed 2020001 +o rules:numerics
(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))