x + \frac{\left(y - x\right) \cdot z}{t}\begin{array}{l}
\mathbf{if}\;x \le -2.805118041439937941139552230088477979341 \cdot 10^{-286}:\\
\;\;\;\;x + \frac{z}{t} \cdot \left(y - x\right)\\
\mathbf{elif}\;x \le 9.722960166984673180429226333422988982195 \cdot 10^{-97}:\\
\;\;\;\;\frac{\sqrt[3]{z}}{t} \cdot \left(\left(\left(y - x\right) \cdot \sqrt[3]{z}\right) \cdot \sqrt[3]{z}\right) + x\\
\mathbf{else}:\\
\;\;\;\;x + \frac{z}{t} \cdot \left(y - x\right)\\
\end{array}double f(double x, double y, double z, double t) {
double r16260689 = x;
double r16260690 = y;
double r16260691 = r16260690 - r16260689;
double r16260692 = z;
double r16260693 = r16260691 * r16260692;
double r16260694 = t;
double r16260695 = r16260693 / r16260694;
double r16260696 = r16260689 + r16260695;
return r16260696;
}
double f(double x, double y, double z, double t) {
double r16260697 = x;
double r16260698 = -2.805118041439938e-286;
bool r16260699 = r16260697 <= r16260698;
double r16260700 = z;
double r16260701 = t;
double r16260702 = r16260700 / r16260701;
double r16260703 = y;
double r16260704 = r16260703 - r16260697;
double r16260705 = r16260702 * r16260704;
double r16260706 = r16260697 + r16260705;
double r16260707 = 9.722960166984673e-97;
bool r16260708 = r16260697 <= r16260707;
double r16260709 = cbrt(r16260700);
double r16260710 = r16260709 / r16260701;
double r16260711 = r16260704 * r16260709;
double r16260712 = r16260711 * r16260709;
double r16260713 = r16260710 * r16260712;
double r16260714 = r16260713 + r16260697;
double r16260715 = r16260708 ? r16260714 : r16260706;
double r16260716 = r16260699 ? r16260706 : r16260715;
return r16260716;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 6.6 |
|---|---|
| Target | 2.1 |
| Herbie | 2.0 |
if x < -2.805118041439938e-286 or 9.722960166984673e-97 < x Initial program 7.0
rmApplied *-un-lft-identity7.0
Applied times-frac1.3
Simplified1.3
if -2.805118041439938e-286 < x < 9.722960166984673e-97Initial program 5.2
rmApplied *-un-lft-identity5.2
Applied times-frac5.1
Simplified5.1
rmApplied *-un-lft-identity5.1
Applied add-cube-cbrt5.9
Applied times-frac5.9
Applied associate-*r*4.3
Simplified4.3
Final simplification2.0
herbie shell --seed 2019170 +o rules:numerics
(FPCore (x y z t)
:name "Numeric.Histogram:binBounds from Chart-1.5.3"
: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)))