\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:\\
\;\;\;\;\frac{1}{\frac{c}{\left(b + \left(x \cdot 9\right) \cdot y\right) \cdot \frac{1}{z} - \left(a \cdot 4\right) \cdot t}}\\
\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 -7.871356618472160089166896848678735709787 \cdot 10^{-243}:\\
\;\;\;\;\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 1.01445260762466640003481055345419026939 \cdot 10^{85}:\\
\;\;\;\;\left(\frac{b + \left(x \cdot 9\right) \cdot y}{z} - \left(a \cdot 4\right) \cdot t\right) \cdot \frac{1}{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 3.764994856652344411432804749280478465856 \cdot 10^{301}:\\
\;\;\;\;\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}:\\
\;\;\;\;\frac{1}{\frac{c}{\left(b + \left(x \cdot 9\right) \cdot y\right) \cdot \frac{1}{z} - \left(a \cdot 4\right) \cdot t}}\\
\end{array}double f(double x, double y, double z, double t, double a, double b, double c) {
double r1193042 = x;
double r1193043 = 9.0;
double r1193044 = r1193042 * r1193043;
double r1193045 = y;
double r1193046 = r1193044 * r1193045;
double r1193047 = z;
double r1193048 = 4.0;
double r1193049 = r1193047 * r1193048;
double r1193050 = t;
double r1193051 = r1193049 * r1193050;
double r1193052 = a;
double r1193053 = r1193051 * r1193052;
double r1193054 = r1193046 - r1193053;
double r1193055 = b;
double r1193056 = r1193054 + r1193055;
double r1193057 = c;
double r1193058 = r1193047 * r1193057;
double r1193059 = r1193056 / r1193058;
return r1193059;
}
double f(double x, double y, double z, double t, double a, double b, double c) {
double r1193060 = x;
double r1193061 = 9.0;
double r1193062 = r1193060 * r1193061;
double r1193063 = y;
double r1193064 = r1193062 * r1193063;
double r1193065 = z;
double r1193066 = 4.0;
double r1193067 = r1193065 * r1193066;
double r1193068 = t;
double r1193069 = r1193067 * r1193068;
double r1193070 = a;
double r1193071 = r1193069 * r1193070;
double r1193072 = r1193064 - r1193071;
double r1193073 = b;
double r1193074 = r1193072 + r1193073;
double r1193075 = c;
double r1193076 = r1193065 * r1193075;
double r1193077 = r1193074 / r1193076;
double r1193078 = -inf.0;
bool r1193079 = r1193077 <= r1193078;
double r1193080 = 1.0;
double r1193081 = r1193073 + r1193064;
double r1193082 = r1193080 / r1193065;
double r1193083 = r1193081 * r1193082;
double r1193084 = r1193070 * r1193066;
double r1193085 = r1193084 * r1193068;
double r1193086 = r1193083 - r1193085;
double r1193087 = r1193075 / r1193086;
double r1193088 = r1193080 / r1193087;
double r1193089 = -7.87135661847216e-243;
bool r1193090 = r1193077 <= r1193089;
double r1193091 = 1.0144526076246664e+85;
bool r1193092 = r1193077 <= r1193091;
double r1193093 = r1193081 / r1193065;
double r1193094 = r1193093 - r1193085;
double r1193095 = r1193080 / r1193075;
double r1193096 = r1193094 * r1193095;
double r1193097 = 3.7649948566523444e+301;
bool r1193098 = r1193077 <= r1193097;
double r1193099 = r1193098 ? r1193077 : r1193088;
double r1193100 = r1193092 ? r1193096 : r1193099;
double r1193101 = r1193090 ? r1193077 : r1193100;
double r1193102 = r1193079 ? r1193088 : r1193101;
return r1193102;
}




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.4 |
| Herbie | 7.4 |
if (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) < -inf.0 or 3.7649948566523444e+301 < (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) Initial program 63.0
Simplified25.1
rmApplied clear-num25.2
rmApplied div-inv25.2
if -inf.0 < (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) < -7.87135661847216e-243 or 1.0144526076246664e+85 < (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) < 3.7649948566523444e+301Initial program 0.7
if -7.87135661847216e-243 < (/ (+ (- (* (* x 9.0) y) (* (* (* z 4.0) t) a)) b) (* z c)) < 1.0144526076246664e+85Initial program 14.5
Simplified1.9
rmApplied div-inv1.9
Final simplification7.4
herbie shell --seed 2019303
(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)))