\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}\;t \le 8.48078266481481385711732205638014053282 \cdot 10^{128}:\\
\;\;\;\;\sqrt{\left(2 \cdot n\right) \cdot \left(U \cdot \left(t - \mathsf{fma}\left(2 \cdot \ell, \frac{\ell}{Om}, \left(U - U*\right) \cdot \left(n \cdot {\left(\frac{\ell}{Om}\right)}^{\left(2 \cdot \frac{2}{2}\right)}\right)\right)\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\sqrt{\left(2 \cdot n\right) \cdot U} \cdot \sqrt{t - \mathsf{fma}\left(2 \cdot \ell, \frac{\ell}{Om}, \left(U - U*\right) \cdot \left(n \cdot {\left(\frac{\ell}{Om}\right)}^{\left(2 \cdot \frac{2}{2}\right)}\right)\right)}\\
\end{array}double f(double n, double U, double t, double l, double Om, double U_) {
double r184751 = 2.0;
double r184752 = n;
double r184753 = r184751 * r184752;
double r184754 = U;
double r184755 = r184753 * r184754;
double r184756 = t;
double r184757 = l;
double r184758 = r184757 * r184757;
double r184759 = Om;
double r184760 = r184758 / r184759;
double r184761 = r184751 * r184760;
double r184762 = r184756 - r184761;
double r184763 = r184757 / r184759;
double r184764 = pow(r184763, r184751);
double r184765 = r184752 * r184764;
double r184766 = U_;
double r184767 = r184754 - r184766;
double r184768 = r184765 * r184767;
double r184769 = r184762 - r184768;
double r184770 = r184755 * r184769;
double r184771 = sqrt(r184770);
return r184771;
}
double f(double n, double U, double t, double l, double Om, double U_) {
double r184772 = t;
double r184773 = 8.480782664814814e+128;
bool r184774 = r184772 <= r184773;
double r184775 = 2.0;
double r184776 = n;
double r184777 = r184775 * r184776;
double r184778 = U;
double r184779 = l;
double r184780 = r184775 * r184779;
double r184781 = Om;
double r184782 = r184779 / r184781;
double r184783 = U_;
double r184784 = r184778 - r184783;
double r184785 = 2.0;
double r184786 = r184775 / r184785;
double r184787 = r184785 * r184786;
double r184788 = pow(r184782, r184787);
double r184789 = r184776 * r184788;
double r184790 = r184784 * r184789;
double r184791 = fma(r184780, r184782, r184790);
double r184792 = r184772 - r184791;
double r184793 = r184778 * r184792;
double r184794 = r184777 * r184793;
double r184795 = sqrt(r184794);
double r184796 = r184777 * r184778;
double r184797 = sqrt(r184796);
double r184798 = sqrt(r184792);
double r184799 = r184797 * r184798;
double r184800 = r184774 ? r184795 : r184799;
return r184800;
}



Bits error versus n



Bits error versus U



Bits error versus t



Bits error versus l



Bits error versus Om



Bits error versus U*
if t < 8.480782664814814e+128Initial program 34.1
rmApplied *-un-lft-identity34.1
Applied times-frac31.2
Simplified31.2
rmApplied sqr-pow31.2
Applied associate-*r*30.4
rmApplied associate-*l*29.9
Simplified31.0
if 8.480782664814814e+128 < t Initial program 37.9
rmApplied *-un-lft-identity37.9
Applied times-frac35.2
Simplified35.2
rmApplied sqr-pow35.2
Applied associate-*r*34.6
rmApplied sqrt-prod22.9
Simplified23.4
Final simplification29.9
herbie shell --seed 2019325 +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*))))))