\frac{x + \frac{y \cdot z - x}{t \cdot z - x}}{x + 1}\begin{array}{l}
\mathbf{if}\;z \le -2.889419895373327148972973112388967775743 \cdot 10^{-8}:\\
\;\;\;\;\frac{1}{\frac{x + 1}{\mathsf{fma}\left(\frac{y}{\mathsf{fma}\left(z, t, -x\right)}, z, x\right)}} - \frac{\frac{x}{t \cdot z - x}}{x + 1}\\
\mathbf{elif}\;z \le 8.620848150685308830177863726582628536017 \cdot 10^{89}:\\
\;\;\;\;\frac{x + \frac{\mathsf{fma}\left(z, y, -x\right) + \left(x - x\right)}{t \cdot z - x}}{x + 1}\\
\mathbf{else}:\\
\;\;\;\;\frac{x + \frac{y}{t}}{x + 1}\\
\end{array}double f(double x, double y, double z, double t) {
double r515183 = x;
double r515184 = y;
double r515185 = z;
double r515186 = r515184 * r515185;
double r515187 = r515186 - r515183;
double r515188 = t;
double r515189 = r515188 * r515185;
double r515190 = r515189 - r515183;
double r515191 = r515187 / r515190;
double r515192 = r515183 + r515191;
double r515193 = 1.0;
double r515194 = r515183 + r515193;
double r515195 = r515192 / r515194;
return r515195;
}
double f(double x, double y, double z, double t) {
double r515196 = z;
double r515197 = -2.889419895373327e-08;
bool r515198 = r515196 <= r515197;
double r515199 = 1.0;
double r515200 = x;
double r515201 = 1.0;
double r515202 = r515200 + r515201;
double r515203 = y;
double r515204 = t;
double r515205 = -r515200;
double r515206 = fma(r515196, r515204, r515205);
double r515207 = r515203 / r515206;
double r515208 = fma(r515207, r515196, r515200);
double r515209 = r515202 / r515208;
double r515210 = r515199 / r515209;
double r515211 = r515204 * r515196;
double r515212 = r515211 - r515200;
double r515213 = r515200 / r515212;
double r515214 = r515213 / r515202;
double r515215 = r515210 - r515214;
double r515216 = 8.620848150685309e+89;
bool r515217 = r515196 <= r515216;
double r515218 = fma(r515196, r515203, r515205);
double r515219 = r515200 - r515200;
double r515220 = r515218 + r515219;
double r515221 = r515220 / r515212;
double r515222 = r515200 + r515221;
double r515223 = r515222 / r515202;
double r515224 = r515203 / r515204;
double r515225 = r515200 + r515224;
double r515226 = r515225 / r515202;
double r515227 = r515217 ? r515223 : r515226;
double r515228 = r515198 ? r515215 : r515227;
return r515228;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
| Original | 7.7 |
|---|---|
| Target | 0.4 |
| Herbie | 3.0 |
if z < -2.889419895373327e-08Initial program 16.2
rmApplied div-sub16.2
Applied associate-+r-16.2
Applied div-sub16.2
Simplified5.4
rmApplied clear-num5.4
if -2.889419895373327e-08 < z < 8.620848150685309e+89Initial program 0.5
rmApplied add-cube-cbrt0.8
Applied prod-diff0.8
Simplified0.5
Simplified0.5
if 8.620848150685309e+89 < z Initial program 19.2
Taylor expanded around inf 7.5
Final simplification3.0
herbie shell --seed 2019303 +o rules:numerics
(FPCore (x y z t)
:name "Diagrams.Trail:splitAtParam from diagrams-lib-1.3.0.3, A"
:precision binary64
:herbie-target
(/ (+ x (- (/ y (- t (/ x z))) (/ x (- (* t z) x)))) (+ x 1))
(/ (+ x (/ (- (* y z) x) (- (* t z) x))) (+ x 1)))