\frac{x + \frac{y \cdot z}{t}}{\left(a + 1\right) + \frac{y \cdot b}{t}}\begin{array}{l}
\mathbf{if}\;t \le -1.6373364464566329 \cdot 10^{139} \lor \neg \left(t \le 2.28491505957256337 \cdot 10^{-15}\right):\\
\;\;\;\;\frac{1}{\left(1 + \mathsf{fma}\left(\frac{y}{t}, b, a\right)\right) \cdot \frac{1}{\mathsf{fma}\left(\frac{y}{t}, z, x\right)}}\\
\mathbf{else}:\\
\;\;\;\;\frac{x + \frac{y \cdot z}{t}}{\left(a + 1\right) + \frac{y \cdot b}{t}}\\
\end{array}double f(double x, double y, double z, double t, double a, double b) {
double r693145 = x;
double r693146 = y;
double r693147 = z;
double r693148 = r693146 * r693147;
double r693149 = t;
double r693150 = r693148 / r693149;
double r693151 = r693145 + r693150;
double r693152 = a;
double r693153 = 1.0;
double r693154 = r693152 + r693153;
double r693155 = b;
double r693156 = r693146 * r693155;
double r693157 = r693156 / r693149;
double r693158 = r693154 + r693157;
double r693159 = r693151 / r693158;
return r693159;
}
double f(double x, double y, double z, double t, double a, double b) {
double r693160 = t;
double r693161 = -1.637336446456633e+139;
bool r693162 = r693160 <= r693161;
double r693163 = 2.2849150595725634e-15;
bool r693164 = r693160 <= r693163;
double r693165 = !r693164;
bool r693166 = r693162 || r693165;
double r693167 = 1.0;
double r693168 = 1.0;
double r693169 = y;
double r693170 = r693169 / r693160;
double r693171 = b;
double r693172 = a;
double r693173 = fma(r693170, r693171, r693172);
double r693174 = r693168 + r693173;
double r693175 = z;
double r693176 = x;
double r693177 = fma(r693170, r693175, r693176);
double r693178 = r693167 / r693177;
double r693179 = r693174 * r693178;
double r693180 = r693167 / r693179;
double r693181 = r693169 * r693175;
double r693182 = r693181 / r693160;
double r693183 = r693176 + r693182;
double r693184 = r693172 + r693168;
double r693185 = r693169 * r693171;
double r693186 = r693185 / r693160;
double r693187 = r693184 + r693186;
double r693188 = r693183 / r693187;
double r693189 = r693166 ? r693180 : r693188;
return r693189;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b
| Original | 16.0 |
|---|---|
| Target | 12.9 |
| Herbie | 12.8 |
if t < -1.637336446456633e+139 or 2.2849150595725634e-15 < t Initial program 11.8
Simplified3.4
rmApplied clear-num3.8
rmApplied div-inv3.9
if -1.637336446456633e+139 < t < 2.2849150595725634e-15Initial program 19.0
Final simplification12.8
herbie shell --seed 2020047 +o rules:numerics
(FPCore (x y z t a b)
:name "Diagrams.Solve.Tridiagonal:solveCyclicTriDiagonal from diagrams-solve-0.1, B"
:precision binary64
:herbie-target
(if (< t -1.3659085366310088e-271) (* 1 (* (+ x (* (/ y t) z)) (/ 1 (+ (+ a 1) (* (/ y t) b))))) (if (< t 3.036967103737246e-130) (/ z b) (* 1 (* (+ x (* (/ y t) z)) (/ 1 (+ (+ a 1) (* (/ y t) b)))))))
(/ (+ x (/ (* y z) t)) (+ (+ a 1) (/ (* y b) t))))