x + \left(y - z\right) \cdot \frac{t - x}{a - z}\begin{array}{l}
\mathbf{if}\;z \le -8.629542751842365 \cdot 10^{+143}:\\
\;\;\;\;\mathsf{fma}\left(\frac{x}{z}, y, t - \frac{t}{z} \cdot y\right)\\
\mathbf{elif}\;z \le 13189468142.046627:\\
\;\;\;\;\mathsf{fma}\left(\sqrt[3]{x} \cdot \sqrt[3]{x}, \sqrt[3]{x}, \left(\left(\sqrt[3]{t - x} \cdot \sqrt[3]{t - x}\right) \cdot \frac{y - z}{\sqrt[3]{a - z} \cdot \sqrt[3]{a - z}}\right) \cdot \frac{\sqrt[3]{t - x}}{\sqrt[3]{a - z}}\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{x}{z}, y, t - \frac{t}{z} \cdot y\right)\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r5737835 = x;
double r5737836 = y;
double r5737837 = z;
double r5737838 = r5737836 - r5737837;
double r5737839 = t;
double r5737840 = r5737839 - r5737835;
double r5737841 = a;
double r5737842 = r5737841 - r5737837;
double r5737843 = r5737840 / r5737842;
double r5737844 = r5737838 * r5737843;
double r5737845 = r5737835 + r5737844;
return r5737845;
}
double f(double x, double y, double z, double t, double a) {
double r5737846 = z;
double r5737847 = -8.629542751842365e+143;
bool r5737848 = r5737846 <= r5737847;
double r5737849 = x;
double r5737850 = r5737849 / r5737846;
double r5737851 = y;
double r5737852 = t;
double r5737853 = r5737852 / r5737846;
double r5737854 = r5737853 * r5737851;
double r5737855 = r5737852 - r5737854;
double r5737856 = fma(r5737850, r5737851, r5737855);
double r5737857 = 13189468142.046627;
bool r5737858 = r5737846 <= r5737857;
double r5737859 = cbrt(r5737849);
double r5737860 = r5737859 * r5737859;
double r5737861 = r5737852 - r5737849;
double r5737862 = cbrt(r5737861);
double r5737863 = r5737862 * r5737862;
double r5737864 = r5737851 - r5737846;
double r5737865 = a;
double r5737866 = r5737865 - r5737846;
double r5737867 = cbrt(r5737866);
double r5737868 = r5737867 * r5737867;
double r5737869 = r5737864 / r5737868;
double r5737870 = r5737863 * r5737869;
double r5737871 = r5737862 / r5737867;
double r5737872 = r5737870 * r5737871;
double r5737873 = fma(r5737860, r5737859, r5737872);
double r5737874 = r5737858 ? r5737873 : r5737856;
double r5737875 = r5737848 ? r5737856 : r5737874;
return r5737875;
}



Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus t



Bits error versus a
if z < -8.629542751842365e+143 or 13189468142.046627 < z Initial program 23.0
rmApplied add-cube-cbrt23.6
Applied add-cube-cbrt23.7
Applied times-frac23.7
Applied associate-*r*20.9
Simplified21.1
Taylor expanded around inf 27.7
Simplified20.4
if -8.629542751842365e+143 < z < 13189468142.046627Initial program 8.3
rmApplied add-cube-cbrt8.9
Applied add-cube-cbrt9.0
Applied times-frac9.0
Applied associate-*r*6.0
Simplified6.0
rmApplied add-cube-cbrt6.5
Applied fma-def6.5
rmApplied frac-times6.5
Applied associate-/r/6.8
Final simplification12.4
herbie shell --seed 2019164 +o rules:numerics
(FPCore (x y z t a)
:name "Numeric.Signal:interpolate from hsignal-0.2.7.1"
(+ x (* (- y z) (/ (- t x) (- a z)))))