\sqrt{\left(\left(2 \cdot n\right) \cdot U\right) \cdot \left(\left(t - 2 \cdot \frac{\ell \cdot \ell}{Om}\right) - \left(n \cdot {\left(\frac{\ell}{Om}\right)}^{2}\right) \cdot \left(U - U*\right)\right)}\begin{array}{l}
\mathbf{if}\;n \le 4.84783032232548084 \cdot 10^{-283}:\\
\;\;\;\;\sqrt{\left(\left(2 \cdot n\right) \cdot U\right) \cdot \left(\left(t - 2 \cdot \left(\ell \cdot \frac{\ell}{Om}\right)\right) - \left(\left(n \cdot {\left(\sqrt[3]{\frac{\ell}{Om}} \cdot \sqrt[3]{\frac{\ell}{Om}}\right)}^{2}\right) \cdot {\left(\sqrt[3]{\frac{\ell}{Om}}\right)}^{2}\right) \cdot \left(U - U*\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\sqrt{2 \cdot n} \cdot \sqrt{U \cdot \left(\left(t - 2 \cdot \left(\ell \cdot \frac{\ell}{Om}\right)\right) - \left(n \cdot {\left(\frac{\ell}{Om}\right)}^{2}\right) \cdot \left(U - U*\right)\right)}\\
\end{array}double f(double n, double U, double t, double l, double Om, double U_) {
double r181853 = 2.0;
double r181854 = n;
double r181855 = r181853 * r181854;
double r181856 = U;
double r181857 = r181855 * r181856;
double r181858 = t;
double r181859 = l;
double r181860 = r181859 * r181859;
double r181861 = Om;
double r181862 = r181860 / r181861;
double r181863 = r181853 * r181862;
double r181864 = r181858 - r181863;
double r181865 = r181859 / r181861;
double r181866 = pow(r181865, r181853);
double r181867 = r181854 * r181866;
double r181868 = U_;
double r181869 = r181856 - r181868;
double r181870 = r181867 * r181869;
double r181871 = r181864 - r181870;
double r181872 = r181857 * r181871;
double r181873 = sqrt(r181872);
return r181873;
}
double f(double n, double U, double t, double l, double Om, double U_) {
double r181874 = n;
double r181875 = 4.847830322325481e-283;
bool r181876 = r181874 <= r181875;
double r181877 = 2.0;
double r181878 = r181877 * r181874;
double r181879 = U;
double r181880 = r181878 * r181879;
double r181881 = t;
double r181882 = l;
double r181883 = Om;
double r181884 = r181882 / r181883;
double r181885 = r181882 * r181884;
double r181886 = r181877 * r181885;
double r181887 = r181881 - r181886;
double r181888 = cbrt(r181884);
double r181889 = r181888 * r181888;
double r181890 = pow(r181889, r181877);
double r181891 = r181874 * r181890;
double r181892 = pow(r181888, r181877);
double r181893 = r181891 * r181892;
double r181894 = U_;
double r181895 = r181879 - r181894;
double r181896 = r181893 * r181895;
double r181897 = r181887 - r181896;
double r181898 = r181880 * r181897;
double r181899 = sqrt(r181898);
double r181900 = sqrt(r181878);
double r181901 = pow(r181884, r181877);
double r181902 = r181874 * r181901;
double r181903 = r181902 * r181895;
double r181904 = r181887 - r181903;
double r181905 = r181879 * r181904;
double r181906 = sqrt(r181905);
double r181907 = r181900 * r181906;
double r181908 = r181876 ? r181899 : r181907;
return r181908;
}



Bits error versus n



Bits error versus U



Bits error versus t



Bits error versus l



Bits error versus Om



Bits error versus U*
Results
if n < 4.847830322325481e-283Initial program 34.5
rmApplied *-un-lft-identity34.5
Applied times-frac32.0
Simplified32.0
rmApplied add-cube-cbrt32.1
Applied unpow-prod-down32.1
Applied associate-*r*31.3
if 4.847830322325481e-283 < n Initial program 33.7
rmApplied *-un-lft-identity33.7
Applied times-frac30.8
Simplified30.8
rmApplied associate-*l*31.2
rmApplied sqrt-prod24.3
Final simplification28.0
herbie shell --seed 2020065 +o rules:numerics
(FPCore (n U t l Om U*)
:name "Toniolo and Linder, Equation (13)"
:precision binary64
(sqrt (* (* (* 2 n) U) (- (- t (* 2 (/ (* l l) Om))) (* (* n (pow (/ l Om) 2)) (- U U*))))))