\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} = -\infty:\\
\;\;\;\;\left(\frac{1}{z} \cdot \frac{b}{c} + 9 \cdot \left(\frac{x}{z} \cdot \frac{y}{c}\right)\right) - 4 \cdot \left(t \cdot \frac{a}{c}\right)\\
\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 -5.349265624300453747172467977577525743982 \cdot 10^{-4}:\\
\;\;\;\;\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:\\
\;\;\;\;\frac{\frac{1}{\frac{z}{b + \left(x \cdot 9\right) \cdot y}} - \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 5.779142116324617173520422784502927192628 \cdot 10^{305}:\\
\;\;\;\;\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{1}{z} \cdot \frac{b}{c} + 9 \cdot \left(\frac{x}{z} \cdot \frac{y}{c}\right)\right) - 4 \cdot \left(t \cdot \frac{a}{c}\right)\\
\end{array}double f(double x, double y, double z, double t, double a, double b, double c) {
double r589158 = x;
double r589159 = 9.0;
double r589160 = r589158 * r589159;
double r589161 = y;
double r589162 = r589160 * r589161;
double r589163 = z;
double r589164 = 4.0;
double r589165 = r589163 * r589164;
double r589166 = t;
double r589167 = r589165 * r589166;
double r589168 = a;
double r589169 = r589167 * r589168;
double r589170 = r589162 - r589169;
double r589171 = b;
double r589172 = r589170 + r589171;
double r589173 = c;
double r589174 = r589163 * r589173;
double r589175 = r589172 / r589174;
return r589175;
}
double f(double x, double y, double z, double t, double a, double b, double c) {
double r589176 = x;
double r589177 = 9.0;
double r589178 = r589176 * r589177;
double r589179 = y;
double r589180 = r589178 * r589179;
double r589181 = z;
double r589182 = 4.0;
double r589183 = r589181 * r589182;
double r589184 = t;
double r589185 = r589183 * r589184;
double r589186 = a;
double r589187 = r589185 * r589186;
double r589188 = r589180 - r589187;
double r589189 = b;
double r589190 = r589188 + r589189;
double r589191 = c;
double r589192 = r589181 * r589191;
double r589193 = r589190 / r589192;
double r589194 = -inf.0;
bool r589195 = r589193 <= r589194;
double r589196 = 1.0;
double r589197 = r589196 / r589181;
double r589198 = r589189 / r589191;
double r589199 = r589197 * r589198;
double r589200 = r589176 / r589181;
double r589201 = r589179 / r589191;
double r589202 = r589200 * r589201;
double r589203 = r589177 * r589202;
double r589204 = r589199 + r589203;
double r589205 = r589186 / r589191;
double r589206 = r589184 * r589205;
double r589207 = r589182 * r589206;
double r589208 = r589204 - r589207;
double r589209 = -0.0005349265624300454;
bool r589210 = r589193 <= r589209;
double r589211 = -0.0;
bool r589212 = r589193 <= r589211;
double r589213 = r589189 + r589180;
double r589214 = r589181 / r589213;
double r589215 = r589196 / r589214;
double r589216 = r589186 * r589182;
double r589217 = r589216 * r589184;
double r589218 = r589215 - r589217;
double r589219 = r589218 / r589191;
double r589220 = 5.779142116324617e+305;
bool r589221 = r589193 <= r589220;
double r589222 = r589221 ? r589193 : r589208;
double r589223 = r589212 ? r589219 : r589222;
double r589224 = r589210 ? r589193 : r589223;
double r589225 = r589195 ? r589208 : r589224;
return r589225;
}




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.7 |
|---|---|
| Target | 14.6 |
| Herbie | 3.3 |
if (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) < -inf.0 or 5.779142116324617e+305 < (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) Initial program 63.6
Simplified25.5
Taylor expanded around 0 29.8
rmApplied *-un-lft-identity29.8
Applied times-frac24.9
Simplified24.9
rmApplied times-frac12.3
rmApplied *-un-lft-identity12.3
Applied times-frac10.8
if -inf.0 < (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) < -0.0005349265624300454 or -0.0 < (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) < 5.779142116324617e+305Initial program 4.0
if -0.0005349265624300454 < (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) < -0.0Initial program 13.0
Simplified0.9
rmApplied clear-num1.0
Final simplification3.3
herbie shell --seed 2019306
(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)))