\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}\;U \le 2.9259008121443 \cdot 10^{-311}:\\
\;\;\;\;\sqrt{U \cdot \left(\left(\left(t - \left(\ell \cdot 2 - \sqrt[3]{\left(U* - U\right) \cdot \left(\left(\sqrt[3]{\ell} \cdot \sqrt[3]{\ell}\right) \cdot \left(\frac{\sqrt[3]{\ell}}{Om} \cdot n\right)\right)} \cdot \left(\sqrt[3]{\left(U* - U\right) \cdot \left(\left(\sqrt[3]{\ell} \cdot \sqrt[3]{\ell}\right) \cdot \left(\frac{\sqrt[3]{\ell}}{Om} \cdot n\right)\right)} \cdot \sqrt[3]{\left(U* - U\right) \cdot \left(\left(\sqrt[3]{\ell} \cdot \sqrt[3]{\ell}\right) \cdot \left(\frac{\sqrt[3]{\ell}}{Om} \cdot n\right)\right)}\right)\right) \cdot \frac{\ell}{Om}\right) \cdot 2\right) \cdot n\right)}\\
\mathbf{else}:\\
\;\;\;\;\sqrt{n \cdot \left(\left(t - \frac{\ell}{Om} \cdot \left(\ell \cdot 2 - \left(U* - U\right) \cdot \left(\left(\sqrt[3]{\ell} \cdot n\right) \cdot \frac{\sqrt[3]{\ell} \cdot \sqrt[3]{\ell}}{Om}\right)\right)\right) \cdot 2\right)} \cdot \sqrt{U}\\
\end{array}double f(double n, double U, double t, double l, double Om, double U_) {
double r1908632 = 2.0;
double r1908633 = n;
double r1908634 = r1908632 * r1908633;
double r1908635 = U;
double r1908636 = r1908634 * r1908635;
double r1908637 = t;
double r1908638 = l;
double r1908639 = r1908638 * r1908638;
double r1908640 = Om;
double r1908641 = r1908639 / r1908640;
double r1908642 = r1908632 * r1908641;
double r1908643 = r1908637 - r1908642;
double r1908644 = r1908638 / r1908640;
double r1908645 = pow(r1908644, r1908632);
double r1908646 = r1908633 * r1908645;
double r1908647 = U_;
double r1908648 = r1908635 - r1908647;
double r1908649 = r1908646 * r1908648;
double r1908650 = r1908643 - r1908649;
double r1908651 = r1908636 * r1908650;
double r1908652 = sqrt(r1908651);
return r1908652;
}
double f(double n, double U, double t, double l, double Om, double U_) {
double r1908653 = U;
double r1908654 = 2.9259008121443e-311;
bool r1908655 = r1908653 <= r1908654;
double r1908656 = t;
double r1908657 = l;
double r1908658 = 2.0;
double r1908659 = r1908657 * r1908658;
double r1908660 = U_;
double r1908661 = r1908660 - r1908653;
double r1908662 = cbrt(r1908657);
double r1908663 = r1908662 * r1908662;
double r1908664 = Om;
double r1908665 = r1908662 / r1908664;
double r1908666 = n;
double r1908667 = r1908665 * r1908666;
double r1908668 = r1908663 * r1908667;
double r1908669 = r1908661 * r1908668;
double r1908670 = cbrt(r1908669);
double r1908671 = r1908670 * r1908670;
double r1908672 = r1908670 * r1908671;
double r1908673 = r1908659 - r1908672;
double r1908674 = r1908657 / r1908664;
double r1908675 = r1908673 * r1908674;
double r1908676 = r1908656 - r1908675;
double r1908677 = r1908676 * r1908658;
double r1908678 = r1908677 * r1908666;
double r1908679 = r1908653 * r1908678;
double r1908680 = sqrt(r1908679);
double r1908681 = r1908662 * r1908666;
double r1908682 = r1908663 / r1908664;
double r1908683 = r1908681 * r1908682;
double r1908684 = r1908661 * r1908683;
double r1908685 = r1908659 - r1908684;
double r1908686 = r1908674 * r1908685;
double r1908687 = r1908656 - r1908686;
double r1908688 = r1908687 * r1908658;
double r1908689 = r1908666 * r1908688;
double r1908690 = sqrt(r1908689);
double r1908691 = sqrt(r1908653);
double r1908692 = r1908690 * r1908691;
double r1908693 = r1908655 ? r1908680 : r1908692;
return r1908693;
}



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 U < 2.9259008121443e-311Initial program 33.5
Simplified30.0
rmApplied div-inv30.0
Applied add-cube-cbrt30.0
Applied times-frac29.5
Simplified29.5
rmApplied associate-*l*29.6
rmApplied div-inv29.6
Applied associate-*l*29.7
Simplified29.6
rmApplied add-cube-cbrt29.6
if 2.9259008121443e-311 < U Initial program 33.0
Simplified30.1
rmApplied div-inv30.1
Applied add-cube-cbrt30.1
Applied times-frac29.7
Simplified29.7
rmApplied associate-*l*29.1
rmApplied sqrt-prod22.2
Final simplification25.9
herbie shell --seed 2019142
(FPCore (n U t l Om U*)
:name "Toniolo and Linder, Equation (13)"
(sqrt (* (* (* 2 n) U) (- (- t (* 2 (/ (* l l) Om))) (* (* n (pow (/ l Om) 2)) (- U U*))))))