x + \left(y - z\right) \cdot \frac{t - x}{a - z}\begin{array}{l}
\mathbf{if}\;x + \left(y - z\right) \cdot \frac{t - x}{a - z} = -\infty:\\
\;\;\;\;x + \frac{\left(y - z\right) \cdot \left(t - x\right)}{a - z}\\
\mathbf{elif}\;x + \left(y - z\right) \cdot \frac{t - x}{a - z} \le -1.034567205203707255381370590550516843978 \cdot 10^{-307}:\\
\;\;\;\;x + \left(y - z\right) \cdot \frac{t - x}{a - z}\\
\mathbf{elif}\;x + \left(y - z\right) \cdot \frac{t - x}{a - z} \le 4.518115222418779116520672469794220737116 \cdot 10^{-285}:\\
\;\;\;\;\mathsf{fma}\left(\frac{x}{z}, y, t\right) - \frac{t \cdot y}{z}\\
\mathbf{else}:\\
\;\;\;\;\sqrt{\mathsf{fma}\left(\frac{y - z}{a - z}, t - x, x\right)} \cdot \sqrt{\mathsf{fma}\left(\frac{y - z}{a - z}, t - x, x\right)}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r89841 = x;
double r89842 = y;
double r89843 = z;
double r89844 = r89842 - r89843;
double r89845 = t;
double r89846 = r89845 - r89841;
double r89847 = a;
double r89848 = r89847 - r89843;
double r89849 = r89846 / r89848;
double r89850 = r89844 * r89849;
double r89851 = r89841 + r89850;
return r89851;
}
double f(double x, double y, double z, double t, double a) {
double r89852 = x;
double r89853 = y;
double r89854 = z;
double r89855 = r89853 - r89854;
double r89856 = t;
double r89857 = r89856 - r89852;
double r89858 = a;
double r89859 = r89858 - r89854;
double r89860 = r89857 / r89859;
double r89861 = r89855 * r89860;
double r89862 = r89852 + r89861;
double r89863 = -inf.0;
bool r89864 = r89862 <= r89863;
double r89865 = r89855 * r89857;
double r89866 = r89865 / r89859;
double r89867 = r89852 + r89866;
double r89868 = -1.0345672052037073e-307;
bool r89869 = r89862 <= r89868;
double r89870 = 4.518115222418779e-285;
bool r89871 = r89862 <= r89870;
double r89872 = r89852 / r89854;
double r89873 = fma(r89872, r89853, r89856);
double r89874 = r89856 * r89853;
double r89875 = r89874 / r89854;
double r89876 = r89873 - r89875;
double r89877 = r89855 / r89859;
double r89878 = fma(r89877, r89857, r89852);
double r89879 = sqrt(r89878);
double r89880 = r89879 * r89879;
double r89881 = r89871 ? r89876 : r89880;
double r89882 = r89869 ? r89862 : r89881;
double r89883 = r89864 ? r89867 : r89882;
return r89883;
}



Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus t



Bits error versus a
if (+ x (* (- y z) (/ (- t x) (- a z)))) < -inf.0Initial program 64.0
rmApplied associate-*r/6.5
if -inf.0 < (+ x (* (- y z) (/ (- t x) (- a z)))) < -1.0345672052037073e-307Initial program 5.1
if -1.0345672052037073e-307 < (+ x (* (- y z) (/ (- t x) (- a z)))) < 4.518115222418779e-285Initial program 60.8
Taylor expanded around inf 26.7
Simplified21.8
if 4.518115222418779e-285 < (+ x (* (- y z) (/ (- t x) (- a z)))) Initial program 7.5
Simplified7.5
rmApplied clear-num7.8
rmApplied add-sqr-sqrt8.2
Simplified8.6
Simplified5.3
Final simplification7.5
herbie shell --seed 2019235 +o rules:numerics
(FPCore (x y z t a)
:name "Numeric.Signal:interpolate from hsignal-0.2.7.1"
:precision binary64
(+ x (* (- y z) (/ (- t x) (- a z)))))