\left(\left(\left(\left(\left(\left(x \cdot 18\right) \cdot y\right) \cdot z\right) \cdot t - \left(a \cdot 4\right) \cdot t\right) + b \cdot c\right) - \left(x \cdot 4\right) \cdot i\right) - \left(j \cdot 27\right) \cdot k
\begin{array}{l}
\mathbf{if}\;\left(\left(\left(\left(\left(x \cdot 18\right) \cdot y\right) \cdot z\right) \cdot t - \left(a \cdot 4\right) \cdot t\right) + b \cdot c\right) - \left(x \cdot 4\right) \cdot i = -\infty:\\
\;\;\;\;\left(\left(\left(\left(\left(x \cdot 18\right) \cdot y\right) \cdot \left(z \cdot t\right) - \left(a \cdot 4\right) \cdot t\right) + b \cdot c\right) - \left(x \cdot 4\right) \cdot i\right) - \left(j \cdot 27\right) \cdot k\\
\mathbf{elif}\;\left(\left(\left(\left(\left(x \cdot 18\right) \cdot y\right) \cdot z\right) \cdot t - \left(a \cdot 4\right) \cdot t\right) + b \cdot c\right) - \left(x \cdot 4\right) \cdot i \le 1.433693085574820316107865306676310981183 \cdot 10^{307}:\\
\;\;\;\;\left(\left(\left(\left(\left(\left(x \cdot 18\right) \cdot y\right) \cdot z\right) \cdot t - \left(a \cdot 4\right) \cdot t\right) + b \cdot c\right) - \left(x \cdot 4\right) \cdot i\right) - j \cdot \left(27 \cdot k\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(t, {\left(18 \cdot \left(x \cdot \left(z \cdot y\right)\right)\right)}^{1} - a \cdot 4, b \cdot c - \mathsf{fma}\left(x, 4 \cdot i, \left(j \cdot 27\right) \cdot k\right)\right)\\
\end{array}double f(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
double r719248 = x;
double r719249 = 18.0;
double r719250 = r719248 * r719249;
double r719251 = y;
double r719252 = r719250 * r719251;
double r719253 = z;
double r719254 = r719252 * r719253;
double r719255 = t;
double r719256 = r719254 * r719255;
double r719257 = a;
double r719258 = 4.0;
double r719259 = r719257 * r719258;
double r719260 = r719259 * r719255;
double r719261 = r719256 - r719260;
double r719262 = b;
double r719263 = c;
double r719264 = r719262 * r719263;
double r719265 = r719261 + r719264;
double r719266 = r719248 * r719258;
double r719267 = i;
double r719268 = r719266 * r719267;
double r719269 = r719265 - r719268;
double r719270 = j;
double r719271 = 27.0;
double r719272 = r719270 * r719271;
double r719273 = k;
double r719274 = r719272 * r719273;
double r719275 = r719269 - r719274;
return r719275;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
double r719276 = x;
double r719277 = 18.0;
double r719278 = r719276 * r719277;
double r719279 = y;
double r719280 = r719278 * r719279;
double r719281 = z;
double r719282 = r719280 * r719281;
double r719283 = t;
double r719284 = r719282 * r719283;
double r719285 = a;
double r719286 = 4.0;
double r719287 = r719285 * r719286;
double r719288 = r719287 * r719283;
double r719289 = r719284 - r719288;
double r719290 = b;
double r719291 = c;
double r719292 = r719290 * r719291;
double r719293 = r719289 + r719292;
double r719294 = r719276 * r719286;
double r719295 = i;
double r719296 = r719294 * r719295;
double r719297 = r719293 - r719296;
double r719298 = -inf.0;
bool r719299 = r719297 <= r719298;
double r719300 = r719281 * r719283;
double r719301 = r719280 * r719300;
double r719302 = r719301 - r719288;
double r719303 = r719302 + r719292;
double r719304 = r719303 - r719296;
double r719305 = j;
double r719306 = 27.0;
double r719307 = r719305 * r719306;
double r719308 = k;
double r719309 = r719307 * r719308;
double r719310 = r719304 - r719309;
double r719311 = 1.4336930855748203e+307;
bool r719312 = r719297 <= r719311;
double r719313 = r719306 * r719308;
double r719314 = r719305 * r719313;
double r719315 = r719297 - r719314;
double r719316 = r719281 * r719279;
double r719317 = r719276 * r719316;
double r719318 = r719277 * r719317;
double r719319 = 1.0;
double r719320 = pow(r719318, r719319);
double r719321 = r719320 - r719287;
double r719322 = r719286 * r719295;
double r719323 = fma(r719276, r719322, r719309);
double r719324 = r719292 - r719323;
double r719325 = fma(r719283, r719321, r719324);
double r719326 = r719312 ? r719315 : r719325;
double r719327 = r719299 ? r719310 : r719326;
return r719327;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b




Bits error versus c




Bits error versus i




Bits error versus j




Bits error versus k
| Original | 5.5 |
|---|---|
| Target | 1.5 |
| Herbie | 3.3 |
if (- (+ (- (* (* (* (* x 18.0) y) z) t) (* (* a 4.0) t)) (* b c)) (* (* x 4.0) i)) < -inf.0Initial program 64.0
rmApplied associate-*l*35.4
if -inf.0 < (- (+ (- (* (* (* (* x 18.0) y) z) t) (* (* a 4.0) t)) (* b c)) (* (* x 4.0) i)) < 1.4336930855748203e+307Initial program 0.3
rmApplied associate-*l*0.3
if 1.4336930855748203e+307 < (- (+ (- (* (* (* (* x 18.0) y) z) t) (* (* a 4.0) t)) (* b c)) (* (* x 4.0) i)) Initial program 62.1
Simplified62.1
rmApplied pow162.1
Applied pow162.1
Applied pow162.1
Applied pow162.1
Applied pow-prod-down62.1
Applied pow-prod-down62.1
Applied pow-prod-down62.1
Simplified37.4
Final simplification3.3
herbie shell --seed 2019353 +o rules:numerics
(FPCore (x y z t a b c i j k)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, E"
:precision binary64
:herbie-target
(if (< t -1.6210815397541398e-69) (- (- (* (* 18 t) (* (* x y) z)) (* (+ (* a t) (* i x)) 4)) (- (* (* k j) 27) (* c b))) (if (< t 165.68027943805222) (+ (- (* (* 18 y) (* x (* z t))) (* (+ (* a t) (* i x)) 4)) (- (* c b) (* 27 (* k j)))) (- (- (* (* 18 t) (* (* x y) z)) (* (+ (* a t) (* i x)) 4)) (- (* (* k j) 27) (* c b)))))
(- (- (+ (- (* (* (* (* x 18) y) z) t) (* (* a 4) t)) (* b c)) (* (* x 4) i)) (* (* j 27) k)))