\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 1.569821859298618806925582301780582570703 \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 r107482 = -2.0;
double r107483 = J;
double r107484 = r107482 * r107483;
double r107485 = K;
double r107486 = 2.0;
double r107487 = r107485 / r107486;
double r107488 = cos(r107487);
double r107489 = r107484 * r107488;
double r107490 = 1.0;
double r107491 = U;
double r107492 = r107486 * r107483;
double r107493 = r107492 * r107488;
double r107494 = r107491 / r107493;
double r107495 = pow(r107494, r107486);
double r107496 = r107490 + r107495;
double r107497 = sqrt(r107496);
double r107498 = r107489 * r107497;
return r107498;
}
double f(double J, double K, double U) {
double r107499 = -2.0;
double r107500 = J;
double r107501 = r107499 * r107500;
double r107502 = K;
double r107503 = 2.0;
double r107504 = r107502 / r107503;
double r107505 = cos(r107504);
double r107506 = r107501 * r107505;
double r107507 = 1.0;
double r107508 = U;
double r107509 = r107503 * r107500;
double r107510 = r107509 * r107505;
double r107511 = r107508 / r107510;
double r107512 = pow(r107511, r107503);
double r107513 = r107507 + r107512;
double r107514 = sqrt(r107513);
double r107515 = r107506 * r107514;
double r107516 = -inf.0;
bool r107517 = r107515 <= r107516;
double r107518 = 1.5698218592986188e+303;
bool r107519 = r107515 <= r107518;
double r107520 = !r107519;
bool r107521 = r107517 || r107520;
double r107522 = 0.25;
double r107523 = sqrt(r107522);
double r107524 = r107523 * r107508;
double r107525 = 0.5;
double r107526 = r107525 * r107502;
double r107527 = cos(r107526);
double r107528 = r107500 * r107527;
double r107529 = r107524 / r107528;
double r107530 = r107506 * r107529;
double r107531 = r107521 ? r107530 : r107515;
return r107531;
}



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 1.5698218592986188e+303 < (* (* (* -2.0 J) (cos (/ K 2.0))) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) (cos (/ K 2.0)))) 2.0)))) Initial program 62.8
Taylor expanded around inf 45.6
if -inf.0 < (* (* (* -2.0 J) (cos (/ K 2.0))) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) (cos (/ K 2.0)))) 2.0)))) < 1.5698218592986188e+303Initial program 0.1
Final simplification13.4
herbie shell --seed 2019303
(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)))))