\sin^{-1} \left(\sqrt{\frac{1 - {\left(\frac{Om}{Omc}\right)}^{2}}{1 + 2 \cdot {\left(\frac{t}{\ell}\right)}^{2}}}\right)\begin{array}{l}
\mathbf{if}\;\frac{t}{\ell} \le 4.3448374903793984 \cdot 10^{+86}:\\
\;\;\;\;\sin^{-1} \left(\frac{\sqrt{1 - \frac{Om}{Omc} \cdot \frac{Om}{Omc}}}{\sqrt{(\left(\frac{t}{\ell} \cdot \frac{t}{\ell}\right) \cdot 2 + 1)_*}}\right)\\
\mathbf{else}:\\
\;\;\;\;\sin^{-1} \left(\frac{\sqrt{1 - \frac{Om}{Omc} \cdot \frac{Om}{Omc}}}{\frac{t \cdot \sqrt{2}}{\ell}}\right)\\
\end{array}double f(double t, double l, double Om, double Omc) {
double r3964803 = 1.0;
double r3964804 = Om;
double r3964805 = Omc;
double r3964806 = r3964804 / r3964805;
double r3964807 = 2.0;
double r3964808 = pow(r3964806, r3964807);
double r3964809 = r3964803 - r3964808;
double r3964810 = t;
double r3964811 = l;
double r3964812 = r3964810 / r3964811;
double r3964813 = pow(r3964812, r3964807);
double r3964814 = r3964807 * r3964813;
double r3964815 = r3964803 + r3964814;
double r3964816 = r3964809 / r3964815;
double r3964817 = sqrt(r3964816);
double r3964818 = asin(r3964817);
return r3964818;
}
double f(double t, double l, double Om, double Omc) {
double r3964819 = t;
double r3964820 = l;
double r3964821 = r3964819 / r3964820;
double r3964822 = 4.3448374903793984e+86;
bool r3964823 = r3964821 <= r3964822;
double r3964824 = 1.0;
double r3964825 = Om;
double r3964826 = Omc;
double r3964827 = r3964825 / r3964826;
double r3964828 = r3964827 * r3964827;
double r3964829 = r3964824 - r3964828;
double r3964830 = sqrt(r3964829);
double r3964831 = r3964821 * r3964821;
double r3964832 = 2.0;
double r3964833 = fma(r3964831, r3964832, r3964824);
double r3964834 = sqrt(r3964833);
double r3964835 = r3964830 / r3964834;
double r3964836 = asin(r3964835);
double r3964837 = sqrt(r3964832);
double r3964838 = r3964819 * r3964837;
double r3964839 = r3964838 / r3964820;
double r3964840 = r3964830 / r3964839;
double r3964841 = asin(r3964840);
double r3964842 = r3964823 ? r3964836 : r3964841;
return r3964842;
}



Bits error versus t



Bits error versus l



Bits error versus Om



Bits error versus Omc
if (/ t l) < 4.3448374903793984e+86Initial program 7.0
Simplified7.0
rmApplied sqrt-div7.0
if 4.3448374903793984e+86 < (/ t l) Initial program 26.8
Simplified26.8
rmApplied sqrt-div26.8
Taylor expanded around -inf 1.4
Final simplification6.0
herbie shell --seed 2019104 +o rules:numerics
(FPCore (t l Om Omc)
:name "Toniolo and Linder, Equation (2)"
(asin (sqrt (/ (- 1 (pow (/ Om Omc) 2)) (+ 1 (* 2 (pow (/ t l) 2)))))))