



Bits error versus x




Bits error versus y
Results
| Original | 0.4 |
|---|---|
| Target | 0.0 |
| Herbie | 0.5 |
Initial program 0.4
rmApplied flip3-+0.4
Applied log-div0.4
Applied associate--l-0.4
Simplified0.4
rmApplied add-sqr-sqrt0.4
Applied log-prod0.4
Simplified0.4
rmApplied add-sqr-sqrt0.4
Applied difference-of-sqr--10.4
rmApplied flip3--0.5
Applied sqrt-div0.5
Applied log-div0.5
Final simplification0.5
herbie shell --seed 2019022
(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)))
Time bar (total: 19.9s)Debug log
| 64.0ms | 82× | body | 10240 | exit |
| 22.0ms | 259× | body | 80 | valid |
| 19.0ms | 4× | body | 1280 | valid |
| 5.0ms | 10× | body | 640 | valid |
| 2.0ms | 5× | body | 320 | valid |
| 1.0ms | 3× | body | 160 | valid |
| 11.0ms | (- (log (+ 1 (exp x))) (* x y)) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 0.5b
Found 3 expressions with local error:
| 0.5b | (log (+ 1 (exp x))) |
| 0.0b | (+ 1 (exp x)) |
| 0.0b | (- (log (+ 1 (exp x))) (* x y)) |
| 6× | log-prod |
| 5× | add-cube-cbrt |
| 5× | *-un-lft-identity |
| 5× | add-sqr-sqrt |
| 4× | add-log-exp |
| 4× | add-exp-log |
| 4× | log-div |
| 4× | pow1 |
| 3× | flip-+ |
| 3× | associate--l+ |
| 3× | add-cbrt-cube |
| 3× | flip3-+ |
| 2× | associate--l- |
| 1× | flip-- |
| 1× | log-pow |
| 1× | rem-log-exp |
| 1× | diff-log |
| 1× | flip3-- |
| 1× | sub-neg |
| 1× | +-commutative |
| 8.0ms | (- (log (+ 1 (exp x))) (* x y)) |
| 2.0ms | (log (+ 1 (exp x))) |
| 1.0ms | (+ 1 (exp x)) |
| 65.0ms | (log (+ 1 (exp x))) |
| 41.0ms | (- (log (+ 1 (exp x))) (* x y)) |
| 11.0ms | (+ 1 (exp x)) |
| 34.0ms | (+ (log 2) (+ (* 1/2 x) (* 1/8 (pow x 2)))) |
| 25.0ms | (+ (log 2) (+ (* 1/2 x) (* 1/8 (pow x 2)))) |
| 22.0ms | (+ x (+ (* 1/2 (pow x 2)) 2)) |
| 15.0ms | (log (+ (pow 1 3) (pow (exp x) 3))) |
| 9.0ms | (- (log (+ (exp x) 1)) (* x y)) |
5 alts after pruning (5 fresh and 0 done)
Merged error: 0.5b
Found 4 expressions with local error:
| 3.6b | (log (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x))))) |
| 3.5b | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 0.6b | (log (+ (pow (exp x) 3) 1)) |
| 0.0b | (- (log (+ (pow (exp x) 3) 1)) (+ (log (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x))))) (* x y))) |
| 11× | *-un-lft-identity |
| 10× | log-prod |
| 9× | add-sqr-sqrt |
| 8× | add-log-exp |
| 8× | log-div |
| 7× | add-cube-cbrt |
| 7× | pow1 |
| 6× | add-exp-log |
| 4× | flip-+ |
| 4× | add-cbrt-cube |
| 4× | flip3-+ |
| 3× | log-pow |
| 3× | associate--l+ |
| 3× | diff-log |
| 2× | associate--r- |
| 2× | distribute-lft-out-- |
| 2× | flip-- |
| 2× | associate-+l- |
| 2× | rem-log-exp |
| 2× | flip3-- |
| 2× | sub-neg |
| 2× | associate--l- |
| 1× | difference-of-squares |
| 1× | associate--r+ |
| 1× | distribute-lft-out |
| 1× | distribute-rgt-out-- |
| 1× | sum-log |
| 20.0ms | (- (log (+ (pow (exp x) 3) 1)) (+ (log (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x))))) (* x y))) |
| 7.0ms | (log (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x))))) |
| 5.0ms | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 3.0ms | (log (+ (pow (exp x) 3) 1)) |
| 109.0ms | (- (log (+ (pow (exp x) 3) 1)) (+ (log (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x))))) (* x y))) |
| 104.0ms | (log (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x))))) |
| 66.0ms | (log (+ (pow (exp x) 3) 1)) |
| 30.0ms | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 273.0ms | (log (- (* (* 1 1) (* 1 1)) (* (- (* (exp x) (exp x)) (* 1 (exp x))) (- (* (exp x) (exp x)) (* 1 (exp x)))))) |
| 227.0ms | (/ (+ (pow (exp x) 3) 1) (* (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x)))) (exp (* x y)))) |
| 208.0ms | (- (log (+ (* (* 1 1) (* 1 1)) (- (* (- (* (exp x) (exp x)) (* 1 (exp x))) (- (* (exp x) (exp x)) (* 1 (exp x)))) (* (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x))))))) (* x y)) |
| 193.0ms | (/ (+ (pow (exp x) 3) 1) (exp (+ (log (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x))))) (* x y)))) |
| 174.0ms | (log (+ (pow (* 1 1) 3) (pow (- (* (exp x) (exp x)) (* 1 (exp x))) 3))) |
5 alts after pruning (5 fresh and 0 done)
Merged error: 0.5b
Found 4 expressions with local error:
| 3.6b | (log (sqrt (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x)))))) |
| 3.5b | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 3.4b | (log (sqrt (- (exp (+ x x)) (+ (exp x) -1)))) |
| 3.1b | (+ (exp x) -1) |
| 16× | log-prod |
| 12× | add-sqr-sqrt |
| 11× | *-un-lft-identity |
| 10× | sqrt-prod |
| 8× | add-cube-cbrt |
| 6× | add-log-exp |
| 6× | add-exp-log |
| 6× | pow1 |
| 4× | log-pow |
| 4× | sqrt-div |
| 4× | add-cbrt-cube |
| 4× | log-div |
| 2× | difference-of-squares |
| 2× | flip-- |
| 2× | flip-+ |
| 2× | rem-log-exp |
| 2× | pow1/2 |
| 2× | flip3-- |
| 2× | flip3-+ |
| 1× | distribute-lft-out-- |
| 1× | distribute-lft-out |
| 1× | exp-sum |
| 1× | diff-log |
| 1× | distribute-rgt-out-- |
| 1× | sub-neg |
| 1× | difference-of-sqr--1 |
| 1× | +-commutative |
| 9.0ms | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 8.0ms | (log (sqrt (- (exp (+ x x)) (+ (exp x) -1)))) |
| 6.0ms | (log (sqrt (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x)))))) |
| 4.0ms | (+ (exp x) -1) |
| 147.0ms | (log (sqrt (- (exp (+ x x)) (+ (exp x) -1)))) |
| 135.0ms | (log (sqrt (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x)))))) |
| 31.0ms | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 17.0ms | (+ (exp x) -1) |
| 583.0ms | (log (sqrt (- (pow (exp (+ x x)) 3) (pow (+ (exp x) -1) 3)))) |
| 319.0ms | (log (sqrt (- (* (* 1 1) (* 1 1)) (* (- (* (exp x) (exp x)) (* 1 (exp x))) (- (* (exp x) (exp x)) (* 1 (exp x))))))) |
| 221.0ms | (log (sqrt (+ (pow (* 1 1) 3) (pow (- (* (exp x) (exp x)) (* 1 (exp x))) 3)))) |
| 173.0ms | (log (sqrt (- (* (exp (+ x x)) (exp (+ x x))) (* (+ (exp x) -1) (+ (exp x) -1))))) |
| 116.0ms | (- (+ (* 1/2 x) (* 1/2 (pow x 2))) (* 5/24 (pow x 4))) |
5 alts after pruning (5 fresh and 0 done)
Merged error: 0.4b
Found 4 expressions with local error:
| 3.6b | (log (sqrt (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x)))))) |
| 3.5b | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 3.4b | (log (sqrt (- (exp (+ x x)) (* (+ (sqrt (exp x)) 1) (- (sqrt (exp x)) 1))))) |
| 3.1b | (- (sqrt (exp x)) 1) |
| 13× | log-prod |
| 10× | add-sqr-sqrt |
| 9× | *-un-lft-identity |
| 8× | sqrt-prod |
| 8× | add-cube-cbrt |
| 6× | add-log-exp |
| 6× | add-exp-log |
| 6× | pow1 |
| 4× | log-pow |
| 4× | sqrt-div |
| 4× | add-cbrt-cube |
| 4× | log-div |
| 3× | flip-- |
| 3× | flip3-- |
| 2× | rem-log-exp |
| 2× | difference-of-sqr-1 |
| 2× | pow1/2 |
| 2× | sub-neg |
| 1× | distribute-lft-out |
| 1× | flip-+ |
| 1× | diff-log |
| 1× | distribute-rgt-out-- |
| 1× | flip3-+ |
| 13.0ms | (log (sqrt (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x)))))) |
| 10.0ms | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 9.0ms | (- (sqrt (exp x)) 1) |
| 9.0ms | (log (sqrt (- (exp (+ x x)) (* (+ (sqrt (exp x)) 1) (- (sqrt (exp x)) 1))))) |
| 154.0ms | (log (sqrt (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x)))))) |
| 133.0ms | (log (sqrt (- (exp (+ x x)) (* (+ (sqrt (exp x)) 1) (- (sqrt (exp x)) 1))))) |
| 28.0ms | (- (sqrt (exp x)) 1) |
| 28.0ms | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 591.0ms | (log (sqrt (- (pow (exp (+ x x)) 3) (pow (* (+ (sqrt (exp x)) 1) (- (sqrt (exp x)) 1)) 3)))) |
| 330.0ms | (log (sqrt (- (* (exp (+ x x)) (exp (+ x x))) (* (* (+ (sqrt (exp x)) 1) (- (sqrt (exp x)) 1)) (* (+ (sqrt (exp x)) 1) (- (sqrt (exp x)) 1)))))) |
| 302.0ms | (log (* (cbrt (sqrt (- (exp (+ x x)) (* (+ (sqrt (exp x)) 1) (- (sqrt (exp x)) 1))))) (cbrt (sqrt (- (exp (+ x x)) (* (+ (sqrt (exp x)) 1) (- (sqrt (exp x)) 1))))))) |
| 298.0ms | (log (sqrt (sqrt (- (exp (+ x x)) (* (+ (sqrt (exp x)) 1) (- (sqrt (exp x)) 1)))))) |
| 295.0ms | (log (sqrt (- (* (* 1 1) (* 1 1)) (* (- (* (exp x) (exp x)) (* 1 (exp x))) (- (* (exp x) (exp x)) (* 1 (exp x))))))) |
5 alts after pruning (4 fresh and 1 done)
Merged error: 0.4b
0% (0.3b remaining)
Error of 0.5b against oracle of 0.2b and baseline of 0.5b
| 2.8s | 2449× | body | 10240 | exit |
| 908.0ms | 8415× | body | 80 | valid |
| 147.0ms | 277× | body | 640 | valid |
| 109.0ms | 114× | body | 1280 | valid |
| 63.0ms | 187× | body | 320 | valid |
| 61.0ms | 113× | body | 160 | valid |