\log \left(1 + e^{x}\right) - x \cdot y\left(\log \left({1}^{3} + {\left(e^{x}\right)}^{3}\right) - \log \left(e^{x} \cdot \left(e^{x} - 1\right) + 1 \cdot 1\right)\right) - x \cdot ydouble f(double x, double y) {
double r108700 = 1.0;
double r108701 = x;
double r108702 = exp(r108701);
double r108703 = r108700 + r108702;
double r108704 = log(r108703);
double r108705 = y;
double r108706 = r108701 * r108705;
double r108707 = r108704 - r108706;
return r108707;
}
double f(double x, double y) {
double r108708 = 1.0;
double r108709 = 3.0;
double r108710 = pow(r108708, r108709);
double r108711 = x;
double r108712 = exp(r108711);
double r108713 = pow(r108712, r108709);
double r108714 = r108710 + r108713;
double r108715 = log(r108714);
double r108716 = r108712 - r108708;
double r108717 = r108712 * r108716;
double r108718 = r108708 * r108708;
double r108719 = r108717 + r108718;
double r108720 = log(r108719);
double r108721 = r108715 - r108720;
double r108722 = y;
double r108723 = r108711 * r108722;
double r108724 = r108721 - r108723;
return r108724;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.5 |
|---|---|
| Target | 0.1 |
| Herbie | 0.5 |
Initial program 0.5
rmApplied flip3-+0.5
Applied log-div0.5
Simplified0.5
Final simplification0.5
herbie shell --seed 2019303
(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)))