\frac{x + \frac{y \cdot z - x}{t \cdot z - x}}{x + 1}\begin{array}{l}
\mathbf{if}\;z \le -5.440078247488523162933428867079497205001 \cdot 10^{157}:\\
\;\;\;\;\frac{\mathsf{fma}\left(\frac{y}{t \cdot z - x}, z, x\right) - \sqrt[3]{\frac{x}{t \cdot z - x} \cdot \left(\frac{x}{t \cdot z - x} \cdot \frac{x}{t \cdot z - x}\right)}}{x + 1}\\
\mathbf{elif}\;z \le 1.514816533856499451078635282534599335268 \cdot 10^{-166}:\\
\;\;\;\;\frac{\frac{y \cdot z - x}{\mathsf{fma}\left(t, z, -x\right)} + x}{x + 1}\\
\mathbf{else}:\\
\;\;\;\;\frac{\mathsf{fma}\left(\frac{1}{t \cdot z - x} \cdot y, z, x\right) - \frac{x}{t \cdot z - x}}{x + 1}\\
\end{array}double f(double x, double y, double z, double t) {
double r29477091 = x;
double r29477092 = y;
double r29477093 = z;
double r29477094 = r29477092 * r29477093;
double r29477095 = r29477094 - r29477091;
double r29477096 = t;
double r29477097 = r29477096 * r29477093;
double r29477098 = r29477097 - r29477091;
double r29477099 = r29477095 / r29477098;
double r29477100 = r29477091 + r29477099;
double r29477101 = 1.0;
double r29477102 = r29477091 + r29477101;
double r29477103 = r29477100 / r29477102;
return r29477103;
}
double f(double x, double y, double z, double t) {
double r29477104 = z;
double r29477105 = -5.440078247488523e+157;
bool r29477106 = r29477104 <= r29477105;
double r29477107 = y;
double r29477108 = t;
double r29477109 = r29477108 * r29477104;
double r29477110 = x;
double r29477111 = r29477109 - r29477110;
double r29477112 = r29477107 / r29477111;
double r29477113 = fma(r29477112, r29477104, r29477110);
double r29477114 = r29477110 / r29477111;
double r29477115 = r29477114 * r29477114;
double r29477116 = r29477114 * r29477115;
double r29477117 = cbrt(r29477116);
double r29477118 = r29477113 - r29477117;
double r29477119 = 1.0;
double r29477120 = r29477110 + r29477119;
double r29477121 = r29477118 / r29477120;
double r29477122 = 1.5148165338564995e-166;
bool r29477123 = r29477104 <= r29477122;
double r29477124 = r29477107 * r29477104;
double r29477125 = r29477124 - r29477110;
double r29477126 = -r29477110;
double r29477127 = fma(r29477108, r29477104, r29477126);
double r29477128 = r29477125 / r29477127;
double r29477129 = r29477128 + r29477110;
double r29477130 = r29477129 / r29477120;
double r29477131 = 1.0;
double r29477132 = r29477131 / r29477111;
double r29477133 = r29477132 * r29477107;
double r29477134 = fma(r29477133, r29477104, r29477110);
double r29477135 = r29477134 - r29477114;
double r29477136 = r29477135 / r29477120;
double r29477137 = r29477123 ? r29477130 : r29477136;
double r29477138 = r29477106 ? r29477121 : r29477137;
return r29477138;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
| Original | 7.5 |
|---|---|
| Target | 0.4 |
| Herbie | 3.7 |
if z < -5.440078247488523e+157Initial program 23.5
rmApplied div-sub23.5
Applied associate-+r-23.5
Simplified9.1
rmApplied add-cbrt-cube9.1
if -5.440078247488523e+157 < z < 1.5148165338564995e-166Initial program 1.8
rmApplied fma-neg1.8
if 1.5148165338564995e-166 < z Initial program 9.7
rmApplied div-sub9.7
Applied associate-+r-9.7
Simplified4.4
rmApplied div-inv4.5
Final simplification3.7
herbie shell --seed 2019172 +o rules:numerics
(FPCore (x y z t)
:name "Diagrams.Trail:splitAtParam from diagrams-lib-1.3.0.3, A"
:herbie-target
(/ (+ x (- (/ y (- t (/ x z))) (/ x (- (* t z) x)))) (+ x 1.0))
(/ (+ x (/ (- (* y z) x) (- (* t z) x))) (+ x 1.0)))