forked from albertotb/curso-ml-R
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path02-supervised.html
1221 lines (708 loc) · 36.1 KB
/
02-supervised.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" lang="" xml:lang="">
<head>
<title>Conceptos generales de aprendizaje supervisado</title>
<meta charset="utf-8" />
<meta name="author" content="Alberto Torres Barrán" />
<meta name="date" content="2019-04-24" />
<link href="libs/remark-css-0.0.1/default.css" rel="stylesheet" />
<link rel="stylesheet" href="custom.css" type="text/css" />
</head>
<body>
<textarea id="source">
class: center, middle, inverse, title-slide
# Conceptos generales de aprendizaje supervisado
## Curso de aprendizaje automático para el INE
### Alberto Torres Barrán
### 2019-04-24
---
<script type="text/x-mathjax-config">
MathJax.Hub.Config({
TeX: {
Macros: {
Xcal: "{\\mathcal{X}}",
Xbf: "{\\mathbf{X}}",
Hbf: "{\\mathbf{H}}",
Rbb: "{\\mathbb{R}}"
},
extensions: ["AMSmath.js","AMSsymbols.js"]
}
});
</script>
# ¿Qué es el Aprendizaje Automático?
De la Wikipedia:
*Machine learning is a subfield of **computer science** that evolved from the study of **pattern recognition** and computational learning theory in artificial intelligence. In 1959, Arthur Samuel defined machinelearning as a “Field of study that gives computers the ability to learn without being **explicitly programmed**”. Machine learning explores the study and construction of algorithms that can learn from and make predictions on **data**.*
---
class: center, middle
![:scale 60%](./img/machine_learning_2x.png)
Fuente: [xkcd #1838](https://xkcd.com/1838/)
???
Aprendizaje automático en la práctica tiene mucho de ingeniería y no tanto de "ciencia"
Mucho prueba y error
La calidad del software ha aumentado mucho en los últimos años, casi cualquiera puede ajustar estos modelos sin conocimientos teóricos profundos
---
class: center, middle
![](./img/cloud.png)
???
* Statistics Más antigua (aprox. 1749), el resto de disciplinas utilizan algunas de sus técnicas: estadística descriptiva, análisis de regresión, inferencia.
* Artificial Intelligence Más moderna, 1940. Algunos problemas que intenta resolver: procesamiento lenguaje natural, planificación, visión por computador, robótica.
* Machine Learning Rama de la IA, 1946. Se utiliza para resolver algunos de los problemas que tiene la IA.
* Pattern Recognition En general se usa como sinónimo de Machine Learning.
* Data Mining Técnicas de modelado estad´ıstico y machine learning aplicadas a un dominio en concreto.
* Data Science Término más moderno, mezcla de todo lo
anterior.
---
class: center
# Data science
![:scale 75%](./img/data-science.png)
Fuente: [R for Data Science](http://r4ds.had.co.nz/)
???
Machine learning == parte de modelado
Data Science == todos los pasos
---
## Casos de éxito
* Coches autónomos
* Análisis de imágenes médicas
* Procesamiento de lenguaje natural
* AlphaGo y juegos Atari
* Generación de imágenes
* Sistemas de recomendación
---
class: middle, center
## Herramientas
![:scale 75%](./img/top-analytics-data-science-machine-learning-software-2015-2017.jpg)
???
Un poco antigua, en la del 2018 Python supera a R pero ambos son muy populares
---
# Tipos de aprendizaje
Existen diversos tipos de tareas, dependiendo de la información disponible:
- **supervisado**: tenemos acceso a pares de ejemplos entrada-salida
- **no supervisado**: no tenemos acceso a las salidas
- otros (limitando de alguna forma el acceso a las salidas):
* *activo*: el algoritmo puede acceder a la salida para nuevos datos de entrada
* *semi-supervisado*: solo se tienen salidas para algunos datos
* *refuerzo*: no se tiene el valor de la salida, pero si una indicación de lo lejos o cerca que se encuentra
---
# Referencias
1. Jerome H. Friedman. [Data Mining and Statistics: What's the Connection? (1998)](http://statweb.stanford.edu/~jhf/ftp/dm-stat.pdf)
2. Leo Breiman. [Statistical Modeling: The Two Cultures (2001)](http://projecteuclid.org/download/pdf_1/euclid.ss/1009213726)
3. Cross Validated. [What is the difference between data mining, statistics, machine learning and AI (2010).](http://stats.stackexchange.com/questions/5026/what-is-the-difference-between-data-mining-statistics-machine-learning-and-ai)
4. Sakthi Dasan Sekar. [What is the difference between Artificial Intelligence, Machine Learning, Statistics, and Data Mining (2014)](http://shakthydoss.com/what-is-the-difference-between-artificial-intelligence-machine-learning-statistics-and-data-mining/)
5. Cross Validated. [What exactly is Big Data? (2015)](http://stats.stackexchange.com/questions/173060/what-exactly-is-big-data)
6. David Donoho. [50 years of Data Science (2015)](http://pages.cs.wisc.edu/~anhai/courses/784-fall15/50YearsDataScience.pdf)
???
Dos culturas:
Una asume que los datos han sido generados por un modelo estocástico específico.
Otra usa modelos algorítmicos y asume que el mecanismo de generación de los datos es desconocido
---
class: middle, center, inverse
# Aprendizaje supervisado
---
* Tenemos disponibles datos con múltiples observaciones:
* ejemplos (*examples*)
* muestras (*samples*)
* ...
--
* Varias variables por observación:
* predictores
* atributos (*atributes*)
* características (*features*)
* covariables (*covariates*)
* variables independientes
* variables explicativas
* ...
--
* Una de ellas es de especial interés:
* variable respuesta
* variable dependiente
* objetivo (*target*)
* salida (*output*)
* etiqueta (*label*)
* ...
---
## Objetivos
1. Predecir el valor de la variable respuesta para nuevas observaciones
2. Obtener información sobre la relación entre las variables independientes y la salida
???
Información sobre la relación, por ej: qué variables son más relevantes
---
## Tipos de problemas
1. Regresión, si la variable respuesta es continua
2. Clasificación, si la variable respuesta es discreta
3. Otros: por ejemplo,
* salida continua pero valores enteros
* salida discreta pero los valores tienen un orden
---
## Aprendizaje estadístico
**Dados**:
* Espacio de las muestras de entrada: `\(\mathcal{X}\)`
* Conjunto de posibles salidas: `\(\mathcal{Y}\)`
* Conjunto de **entrenamiento**: `\(S = \{x_i,\, y_i\}_{i=1}^n\)`, contenido en el espacio `\(\mathcal{X} \times \mathcal{Y}\)`
--
**Objetivo**:
* Aprender una regla de predicción (hipótesis), `\(h: \mathcal{X} \rightarrow \mathcal{Y}\)`
--
**Asumimos**:
* Los ejemplos se han generado por una distribución de probabilidad desconocida `\(\mathcal{P}\)`
* Existe una función de pérdida `\(L: \mathcal{Y} \times \mathcal{Y} \rightarrow \mathbb{R}\)` que mide como de lejos se encuentra `\(h(x)\)` de `\(y\)`
* El conjunto posible de hipótesis `\((\mathcal{F})\)` es finito
---
## Minimización del riesgo empírico
Elegir `\(h\)` tal que minimice el riesgo esperado
`$$R(h) = \int_{\mathcal{X} \times \mathcal{Y}} L(h(x), y)\, dP(x, y)$$`
**Problema**: cómo podemos calcular `\(R\)` si `\(P\)` es desconocida?
Podemos evaluar la función de pérdida en el conjunto `\(S\)` (riesgo empírico):
`$$\hat{R}(h) = \frac{1}{n}\sum_{i=1}^{n} L(h(x_i), y_i)$$`
Si `\(n\)` suficientemente grande, esperamos que `\(\hat{R}(x) \sim R(x)\)` `\(\rightarrow\)`
minimizar el riesgo empírico es una buena aproximación de minimizar el riesgo esperado
---
## Descomposición del error
Minimizador del riesgo: `$$h^* = \arg\min_{h \in \mathcal{F}}\, R(h)$$`
Minimizador del riesgo empírico: `$$\hat{h}^* = \arg\min_{h \in \mathcal{F}}\, \hat{R}(h)$$`
Riesgo de Bayes o error de Bayes: `$$R^* = \inf_h\, R(h)$$`
*Nota*: sobre todas las funciones `\(h: \mathcal{X} \rightarrow \mathcal{Y}\)`, no solo las contenidas en `\(\mathcal{F}\)`!!
---
La differencia entre el riesgo y el error de Bayes es:
`$$R(h) - R^* = \underbrace{\big(R(h) - R(\hat{h}^*)\big)}_\text{error optimización} + \underbrace{\big(R(\hat{h}^*) - R(h^*)\big)}_\text{error estimación} + \underbrace{\big(R(h^*) - R^*\big)}_\text{error aproximación}$$`
--
**Error optimización**: como de buena es la optimización que llevó a la hipótesis `\(h\)`, relativa a al óptimo del riesgo empírico
* Disminuye al mejorar el algoritmo de optimización
--
**Error de estimación**: surge por aproximar el riesgo esperado con el riesgo empírico
* Disminuye si aumentamos el conjunto de datos de entrenamiento `\(n\)`
--
**Error de aproximación**: surge por aproximar la mejor función posible por la mejor función dentro de `\(\mathcal{F}\)`
* Disminuye si reemplazamos `\(\mathcal{F}\)` por otra clase más flexible
???
Si asumimos que el error de optimización es 0, existe un equilibrio entre el error de estimación y el error de aproximación: por un lado nos interesa elegir clases de funciones muy flexibles, pero por otro estas van a necesitar muchos más ejemplos para aproximar el riesgo esperado con el riesgo empírico de forma correcta
---
## Ejemplo
* Elegimos `\(\mathcal{F}\)` como las clase de funciones del tipo `\(f(x) = w_0 + x^T w\)`
* Función de pérdida: `\(L(y, f(x)) = (y - f(x))^2\)`
* Riesgo empírico: `$$R(w) = \frac{1}{n} \sum_{i=1}^n (y_i - w_0 + x_i^T w)^2$$`
???
En este caso el riesgo es una función cuadrática de los parámetros w
---
## Regresión lineal
Dado el conjunto de entrenamiento `\(S = \{y_i, x_i\}_{i=1}^n\)`
* Agrupamos todos los ejemplos de entrada `\(x_i\)` en una matrix `\(\mathbf{X}\)` de tamaño `\(n \times d\)`
* Agrupamos todas las salidas en un vector columna `\(y\)` de tamaño `\(n \times 1\)`
Expresamos el riesgo empírico en notación matricial: `$$R(w) = (y - \mathbf{X}w)^T (y - \mathbf{X}w)$$`
Gradiente: `$$\nabla_w R(w) = \mathbf{X}^T(y - \mathbf{X}w) = \mathbf{X}^Ty - \mathbf{X}^T\mathbf{X}w$$`
Minimizamos el riesgo empírico: `$$\nabla_w R(w) = 0\quad \Rightarrow \quad w^* = (\mathbf{X}^T\mathbf{X})^{-1} \mathbf{X}^T y$$`
Recuperamos mínimos cuadrados ordinarios!
???
El término `\(w_0\)` se incluye dentro del vector `\(w\)` añadiendo una columna constante de 1s como primer elemento de X
---
Posibles problemas del modelo:
* Teóricos:
1. asumimos que `\(y\)` depende linealmente de `\(x\)`
2. asumimos que el modelo está especificado correctamente (no faltan variables)
* Numéricos:
1. hay menos variables que observaciones
2. no hay dos variables con correlación perfecta
???
En los problemas numéricos, en ambos casos hace que la matriz no tenga rango completo y por tanto no podemos calcular la inversa (de forma exacta!!)
---
## Selección de modelos
* Para medir la calidad del modelo, podemos calcular el riesgo o error empírico en el conjunto de entrenamiento
* Este error se puede disminuir de forma casi arbitraria aumentando la complejidad de la clase de funciones
* **Ejemplo**: en el caso de la regresión lineal, podemos añadir nuevas variables que sean expansiones polinómicas de las ya existentes
* Interesa el **error de generalización**, es decir, el error en nuevas observaciones no usadas para entrenar el modelo
* Partir los datos iniciales en dos conjuntos:
1. conjunto de entrenamiento
2. conjunto de test
???
* El error de test es una buena aproximación del error de generalización
* Estamos asumiendo que ambos provienen de la misma distribución
* Por tanto, la partición tiene que ser aleatoria
---
## Equilibrio sesgo-varianza
* Asumimos que los datos han sido generados por `$$Y = f(X) + \epsilon$$` con `\(\mathbb{E}[\epsilon] = 0\)` y `\(\text{Var}(\epsilon) = \sigma^2\)`
* El error esperado de un estimador `\(\hat{f}(X)\)` en el punto `\(x\)` (usando pérdida cuadrática) es `$$\text{EPE} = \mathbb{E}[(Y - \hat{f}(x))^2]$$`
* Podemos descomponerlo en: `$$\text{EPE} = \underbrace{\Bigl(\mathbb{E}[\hat{f}(x)] - f(x) \Bigr)^2}_{\text{Sesgo}^2} + \underbrace{E\Bigl[\hat{f}(x) - \mathbb{E}[\hat{f}(x)] \Bigr]^2}_{\text{Varianza}} + \underbrace{\vphantom{\Bigl(}\sigma^2}_{\text{Ruido}}$$`
---
class: center, middle
![](./img/bias_variance_dardos.jpg)
---
## Sobreajuste
* Los términos de sesgo y varianza son opuestos: si disminuimos uno aumenta el otro y viceversa
* El término de ruido es inherente a los datos
* Si el modelo es muy simple, el estimador está sesgado y no se ajusta bien a los datos (infraajuste)
* Si el modelo es demasiado complejo, es muy sensible a pequeñas variaciones en los datos
* Además, el error de test será mucho más alto que el error de entrenamiento (**sobreajuste**)
* **Solución**: encontrar un equilibrio que minimice el error en el conjunto de test
---
class: middle, center
![:scale 120%](./img/biasvariance.svg)
---
## Simulación
```r
set.seed(1)
n <- 10
x <- seq(0, 1, length.out = n)
y <- 1.5*x - x^2 + rnorm(n, 0, 0.05)
data <- data.frame(x=x, y=y)
x_new <- seq(0, 1, length.out=500)
newdata <- data.frame(x=x_new)
fit1 <- lm(y ~ x + I(x^2), data=data)
fit2 <- lm(y ~ x + I(x^2) + I(x^3) + I(x^4) + I(x^5)
+ I(x^6) + I(x^7) + I(x^8) + I(x^9),
data=data)
fit3 <- lm(y ~ x, data=data)
y_pred1 <- predict(fit1, newdata=newdata)
y_pred2 <- predict(fit2, newdata=newdata)
ntest <- 1
xtest <- runif(ntest)
ytest <- 1.5*xtest - xtest^2 + rnorm(ntest, 0, 0.05)
```
---
```r
plot(data)
lines(x_new, y_pred1, col="blue")
lines(x_new, y_pred2, col="red")
abline(fit3, col="purple")
points(xtest, ytest, col="darkgreen")
legend("bottomright",
c(expression(w[0] + w[1]*x),
expression(w[0] + w[1]*x + w[2]*x^2),
expression(w[0] + w[1]*x + w[2]*x^2 + ldots + w[9]*x^9)),
lty=1, lwd=1.5, col=c("purple", "blue", "red"), inset=0.04)
```
<img src="02-supervised_files/figure-html/unnamed-chunk-2-1.png" style="display: block; margin: auto;" />
---
class: center, middle
![:scale 75%](./img/eslr_ex.png)
Ejemplo de clasificación en 2 dimensiones [ESL]
---
## Vecinos próximos
* Modelo sencillo que usa las observaciones cercanas a `\(x\)` para realizar la predicción: `$$f(x) = \frac{1}{k} \sum_{x_i \in N_k(x)} y_i$$` donde `\(N_k(x)\)` son las `\(k\)` observaciones más cercanas
* Necesaria una métrica (por ej. distancia euclidea)
* Se puede usar tanto para problemas de clasificación como regresión
* Muy sensible al valor de `\(k\)`
---
class: center, middle
![:scale 75%](./img/knn_class.png)
---
```r
library(class)
n <- nrow(iris)
# muestreo aleatorio
idx <- sample(n, n*0.75)
# partir en conjuntos de entrenamiento y test
train <- iris[idx, ]
test <- iris[-idx, ]
# separar variables indenpendientes de la clase (variable respuesta)
# entrenamiento
y_train <- train[, 5]
X_train <- train[, -5]
# test
y_test <- test[, 5]
X_test <- test[, -5]
# modelo knn
y_pred <- knn(X_train, X_test, y_train, k=3)
# tasa acierto
mean(y_test == y_pred)*100
```
```
## [1] 97.36842
```
---
<img src="02-supervised_files/figure-html/unnamed-chunk-4-1.png" style="display: block; margin: auto;" />
---
class: center
## Maldición de la dimensionalidad
![:scale 90%](./img/curse_dim.png)
---
* En 2 dimensiones, para capturar un 10% del volumen necesitamos cubrir aprox. el 25% del rango de cada coordenada
* En 10 dimensiones, necesitamos el 80%
* Otro problema relacionado es la densidad del muestreo:
* Si en 1 dimensión necesitamos `\(n=100\)` muestras para cubrir el espacio, en 10 dimensiones necesitamos `\(n=100^{10}\)` para tener la misma densidad de muestreo (crecimiento exponencial)
* A medida que la dimensión crece, las observaciones están mas cerca de las esquinas del hipercubo que del centro
* Observaciones cercanas a las esquinas son más difíciles de clasificar porque el valor de sus atributos cambia muy bruscamente
* Resumiendo, si `\(d\)` es muy grande, métodos como KNN basados en distancias tienen problemas
???
Observaciones uniformes en un hipercubo de dimension d
Cambio brusco: ejemplos en esquinas opuestas del cuadrado unidad
los puntos que te pueden decir algo de valores tan extremos estan lejos: tienes que extrapolar de ejemplos cercanos no tan extremos en lugar de interpolar
---
## Regresión lineal vs vecinos próximos
* La frontera de decisión de la regresión lineal es suave: tiene poca varianza pero potencialmente mucho sesgo
* `\(k\)`-vecinos próximos no asume ninguna estructura en los datos:
* la frontera de decisión depende localmente solo de los `\(k\)` puntos más cercanos
* tiene poco sesgo pero mucha varianza, ya que es muy inestable
* Elegir un modelo u otro depende de los datos del problema
---
## Vecinos próximos: dependencia de `\(k\)`
<img src="02-supervised_files/figure-html/unnamed-chunk-5-1.png" style="display: block; margin: auto;" />
---
<img src="02-supervised_files/figure-html/unnamed-chunk-6-1.png" style="display: block; margin: auto;" />
---
<img src="02-supervised_files/figure-html/unnamed-chunk-7-1.png" style="display: block; margin: auto;" />
---
## Selección de hiper-parámetros
* `\(k\)` es un **hiper-parámetro** que controla la complejidad del modelo
* Podemos realizar un argumento similar a la comparación con la regresión lineal:
* Para `\(k\)` grande, la frontera es más suave pero tiene (potencialmente) mayor sesgo
* Para `\(k\)` pequeño la frontera es muy inestable (mayor varianza), pero menos sesgo
* Nota: usar el error de entrenamiento para elegir el valor de `\(k\)` es mala idea, para `\(k=1\)` tenemos error 0!!
* Los distintos valores de `\(k\)` se pueden comparar usando el conjunto de test
---
## Conjunto de validación
* Elegir `\(k\)` como el valor que minimiza error de test `\(\rightarrow\)` error de test ya **no** es una buena estimación del rendimiento del modelo en nuevos datos
* Lo mismo ocurre si elegimos la clase de funciones (modelo) usando el error de test
* **Solución**: crear un tercer conjunto, conjunto de validación, para seleccionar hiper-parámetros y comparar modelos
* Finalmente, reportar el error de test como estimación del poder de generalización del modelo
---
## Validación cruzada
* Se divide el conjunto de entrenamiento en `\(K\)` particiones
* Usar `\(K-1\)` particiones como entrenamiento y la otra como test para ajustar `\(K\)` modelos
* `\(\hat{f}^{-k}(x)\)` es el modelo entrenado con todas las particiones menos la `\(k\)`
* Calcular el error de validación cruzada: `$$\text{CV}(\hat{f}) = \frac{1}{n}\sum_{i=1}^n{L(y_i, \hat{f}^{-\kappa(i)}(x_i))}$$`
donde `\(\kappa: \{1, \dots, n\} \rightarrow \{1, \dots, K\}\)` es una función que indica a que partición pertenece cada observación `\(i\)`
* Cuando `\(K = n\)` se conoce como validación cruzada *leave-one-out*
???
Tipicos valores para `\(K\)` son 5 o 10
LOOCV el estimador del error de generalizacion es aprox. no sesgado pero puede tener mucha varianza. Tambien es computacionalmente muy costoso
---
class: middle, center
![](./img/crossval.jpg)
Wikipedia. [Cross-validation](https://en.wikipedia.org/wiki/Cross-validation_(statistics))
---
## Regularización
* A menudo se puede reducir la varianza de un estimador a cambio de introducir un pequeño sesgo
* Este término también puede inducir propiedades en la solución, por ej. *sparsity*
* Para ello limitamos la complejidad del modelo añadiendo a la función de pérdida un término de **regularización** `$$\hat{f} = \arg\min_f\; \{L(y, f(x)) + \lambda J(f)\}$$`
* Muchos modelos en aprendizaje automático encajan en este paradigma
---
## Ejemplo
* El estimador de mínimos cuadrados es el mejor estimador no sesgado (mejor = menos varianza)
* Un término de regularización muy habitual es la norma `\(l_2\)`: `$$||w||^2_2 = w^T w$$`
* Junto con la función de pérdida de la regresión lineal, el modelose conoce como regresión ridge: `$$w^* = \arg\min_w\; \{(y - \mathbf{X}w)^T (y - \mathbf{X}w) + \lambda w^Tw\}$$`
* Tomando derivadas e igualando a 0 la solución es `$$w^* = (\mathbf{X}^T \mathbf{X} + \lambda \mathbf{I})^{-1} (\mathbf{X}^T y)$$` donde `\(\mathbf{I}\)` es la matriz identidad
???
BLUE = Best linear unbiased estimator (teorema de Gauss)
Ahora siempre es invertible para `\(\lambda > 0\)`
Funcion en R: lm.ridge(), paquete MASS
---
## Regresión ridge en R
* La función `lm.ridge()` de la librería `MASS` entrena una regresión lineal con regularización *ridge* para varios valores del parámetro `\(\lambda\)`
* La librería `ridge` implementa la función `linearRidge()` que selecciona automáticamente el valor óptimo del parámetro `\(\lambda\)` usando el método propuesto en [Cule et al (2012)](https://arxiv.org/pdf/1205.0686.pdf)
---
## Regresión logística
Equivalente a la regresión lineal para problemas de clasificación
**Objetivo**: estimar la probabilidad a posteriori de pertenencia a cada clase
Función logística o sigmoidea: `$$\sigma(a) = \frac{1}{1 + \exp{(-a)}}$$`
Para 2 clases con etiquetas `\(\{0, 1\}\)`, definimos:
`$$p(y_i = 1\,|\, x_i) = \sigma(w^Tx_i)$$`
Por tanto
`$$p(y_i = 0\,|\, x_i) = 1 - \sigma(w^T x_i) = \sigma(-w^Tx_i)$$`
???
La funcion logistica es conveniente porque toma un argumento en el rango `\([-\inf, \inf]\)` y tiene como salida un numero en el rango `\([0, 1]\)`
Ademas, satura muy pronto gracias a la exponencial
---
class: center, middle
## Curva logística
![](./img/Logistic-curve.svg)
Wikipedia, [Logistic function](https://en.wikipedia.org/wiki/Logistic_function)
---
## Interpretación: odds ratio
* Dado un modelo lineal con una única variable independiente, el **odds ratio** se define como `$$\text{OR} = \frac{\exp(w_0 + w_1 (x + 1))}{\exp(w_0 + w_1 x)} = \exp(w_1)$$`
* Es decir, como cambian las probabilidades de la salida cuando la variable `\(x\)` aumenta una unidad:
1. Si `\(\text{OR} = 1\)` la variable x no tiene ninguna asociación con la salida
2. Si `\(\text{OR} > 1\)` la variable está asociada con una mayor probabilidad de la salida
3. Si `\(\text{OR} < 1\)` la variable está asociada con una menor probabilidad de la salida
---
## Calidad modelos clasificación
.pull-left[
![](./img/confusion_matrix.png)
]
.pull-right[
Medidas:
* Tasa de acierto: `\(\frac{\text{TP} + \text{TN}}{\text{P} + \text{N}}\)`
* Sensitividad, recall, TPR: `\(\frac{\text{TP}}{\text{TP} + \text{FN}}\)`
* Especificidad, TNR: `\(\frac{\text{TN}}{\text{TN} + \text{FP}}\)`
* Precisión, PPV: `\(\frac{\text{TP}}{\text{TP} + \text{FP}}\)`
* F1-score: `\(2\times \frac{\text{PPV} \times \text{TPR}}{\text{PPV} + \text{TPR}}\)`
]
---
## Regresión logística: optimización
Estos modelos se optimizan usando el log de la verosimilitud condicionada a `\(\Xbf\)`:
`$$\mathcal{L}(w) = \sum_{i=1}^n{y_i \log [\sigma(w^T x_i)] + (1-y_i)\log[ \sigma(-w^T x_i)]} = y_i(w^Tx_i)+\log[\sigma(-w^T x_i)]$$`
Derivada: `$$\partial_w \mathcal{L}(w) = x_i(y_i - \sigma(w^T x_i))$$`
Son `\(d+1\)` ecuaciones no lineales en `\(w\)`
Se pueden resolver usando una variante específica de Newton-Raphson: Iteratively Re-weighted Least Squares (IRLS)
Segunda derivada: `$$\partial^2 \mathcal{L}(w) = -\sum_{i=1}^n{x_i x_i^T \sigma(w^T x_i)(1-\sigma(w^T x_i))}$$`
---
class: middle, center, inverse
# Optimización numérica: Introducción
---
## Descenso por gradiente
* Dada una función convexa y diferenciable `\(f(w)\)`, podemos encontrar su mínimo iterando: `$$w^{k+1} = w^k - \eta \nabla f(w^k)$$`
* `\(\eta\)` es un parámetro que controla la longitud del paso
* Si `\(\eta\)` es suficientemente pequeño, el valor de `\(f(w)\)` decrece de forma monótona en cada paso
* También se puede demostrar que la secuencia `\(\{w^k\}\)` converge al óptimo `\(w^*\)`
* Método de primer orden, ya que solo usa información de la primera derivada (gradiente)
???
En R la función `lm()` usa descomposición QR, no descenso por gradiente
[ref](https://stats.stackexchange.com/questions/94496/lm-function-in-r)
---
class: middle, center
![:scale 75%](./img/Gradient_descent.svg)
---
## Newton-Raphson (N-R)
* Queremos minimizar una función convexa dos veces diferenciable, `\(f: \Rbb^d \rightarrow \Rbb\)`
* Expansión de Taylor de segundo orden de `\(f\)` en `\(x\)`: `$$f(x+h) \approx f(x) + \nabla f(x)^T h + \frac{1}{2}h^T \Hbf h$$` donde `\(\Hbf\)` es la matriz de segundas derivadas (Hessiana)
* Entonces `$$\nabla_h f(x+h) = \nabla f(x) + \Hbf h$$`
* Por tanto el `\(h\)` que minmiza la aproximación de segundo orden es `$$h^* = -\Hbf^{-1}\nabla f(x)$$`
* Iteramos: `$$x^{k+1} = x^k -\Hbf^{-1}\nabla f(x)$$`
---
## N-R para regresión logística
Resscribimos las derivadas en notación matricial:
`\begin{align}
\partial \mathcal{L}(w) &= \Xbf^T(y - p) \\
\partial^2 \mathcal{L}(w) &= -\Xbf^T\mathbf{W}\Xbf
\end{align}`
donde `\(p_i = \sigma(w^T x_i)\)` y `\(\mathbf{W}_{ii} = \sigma(w^T x_i)(1 - \sigma(w^T x_i))\)`
Actualización de N-R:
`\begin{align}
w^{k+1} &= w^k + (\Xbf^T\mathbf{W}\Xbf)^{-1} \Xbf^T(y - p) \\
&= (\Xbf^T\mathbf{W}\Xbf^T) \Xbf^T\mathbf{W} z
\end{align}`
con `\(z = \Xbf w^k + \mathbf{W}^{-1}(y - p)\)`
Es decir, en cada iteración se resuelve el problema de mínimos cuadrados `$$w^{k+1} = \arg\min_w\; (z - \Xbf w)^T \mathbf{W} (z - \Xbf w)$$`
---
## *Iteratively Re-weighted Least Squares*
* Dado un valor inicial `\(w^0\)`
* Iterar para `\(k=0, 1, 2, 3, \dots\)`
1. Calcular `\(p^k\)` con `\(p_i = \sigma((w^k)^T x_i)\)`
2. Calcular `\(\mathbf{W}^k\)` con elementos diagonales `\(\mathbf{W}_{ii}^k = \sigma((w^k)^T x_i)(1 - \sigma((w^k)^T x_i)\)`
3. Calcular `\(z^k = \Xbf w^k + (\mathbf{W}^k)^{-1}(y - p^k)\)`
4. Actualizar pesos `\(w\)` `$$w^{k+1} = \arg\min_{w^k}\; (z^k - \Xbf w^k)^T \mathbf{W}^k (z^k - \Xbf w^k)$$`
* Hay que establecer un criterio de parada
* Puede tener problemas de convergencia dependiendo del valor inicial
???
Parar si el gradiente es muy pequeño
Parar si la diferencia entre dos valores consecutivos de f(x) esta por debajo de un umbral
---
class: center, middle
![:scale 60%](./img/Newton_optimization_vs_grad_descent.svg)
???
Descenso por gradiente (verde)
Newton (rojo)
Newton toma un camino mas directo al optimo porque puede usar información de la curvatura
---
class: middle, center, inverse
# Aprendizaje supervisado en la práctica
---
## Primeros pasos
* Los datos a analizar a menudo provienen de fuentes
variadas (redes sociales, sensores, encuestas, ...) y están
almacenados en diferentes soportes (ficheros de texto, base
de datos, ficheros binarios, streams...)
* Lo primero es identificar el problema qué queremos resolver
y cuales son las variables que tenemos disponibles y pueden
aportar información
* Ante la duda, no descartar variables/información ni
observaciones antes de tiempo
* Lo segundo es combinar todas esa información y
transformarla en una mezcla de variables numéricas
(valores continuos) y categóricas (valores discretos)
* El objetivo final del preproceso es organizar esos datos en
un formato tabular (filas y columnas)
---
## Distintos tipos de información
* En ocasiones no es trivial transformar ciertos tipos de información en variables numéricas y/o categóricas
* Para estos casos a menudo es necesario un preproceso extra, muy dependiente del problema a resolver y específico del dominio
* Ejemplos:
1. Texto (tweets, páginas web, documentos): word2vec, bag-of-words, modelos n-gram
2. Imágenes: valores RGB de los píxeles, intensidad de gris
3. Audio: transformada de Fourier, coeficientes MFCC
4. Video: secuencia de frames
5. Series temporales: añadir *lags* como variables
---
## Valores que faltan
* Es importante distinguir cuando una variable tiene valor 0 de "no conocido"
* Si es posible, nos gustaría saber también el mecanismo que origina el valor que falta:
1. MCAR (*Missing Completely At Random*): el motivo por el que falta un valor no está relacionado con otras variables
2. MAR (*Missing At Random*): el motivo está relacionado con otras variables
3. NMAR (*Not Missing At Random*): no sabemos el motivo por el que falta
* Estos valores pueden venir representados por múltiples caracteres (“*”, “-”, campo vacio, etc.)
* Hay que codificarlos de manera especial para tenerlos en cuenta en los análisis (en R `NA`)
**Ejemplo**: en datos que provienen de un reconocimiento médico varios pacientes no tienen ningún valor en el campo de “Fármacos”. ¿No toman ninguna medicación o el médico no ha registrado la respuesa?
???
MCAR: se pueden ignorar o completar con los valores de esa variable
MAR: se pueden completar con los valores de esa variable teniendo en cuenta los valores de las variables con las que asumimos que está relacionado
NMAR: no podemos hacer gran cosa
---
## Completar valores que faltan
1. Ignorar observaciones donde falte alguna variable
2. Completar observaciones con:
* media o mediana, datos continuos
* moda, datos categóricos
usando:
* todas las observaciones de esa variable
* observaciones pero agrupadas por otras variables
3. Modelos predictivos
* Paquete `mice` en R
* KNN: usar solo observaciones cercanas
Otras [librerías](https://medium.com/coinmonks/dealing-with-missing-data-using-r-3ae428da2d17)
???
1. se pierden datos, solo es completamente seguro para MCAR
2. para datos MAR, dificil saber de antemano por que variables hay que agrupar
3. KNN: muy costoso si hay muchas observaciones, elegir valor de k es critico
---
## Valores extremos