Importar la base de datos

# file.choose()
base_de_datos <- read.csv("C:\\Users\\maria\\Documents\\ITESM LAET\\Semestre 7\\M3\\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 base de datos

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

Crear árbol de decisión

library(rpart)
arbol <- rpart(formula = survived ~ ., data = Titanic)
arbol
## n= 1046 
## 
## node), split, n, loss, yval, (yprob)
##       * denotes terminal node
## 
##  1) root 1046 427 Murió (0.59177820 0.40822180)  
##    2) sex=male 658 135 Murió (0.79483283 0.20516717)  
##      4) age>=9.5 615 110 Murió (0.82113821 0.17886179) *
##      5) age< 9.5 43  18 Sobrevivió (0.41860465 0.58139535)  
##       10) pclass=3 29  11 Murió (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 Murió (0.52631579 0.47368421)  
##       12) age>=1.5 145  66 Murió (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")
library(rpart.plot)
rpart.plot(arbol)

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

Conclusión

En este ejercicio analizamos la base de datos de los pasajeros del Titanic con el objetivo de agrupar la información y lograr comprenderla mejor. Para esto, se realizó el diagrama de “Árbol de decisión”, donde pudimos observar la cantidad de sobrevivientes y de pasajeros muertos tomando en cuenta distintas variables como sexo, edad o clase.

En este caso, descubrimos que el 41% del total de los pasajeros sobrevivieron; sin embargo, al ser mujer tenías una posibilidad de sobrevivir del 75%, esta posibilidad aumentaba a un 93% si no eras de tercera clase, y si si eras, la posibilidad de sobrevivir disminuía al 47%. Por otro lado, si eras de la tercera clase, las niñas de menos de 1.5 años tenían la posibilidad de sobrevivir un 86% y las mayores de un 46%. En el caso de los hombres, todos los niños menores a 9.5 años sobrevivieron y la posibilidad de sobrevivir solo por ser hombre disminuía de un 41% a un 21%.

Este árbol puede ser utilizado en múltiples circunstancias, en los negocios, un árbol de decisión nos puede servir para analizar de una forma más visual los posibles resultados, costos y consecuencias de una decisión compleja.

LS0tDQp0aXRsZTogPHNwYW4gc3R5bGU9IkNvbG9yOk9yYW5nZSIgPiJUaXRhbmljIg0KYXV0aG9yOiAiTWFyaWFuYSBVbGxvYSAtIEEwMTI1MzA3NiINCmRhdGU6ICIyMDIyLTA5LTA2Ig0Kb3V0cHV0OiANCiAgaHRtbF9kb2N1bWVudDoNCiAgICB0b2M6IHRydWUNCiAgICB0b2NfZmxvYXQ6IHRydWUNCiAgICBjb2RlX2Rvd25sb2FkOiB0cnVlDQotLS0NCjxpbWcgc3JjPSAiQzpcXFVzZXJzXFxtYXJpYVxcRG9jdW1lbnRzXFxJVEVTTSBMQUVUXFxTZW1lc3RyZSA3XFxNM1xcaW1hZ2VuZXNcXHRpdGFuaWMucG5nIj4NCg0KIyMjIEltcG9ydGFyIGxhIGJhc2UgZGUgZGF0b3MNCmBgYHtyfQ0KIyBmaWxlLmNob29zZSgpDQpiYXNlX2RlX2RhdG9zIDwtIHJlYWQuY3N2KCJDOlxcVXNlcnNcXG1hcmlhXFxEb2N1bWVudHNcXElURVNNIExBRVRcXFNlbWVzdHJlIDdcXE0zXFx0aXRhbmljLmNzdiIpDQpgYGANCg0KDQojIyMgRW50ZW5kZXIgbGEgYmFzZSBkZSBkYXRvcw0KYGBge3J9DQpzdW1tYXJ5KGJhc2VfZGVfZGF0b3MpDQpgYGANCg0KDQojIyMgRmlsdHJhciBiYXNlIGRlIGRhdG9zDQpgYGB7cn0NClRpdGFuaWMgPC0gYmFzZV9kZV9kYXRvc1ssYygicGNsYXNzIiwiYWdlIiwic2V4Iiwic3Vydml2ZWQiKV0NCiANClRpdGFuaWMkc3Vydml2ZWQgPC0gYXMuZmFjdG9yKGlmZWxzZShUaXRhbmljJHN1cnZpdmVkPT0wLCJNdXJpw7MiLCJTb2JyZXZpdmnDsyIpKQ0KVGl0YW5pYyRwY2xhc3MgPC0gYXMuZmFjdG9yKFRpdGFuaWMkcGNsYXNzKQ0KVGl0YW5pYyRzZXggPC0gYXMuZmFjdG9yKFRpdGFuaWMkc2V4KQ0Kc3RyKFRpdGFuaWMpDQoNCnN1bShpcy5uYShUaXRhbmljKSkNCg0KVGl0YW5pYyA8LSBuYS5vbWl0KFRpdGFuaWMpDQpgYGANCg0KDQojIyMgQ3JlYXIgw6FyYm9sIGRlIGRlY2lzacOzbg0KYGBge3J9DQpsaWJyYXJ5KHJwYXJ0KQ0KYXJib2wgPC0gcnBhcnQoZm9ybXVsYSA9IHN1cnZpdmVkIH4gLiwgZGF0YSA9IFRpdGFuaWMpDQphcmJvbA0KDQojaW5zdGFsbC5wYWNrYWdlcygicnBhcnQucGxvdCIpDQpsaWJyYXJ5KHJwYXJ0LnBsb3QpDQpycGFydC5wbG90KGFyYm9sKQ0KDQpwcnAoYXJib2wsZXh0cmE9NywgcHJlZml4PSJmcmFjY2lvbi9uIikNCg0KYGBgDQoNCiMjIyAqKkNvbmNsdXNpw7NuKioNCkVuIGVzdGUgZWplcmNpY2lvIGFuYWxpemFtb3MgbGEgYmFzZSBkZSBkYXRvcyBkZSBsb3MgcGFzYWplcm9zIGRlbCBUaXRhbmljIGNvbiBlbCBvYmpldGl2byBkZSBhZ3J1cGFyIGxhIGluZm9ybWFjacOzbiB5IGxvZ3JhciBjb21wcmVuZGVybGEgbWVqb3IuIFBhcmEgZXN0bywgc2UgcmVhbGl6w7MgZWwgZGlhZ3JhbWEgZGUgIsOBcmJvbCBkZSBkZWNpc2nDs24iLCBkb25kZSBwdWRpbW9zIG9ic2VydmFyIGxhIGNhbnRpZGFkIGRlIHNvYnJldml2aWVudGVzIHkgZGUgcGFzYWplcm9zIG11ZXJ0b3MgdG9tYW5kbyBlbiBjdWVudGEgZGlzdGludGFzIHZhcmlhYmxlcyBjb21vIHNleG8sIGVkYWQgbyBjbGFzZS4gDQoNCkVuIGVzdGUgY2FzbywgZGVzY3Vicmltb3MgcXVlIGVsICoqNDElIGRlbCB0b3RhbCBkZSBsb3MgcGFzYWplcm9zIHNvYnJldml2aWVyb24qKjsgc2luIGVtYmFyZ28sIGFsICpzZXIgbXVqZXIgdGVuw61hcyB1bmEgcG9zaWJpbGlkYWQgZGUgc29icmV2aXZpciBkZWwgNzUlKiwgZXN0YSBwb3NpYmlsaWRhZCBhdW1lbnRhYmEgYSB1biA5MyUgc2kgKipubyoqIGVyYXMgZGUgdGVyY2VyYSBjbGFzZSwgeSBzaSBzaSBlcmFzLCBsYSBwb3NpYmlsaWRhZCBkZSBzb2JyZXZpdmlyIGRpc21pbnXDrWEgYWwgNDclLiBQb3Igb3RybyBsYWRvLCBzaSBlcmFzIGRlIGxhIHRlcmNlcmEgY2xhc2UsIGxhcyBuacOxYXMgZGUgbWVub3MgZGUgMS41IGHDsW9zIHRlbsOtYW4gbGEgcG9zaWJpbGlkYWQgZGUgc29icmV2aXZpciB1biA4NiUgeSBsYXMgbWF5b3JlcyBkZSB1biA0NiUuDQpFbiBlbCBjYXNvIGRlIGxvcyBob21icmVzLCAqKnRvZG9zIGxvcyBuacOxb3MgbWVub3JlcyBhIDkuNSBhw7FvcyBzb2JyZXZpdmllcm9uKiogeSBsYSBwb3NpYmlsaWRhZCBkZSBzb2JyZXZpdmlyIHNvbG8gcG9yIHNlciBob21icmUgZGlzbWludcOtYSBkZSB1biA0MSUgYSB1biAyMSUuDQoNCg0KRXN0ZSDDoXJib2wgcHVlZGUgc2VyIHV0aWxpemFkbyBlbiBtw7psdGlwbGVzIGNpcmN1bnN0YW5jaWFzLCBlbiBsb3MgbmVnb2Npb3MsIHVuIMOhcmJvbCBkZSBkZWNpc2nDs24gbm9zIHB1ZWRlIHNlcnZpciBwYXJhIGFuYWxpemFyIGRlIHVuYSBmb3JtYSBtw6FzIHZpc3VhbCBsb3MgcG9zaWJsZXMgcmVzdWx0YWRvcywgY29zdG9zIHkgY29uc2VjdWVuY2lhcyBkZSB1bmEgZGVjaXNpw7NuIGNvbXBsZWphLg0KDQoNCg0K