\frac{x \cdot y - \left(z \cdot 9\right) \cdot t}{a \cdot 2}\begin{array}{l}
\mathbf{if}\;a \le -1.228510223266635066615353468569416308744 \cdot 10^{-99}:\\
\;\;\;\;0.5 \cdot \frac{x}{\frac{a}{y}} - 4.5 \cdot \frac{t}{\frac{a}{z}}\\
\mathbf{elif}\;a \le 64104884799497751389513187328:\\
\;\;\;\;\frac{0.5 \cdot \left(x \cdot y\right) - 4.5 \cdot \left(t \cdot z\right)}{a}\\
\mathbf{else}:\\
\;\;\;\;0.5 \cdot \left(\frac{x}{\sqrt[3]{a} \cdot \sqrt[3]{a}} \cdot \frac{y}{\sqrt[3]{a}}\right) - 4.5 \cdot \frac{t}{\frac{a}{z}}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r477672 = x;
double r477673 = y;
double r477674 = r477672 * r477673;
double r477675 = z;
double r477676 = 9.0;
double r477677 = r477675 * r477676;
double r477678 = t;
double r477679 = r477677 * r477678;
double r477680 = r477674 - r477679;
double r477681 = a;
double r477682 = 2.0;
double r477683 = r477681 * r477682;
double r477684 = r477680 / r477683;
return r477684;
}
double f(double x, double y, double z, double t, double a) {
double r477685 = a;
double r477686 = -1.228510223266635e-99;
bool r477687 = r477685 <= r477686;
double r477688 = 0.5;
double r477689 = x;
double r477690 = y;
double r477691 = r477685 / r477690;
double r477692 = r477689 / r477691;
double r477693 = r477688 * r477692;
double r477694 = 4.5;
double r477695 = t;
double r477696 = z;
double r477697 = r477685 / r477696;
double r477698 = r477695 / r477697;
double r477699 = r477694 * r477698;
double r477700 = r477693 - r477699;
double r477701 = 6.410488479949775e+28;
bool r477702 = r477685 <= r477701;
double r477703 = r477689 * r477690;
double r477704 = r477688 * r477703;
double r477705 = r477695 * r477696;
double r477706 = r477694 * r477705;
double r477707 = r477704 - r477706;
double r477708 = r477707 / r477685;
double r477709 = cbrt(r477685);
double r477710 = r477709 * r477709;
double r477711 = r477689 / r477710;
double r477712 = r477690 / r477709;
double r477713 = r477711 * r477712;
double r477714 = r477688 * r477713;
double r477715 = r477714 - r477699;
double r477716 = r477702 ? r477708 : r477715;
double r477717 = r477687 ? r477700 : r477716;
return r477717;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 7.7 |
|---|---|
| Target | 5.2 |
| Herbie | 4.2 |
if a < -1.228510223266635e-99Initial program 9.0
Taylor expanded around 0 8.9
rmApplied associate-/l*7.4
rmApplied associate-/l*5.2
if -1.228510223266635e-99 < a < 6.410488479949775e+28Initial program 1.5
Taylor expanded around 0 1.6
rmApplied associate-*r/1.6
Applied associate-*r/1.5
Applied sub-div1.5
if 6.410488479949775e+28 < a Initial program 12.3
Taylor expanded around 0 12.2
rmApplied associate-/l*9.7
rmApplied add-cube-cbrt10.0
Applied times-frac5.6
Final simplification4.2
herbie shell --seed 2019326 +o rules:numerics
(FPCore (x y z t a)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, I"
:precision binary64
:herbie-target
(if (< a -2.090464557976709e+86) (- (* 0.5 (/ (* y x) a)) (* 4.5 (/ t (/ a z)))) (if (< a 2.144030707833976e+99) (/ (- (* x y) (* z (* 9 t))) (* a 2)) (- (* (/ y a) (* x 0.5)) (* (/ t a) (* z 4.5)))))
(/ (- (* x y) (* (* z 9) t)) (* a 2)))