\log \left(1 + e^{x}\right) - x \cdot y\left(\log \left({1}^{3} + {\left(e^{x}\right)}^{3}\right) - \left(\sqrt[3]{\log \left(\mathsf{fma}\left(1, 1, e^{x} \cdot \left(e^{x} - 1\right)\right)\right)} \cdot \sqrt[3]{\log \left(\sqrt{\mathsf{fma}\left(1, 1, e^{x} \cdot \left(e^{x} - 1\right)\right)}\right) + \log \left(\sqrt{\mathsf{fma}\left(1, 1, e^{x} \cdot \left(e^{x} - 1\right)\right)}\right)}\right) \cdot \sqrt[3]{\log \left(\mathsf{fma}\left(1, 1, e^{x} \cdot \left(e^{x} - 1\right)\right)\right)}\right) - x \cdot ydouble f(double x, double y) {
double r153182 = 1.0;
double r153183 = x;
double r153184 = exp(r153183);
double r153185 = r153182 + r153184;
double r153186 = log(r153185);
double r153187 = y;
double r153188 = r153183 * r153187;
double r153189 = r153186 - r153188;
return r153189;
}
double f(double x, double y) {
double r153190 = 1.0;
double r153191 = 3.0;
double r153192 = pow(r153190, r153191);
double r153193 = x;
double r153194 = exp(r153193);
double r153195 = pow(r153194, r153191);
double r153196 = r153192 + r153195;
double r153197 = log(r153196);
double r153198 = r153194 - r153190;
double r153199 = r153194 * r153198;
double r153200 = fma(r153190, r153190, r153199);
double r153201 = log(r153200);
double r153202 = cbrt(r153201);
double r153203 = sqrt(r153200);
double r153204 = log(r153203);
double r153205 = r153204 + r153204;
double r153206 = cbrt(r153205);
double r153207 = r153202 * r153206;
double r153208 = r153207 * r153202;
double r153209 = r153197 - r153208;
double r153210 = y;
double r153211 = r153193 * r153210;
double r153212 = r153209 - r153211;
return r153212;
}




Bits error versus x




Bits error versus y
| Original | 0.5 |
|---|---|
| Target | 0.1 |
| Herbie | 0.5 |
Initial program 0.5
rmApplied flip3-+0.5
Applied log-div0.5
Simplified0.5
rmApplied add-cube-cbrt0.5
rmApplied add-sqr-sqrt0.5
Applied log-prod0.5
Final simplification0.5
herbie shell --seed 2020047 +o rules:numerics
(FPCore (x y)
:name "Logistic regression 2"
:precision binary64
:herbie-target
(if (<= x 0.0) (- (log (+ 1 (exp x))) (* x y)) (- (log (+ 1 (exp (- x)))) (* (- x) (- 1 y))))
(- (log (+ 1 (exp x))) (* x y)))