\left(x \cdot \log y + z \cdot \log \left(1 - y\right)\right) - t
\left(\left(x \cdot \left(2 \cdot \log \left(\sqrt[3]{y}\right)\right) + x \cdot \log \left({\left(\frac{1}{y}\right)}^{\frac{-1}{3}}\right)\right) + \left(z \cdot \log 1 - \left(1 \cdot \left(z \cdot y\right) + \frac{1}{2} \cdot \frac{z \cdot {y}^{2}}{{1}^{2}}\right)\right)\right) - tdouble f(double x, double y, double z, double t) {
double r426171 = x;
double r426172 = y;
double r426173 = log(r426172);
double r426174 = r426171 * r426173;
double r426175 = z;
double r426176 = 1.0;
double r426177 = r426176 - r426172;
double r426178 = log(r426177);
double r426179 = r426175 * r426178;
double r426180 = r426174 + r426179;
double r426181 = t;
double r426182 = r426180 - r426181;
return r426182;
}
double f(double x, double y, double z, double t) {
double r426183 = x;
double r426184 = 2.0;
double r426185 = y;
double r426186 = cbrt(r426185);
double r426187 = log(r426186);
double r426188 = r426184 * r426187;
double r426189 = r426183 * r426188;
double r426190 = 1.0;
double r426191 = r426190 / r426185;
double r426192 = -0.3333333333333333;
double r426193 = pow(r426191, r426192);
double r426194 = log(r426193);
double r426195 = r426183 * r426194;
double r426196 = r426189 + r426195;
double r426197 = z;
double r426198 = 1.0;
double r426199 = log(r426198);
double r426200 = r426197 * r426199;
double r426201 = r426197 * r426185;
double r426202 = r426198 * r426201;
double r426203 = 0.5;
double r426204 = pow(r426185, r426184);
double r426205 = r426197 * r426204;
double r426206 = pow(r426198, r426184);
double r426207 = r426205 / r426206;
double r426208 = r426203 * r426207;
double r426209 = r426202 + r426208;
double r426210 = r426200 - r426209;
double r426211 = r426196 + r426210;
double r426212 = t;
double r426213 = r426211 - r426212;
return r426213;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 9.5 |
|---|---|
| Target | 0.3 |
| Herbie | 0.4 |
Initial program 9.5
Taylor expanded around 0 0.3
rmApplied add-cube-cbrt0.3
Applied log-prod0.4
Applied distribute-lft-in0.4
Simplified0.4
Taylor expanded around inf 0.4
Final simplification0.4
herbie shell --seed 2020018
(FPCore (x y z t)
:name "Numeric.SpecFunctions:invIncompleteBetaWorker from math-functions-0.1.5.2, B"
:precision binary64
:herbie-target
(- (* (- z) (+ (+ (* 0.5 (* y y)) y) (* (/ 0.3333333333333333 (* 1 (* 1 1))) (* y (* y y))))) (- t (* x (log y))))
(- (+ (* x (log y)) (* z (log (- 1 y)))) t))