\left(J \cdot \left(e^{\ell} - e^{-\ell}\right)\right) \cdot \cos \left(\frac{K}{2}\right) + U\mathsf{fma}\left(\left(\ell \cdot J\right) \cdot 2, \cos \left(\frac{K}{2}\right), U\right)double f(double J, double l, double K, double U) {
double r1476600 = J;
double r1476601 = l;
double r1476602 = exp(r1476601);
double r1476603 = -r1476601;
double r1476604 = exp(r1476603);
double r1476605 = r1476602 - r1476604;
double r1476606 = r1476600 * r1476605;
double r1476607 = K;
double r1476608 = 2.0;
double r1476609 = r1476607 / r1476608;
double r1476610 = cos(r1476609);
double r1476611 = r1476606 * r1476610;
double r1476612 = U;
double r1476613 = r1476611 + r1476612;
return r1476613;
}
double f(double J, double l, double K, double U) {
double r1476614 = l;
double r1476615 = J;
double r1476616 = r1476614 * r1476615;
double r1476617 = 2.0;
double r1476618 = r1476616 * r1476617;
double r1476619 = K;
double r1476620 = r1476619 / r1476617;
double r1476621 = cos(r1476620);
double r1476622 = U;
double r1476623 = fma(r1476618, r1476621, r1476622);
return r1476623;
}



Bits error versus J



Bits error versus l



Bits error versus K



Bits error versus U
Initial program 17.0
Simplified17.0
Taylor expanded around 0 0.6
Final simplification0.6
herbie shell --seed 2019156 +o rules:numerics
(FPCore (J l K U)
:name "Maksimov and Kolovsky, Equation (4)"
(+ (* (* J (- (exp l) (exp (- l)))) (cos (/ K 2))) U))