\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 \lor \neg \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 \le 8.945969254806337280686419019328119507179 \cdot 10^{253}\right):\\
\;\;\;\;\left(\left(\left(\left(x \cdot 18\right) \cdot \left(y \cdot \left(z \cdot t\right)\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{else}:\\
\;\;\;\;\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)\\
\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 r651522 = x;
double r651523 = 18.0;
double r651524 = r651522 * r651523;
double r651525 = y;
double r651526 = r651524 * r651525;
double r651527 = z;
double r651528 = r651526 * r651527;
double r651529 = t;
double r651530 = r651528 * r651529;
double r651531 = a;
double r651532 = 4.0;
double r651533 = r651531 * r651532;
double r651534 = r651533 * r651529;
double r651535 = r651530 - r651534;
double r651536 = b;
double r651537 = c;
double r651538 = r651536 * r651537;
double r651539 = r651535 + r651538;
double r651540 = r651522 * r651532;
double r651541 = i;
double r651542 = r651540 * r651541;
double r651543 = r651539 - r651542;
double r651544 = j;
double r651545 = 27.0;
double r651546 = r651544 * r651545;
double r651547 = k;
double r651548 = r651546 * r651547;
double r651549 = r651543 - r651548;
return r651549;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
double r651550 = x;
double r651551 = 18.0;
double r651552 = r651550 * r651551;
double r651553 = y;
double r651554 = r651552 * r651553;
double r651555 = z;
double r651556 = r651554 * r651555;
double r651557 = t;
double r651558 = r651556 * r651557;
double r651559 = a;
double r651560 = 4.0;
double r651561 = r651559 * r651560;
double r651562 = r651561 * r651557;
double r651563 = r651558 - r651562;
double r651564 = b;
double r651565 = c;
double r651566 = r651564 * r651565;
double r651567 = r651563 + r651566;
double r651568 = r651550 * r651560;
double r651569 = i;
double r651570 = r651568 * r651569;
double r651571 = r651567 - r651570;
double r651572 = -inf.0;
bool r651573 = r651571 <= r651572;
double r651574 = 8.945969254806337e+253;
bool r651575 = r651571 <= r651574;
double r651576 = !r651575;
bool r651577 = r651573 || r651576;
double r651578 = r651555 * r651557;
double r651579 = r651553 * r651578;
double r651580 = r651552 * r651579;
double r651581 = r651580 - r651562;
double r651582 = r651581 + r651566;
double r651583 = r651582 - r651570;
double r651584 = j;
double r651585 = 27.0;
double r651586 = r651584 * r651585;
double r651587 = k;
double r651588 = r651586 * r651587;
double r651589 = r651583 - r651588;
double r651590 = r651585 * r651587;
double r651591 = r651584 * r651590;
double r651592 = r651571 - r651591;
double r651593 = r651577 ? r651589 : r651592;
return r651593;
}




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
Results
| Original | 5.7 |
|---|---|
| Target | 1.6 |
| Herbie | 1.5 |
if (- (+ (- (* (* (* (* x 18.0) y) z) t) (* (* a 4.0) t)) (* b c)) (* (* x 4.0) i)) < -inf.0 or 8.945969254806337e+253 < (- (+ (- (* (* (* (* x 18.0) y) z) t) (* (* a 4.0) t)) (* b c)) (* (* x 4.0) i)) Initial program 35.2
rmApplied associate-*l*24.7
rmApplied associate-*l*7.9
if -inf.0 < (- (+ (- (* (* (* (* x 18.0) y) z) t) (* (* a 4.0) t)) (* b c)) (* (* x 4.0) i)) < 8.945969254806337e+253Initial program 0.3
rmApplied associate-*l*0.3
Final simplification1.5
herbie shell --seed 2019323 +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)))