\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 6.281380710180291348067443154791932971737 \cdot 10^{305}\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 r120549 = -2.0;
double r120550 = J;
double r120551 = r120549 * r120550;
double r120552 = K;
double r120553 = 2.0;
double r120554 = r120552 / r120553;
double r120555 = cos(r120554);
double r120556 = r120551 * r120555;
double r120557 = 1.0;
double r120558 = U;
double r120559 = r120553 * r120550;
double r120560 = r120559 * r120555;
double r120561 = r120558 / r120560;
double r120562 = pow(r120561, r120553);
double r120563 = r120557 + r120562;
double r120564 = sqrt(r120563);
double r120565 = r120556 * r120564;
return r120565;
}
double f(double J, double K, double U) {
double r120566 = -2.0;
double r120567 = J;
double r120568 = r120566 * r120567;
double r120569 = K;
double r120570 = 2.0;
double r120571 = r120569 / r120570;
double r120572 = cos(r120571);
double r120573 = r120568 * r120572;
double r120574 = 1.0;
double r120575 = U;
double r120576 = r120570 * r120567;
double r120577 = r120576 * r120572;
double r120578 = r120575 / r120577;
double r120579 = pow(r120578, r120570);
double r120580 = r120574 + r120579;
double r120581 = sqrt(r120580);
double r120582 = r120573 * r120581;
double r120583 = -inf.0;
bool r120584 = r120582 <= r120583;
double r120585 = 6.281380710180291e+305;
bool r120586 = r120582 <= r120585;
double r120587 = !r120586;
bool r120588 = r120584 || r120587;
double r120589 = 0.25;
double r120590 = sqrt(r120589);
double r120591 = r120590 * r120575;
double r120592 = 0.5;
double r120593 = r120592 * r120569;
double r120594 = cos(r120593);
double r120595 = r120567 * r120594;
double r120596 = r120591 / r120595;
double r120597 = r120573 * r120596;
double r120598 = r120588 ? r120597 : r120582;
return r120598;
}



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 6.281380710180291e+305 < (* (* (* -2.0 J) (cos (/ K 2.0))) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) (cos (/ K 2.0)))) 2.0)))) Initial program 63.6
Taylor expanded around inf 45.9
if -inf.0 < (* (* (* -2.0 J) (cos (/ K 2.0))) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) (cos (/ K 2.0)))) 2.0)))) < 6.281380710180291e+305Initial program 0.1
Final simplification12.9
herbie shell --seed 2019353
(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)))))