x + \frac{\left(y - z\right) \cdot \left(t - x\right)}{a - z}\begin{array}{l}
\mathbf{if}\;z \le -3.2582793557416086 \cdot 10^{232}:\\
\;\;\;\;t\\
\mathbf{elif}\;z \le 2.17941341566278614 \cdot 10^{139}:\\
\;\;\;\;x + \frac{y - z}{\frac{a - z}{t - x}}\\
\mathbf{elif}\;z \le 3.37471355853467873 \cdot 10^{210}:\\
\;\;\;\;x + \left(\sqrt[3]{\frac{y - z}{\sqrt[3]{a - z} \cdot \sqrt[3]{a - z}}} \cdot \sqrt[3]{\frac{y - z}{\sqrt[3]{a - z} \cdot \sqrt[3]{a - z}}}\right) \cdot \left(\sqrt[3]{\frac{y - z}{\sqrt[3]{a - z} \cdot \sqrt[3]{a - z}}} \cdot \frac{t - x}{\sqrt[3]{a - z}}\right)\\
\mathbf{else}:\\
\;\;\;\;\left(\frac{x \cdot y}{z} + t\right) - \frac{t \cdot y}{z}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r782130 = x;
double r782131 = y;
double r782132 = z;
double r782133 = r782131 - r782132;
double r782134 = t;
double r782135 = r782134 - r782130;
double r782136 = r782133 * r782135;
double r782137 = a;
double r782138 = r782137 - r782132;
double r782139 = r782136 / r782138;
double r782140 = r782130 + r782139;
return r782140;
}
double f(double x, double y, double z, double t, double a) {
double r782141 = z;
double r782142 = -3.2582793557416086e+232;
bool r782143 = r782141 <= r782142;
double r782144 = t;
double r782145 = 2.1794134156627861e+139;
bool r782146 = r782141 <= r782145;
double r782147 = x;
double r782148 = y;
double r782149 = r782148 - r782141;
double r782150 = a;
double r782151 = r782150 - r782141;
double r782152 = r782144 - r782147;
double r782153 = r782151 / r782152;
double r782154 = r782149 / r782153;
double r782155 = r782147 + r782154;
double r782156 = 3.374713558534679e+210;
bool r782157 = r782141 <= r782156;
double r782158 = cbrt(r782151);
double r782159 = r782158 * r782158;
double r782160 = r782149 / r782159;
double r782161 = cbrt(r782160);
double r782162 = r782161 * r782161;
double r782163 = r782152 / r782158;
double r782164 = r782161 * r782163;
double r782165 = r782162 * r782164;
double r782166 = r782147 + r782165;
double r782167 = r782147 * r782148;
double r782168 = r782167 / r782141;
double r782169 = r782168 + r782144;
double r782170 = r782144 * r782148;
double r782171 = r782170 / r782141;
double r782172 = r782169 - r782171;
double r782173 = r782157 ? r782166 : r782172;
double r782174 = r782146 ? r782155 : r782173;
double r782175 = r782143 ? r782144 : r782174;
return r782175;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 24.5 |
|---|---|
| Target | 11.7 |
| Herbie | 12.9 |
if z < -3.2582793557416086e+232Initial program 52.1
rmApplied add-cube-cbrt52.4
Applied times-frac26.3
rmApplied add-cube-cbrt26.3
Applied cbrt-prod26.4
Applied add-cube-cbrt26.5
Applied times-frac26.5
Applied associate-*r*26.0
rmApplied *-un-lft-identity26.0
Applied times-frac26.1
Applied associate-*l*28.9
Taylor expanded around 0 21.7
if -3.2582793557416086e+232 < z < 2.1794134156627861e+139Initial program 17.5
rmApplied associate-/l*10.4
if 2.1794134156627861e+139 < z < 3.374713558534679e+210Initial program 41.9
rmApplied add-cube-cbrt42.2
Applied times-frac18.2
rmApplied add-cube-cbrt18.4
Applied associate-*l*18.4
if 3.374713558534679e+210 < z Initial program 51.4
Taylor expanded around inf 24.3
Final simplification12.9
herbie shell --seed 2020047
(FPCore (x y z t a)
:name "Graphics.Rendering.Chart.Axis.Types:invLinMap from Chart-1.5.3"
:precision binary64
:herbie-target
(if (< z -1.2536131056095036e+188) (- t (* (/ y z) (- t x))) (if (< z 4.446702369113811e+64) (+ x (/ (- y z) (/ (- a z) (- t x)))) (- t (* (/ y z) (- t x)))))
(+ x (/ (* (- y z) (- t x)) (- a z))))