x + \frac{\left(y - x\right) \cdot z}{t}\begin{array}{l}
\mathbf{if}\;t \le -1.229651158615936528983347561392124591292 \cdot 10^{-21}:\\
\;\;\;\;\mathsf{fma}\left(\frac{y - x}{t}, z, x\right)\\
\mathbf{elif}\;t \le 1.625406329571911990929648461559105916592 \cdot 10^{-217}:\\
\;\;\;\;x + \frac{1}{t} \cdot \left(\left(y - x\right) \cdot z\right)\\
\mathbf{else}:\\
\;\;\;\;x + \frac{y - x}{\sqrt[3]{t} \cdot \sqrt[3]{t}} \cdot \frac{z}{\sqrt[3]{t}}\\
\end{array}double f(double x, double y, double z, double t) {
double r477740 = x;
double r477741 = y;
double r477742 = r477741 - r477740;
double r477743 = z;
double r477744 = r477742 * r477743;
double r477745 = t;
double r477746 = r477744 / r477745;
double r477747 = r477740 + r477746;
return r477747;
}
double f(double x, double y, double z, double t) {
double r477748 = t;
double r477749 = -1.2296511586159365e-21;
bool r477750 = r477748 <= r477749;
double r477751 = y;
double r477752 = x;
double r477753 = r477751 - r477752;
double r477754 = r477753 / r477748;
double r477755 = z;
double r477756 = fma(r477754, r477755, r477752);
double r477757 = 1.625406329571912e-217;
bool r477758 = r477748 <= r477757;
double r477759 = 1.0;
double r477760 = r477759 / r477748;
double r477761 = r477753 * r477755;
double r477762 = r477760 * r477761;
double r477763 = r477752 + r477762;
double r477764 = cbrt(r477748);
double r477765 = r477764 * r477764;
double r477766 = r477753 / r477765;
double r477767 = r477755 / r477764;
double r477768 = r477766 * r477767;
double r477769 = r477752 + r477768;
double r477770 = r477758 ? r477763 : r477769;
double r477771 = r477750 ? r477756 : r477770;
return r477771;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
| Original | 6.6 |
|---|---|
| Target | 2.0 |
| Herbie | 2.5 |
if t < -1.2296511586159365e-21Initial program 9.1
Simplified1.1
if -1.2296511586159365e-21 < t < 1.625406329571912e-217Initial program 2.0
rmApplied associate-/l*3.8
rmApplied div-inv3.9
Applied *-un-lft-identity3.9
Applied times-frac2.1
Simplified2.1
if 1.625406329571912e-217 < t Initial program 6.8
rmApplied add-cube-cbrt7.2
Applied times-frac3.7
Final simplification2.5
herbie shell --seed 2020001 +o rules:numerics
(FPCore (x y z t)
:name "Numeric.Histogram:binBounds from Chart-1.5.3"
:precision binary64
:herbie-target
(if (< x -9.025511195533005e-135) (- x (* (/ z t) (- x y))) (if (< x 4.275032163700715e-250) (+ x (* (/ (- y x) t) z)) (+ x (/ (- y x) (/ t z)))))
(+ x (/ (* (- y x) z) t)))