\sqrt{\frac{1}{2} \cdot \left(1 + \frac{1}{\sqrt{1 + {\left(\frac{2 \cdot \ell}{Om}\right)}^{2} \cdot \left({\left(\sin kx\right)}^{2} + {\left(\sin ky\right)}^{2}\right)}}\right)}\sqrt{\frac{1}{2} \cdot \left(1 + \frac{\frac{1}{\sqrt[3]{\sqrt{1 + {\left(\frac{2 \cdot \ell}{Om}\right)}^{2} \cdot \left({\left(\sin kx\right)}^{2} + {\left(\sin ky\right)}^{2}\right)}} \cdot \sqrt[3]{\sqrt{1 + {\left(\frac{2 \cdot \ell}{Om}\right)}^{2} \cdot \left({\left(\sin kx\right)}^{2} + {\left(\sin ky\right)}^{2}\right)}}}}{\left(\sqrt[3]{\sqrt[3]{\sqrt{1 + {\left(\frac{2 \cdot \ell}{Om}\right)}^{2} \cdot \left({\left(\sin kx\right)}^{2} + {\left(\sin ky\right)}^{2}\right)}}} \cdot \sqrt[3]{\sqrt[3]{\sqrt{1 + {\left(\frac{2 \cdot \ell}{Om}\right)}^{2} \cdot \left({\left(\sin kx\right)}^{2} + {\left(\sin ky\right)}^{2}\right)}}}\right) \cdot \sqrt[3]{\sqrt[3]{\sqrt{1 + {\left(\frac{2 \cdot \ell}{Om}\right)}^{2} \cdot \left({\left(\sin kx\right)}^{2} + {\left(\sin ky\right)}^{2}\right)}}}}\right)}double f(double l, double Om, double kx, double ky) {
double r55094 = 1.0;
double r55095 = 2.0;
double r55096 = r55094 / r55095;
double r55097 = l;
double r55098 = r55095 * r55097;
double r55099 = Om;
double r55100 = r55098 / r55099;
double r55101 = pow(r55100, r55095);
double r55102 = kx;
double r55103 = sin(r55102);
double r55104 = pow(r55103, r55095);
double r55105 = ky;
double r55106 = sin(r55105);
double r55107 = pow(r55106, r55095);
double r55108 = r55104 + r55107;
double r55109 = r55101 * r55108;
double r55110 = r55094 + r55109;
double r55111 = sqrt(r55110);
double r55112 = r55094 / r55111;
double r55113 = r55094 + r55112;
double r55114 = r55096 * r55113;
double r55115 = sqrt(r55114);
return r55115;
}
double f(double l, double Om, double kx, double ky) {
double r55116 = 1.0;
double r55117 = 2.0;
double r55118 = r55116 / r55117;
double r55119 = l;
double r55120 = r55117 * r55119;
double r55121 = Om;
double r55122 = r55120 / r55121;
double r55123 = pow(r55122, r55117);
double r55124 = kx;
double r55125 = sin(r55124);
double r55126 = pow(r55125, r55117);
double r55127 = ky;
double r55128 = sin(r55127);
double r55129 = pow(r55128, r55117);
double r55130 = r55126 + r55129;
double r55131 = r55123 * r55130;
double r55132 = r55116 + r55131;
double r55133 = sqrt(r55132);
double r55134 = cbrt(r55133);
double r55135 = r55134 * r55134;
double r55136 = r55116 / r55135;
double r55137 = cbrt(r55134);
double r55138 = r55137 * r55137;
double r55139 = r55138 * r55137;
double r55140 = r55136 / r55139;
double r55141 = r55116 + r55140;
double r55142 = r55118 * r55141;
double r55143 = sqrt(r55142);
return r55143;
}



Bits error versus l



Bits error versus Om



Bits error versus kx



Bits error versus ky
Results
Initial program 1.9
rmApplied add-cube-cbrt1.9
Applied associate-/r*1.9
rmApplied add-cube-cbrt1.9
Final simplification1.9
herbie shell --seed 2020046
(FPCore (l Om kx ky)
:name "Toniolo and Linder, Equation (3a)"
:precision binary64
(sqrt (* (/ 1 2) (+ 1 (/ 1 (sqrt (+ 1 (* (pow (/ (* 2 l) Om) 2) (+ (pow (sin kx) 2) (pow (sin ky) 2))))))))))