\sin^{-1} \left(\sqrt{\frac{1 - {\left(\frac{Om}{Omc}\right)}^{2}}{1 + 2 \cdot {\left(\frac{t}{\ell}\right)}^{2}}}\right)\sin^{-1} \left(\sqrt{\frac{1 \cdot 1 - {\left(\frac{Om}{Omc}\right)}^{2} \cdot {\left(\frac{Om}{Omc}\right)}^{2}}{\left(1 + 2 \cdot {\left(\frac{t}{\ell}\right)}^{2}\right) \cdot \left(1 + {\left(\frac{Om}{Omc}\right)}^{2}\right)}}\right)double f(double t, double l, double Om, double Omc) {
double r93668 = 1.0;
double r93669 = Om;
double r93670 = Omc;
double r93671 = r93669 / r93670;
double r93672 = 2.0;
double r93673 = pow(r93671, r93672);
double r93674 = r93668 - r93673;
double r93675 = t;
double r93676 = l;
double r93677 = r93675 / r93676;
double r93678 = pow(r93677, r93672);
double r93679 = r93672 * r93678;
double r93680 = r93668 + r93679;
double r93681 = r93674 / r93680;
double r93682 = sqrt(r93681);
double r93683 = asin(r93682);
return r93683;
}
double f(double t, double l, double Om, double Omc) {
double r93684 = 1.0;
double r93685 = r93684 * r93684;
double r93686 = Om;
double r93687 = Omc;
double r93688 = r93686 / r93687;
double r93689 = 2.0;
double r93690 = pow(r93688, r93689);
double r93691 = r93690 * r93690;
double r93692 = r93685 - r93691;
double r93693 = t;
double r93694 = l;
double r93695 = r93693 / r93694;
double r93696 = pow(r93695, r93689);
double r93697 = r93689 * r93696;
double r93698 = r93684 + r93697;
double r93699 = r93684 + r93690;
double r93700 = r93698 * r93699;
double r93701 = r93692 / r93700;
double r93702 = sqrt(r93701);
double r93703 = asin(r93702);
return r93703;
}



Bits error versus t



Bits error versus l



Bits error versus Om



Bits error versus Omc
Results
Initial program 10.3
rmApplied flip--10.3
Applied associate-/l/10.3
Final simplification10.3
herbie shell --seed 2019325
(FPCore (t l Om Omc)
:name "Toniolo and Linder, Equation (2)"
:precision binary64
(asin (sqrt (/ (- 1 (pow (/ Om Omc) 2)) (+ 1 (* 2 (pow (/ t l) 2)))))))