\log \left(1 + e^{x}\right) - x \cdot y\mathsf{fma}\left(-y, x, \log \left(1 + e^{x}\right)\right)double f(double x, double y) {
double r187655 = 1.0;
double r187656 = x;
double r187657 = exp(r187656);
double r187658 = r187655 + r187657;
double r187659 = log(r187658);
double r187660 = y;
double r187661 = r187656 * r187660;
double r187662 = r187659 - r187661;
return r187662;
}
double f(double x, double y) {
double r187663 = y;
double r187664 = -r187663;
double r187665 = x;
double r187666 = 1.0;
double r187667 = exp(r187665);
double r187668 = r187666 + r187667;
double r187669 = log(r187668);
double r187670 = fma(r187664, r187665, r187669);
return r187670;
}




Bits error versus x




Bits error versus y
| Original | 0.5 |
|---|---|
| Target | 0.1 |
| Herbie | 0.5 |
Initial program 0.5
Simplified0.5
Final simplification0.5
herbie shell --seed 2019195 +o rules:numerics
(FPCore (x y)
:name "Logistic regression 2"
:herbie-target
(if (<= x 0.0) (- (log (+ 1.0 (exp x))) (* x y)) (- (log (+ 1.0 (exp (- x)))) (* (- x) (- 1.0 y))))
(- (log (+ 1.0 (exp x))) (* x y)))