\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:\\
\;\;\;\;1 \cdot \left(\frac{t}{z - y} \cdot \left(x - y\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{x - y}{z - y} \cdot t\\
\end{array}double f(double x, double y, double z, double t) {
double r473850 = x;
double r473851 = y;
double r473852 = r473850 - r473851;
double r473853 = z;
double r473854 = r473853 - r473851;
double r473855 = r473852 / r473854;
double r473856 = t;
double r473857 = r473855 * r473856;
return r473857;
}
double f(double x, double y, double z, double t) {
double r473858 = x;
double r473859 = y;
double r473860 = r473858 - r473859;
double r473861 = z;
double r473862 = r473861 - r473859;
double r473863 = r473860 / r473862;
double r473864 = -1.4772699565267299e-242;
bool r473865 = r473863 <= r473864;
double r473866 = 1.0;
double r473867 = t;
double r473868 = r473862 / r473860;
double r473869 = r473867 / r473868;
double r473870 = r473866 * r473869;
double r473871 = -0.0;
bool r473872 = r473863 <= r473871;
double r473873 = r473867 / r473862;
double r473874 = r473873 * r473860;
double r473875 = r473866 * r473874;
double r473876 = r473863 * r473867;
double r473877 = r473872 ? r473875 : r473876;
double r473878 = r473865 ? r473870 : r473877;
return r473878;
}




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 *-un-lft-identity2.8
Applied times-frac2.8
Applied *-un-lft-identity2.8
Applied times-frac2.8
Applied associate-*l*2.8
Simplified2.5
if -1.4772699565267299e-242 < (/ (- x y) (- z y)) < -0.0Initial program 13.3
rmApplied clear-num14.8
rmApplied *-un-lft-identity14.8
Applied *-un-lft-identity14.8
Applied times-frac14.8
Applied *-un-lft-identity14.8
Applied times-frac14.8
Applied associate-*l*14.8
Simplified14.7
rmApplied associate-/r/0.2
if -0.0 < (/ (- x y) (- z y)) Initial program 1.6
Final simplification1.4
herbie shell --seed 2020001
(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))