\log \left(1 + e^{x}\right) - x \cdot y\mathsf{log1p}\left(e^{x}\right) - y \cdot xdouble f(double x, double y) {
double r5742397 = 1.0;
double r5742398 = x;
double r5742399 = exp(r5742398);
double r5742400 = r5742397 + r5742399;
double r5742401 = log(r5742400);
double r5742402 = y;
double r5742403 = r5742398 * r5742402;
double r5742404 = r5742401 - r5742403;
return r5742404;
}
double f(double x, double y) {
double r5742405 = x;
double r5742406 = exp(r5742405);
double r5742407 = log1p(r5742406);
double r5742408 = y;
double r5742409 = r5742408 * r5742405;
double r5742410 = r5742407 - r5742409;
return r5742410;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.5 |
|---|---|
| Target | 0.1 |
| Herbie | 0.5 |
Initial program 0.5
Simplified0.5
Taylor expanded around inf 0.5
Simplified0.5
Final simplification0.5
herbie shell --seed 2019149 +o rules:numerics
(FPCore (x y)
:name "Logistic regression 2"
:herbie-target
(if (<= x 0) (- (log (+ 1 (exp x))) (* x y)) (- (log (+ 1 (exp (- x)))) (* (- x) (- 1 y))))
(- (log (+ 1 (exp x))) (* x y)))