\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}}\begin{array}{l}
\mathbf{if}\;\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} = -\infty \lor \neg \left(\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \le 4.5251739783607176 \cdot 10^{303}\right):\\
\;\;\;\;\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \frac{\sqrt{0.25} \cdot U}{J \cdot \cos \left(0.5 \cdot K\right)}\\
\mathbf{else}:\\
\;\;\;\;\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}}\\
\end{array}double f(double J, double K, double U) {
double r170936 = -2.0;
double r170937 = J;
double r170938 = r170936 * r170937;
double r170939 = K;
double r170940 = 2.0;
double r170941 = r170939 / r170940;
double r170942 = cos(r170941);
double r170943 = r170938 * r170942;
double r170944 = 1.0;
double r170945 = U;
double r170946 = r170940 * r170937;
double r170947 = r170946 * r170942;
double r170948 = r170945 / r170947;
double r170949 = pow(r170948, r170940);
double r170950 = r170944 + r170949;
double r170951 = sqrt(r170950);
double r170952 = r170943 * r170951;
return r170952;
}
double f(double J, double K, double U) {
double r170953 = -2.0;
double r170954 = J;
double r170955 = r170953 * r170954;
double r170956 = K;
double r170957 = 2.0;
double r170958 = r170956 / r170957;
double r170959 = cos(r170958);
double r170960 = r170955 * r170959;
double r170961 = 1.0;
double r170962 = U;
double r170963 = r170957 * r170954;
double r170964 = r170963 * r170959;
double r170965 = r170962 / r170964;
double r170966 = pow(r170965, r170957);
double r170967 = r170961 + r170966;
double r170968 = sqrt(r170967);
double r170969 = r170960 * r170968;
double r170970 = -inf.0;
bool r170971 = r170969 <= r170970;
double r170972 = 4.5251739783607176e+303;
bool r170973 = r170969 <= r170972;
double r170974 = !r170973;
bool r170975 = r170971 || r170974;
double r170976 = 0.25;
double r170977 = sqrt(r170976);
double r170978 = r170977 * r170962;
double r170979 = 0.5;
double r170980 = r170979 * r170956;
double r170981 = cos(r170980);
double r170982 = r170954 * r170981;
double r170983 = r170978 / r170982;
double r170984 = r170960 * r170983;
double r170985 = r170975 ? r170984 : r170969;
return r170985;
}



Bits error versus J



Bits error versus K



Bits error versus U
Results
if (* (* (* -2.0 J) (cos (/ K 2.0))) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) (cos (/ K 2.0)))) 2.0)))) < -inf.0 or 4.5251739783607176e+303 < (* (* (* -2.0 J) (cos (/ K 2.0))) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) (cos (/ K 2.0)))) 2.0)))) Initial program 63.2
Taylor expanded around inf 45.8
if -inf.0 < (* (* (* -2.0 J) (cos (/ K 2.0))) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) (cos (/ K 2.0)))) 2.0)))) < 4.5251739783607176e+303Initial program 0.1
Final simplification13.1
herbie shell --seed 2020064
(FPCore (J K U)
:name "Maksimov and Kolovsky, Equation (3)"
:precision binary64
(* (* (* -2 J) (cos (/ K 2))) (sqrt (+ 1 (pow (/ U (* (* 2 J) (cos (/ K 2)))) 2)))))