\sqrt[3]{\frac{1}{2 \cdot a} \cdot \left(\left(-g\right) + \sqrt{g \cdot g - h \cdot h}\right)} + \sqrt[3]{\frac{1}{2 \cdot a} \cdot \left(\left(-g\right) - \sqrt{g \cdot g - h \cdot h}\right)}\sqrt[3]{\frac{1}{2 \cdot a}} \cdot \sqrt[3]{\sqrt{g \cdot g - h \cdot h} - g} + \sqrt[3]{\frac{1}{2 \cdot a}} \cdot \sqrt[3]{\left(-g\right) - \sqrt{g \cdot g - h \cdot h}}double f(double g, double h, double a) {
double r219053 = 1.0;
double r219054 = 2.0;
double r219055 = a;
double r219056 = r219054 * r219055;
double r219057 = r219053 / r219056;
double r219058 = g;
double r219059 = -r219058;
double r219060 = r219058 * r219058;
double r219061 = h;
double r219062 = r219061 * r219061;
double r219063 = r219060 - r219062;
double r219064 = sqrt(r219063);
double r219065 = r219059 + r219064;
double r219066 = r219057 * r219065;
double r219067 = cbrt(r219066);
double r219068 = r219059 - r219064;
double r219069 = r219057 * r219068;
double r219070 = cbrt(r219069);
double r219071 = r219067 + r219070;
return r219071;
}
double f(double g, double h, double a) {
double r219072 = 1.0;
double r219073 = 2.0;
double r219074 = a;
double r219075 = r219073 * r219074;
double r219076 = r219072 / r219075;
double r219077 = cbrt(r219076);
double r219078 = g;
double r219079 = r219078 * r219078;
double r219080 = h;
double r219081 = r219080 * r219080;
double r219082 = r219079 - r219081;
double r219083 = sqrt(r219082);
double r219084 = r219083 - r219078;
double r219085 = cbrt(r219084);
double r219086 = r219077 * r219085;
double r219087 = -r219078;
double r219088 = r219087 - r219083;
double r219089 = cbrt(r219088);
double r219090 = r219077 * r219089;
double r219091 = r219086 + r219090;
return r219091;
}



Bits error versus g



Bits error versus h



Bits error versus a
Results
Initial program 36.6
rmApplied cbrt-prod34.7
Simplified34.7
rmApplied cbrt-prod33.0
Final simplification33.0
herbie shell --seed 2020047
(FPCore (g h a)
:name "2-ancestry mixing, positive discriminant"
:precision binary64
(+ (cbrt (* (/ 1 (* 2 a)) (+ (- g) (sqrt (- (* g g) (* h h)))))) (cbrt (* (/ 1 (* 2 a)) (- (- g) (sqrt (- (* g g) (* h h))))))))