\frac{\left(\left(x \cdot 9\right) \cdot y - \left(\left(z \cdot 4\right) \cdot t\right) \cdot a\right) + b}{z \cdot c}\begin{array}{l}
\mathbf{if}\;\frac{\left(\left(x \cdot 9\right) \cdot y - \left(\left(z \cdot 4\right) \cdot t\right) \cdot a\right) + b}{z \cdot c} \le -9.300232518812952249570457999506207707385 \cdot 10^{238}:\\
\;\;\;\;\left(\frac{1}{z} \cdot \frac{b}{c} + 9 \cdot \frac{x}{\frac{z \cdot c}{y}}\right) - 4 \cdot \frac{t}{\frac{c}{a}}\\
\mathbf{elif}\;\frac{\left(\left(x \cdot 9\right) \cdot y - \left(\left(z \cdot 4\right) \cdot t\right) \cdot a\right) + b}{z \cdot c} \le -2.982946141337434241738306830170385159844 \cdot 10^{-208}:\\
\;\;\;\;\frac{\left(\left(x \cdot 9\right) \cdot y - \left(\left(z \cdot 4\right) \cdot t\right) \cdot a\right) + b}{z \cdot c}\\
\mathbf{elif}\;\frac{\left(\left(x \cdot 9\right) \cdot y - \left(\left(z \cdot 4\right) \cdot t\right) \cdot a\right) + b}{z \cdot c} \le -0.0:\\
\;\;\;\;\left(\sqrt[3]{\frac{\left(x \cdot 9\right) \cdot y + b}{z} - \left(a \cdot 4\right) \cdot t} \cdot \sqrt[3]{\frac{\left(x \cdot 9\right) \cdot y + b}{z} - \left(a \cdot 4\right) \cdot t}\right) \cdot \frac{\sqrt[3]{\frac{\left(x \cdot 9\right) \cdot y + b}{z} - \left(a \cdot 4\right) \cdot t}}{c}\\
\mathbf{elif}\;\frac{\left(\left(x \cdot 9\right) \cdot y - \left(\left(z \cdot 4\right) \cdot t\right) \cdot a\right) + b}{z \cdot c} \le 4.299811555402724123181084098955168983672 \cdot 10^{307}:\\
\;\;\;\;\frac{\left(\left(x \cdot 9\right) \cdot y - \left(\left(z \cdot 4\right) \cdot t\right) \cdot a\right) + b}{z \cdot c}\\
\mathbf{else}:\\
\;\;\;\;\left(\frac{b}{z \cdot c} + \left(9 \cdot \frac{x}{z}\right) \cdot \frac{y}{c}\right) - 4 \cdot \frac{t}{\frac{c}{a}}\\
\end{array}double f(double x, double y, double z, double t, double a, double b, double c) {
double r579569 = x;
double r579570 = 9.0;
double r579571 = r579569 * r579570;
double r579572 = y;
double r579573 = r579571 * r579572;
double r579574 = z;
double r579575 = 4.0;
double r579576 = r579574 * r579575;
double r579577 = t;
double r579578 = r579576 * r579577;
double r579579 = a;
double r579580 = r579578 * r579579;
double r579581 = r579573 - r579580;
double r579582 = b;
double r579583 = r579581 + r579582;
double r579584 = c;
double r579585 = r579574 * r579584;
double r579586 = r579583 / r579585;
return r579586;
}
double f(double x, double y, double z, double t, double a, double b, double c) {
double r579587 = x;
double r579588 = 9.0;
double r579589 = r579587 * r579588;
double r579590 = y;
double r579591 = r579589 * r579590;
double r579592 = z;
double r579593 = 4.0;
double r579594 = r579592 * r579593;
double r579595 = t;
double r579596 = r579594 * r579595;
double r579597 = a;
double r579598 = r579596 * r579597;
double r579599 = r579591 - r579598;
double r579600 = b;
double r579601 = r579599 + r579600;
double r579602 = c;
double r579603 = r579592 * r579602;
double r579604 = r579601 / r579603;
double r579605 = -9.300232518812952e+238;
bool r579606 = r579604 <= r579605;
double r579607 = 1.0;
double r579608 = r579607 / r579592;
double r579609 = r579600 / r579602;
double r579610 = r579608 * r579609;
double r579611 = r579603 / r579590;
double r579612 = r579587 / r579611;
double r579613 = r579588 * r579612;
double r579614 = r579610 + r579613;
double r579615 = r579602 / r579597;
double r579616 = r579595 / r579615;
double r579617 = r579593 * r579616;
double r579618 = r579614 - r579617;
double r579619 = -2.9829461413374342e-208;
bool r579620 = r579604 <= r579619;
double r579621 = -0.0;
bool r579622 = r579604 <= r579621;
double r579623 = r579591 + r579600;
double r579624 = r579623 / r579592;
double r579625 = r579597 * r579593;
double r579626 = r579625 * r579595;
double r579627 = r579624 - r579626;
double r579628 = cbrt(r579627);
double r579629 = r579628 * r579628;
double r579630 = r579628 / r579602;
double r579631 = r579629 * r579630;
double r579632 = 4.299811555402724e+307;
bool r579633 = r579604 <= r579632;
double r579634 = r579600 / r579603;
double r579635 = r579587 / r579592;
double r579636 = r579588 * r579635;
double r579637 = r579590 / r579602;
double r579638 = r579636 * r579637;
double r579639 = r579634 + r579638;
double r579640 = r579639 - r579617;
double r579641 = r579633 ? r579604 : r579640;
double r579642 = r579622 ? r579631 : r579641;
double r579643 = r579620 ? r579604 : r579642;
double r579644 = r579606 ? r579618 : r579643;
return r579644;
}




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
Results
| Original | 20.6 |
|---|---|
| Target | 14.3 |
| Herbie | 4.3 |
if (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) < -9.300232518812952e+238Initial program 38.3
Simplified22.7
Taylor expanded around 0 19.2
rmApplied associate-/l*17.1
rmApplied associate-/l*10.4
rmApplied *-un-lft-identity10.4
Applied times-frac15.0
if -9.300232518812952e+238 < (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) < -2.9829461413374342e-208 or -0.0 < (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) < 4.299811555402724e+307Initial program 4.0
if -2.9829461413374342e-208 < (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) < -0.0Initial program 30.2
Simplified0.7
rmApplied *-un-lft-identity0.7
Applied add-cube-cbrt1.4
Applied times-frac1.4
Simplified1.4
if 4.299811555402724e+307 < (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) Initial program 64.0
Simplified26.8
Taylor expanded around 0 30.3
rmApplied associate-/l*25.1
rmApplied times-frac10.7
Applied associate-*r*10.7
Final simplification4.3
herbie shell --seed 2019235
(FPCore (x y z t a b c)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, J"
:precision binary64
:herbie-target
(if (< (/ (+ (- (* (* x 9) y) (* (* (* z 4) t) a)) b) (* z c)) -1.1001567408041049e-171) (/ (+ (- (* (* x 9) y) (* (* z 4) (* t a))) b) (* z c)) (if (< (/ (+ (- (* (* x 9) y) (* (* (* z 4) t) a)) b) (* z c)) -0.0) (/ (/ (+ (- (* (* x 9) y) (* (* (* z 4) t) a)) b) z) c) (if (< (/ (+ (- (* (* x 9) y) (* (* (* z 4) t) a)) b) (* z c)) 1.17088779117474882e-53) (/ (+ (- (* (* x 9) y) (* (* z 4) (* t a))) b) (* z c)) (if (< (/ (+ (- (* (* x 9) y) (* (* (* z 4) t) a)) b) (* z c)) 2.8768236795461372e130) (- (+ (* (* 9 (/ y c)) (/ x z)) (/ b (* c z))) (* 4 (/ (* a t) c))) (if (< (/ (+ (- (* (* x 9) y) (* (* (* z 4) t) a)) b) (* z c)) 1.3838515042456319e158) (/ (+ (- (* (* x 9) y) (* (* z 4) (* t a))) b) (* z c)) (- (+ (* 9 (* (/ y (* c z)) x)) (/ b (* c z))) (* 4 (/ (* a t) c))))))))
(/ (+ (- (* (* x 9) y) (* (* (* z 4) t) a)) b) (* z c)))