double f(double x, double y) {
double r5068122 = 1.0;
double r5068123 = x;
double r5068124 = exp(r5068123);
double r5068125 = r5068122 + r5068124;
double r5068126 = log(r5068125);
double r5068127 = y;
double r5068128 = r5068123 * r5068127;
double r5068129 = r5068126 - r5068128;
return r5068129;
}
double f(double x, double y) {
double r5068130 = x;
double r5068131 = exp(r5068130);
double r5068132 = log1p(r5068131);
double r5068133 = y;
double r5068134 = r5068133 * r5068130;
double r5068135 = r5068132 - r5068134;
return r5068135;
}
\log \left(1 + e^{x}\right) - x \cdot y\log_* (1 + e^{x}) - y \cdot x



Bits error versus x




Bits error versus y
| Original | 0.5 |
|---|---|
| Target | 0.1 |
| Herbie | 0.4 |
Initial program 0.5
Simplified0.4
Final simplification0.4
herbie shell --seed 2019101 +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)))