\left(2.0 \cdot \sqrt{x}\right) \cdot \cos \left(y - \frac{z \cdot t}{3.0}\right) - \frac{a}{b \cdot 3.0}\begin{array}{l}
\mathbf{if}\;z \cdot t \le -2.0242052511188462 \cdot 10^{+300}:\\
\;\;\;\;\mathsf{fma}\left(y \cdot y, \frac{-1}{2}, 1\right) \cdot \left(\sqrt{x} \cdot 2.0\right) - \frac{a}{b \cdot 3.0}\\
\mathbf{elif}\;z \cdot t \le -9.018122894565441 \cdot 10^{+61}:\\
\;\;\;\;\left(\cos \left(\mathsf{fma}\left(\sqrt[3]{y} \cdot \sqrt[3]{y}, \sqrt[3]{y}, \frac{-t}{3.0} \cdot z\right)\right) \cdot \cos \left(\mathsf{fma}\left(\frac{-t}{3.0}, z, \frac{t}{3.0} \cdot z\right)\right) - \sin \left(\mathsf{fma}\left(\sqrt[3]{y} \cdot \sqrt[3]{y}, \sqrt[3]{y}, \frac{-t}{3.0} \cdot z\right)\right) \cdot \sin \left(\mathsf{fma}\left(\frac{-t}{3.0}, z, \frac{t}{3.0} \cdot z\right)\right)\right) \cdot \left(\sqrt{x} \cdot 2.0\right) - \frac{a}{b \cdot 3.0}\\
\mathbf{elif}\;z \cdot t \le 7.38439639698813 \cdot 10^{+306}:\\
\;\;\;\;\left(\sqrt{x} \cdot 2.0\right) \cdot \left(\cos \left(\frac{z \cdot t}{3.0}\right) \cdot \cos y + \sin y \cdot \sin \left(\frac{t}{\sqrt[3]{3.0}} \cdot \frac{z}{\sqrt[3]{3.0} \cdot \sqrt[3]{3.0}}\right)\right) - \frac{a}{b \cdot 3.0}\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(y \cdot y, \frac{-1}{2}, 1\right) \cdot \left(\sqrt{x} \cdot 2.0\right) - \frac{a}{b \cdot 3.0}\\
\end{array}double f(double x, double y, double z, double t, double a, double b) {
double r33195052 = 2.0;
double r33195053 = x;
double r33195054 = sqrt(r33195053);
double r33195055 = r33195052 * r33195054;
double r33195056 = y;
double r33195057 = z;
double r33195058 = t;
double r33195059 = r33195057 * r33195058;
double r33195060 = 3.0;
double r33195061 = r33195059 / r33195060;
double r33195062 = r33195056 - r33195061;
double r33195063 = cos(r33195062);
double r33195064 = r33195055 * r33195063;
double r33195065 = a;
double r33195066 = b;
double r33195067 = r33195066 * r33195060;
double r33195068 = r33195065 / r33195067;
double r33195069 = r33195064 - r33195068;
return r33195069;
}
double f(double x, double y, double z, double t, double a, double b) {
double r33195070 = z;
double r33195071 = t;
double r33195072 = r33195070 * r33195071;
double r33195073 = -2.0242052511188462e+300;
bool r33195074 = r33195072 <= r33195073;
double r33195075 = y;
double r33195076 = r33195075 * r33195075;
double r33195077 = -0.5;
double r33195078 = 1.0;
double r33195079 = fma(r33195076, r33195077, r33195078);
double r33195080 = x;
double r33195081 = sqrt(r33195080);
double r33195082 = 2.0;
double r33195083 = r33195081 * r33195082;
double r33195084 = r33195079 * r33195083;
double r33195085 = a;
double r33195086 = b;
double r33195087 = 3.0;
double r33195088 = r33195086 * r33195087;
double r33195089 = r33195085 / r33195088;
double r33195090 = r33195084 - r33195089;
double r33195091 = -9.018122894565441e+61;
bool r33195092 = r33195072 <= r33195091;
double r33195093 = cbrt(r33195075);
double r33195094 = r33195093 * r33195093;
double r33195095 = -r33195071;
double r33195096 = r33195095 / r33195087;
double r33195097 = r33195096 * r33195070;
double r33195098 = fma(r33195094, r33195093, r33195097);
double r33195099 = cos(r33195098);
double r33195100 = r33195071 / r33195087;
double r33195101 = r33195100 * r33195070;
double r33195102 = fma(r33195096, r33195070, r33195101);
double r33195103 = cos(r33195102);
double r33195104 = r33195099 * r33195103;
double r33195105 = sin(r33195098);
double r33195106 = sin(r33195102);
double r33195107 = r33195105 * r33195106;
double r33195108 = r33195104 - r33195107;
double r33195109 = r33195108 * r33195083;
double r33195110 = r33195109 - r33195089;
double r33195111 = 7.38439639698813e+306;
bool r33195112 = r33195072 <= r33195111;
double r33195113 = r33195072 / r33195087;
double r33195114 = cos(r33195113);
double r33195115 = cos(r33195075);
double r33195116 = r33195114 * r33195115;
double r33195117 = sin(r33195075);
double r33195118 = cbrt(r33195087);
double r33195119 = r33195071 / r33195118;
double r33195120 = r33195118 * r33195118;
double r33195121 = r33195070 / r33195120;
double r33195122 = r33195119 * r33195121;
double r33195123 = sin(r33195122);
double r33195124 = r33195117 * r33195123;
double r33195125 = r33195116 + r33195124;
double r33195126 = r33195083 * r33195125;
double r33195127 = r33195126 - r33195089;
double r33195128 = r33195112 ? r33195127 : r33195090;
double r33195129 = r33195092 ? r33195110 : r33195128;
double r33195130 = r33195074 ? r33195090 : r33195129;
return r33195130;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b
| Original | 20.1 |
|---|---|
| Target | 18.4 |
| Herbie | 16.7 |
if (* z t) < -2.0242052511188462e+300 or 7.38439639698813e+306 < (* z t) Initial program 61.6
Taylor expanded around 0 44.8
Simplified44.8
if -2.0242052511188462e+300 < (* z t) < -9.018122894565441e+61Initial program 33.5
rmApplied *-un-lft-identity33.5
Applied times-frac33.2
Applied add-cube-cbrt33.2
Applied prod-diff33.2
Applied cos-sum27.6
if -9.018122894565441e+61 < (* z t) < 7.38439639698813e+306Initial program 10.6
rmApplied cos-diff10.0
rmApplied add-cube-cbrt10.0
Applied times-frac10.0
Final simplification16.7
herbie shell --seed 2019163 +o rules:numerics
(FPCore (x y z t a b)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, K"
:herbie-target
(if (< z -1.3793337487235141e+129) (- (* (* 2.0 (sqrt x)) (cos (- (/ 1 y) (/ (/ 0.3333333333333333 z) t)))) (/ (/ a 3.0) b)) (if (< z 3.516290613555987e+106) (- (* (* (sqrt x) 2.0) (cos (- y (* (/ t 3.0) z)))) (/ (/ a 3.0) b)) (- (* (cos (- y (/ (/ 0.3333333333333333 z) t))) (* 2.0 (sqrt x))) (/ (/ a b) 3.0))))
(- (* (* 2.0 (sqrt x)) (cos (- y (/ (* z t) 3.0)))) (/ a (* b 3.0))))