Importar base de datos

#file.choose() 

base_de_datos <- read.csv("C:\\Users\\danyc\\OneDrive - Instituto Tecnologico y de Estudios Superiores de Monterrey\\Desktop\\Excel y CSV\\titanic.csv")

Entender la base de datos

summary(base_de_datos)
##      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

Filtrar la base de datos

Titanic <- base_de_datos[,c("pclass", "age","sex", "survived")]

Titanic$survived <- as.factor(ifelse(Titanic$survived==0, "Murio", "Sobrevivió"))
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","Sobrevivió": 2 2 1 1 1 2 2 1 2 1 ...
sum(is.na(Titanic))
## [1] 266

Omitir NA

Titanic <- na.omit(Titanic)

Crear árbol de decisión

Nota: Los porcentajes son los que tienen punto decimal, ya que los porcentajes desplegados son generales y no nos funcionan con el proposito que quisieramos.

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 Sobrevivió (0.41860465 0.58139535)  
##       10) pclass=3 29  11 Murio (0.62068966 0.37931034) *
##       11) pclass=1,2 14   0 Sobrevivió (0.00000000 1.00000000) *
##    3) sex=female 388  96 Sobrevivió (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 Sobrevivió (0.14285714 0.85714286) *
##      7) pclass=1,2 236  16 Sobrevivió (0.06779661 0.93220339) *
#install.packages (rpart.plot)
#install.packages("rpart.plot")
library(rpart.plot)
rpart.plot(arbol)

prp(arbol,extra=7, prefix="fracción\n")

Conclusión y Aprendizaje

Haciendo una interpretación y comenzando con esto podemos ver que las personas con mas mortalidad en el barco fueron los de 3era clase mayores a 9 años, esto lo podríamos relacionar con la pelicula y el caso de la vida real en donde los que se salvaron de manera más rápida fueron la personas del sexo femenino, de clase alta y menores de 9 años, puesto a que el racismo y clasismo era muy marcado en estos años.

Esta introducción a los árboles de decisiones nos ayudan a conocer un poco más de lo que podría resultar de distintos escenarios al reflejar de cierta manera una “Consecuencia” o una reacción a la acción que queremos hacer, númericamente en este caso y al estar trabajando con bases de datos.

LS0tDQp0aXRsZTogPHNwYW4gc3R5bGU9IkNvbG9yOkJsdWUiPiBNb2RlbG8gUHJlZGljdGl2byAiw4FyYm9sIGRlIERlY2lzacOzbiBUaXRhbmljIiA8L3NwYW4+DQphdXRob3I6ICJEYW5pZWxhIEPDoXJkZW5hcyBaIC8vIEEwMTcyMDUzNSINCmRhdGU6ICIyMDIyLTA5LTA4Ig0Kb3V0cHV0OiANCiAgICAgIGh0bWxfZG9jdW1lbnQ6DQogICAgICAgIHRvYzogdHJ1ZQ0KICAgICAgICB0b2NfZmxvYXQ6IHRydWUNCiAgICAgICAgY29kZV9mb2xkaW5nOiAiaGlkZSINCiAgICAgICAgY29kZV9kb3dubG9hZDogdHJ1ZQ0KLS0tDQoqKioNCjxjZW50ZXI+DQojIDxpbWcgc3JjPSAiQzpcXFVzZXJzXFxkYW55Y1xcRG93bmxvYWRzXFx0aXRhbmljLmdpZiIgLz4NCjxjZW50ZXIvPiANCg0KIyA8c3BhbiBzdHlsZT0iQ29sb3I6IzMwMkU4MCI+IEltcG9ydGFyIGJhc2UgZGUgZGF0b3MgIDwvc3Bhbj4NCmBgYHtyfQ0KI2ZpbGUuY2hvb3NlKCkgDQoNCmJhc2VfZGVfZGF0b3MgPC0gcmVhZC5jc3YoIkM6XFxVc2Vyc1xcZGFueWNcXE9uZURyaXZlIC0gSW5zdGl0dXRvIFRlY25vbG9naWNvIHkgZGUgRXN0dWRpb3MgU3VwZXJpb3JlcyBkZSBNb250ZXJyZXlcXERlc2t0b3BcXEV4Y2VsIHkgQ1NWXFx0aXRhbmljLmNzdiIpDQpgYGANCg0KDQoNCg0KIyA8c3BhbiBzdHlsZT0iQ29sb3I6Ymx1ZSI+IEVudGVuZGVyIGxhIGJhc2UgZGUgZGF0b3MgPC9zcGFuPg0KYGBge3J9DQoNCnN1bW1hcnkoYmFzZV9kZV9kYXRvcykNCmBgYA0KDQoNCg0KIyA8c3BhbiBzdHlsZT0iQ29sb3I6Ymx1ZSI+IEZpbHRyYXIgbGEgYmFzZSBkZSBkYXRvcyA8L3NwYW4+DQpgYGB7cn0NClRpdGFuaWMgPC0gYmFzZV9kZV9kYXRvc1ssYygicGNsYXNzIiwgImFnZSIsInNleCIsICJzdXJ2aXZlZCIpXQ0KDQpUaXRhbmljJHN1cnZpdmVkIDwtIGFzLmZhY3RvcihpZmVsc2UoVGl0YW5pYyRzdXJ2aXZlZD09MCwgIk11cmlvIiwgIlNvYnJldml2acOzIikpDQpUaXRhbmljJHBjbGFzczwtIGFzLmZhY3RvcihUaXRhbmljJHBjbGFzcykNClRpdGFuaWMkc2V4PC0gYXMuZmFjdG9yKFRpdGFuaWMkc2V4KQ0Kc3RyKFRpdGFuaWMpDQoNCnN1bShpcy5uYShUaXRhbmljKSkNCmBgYA0KDQoNCiMjIDxzcGFuIHN0eWxlPSJDb2xvcjojMzAyRTgwIj4gT21pdGlyIE5BICA8L3NwYW4+DQpgYGB7cn0NCg0KVGl0YW5pYyA8LSBuYS5vbWl0KFRpdGFuaWMpDQoNCmBgYA0KDQojIDxzcGFuIHN0eWxlPSJDb2xvcjpibHVlIj4gQ3JlYXIgw6FyYm9sIGRlIGRlY2lzacOzbiA8L3NwYW4+DQpOb3RhOiBMb3MgcG9yY2VudGFqZXMgc29uIGxvcyBxdWUgdGllbmVuIHB1bnRvIGRlY2ltYWwsIHlhIHF1ZSBsb3MgcG9yY2VudGFqZXMgZGVzcGxlZ2Fkb3Mgc29uIGdlbmVyYWxlcyB5IG5vIG5vcyBmdW5jaW9uYW4gY29uIGVsIHByb3Bvc2l0byBxdWUgcXVpc2llcmFtb3MuDQpgYGB7ciwgZmlnLmRpbT1jKDUsIDMpfQ0KbGlicmFyeShycGFydCkNCmFyYm9sIDwtIHJwYXJ0IChmb3JtdWxhID0gc3Vydml2ZWQgfiAuLCBkYXRhID0gVGl0YW5pYykNCmFyYm9sDQoNCiNpbnN0YWxsLnBhY2thZ2VzIChycGFydC5wbG90KQ0KI2luc3RhbGwucGFja2FnZXMoInJwYXJ0LnBsb3QiKQ0KbGlicmFyeShycGFydC5wbG90KQ0KcnBhcnQucGxvdChhcmJvbCkNCg0KcHJwKGFyYm9sLGV4dHJhPTcsIHByZWZpeD0iZnJhY2Npw7NuXG4iKQ0KYGBgDQoNCg0KIyA8c3BhbiBzdHlsZT0iQ29sb3I6IzMwMkU4MCI+IENvbmNsdXNpw7NuIHkgQXByZW5kaXphamUgPC9zcGFuPg0KDQo8c3R5bGU+DQpkaXYuYmx1ZSB7IGJhY2tncm91bmQtY29sb3I6I0RBRjBGNjsgYm9yZGVyLXJhZGl1czogNXB4OyBwYWRkaW5nOiAyMHB4O30NCjwvc3R5bGU+DQo8ZGl2IGNsYXNzID0gImJsdWUiPg0KDQpIYWNpZW5kbyB1bmEgaW50ZXJwcmV0YWNpw7NuIHkgY29tZW56YW5kbyBjb24gZXN0byBwb2RlbW9zIHZlciBxdWUgbGFzIHBlcnNvbmFzIGNvbiBtYXMgbW9ydGFsaWRhZCBlbiBlbCBiYXJjbyBmdWVyb24gbG9zIGRlIDNlcmEgY2xhc2UgbWF5b3JlcyBhIDkgYcOxb3MsIGVzdG8gbG8gcG9kcsOtYW1vcyByZWxhY2lvbmFyIGNvbiBsYSBwZWxpY3VsYSB5IGVsIGNhc28gZGUgbGEgdmlkYSByZWFsIGVuIGRvbmRlIGxvcyBxdWUgc2Ugc2FsdmFyb24gZGUgbWFuZXJhIG3DoXMgcsOhcGlkYSBmdWVyb24gbGEgcGVyc29uYXMgZGVsICpzZXhvIGZlbWVuaW5vKiwgZGUgY2xhc2UgYWx0YSB5IG1lbm9yZXMgZGUgOSBhw7FvcywgcHVlc3RvIGEgcXVlIGVsIHJhY2lzbW8geSBjbGFzaXNtbyBlcmEgbXV5IG1hcmNhZG8gZW4gZXN0b3MgYcOxb3MuIA0KDQpFc3RhICoqaW50cm9kdWNjacOzbioqIGEgbG9zIMOhcmJvbGVzIGRlIGRlY2lzaW9uZXMgbm9zIGF5dWRhbiBhIGNvbm9jZXIgdW4gcG9jbyBtw6FzIGRlIGxvIHF1ZSBwb2Ryw61hIHJlc3VsdGFyIGRlIGRpc3RpbnRvcyBlc2NlbmFyaW9zIGFsIHJlZmxlamFyIGRlIGNpZXJ0YSBtYW5lcmEgdW5hICJDb25zZWN1ZW5jaWEiIG8gdW5hIHJlYWNjacOzbiBhIGxhIGFjY2nDs24gcXVlIHF1ZXJlbW9zIGhhY2VyLCBuw7ptZXJpY2FtZW50ZSBlbiBlc3RlIGNhc28geSBhbCBlc3RhciB0cmFiYWphbmRvIGNvbiBiYXNlcyBkZSBkYXRvcy4NCg0KDQo8L2Rpdj4gIA0KDQoNCjxjZW50ZXI+DQo8aW1nIHNyYz0gIkM6XFxVc2Vyc1xcZGFueWNcXERvd25sb2Fkc1xcZ29vZGJ5ZS5naWYiIC8+DQo8Y2VudGVyLz4=