double code(double J, double K, double U) {
return ((double) (((double) (((double) (-2.0 * J)) * ((double) cos(((double) (K / 2.0)))))) * ((double) sqrt(((double) (1.0 + ((double) pow(((double) (U / ((double) (((double) (2.0 * J)) * ((double) cos(((double) (K / 2.0)))))))), 2.0))))))));
}
double code(double J, double K, double U) {
double VAR;
if ((((double) (((double) (((double) (-2.0 * J)) * ((double) cos(((double) (K / 2.0)))))) * ((double) sqrt(((double) (1.0 + ((double) pow(((double) (U / ((double) (((double) cos(((double) (K / 2.0)))) * ((double) (J * 2.0)))))), 2.0)))))))) <= -inf.0)) {
VAR = ((double) (((double) (((double) (-2.0 * J)) * ((double) cos(((double) (K / 2.0)))))) * ((double) (U * ((double) (((double) sqrt(0.25)) / ((double) (J * ((double) cos(((double) (K * 0.5))))))))))));
} else {
double VAR_1;
if ((((double) (((double) (((double) (-2.0 * J)) * ((double) cos(((double) (K / 2.0)))))) * ((double) sqrt(((double) (1.0 + ((double) pow(((double) (U / ((double) (((double) cos(((double) (K / 2.0)))) * ((double) (J * 2.0)))))), 2.0)))))))) <= 2.9562275782773536e+301)) {
VAR_1 = ((double) (((double) (((double) (-2.0 * J)) * ((double) cos(((double) (K / 2.0)))))) * ((double) sqrt(((double) (1.0 + ((double) pow(((double) (U / ((double) (((double) cos(((double) (K / 2.0)))) * ((double) (J * 2.0)))))), 2.0))))))));
} else {
VAR_1 = ((double) (-2.0 * ((double) (J * ((double) (((double) cos(((double) (K / 2.0)))) * ((double) (U * ((double) (((double) sqrt(0.25)) / ((double) (J * ((double) cos(((double) (K * 0.5))))))))))))))));
}
VAR = VAR_1;
}
return VAR;
}



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.0Initial program 64.0
Taylor expanded around inf 46.3
Simplified46.4
if -inf.0 < (* (* (* -2.0 J) (cos (/ K 2.0))) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) (cos (/ K 2.0)))) 2.0)))) < 2.9562275782773536e301Initial program 0.1
if 2.9562275782773536e301 < (* (* (* -2.0 J) (cos (/ K 2.0))) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) (cos (/ K 2.0)))) 2.0)))) Initial program 60.6
Simplified60.5
Taylor expanded around inf 46.5
Simplified46.5
Final simplification13.3
herbie shell --seed 2020181
(FPCore (J K U)
:name "Maksimov and Kolovsky, Equation (3)"
:precision binary64
(* (* (* -2.0 J) (cos (/ K 2.0))) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) (cos (/ K 2.0)))) 2.0)))))