Teoría

La regresión logística es un modelo estadístico de clasificación binaria, que estima la probabilidad de que ocurra un evento (valor 1) frente a que no ocurra (valor 0), en función de variables independientes.

Instalar paquetes y llamar librerías

# install.packages("caret")
library(caret)
# install.packages("tidyverse")
library(tidyverse)

Crear la base de datos

df <- read.csv("titanic.csv")

Entender la base de datos

summary(df)
##      pclass         survived         name               sex           
##  Min.   :1.000   Min.   :0.000   Length:1310        Length:1310       
##  1st Qu.:2.000   1st Qu.:0.000   Class :character   Class :character  
##  Median :3.000   Median :0.000   Mode  :character   Mode  :character  
##  Mean   :2.295   Mean   :0.382                                        
##  3rd Qu.:3.000   3rd Qu.:1.000                                        
##  Max.   :3.000   Max.   :1.000                                        
##  NA's   :1       NA's   :1                                            
##       age              sibsp            parch          ticket         
##  Min.   : 0.1667   Min.   :0.0000   Min.   :0.000   Length:1310       
##  1st Qu.:21.0000   1st Qu.:0.0000   1st Qu.:0.000   Class :character  
##  Median :28.0000   Median :0.0000   Median :0.000   Mode  :character  
##  Mean   :29.8811   Mean   :0.4989   Mean   :0.385                     
##  3rd Qu.:39.0000   3rd Qu.:1.0000   3rd Qu.:0.000                     
##  Max.   :80.0000   Max.   :8.0000   Max.   :9.000                     
##  NA's   :264       NA's   :1        NA's   :1                         
##       fare            cabin             embarked             boat          
##  Min.   :  0.000   Length:1310        Length:1310        Length:1310       
##  1st Qu.:  7.896   Class :character   Class :character   Class :character  
##  Median : 14.454   Mode  :character   Mode  :character   Mode  :character  
##  Mean   : 33.295                                                           
##  3rd Qu.: 31.275                                                           
##  Max.   :512.329                                                           
##  NA's   :2                                                                 
##       body        home.dest        
##  Min.   :  1.0   Length:1310       
##  1st Qu.: 72.0   Class :character  
##  Median :155.0   Mode  :character  
##  Mean   :160.8                     
##  3rd Qu.:256.0                     
##  Max.   :328.0                     
##  NA's   :1189
str(df)
## 'data.frame':    1310 obs. of  14 variables:
##  $ pclass   : int  1 1 1 1 1 1 1 1 1 1 ...
##  $ survived : int  1 1 0 0 0 1 1 0 1 0 ...
##  $ name     : chr  "Allen, Miss. Elisabeth Walton" "Allison, Master. Hudson Trevor" "Allison, Miss. Helen Loraine" "Allison, Mr. Hudson Joshua Creighton" ...
##  $ sex      : chr  "female" "male" "female" "male" ...
##  $ age      : num  29 0.917 2 30 25 ...
##  $ sibsp    : int  0 1 1 1 1 0 1 0 2 0 ...
##  $ parch    : int  0 2 2 2 2 0 0 0 0 0 ...
##  $ ticket   : chr  "24160" "113781" "113781" "113781" ...
##  $ fare     : num  211 152 152 152 152 ...
##  $ cabin    : chr  "B5" "C22 C26" "C22 C26" "C22 C26" ...
##  $ embarked : chr  "S" "S" "S" "S" ...
##  $ boat     : chr  "2" "11" "" "" ...
##  $ body     : int  NA NA NA 135 NA NA NA NA NA 22 ...
##  $ home.dest: chr  "St Louis, MO" "Montreal, PQ / Chesterville, ON" "Montreal, PQ / Chesterville, ON" "Montreal, PQ / Chesterville, ON" ...
df <- df[, c("survived", "pclass", "sex", "age")]
df <- na.omit(df)
df$survived <- as.factor(df$survived)
df$pclass   <- as.factor(df$pclass)
df$sex      <- as.factor(df$sex)

Crear el modelo

modelo <- glm(survived ~ ., data = df, family = binomial)
summary(modelo)
## 
## Call:
## glm(formula = survived ~ ., family = binomial, data = df)
## 
## Coefficients:
##              Estimate Std. Error z value Pr(>|z|)    
## (Intercept)  3.522074   0.326702  10.781  < 2e-16 ***
## pclass2     -1.280570   0.225538  -5.678 1.36e-08 ***
## pclass3     -2.289661   0.225802 -10.140  < 2e-16 ***
## sexmale     -2.497845   0.166037 -15.044  < 2e-16 ***
## age         -0.034393   0.006331  -5.433 5.56e-08 ***
## ---
## Signif. codes:  0 '***' 0.001 '**' 0.01 '*' 0.05 '.' 0.1 ' ' 1
## 
## (Dispersion parameter for binomial family taken to be 1)
## 
##     Null deviance: 1414.62  on 1045  degrees of freedom
## Residual deviance:  982.45  on 1041  degrees of freedom
## AIC: 992.45
## 
## Number of Fisher Scoring iterations: 4

Probar el modelo

prueba <- data.frame(
  pclass = as.factor(c(1, 3)),
  sex    = as.factor(c("female", "male")),
  age    = c(25, 40)
)
probabilidad <- predict(modelo, newdata = prueba, type = "response")
cbind(prueba, Probabilidad_Sobrevive = probabilidad)
##   pclass    sex age Probabilidad_Sobrevive
## 1      1 female  25             0.93476160
## 2      3   male  40             0.06653593

Conclusiones

En conclusión, el modelo de regresión logística sobre el Titanic revela que:

  • Sexo: Ser mujer aumenta significativamente la probabilidad de sobrevivir. Una mujer de 1ª clase con 25 años tiene una probabilidad muy alta de supervivencia.
  • Clase: A mayor clase (1ª > 2ª > 3ª), mayor probabilidad de sobrevivir. La clase social fue determinante.
  • Edad: A mayor edad, menor probabilidad de sobrevivir, aunque su efecto es menor comparado con sexo y clase.
  • Un hombre de 3ª clase con 40 años tiene una probabilidad muy baja de haber sobrevivido.
LS0tCnRpdGxlOiAiUmVncmVzacOzbiBMb2fDrXN0aWNhIgphdXRob3I6ICJSIgpkYXRlOiAiIgpvdXRwdXQ6CiAgaHRtbF9kb2N1bWVudDoKICAgIHRvYzogVFJVRQogICAgdG9jX2Zsb2F0OiBUUlVFCiAgICBjb2RlX2Rvd25sb2FkOiBUUlVFCiAgICB0aGVtZTogYm9vdHN0cmFwCi0tLQoKIVtdKCkKCiMgPHNwYW4gc3R5bGU9ImNvbG9yOmJsdWUiPiBUZW9yw61hIDwvc3Bhbj4KTGEgKipyZWdyZXNpw7NuIGxvZ8Otc3RpY2EqKiBlcyB1biBtb2RlbG8gZXN0YWTDrXN0aWNvIGRlIGNsYXNpZmljYWNpw7NuIGJpbmFyaWEsIHF1ZSBlc3RpbWEgbGEgcHJvYmFiaWxpZGFkIGRlIHF1ZSBvY3VycmEgdW4gZXZlbnRvICh2YWxvciAxKSBmcmVudGUgYSBxdWUgbm8gb2N1cnJhICh2YWxvciAwKSwgZW4gZnVuY2nDs24gZGUgdmFyaWFibGVzIGluZGVwZW5kaWVudGVzLgoKIyA8c3BhbiBzdHlsZT0iY29sb3I6Ymx1ZSI+IEluc3RhbGFyIHBhcXVldGVzIHkgbGxhbWFyIGxpYnJlcsOtYXMgPC9zcGFuPgpgYGB7ciBtZXNzYWdlPUZBTFNFLCB3YXJuaW5nPUZBTFNFfQojIGluc3RhbGwucGFja2FnZXMoImNhcmV0IikKbGlicmFyeShjYXJldCkKIyBpbnN0YWxsLnBhY2thZ2VzKCJ0aWR5dmVyc2UiKQpsaWJyYXJ5KHRpZHl2ZXJzZSkKYGBgCgojIDxzcGFuIHN0eWxlPSJjb2xvcjpibHVlIj4gQ3JlYXIgbGEgYmFzZSBkZSBkYXRvcyA8L3NwYW4+CmBgYHtyfQpkZiA8LSByZWFkLmNzdigidGl0YW5pYy5jc3YiKQpgYGAKCiMgPHNwYW4gc3R5bGU9ImNvbG9yOmJsdWUiPiBFbnRlbmRlciBsYSBiYXNlIGRlIGRhdG9zIDwvc3Bhbj4KYGBge3J9CnN1bW1hcnkoZGYpCnN0cihkZikKZGYgPC0gZGZbLCBjKCJzdXJ2aXZlZCIsICJwY2xhc3MiLCAic2V4IiwgImFnZSIpXQpkZiA8LSBuYS5vbWl0KGRmKQpkZiRzdXJ2aXZlZCA8LSBhcy5mYWN0b3IoZGYkc3Vydml2ZWQpCmRmJHBjbGFzcyAgIDwtIGFzLmZhY3RvcihkZiRwY2xhc3MpCmRmJHNleCAgICAgIDwtIGFzLmZhY3RvcihkZiRzZXgpCmBgYAoKIyA8c3BhbiBzdHlsZT0iY29sb3I6Ymx1ZSI+IENyZWFyIGVsIG1vZGVsbyA8L3NwYW4+CmBgYHtyfQptb2RlbG8gPC0gZ2xtKHN1cnZpdmVkIH4gLiwgZGF0YSA9IGRmLCBmYW1pbHkgPSBiaW5vbWlhbCkKc3VtbWFyeShtb2RlbG8pCmBgYAoKIyA8c3BhbiBzdHlsZT0iY29sb3I6Ymx1ZSI+IFByb2JhciBlbCBtb2RlbG8gPC9zcGFuPgpgYGB7cn0KcHJ1ZWJhIDwtIGRhdGEuZnJhbWUoCiAgcGNsYXNzID0gYXMuZmFjdG9yKGMoMSwgMykpLAogIHNleCAgICA9IGFzLmZhY3RvcihjKCJmZW1hbGUiLCAibWFsZSIpKSwKICBhZ2UgICAgPSBjKDI1LCA0MCkKKQpwcm9iYWJpbGlkYWQgPC0gcHJlZGljdChtb2RlbG8sIG5ld2RhdGEgPSBwcnVlYmEsIHR5cGUgPSAicmVzcG9uc2UiKQpjYmluZChwcnVlYmEsIFByb2JhYmlsaWRhZF9Tb2JyZXZpdmUgPSBwcm9iYWJpbGlkYWQpCmBgYAoKIyA8c3BhbiBzdHlsZT0iY29sb3I6Ymx1ZSI+IENvbmNsdXNpb25lcyA8L3NwYW4+CkVuIGNvbmNsdXNpw7NuLCBlbCBtb2RlbG8gZGUgcmVncmVzacOzbiBsb2fDrXN0aWNhIHNvYnJlIGVsIFRpdGFuaWMgcmV2ZWxhIHF1ZToKCiogKipTZXhvKio6IFNlciBtdWplciBhdW1lbnRhIHNpZ25pZmljYXRpdmFtZW50ZSBsYSBwcm9iYWJpbGlkYWQgZGUgc29icmV2aXZpci4gVW5hIG11amVyIGRlIDHCqiBjbGFzZSBjb24gMjUgYcOxb3MgdGllbmUgdW5hIHByb2JhYmlsaWRhZCBtdXkgYWx0YSBkZSBzdXBlcnZpdmVuY2lhLgoqICoqQ2xhc2UqKjogQSBtYXlvciBjbGFzZSAoMcKqID4gMsKqID4gM8KqKSwgbWF5b3IgcHJvYmFiaWxpZGFkIGRlIHNvYnJldml2aXIuIExhIGNsYXNlIHNvY2lhbCBmdWUgZGV0ZXJtaW5hbnRlLgoqICoqRWRhZCoqOiBBIG1heW9yIGVkYWQsIG1lbm9yIHByb2JhYmlsaWRhZCBkZSBzb2JyZXZpdmlyLCBhdW5xdWUgc3UgZWZlY3RvIGVzIG1lbm9yIGNvbXBhcmFkbyBjb24gc2V4byB5IGNsYXNlLgoqIFVuIGhvbWJyZSBkZSAzwqogY2xhc2UgY29uIDQwIGHDsW9zIHRpZW5lIHVuYSBwcm9iYWJpbGlkYWQgbXV5IGJhamEgZGUgaGFiZXIgc29icmV2aXZpZG8uCg==