



Bits error versus x




Bits error versus y
Results
| Original | 0.5 |
|---|---|
| Target | 0.0 |
| Herbie | 0.5 |
Initial program 0.5
Taylor expanded around inf 0.5
Final simplification0.5
herbie shell --seed 2019016
(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: 13.7s)Debug log
| 359× | (pre true 80) |
| 262× | (body real 80) |
| 71× | (body exit 10240) |
| 12× | (body real 640) |
| 9× | (body real 320) |
| 3× | (body real 160) |
| 2× | (body real 1280) |
| 8.0ms | (- (log (+ 1 (exp x))) (* x y)) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 0.4b
Found 3 expressions with local error:
| 0.4b | (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 |
| 4.0ms | (- (log (+ 1 (exp x))) (* x y)) |
| 1.0ms | (log (+ 1 (exp x))) |
| 1.0ms | (+ 1 (exp x)) |
| 75.0ms | (log (+ 1 (exp x))) |
| 46.0ms | (- (log (+ 1 (exp x))) (* x y)) |
| 7.0ms | (+ 1 (exp x)) |
| 39.0ms | (+ (log 2) (+ (* 1/2 x) (* 1/8 (pow x 2)))) |
| 26.0ms | (+ (log 2) (+ (* 1/2 x) (* 1/8 (pow x 2)))) |
| 19.0ms | (+ x (+ (* 1/2 (pow x 2)) 2)) |
| 16.0ms | (log (+ (pow 1 3) (pow (exp x) 3))) |
| 15.0ms | (log (+ (pow 1 3) (pow (exp x) 3))) |
5 alts after pruning (5 fresh and 0 done)
Merged error: 0.3b
Found 3 expressions with local error:
| 0.4b | (log (+ (exp x) 1)) |
| 0.0b | (+ (exp x) 1) |
| 0.0b | (- (log (+ (exp x) 1)) (* 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 |
| 11.0ms | (- (log (+ (exp x) 1)) (* x y)) |
| 5.0ms | (+ (exp x) 1) |
| 4.0ms | (log (+ (exp x) 1)) |
| 70.0ms | (log (+ (exp x) 1)) |
| 57.0ms | (- (log (+ (exp x) 1)) (* x y)) |
| 7.0ms | (+ (exp x) 1) |
| 54.0ms | (log (- (* (exp x) (exp x)) (* 1 1))) |
| 41.0ms | (+ (log 2) (+ (* 1/2 x) (* 1/8 (pow x 2)))) |
| 37.0ms | (log (- (* (exp x) (exp x)) (* 1 1))) |
| 27.0ms | (+ x (+ (* 1/2 (pow x 2)) 2)) |
| 27.0ms | (+ (log 2) (+ (* 1/2 x) (* 1/8 (pow x 2)))) |
5 alts after pruning (4 fresh and 1 done)
Merged error: 0.3b
Found 4 expressions with local error:
| 5.0b | (log (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x))))) |
| 4.6b | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 0.7b | (log (+ (pow (exp x) 3) 1)) |
| 0.0b | (pow (exp x) 3) |
| 9× | *-un-lft-identity |
| 8× | add-cube-cbrt |
| 8× | add-sqr-sqrt |
| 7× | log-prod |
| 7× | pow1 |
| 6× | add-log-exp |
| 6× | add-exp-log |
| 5× | add-cbrt-cube |
| 4× | log-div |
| 3× | cube-prod |
| 3× | unpow-prod-down |
| 2× | flip-+ |
| 2× | log-pow |
| 2× | rem-log-exp |
| 2× | flip3-+ |
| 1× | rem-cube-cbrt |
| 1× | distribute-lft-out |
| 1× | flip-- |
| 1× | pow-exp |
| 1× | unpow3 |
| 1× | diff-log |
| 1× | distribute-rgt-out-- |
| 1× | flip3-- |
| 1× | pow-pow |
| 1× | sub-neg |
| 1× | pow-to-exp |
| 1× | cube-mult |
| 12.0ms | (log (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x))))) |
| 10.0ms | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 7.0ms | (log (+ (pow (exp x) 3) 1)) |
| 2.0ms | (pow (exp x) 3) |
| 144.0ms | (log (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x))))) |
| 84.0ms | (log (+ (pow (exp x) 3) 1)) |
| 23.0ms | (pow (exp x) 3) |
| 22.0ms | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 320.0ms | (log (- (* (* 1 1) (* 1 1)) (* (- (* (exp x) (exp x)) (* 1 (exp x))) (- (* (exp x) (exp x)) (* 1 (exp x)))))) |
| 176.0ms | (log (+ (pow (* 1 1) 3) (pow (- (* (exp x) (exp x)) (* 1 (exp x))) 3))) |
| 96.0ms | (+ x (+ (* 7/6 (pow x 3)) (* 3/2 (pow x 2)))) |
| 92.0ms | (log (+ (pow (pow (exp x) 3) 3) (pow 1 3))) |
| 82.0ms | (log (- (* (pow (exp x) 3) (pow (exp x) 3)) (* 1 1))) |
5 alts after pruning (4 fresh and 1 done)
Merged error: 0.3b
Found 4 expressions with local error:
| 4.8b | (log (sqrt (- (exp (+ x x)) (+ (exp x) -1)))) |
| 4.8b | (log (sqrt (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x)))))) |
| 4.6b | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 4.4b | (+ (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 |
| 14.0ms | (log (sqrt (- (exp (+ x x)) (+ (exp x) -1)))) |
| 8.0ms | (log (sqrt (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x)))))) |
| 5.0ms | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 2.0ms | (+ (exp x) -1) |
| 150.0ms | (log (sqrt (+ (* 1 1) (- (* (exp x) (exp x)) (* 1 (exp x)))))) |
| 114.0ms | (log (sqrt (- (exp (+ x x)) (+ (exp x) -1)))) |
| 23.0ms | (- (* (exp x) (exp x)) (* 1 (exp x))) |
| 13.0ms | (+ (exp x) -1) |
| 589.0ms | (log (sqrt (- (pow (exp (+ x x)) 3) (pow (+ (exp x) -1) 3)))) |
| 354.0ms | (log (sqrt (- (* (* 1 1) (* 1 1)) (* (- (* (exp x) (exp x)) (* 1 (exp x))) (- (* (exp x) (exp x)) (* 1 (exp x))))))) |
| 234.0ms | (log (sqrt (+ (pow (* 1 1) 3) (pow (- (* (exp x) (exp x)) (* 1 (exp x))) 3)))) |
| 210.0ms | (log (sqrt (- (* (exp (+ x x)) (exp (+ x x))) (* (+ (exp x) -1) (+ (exp x) -1))))) |
| 116.0ms | (+ x (+ (* 1/6 (pow x 3)) (* 1/2 (pow x 2)))) |
5 alts after pruning (3 fresh and 2 done)
Merged error: 0.3b
0% (0.2b remaining)
Error of 0.5b against oracle of 0.3b and baseline of 0.5b
| 11544× | (pre true 80) |
| 8434× | (body real 80) |
| 2466× | (body exit 10240) |
| 256× | (body real 640) |
| 165× | (body real 320) |
| 122× | (body real 1280) |
| 101× | (body real 160) |