Importar la base de datos

titanic <- read.csv("C:\\Users\\USUARIO\\Downloads\\titanic.csv")

Entender la base de datos

summary(titanic)
##      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(titanic)
## '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" ...

Filtrar base de datos

Titanic <- titanic[,c("pclass","age","sex","survived")]
Titanic$survived <- as.factor(ifelse(Titanic$survived==0, "Murio", "Sobrevive"))
Titanic$pclass <- as.factor(Titanic$pclass)
Titanic$sex <- as.factor(Titanic$sex)
str(Titanic)
## 'data.frame':    1310 obs. of  4 variables:
##  $ pclass  : Factor w/ 3 levels "1","2","3": 1 1 1 1 1 1 1 1 1 1 ...
##  $ age     : num  29 0.917 2 30 25 ...
##  $ sex     : Factor w/ 3 levels "","female","male": 2 3 2 3 2 3 2 3 2 3 ...
##  $ survived: Factor w/ 2 levels "Murio","Sobrevive": 2 2 1 1 1 2 2 1 2 1 ...
sum(is.na(Titanic))
## [1] 266
sapply(Titanic, function(x) sum(is.na(x)))
##   pclass      age      sex survived 
##        1      264        0        1
Titanic <- na.omit(Titanic)

Crear árbol de decisión

# install.packages("rpart")
library(rpart)
arbol <- rpart(formula=survived ~ ., data = Titanic)
arbol
## n= 1046 
## 
## node), split, n, loss, yval, (yprob)
##       * denotes terminal node
## 
##  1) root 1046 427 Murio (0.59177820 0.40822180)  
##    2) sex=male 658 135 Murio (0.79483283 0.20516717)  
##      4) age>=9.5 615 110 Murio (0.82113821 0.17886179) *
##      5) age< 9.5 43  18 Sobrevive (0.41860465 0.58139535)  
##       10) pclass=3 29  11 Murio (0.62068966 0.37931034) *
##       11) pclass=1,2 14   0 Sobrevive (0.00000000 1.00000000) *
##    3) sex=female 388  96 Sobrevive (0.24742268 0.75257732)  
##      6) pclass=3 152  72 Murio (0.52631579 0.47368421)  
##       12) age>=1.5 145  66 Murio (0.54482759 0.45517241) *
##       13) age< 1.5 7   1 Sobrevive (0.14285714 0.85714286) *
##      7) pclass=1,2 236  16 Sobrevive (0.06779661 0.93220339) *
# install.packages("rpart.plot")
library(rpart.plot)
rpart.plot(arbol)

prp(arbol,extra = 7,prefix = "fraccion")

Interpretación

El modelo de árbol de decisión aplicado a la base de datos del Titanic nos permite analizar los factores que influyeron en la supervivencia de los pasajeros.

  1. El género fue el factor más determinante:
    • Los hombres tuvieron una mayor tasa de mortalidad (cerca del 80%), especialmente aquellos mayores de 9.5 años.
    • Las mujeres sobrevivieron en mayor proporción, con más del 75% de supervivencia.
  2. La clase social también influyó en la supervivencia:
    • Los pasajeros de primera y segunda clase tuvieron mayor probabilidad de sobrevivir.
    • Los de tercera clase, en especial los hombres, tuvieron una tasa de mortalidad más alta.
  3. La edad fue un factor relevante:
    • Niños menores de 1.5 años en primera y segunda clase tuvieron una mayor tasa de supervivencia.
    • Los niños en tercera clase tuvieron menor probabilidad de sobrevivir en comparación con los de clases superiores.

Conclusión

El árbol de decisión confirma que el sexo, la clase social y la edad fueron los principales factores asociados a la supervivencia en el Titanic. Este modelo permite visualizar de manera clara los patrones de supervivencia y puede ser mejorado incluyendo más variables o ajustando sus parámetros.

LS0tDQp0aXRsZTogIsOBcmJvbCBkZSBEZWNpc2nDs24gLSBUaXRhbmljIg0KYXV0aG9yOiAiRmFiaWFuYSBNZWRpbmFjZWxsaSAtIEEwMDgzNTg5NiINCmRhdGU6ICIyMDI1LTAyLTI3Ig0Kb3V0cHV0Og0KICBodG1sX2RvY3VtZW50Og0KICAgIHRvYzogdHJ1ZQ0KICAgIHRvY19mbG9hdDogdHJ1ZQ0KICAgIGNvZGVfZG93bmxvYWQ6IHRydWUNCiAgICB0aGVtZTogc2ltcGxlDQogICAgaGlnaGxpZ2h0OiBweWdtZW50cw0KLS0tDQoNCiFbXShDOlxcVXNlcnNcXFVTVUFSSU9cXERlc2t0b3BcXEJsb3F1ZSAtIE1vZHVsbyAyXFx0aXRhbmljZ2lmLmdpZikgIA0KDQojIDxzcGFuIHN0eWxlPSJjb2xvcjogU3RlZWxHcmF5OyI+SW1wb3J0YXIgbGEgYmFzZSBkZSBkYXRvczwvc3Bhbj4NCmBgYHtyfQ0KdGl0YW5pYyA8LSByZWFkLmNzdigiQzpcXFVzZXJzXFxVU1VBUklPXFxEb3dubG9hZHNcXHRpdGFuaWMuY3N2IikNCmBgYA0KIyMgPHNwYW4gc3R5bGU9ImNvbG9yOiBTdGVlbEdyYXk7Ij5FbnRlbmRlciBsYSBiYXNlIGRlIGRhdG9zPC9zcGFuPg0KYGBge3J9DQpzdW1tYXJ5KHRpdGFuaWMpDQpzdHIodGl0YW5pYykNCmBgYA0KIyA8c3BhbiBzdHlsZT0iY29sb3I6IFN0ZWVsR3JheTsiPkZpbHRyYXIgYmFzZSBkZSBkYXRvczwvc3Bhbj4NCmBgYHtyfQ0KVGl0YW5pYyA8LSB0aXRhbmljWyxjKCJwY2xhc3MiLCJhZ2UiLCJzZXgiLCJzdXJ2aXZlZCIpXQ0KVGl0YW5pYyRzdXJ2aXZlZCA8LSBhcy5mYWN0b3IoaWZlbHNlKFRpdGFuaWMkc3Vydml2ZWQ9PTAsICJNdXJpbyIsICJTb2JyZXZpdmUiKSkNClRpdGFuaWMkcGNsYXNzIDwtIGFzLmZhY3RvcihUaXRhbmljJHBjbGFzcykNClRpdGFuaWMkc2V4IDwtIGFzLmZhY3RvcihUaXRhbmljJHNleCkNCnN0cihUaXRhbmljKQ0Kc3VtKGlzLm5hKFRpdGFuaWMpKQ0Kc2FwcGx5KFRpdGFuaWMsIGZ1bmN0aW9uKHgpIHN1bShpcy5uYSh4KSkpDQpUaXRhbmljIDwtIG5hLm9taXQoVGl0YW5pYykNCmBgYA0KIyA8c3BhbiBzdHlsZT0iY29sb3I6IFN0ZWVsR3JheTsiPkNyZWFyIMOhcmJvbCBkZSBkZWNpc2nDs248L3NwYW4+DQpgYGB7cn0NCiMgaW5zdGFsbC5wYWNrYWdlcygicnBhcnQiKQ0KbGlicmFyeShycGFydCkNCmFyYm9sIDwtIHJwYXJ0KGZvcm11bGE9c3Vydml2ZWQgfiAuLCBkYXRhID0gVGl0YW5pYykNCmFyYm9sDQojIGluc3RhbGwucGFja2FnZXMoInJwYXJ0LnBsb3QiKQ0KbGlicmFyeShycGFydC5wbG90KQ0KcnBhcnQucGxvdChhcmJvbCkNCnBycChhcmJvbCxleHRyYSA9IDcscHJlZml4ID0gImZyYWNjaW9uIikNCmBgYCAgDQoNCiMgPHNwYW4gc3R5bGU9ImNvbG9yOiBTdGVlbEdyYXk7Ij5JbnRlcnByZXRhY2nDs248L3NwYW4+ICANCg0KRWwgbW9kZWxvIGRlICoqw6FyYm9sIGRlIGRlY2lzacOzbioqIGFwbGljYWRvIGEgbGEgYmFzZSBkZSBkYXRvcyBkZWwgVGl0YW5pYyBub3MgcGVybWl0ZSBhbmFsaXphciBsb3MgZmFjdG9yZXMgcXVlIGluZmx1eWVyb24gZW4gbGEgc3VwZXJ2aXZlbmNpYSBkZSBsb3MgcGFzYWplcm9zLiAgDQoNCjEuICoqRWwgZ8OpbmVybyBmdWUgZWwgZmFjdG9yIG3DoXMgZGV0ZXJtaW5hbnRlKio6ICANCiAgIC0gKipMb3MgaG9tYnJlcyB0dXZpZXJvbiB1bmEgbWF5b3IgdGFzYSBkZSBtb3J0YWxpZGFkKiogKGNlcmNhIGRlbCA4MCUpLCBlc3BlY2lhbG1lbnRlIGFxdWVsbG9zIG1heW9yZXMgZGUgOS41IGHDsW9zLiAgDQogICAtICoqTGFzIG11amVyZXMgc29icmV2aXZpZXJvbiBlbiBtYXlvciBwcm9wb3JjacOzbioqLCBjb24gbcOhcyBkZWwgNzUlIGRlIHN1cGVydml2ZW5jaWEuICANCg0KMi4gKipMYSBjbGFzZSBzb2NpYWwgdGFtYmnDqW4gaW5mbHV5w7MgZW4gbGEgc3VwZXJ2aXZlbmNpYSoqOiAgDQogICAtICoqTG9zIHBhc2FqZXJvcyBkZSBwcmltZXJhIHkgc2VndW5kYSBjbGFzZSB0dXZpZXJvbiBtYXlvciBwcm9iYWJpbGlkYWQgZGUgc29icmV2aXZpcioqLiAgDQogICAtICoqTG9zIGRlIHRlcmNlcmEgY2xhc2UsIGVuIGVzcGVjaWFsIGxvcyBob21icmVzLCB0dXZpZXJvbiB1bmEgdGFzYSBkZSBtb3J0YWxpZGFkIG3DoXMgYWx0YSoqLiAgDQoNCjMuICoqTGEgZWRhZCBmdWUgdW4gZmFjdG9yIHJlbGV2YW50ZSoqOiAgDQogICAtICoqTmnDsW9zIG1lbm9yZXMgZGUgMS41IGHDsW9zIGVuIHByaW1lcmEgeSBzZWd1bmRhIGNsYXNlIHR1dmllcm9uIHVuYSBtYXlvciB0YXNhIGRlIHN1cGVydml2ZW5jaWEqKi4gIA0KICAgLSAqKkxvcyBuacOxb3MgZW4gdGVyY2VyYSBjbGFzZSB0dXZpZXJvbiBtZW5vciBwcm9iYWJpbGlkYWQgZGUgc29icmV2aXZpciBlbiBjb21wYXJhY2nDs24gY29uIGxvcyBkZSBjbGFzZXMgc3VwZXJpb3JlcyoqLiAgDQoNCiMgPHNwYW4gc3R5bGU9ImNvbG9yOiBTdGVlbEdyYXk7Ij4gQ29uY2x1c2nDs248L3NwYW4+ICAgIA0KRWwgw6FyYm9sIGRlIGRlY2lzacOzbiBjb25maXJtYSBxdWUgZWwgKipzZXhvLCBsYSBjbGFzZSBzb2NpYWwgeSBsYSBlZGFkKiogZnVlcm9uIGxvcyBwcmluY2lwYWxlcyBmYWN0b3JlcyBhc29jaWFkb3MgYSBsYSBzdXBlcnZpdmVuY2lhIGVuIGVsIFRpdGFuaWMuIEVzdGUgbW9kZWxvIHBlcm1pdGUgdmlzdWFsaXphciBkZSBtYW5lcmEgY2xhcmEgbG9zIHBhdHJvbmVzIGRlIHN1cGVydml2ZW5jaWEgeSBwdWVkZSBzZXIgbWVqb3JhZG8gaW5jbHV5ZW5kbyBtw6FzIHZhcmlhYmxlcyBvIGFqdXN0YW5kbyBzdXMgcGFyw6FtZXRyb3MuDQoNCg==