# Instalar paquetes y llamar librerías
#install.packages("randomForest")
library(randomForest)
## randomForest 4.7-1.1
## Type rfNews() to see new features/changes/bug fixes.
#install.packages("caret") 
library(caret)
## Loading required package: ggplot2
## 
## Attaching package: 'ggplot2'
## The following object is masked from 'package:randomForest':
## 
##     margin
## Loading required package: lattice
library(e1071)
# Crear la base de datos
df <- read.csv("~/Downloads/heart.csv")
# Análisis exploratorio
summary(df)
##       age             sex               cp            trestbps    
##  Min.   :29.00   Min.   :0.0000   Min.   :0.0000   Min.   : 94.0  
##  1st Qu.:48.00   1st Qu.:0.0000   1st Qu.:0.0000   1st Qu.:120.0  
##  Median :56.00   Median :1.0000   Median :1.0000   Median :130.0  
##  Mean   :54.43   Mean   :0.6956   Mean   :0.9424   Mean   :131.6  
##  3rd Qu.:61.00   3rd Qu.:1.0000   3rd Qu.:2.0000   3rd Qu.:140.0  
##  Max.   :77.00   Max.   :1.0000   Max.   :3.0000   Max.   :200.0  
##       chol          fbs            restecg          thalach     
##  Min.   :126   Min.   :0.0000   Min.   :0.0000   Min.   : 71.0  
##  1st Qu.:211   1st Qu.:0.0000   1st Qu.:0.0000   1st Qu.:132.0  
##  Median :240   Median :0.0000   Median :1.0000   Median :152.0  
##  Mean   :246   Mean   :0.1493   Mean   :0.5298   Mean   :149.1  
##  3rd Qu.:275   3rd Qu.:0.0000   3rd Qu.:1.0000   3rd Qu.:166.0  
##  Max.   :564   Max.   :1.0000   Max.   :2.0000   Max.   :202.0  
##      exang           oldpeak          slope             ca        
##  Min.   :0.0000   Min.   :0.000   Min.   :0.000   Min.   :0.0000  
##  1st Qu.:0.0000   1st Qu.:0.000   1st Qu.:1.000   1st Qu.:0.0000  
##  Median :0.0000   Median :0.800   Median :1.000   Median :0.0000  
##  Mean   :0.3366   Mean   :1.072   Mean   :1.385   Mean   :0.7541  
##  3rd Qu.:1.0000   3rd Qu.:1.800   3rd Qu.:2.000   3rd Qu.:1.0000  
##  Max.   :1.0000   Max.   :6.200   Max.   :2.000   Max.   :4.0000  
##       thal           target      
##  Min.   :0.000   Min.   :0.0000  
##  1st Qu.:2.000   1st Qu.:0.0000  
##  Median :2.000   Median :1.0000  
##  Mean   :2.324   Mean   :0.5132  
##  3rd Qu.:3.000   3rd Qu.:1.0000  
##  Max.   :3.000   Max.   :1.0000
str(df)
## 'data.frame':    1025 obs. of  14 variables:
##  $ age     : int  52 53 70 61 62 58 58 55 46 54 ...
##  $ sex     : int  1 1 1 1 0 0 1 1 1 1 ...
##  $ cp      : int  0 0 0 0 0 0 0 0 0 0 ...
##  $ trestbps: int  125 140 145 148 138 100 114 160 120 122 ...
##  $ chol    : int  212 203 174 203 294 248 318 289 249 286 ...
##  $ fbs     : int  0 1 0 0 1 0 0 0 0 0 ...
##  $ restecg : int  1 0 1 1 1 0 2 0 0 0 ...
##  $ thalach : int  168 155 125 161 106 122 140 145 144 116 ...
##  $ exang   : int  0 1 1 0 0 0 0 1 0 1 ...
##  $ oldpeak : num  1 3.1 2.6 0 1.9 1 4.4 0.8 0.8 3.2 ...
##  $ slope   : int  2 0 0 2 1 1 0 1 2 1 ...
##  $ ca      : int  2 0 0 1 3 0 3 1 0 2 ...
##  $ thal    : int  3 3 3 3 2 2 1 3 3 2 ...
##  $ target  : int  0 0 0 0 0 1 0 0 0 0 ...
df$target <- as.factor(df$target)
summary(df)
##       age             sex               cp            trestbps    
##  Min.   :29.00   Min.   :0.0000   Min.   :0.0000   Min.   : 94.0  
##  1st Qu.:48.00   1st Qu.:0.0000   1st Qu.:0.0000   1st Qu.:120.0  
##  Median :56.00   Median :1.0000   Median :1.0000   Median :130.0  
##  Mean   :54.43   Mean   :0.6956   Mean   :0.9424   Mean   :131.6  
##  3rd Qu.:61.00   3rd Qu.:1.0000   3rd Qu.:2.0000   3rd Qu.:140.0  
##  Max.   :77.00   Max.   :1.0000   Max.   :3.0000   Max.   :200.0  
##       chol          fbs            restecg          thalach     
##  Min.   :126   Min.   :0.0000   Min.   :0.0000   Min.   : 71.0  
##  1st Qu.:211   1st Qu.:0.0000   1st Qu.:0.0000   1st Qu.:132.0  
##  Median :240   Median :0.0000   Median :1.0000   Median :152.0  
##  Mean   :246   Mean   :0.1493   Mean   :0.5298   Mean   :149.1  
##  3rd Qu.:275   3rd Qu.:0.0000   3rd Qu.:1.0000   3rd Qu.:166.0  
##  Max.   :564   Max.   :1.0000   Max.   :2.0000   Max.   :202.0  
##      exang           oldpeak          slope             ca        
##  Min.   :0.0000   Min.   :0.000   Min.   :0.000   Min.   :0.0000  
##  1st Qu.:0.0000   1st Qu.:0.000   1st Qu.:1.000   1st Qu.:0.0000  
##  Median :0.0000   Median :0.800   Median :1.000   Median :0.0000  
##  Mean   :0.3366   Mean   :1.072   Mean   :1.385   Mean   :0.7541  
##  3rd Qu.:1.0000   3rd Qu.:1.800   3rd Qu.:2.000   3rd Qu.:1.0000  
##  Max.   :1.0000   Max.   :6.200   Max.   :2.000   Max.   :4.0000  
##       thal       target 
##  Min.   :0.000   0:499  
##  1st Qu.:2.000   1:526  
##  Median :2.000          
##  Mean   :2.324          
##  3rd Qu.:3.000          
##  Max.   :3.000
str(df)
## 'data.frame':    1025 obs. of  14 variables:
##  $ age     : int  52 53 70 61 62 58 58 55 46 54 ...
##  $ sex     : int  1 1 1 1 0 0 1 1 1 1 ...
##  $ cp      : int  0 0 0 0 0 0 0 0 0 0 ...
##  $ trestbps: int  125 140 145 148 138 100 114 160 120 122 ...
##  $ chol    : int  212 203 174 203 294 248 318 289 249 286 ...
##  $ fbs     : int  0 1 0 0 1 0 0 0 0 0 ...
##  $ restecg : int  1 0 1 1 1 0 2 0 0 0 ...
##  $ thalach : int  168 155 125 161 106 122 140 145 144 116 ...
##  $ exang   : int  0 1 1 0 0 0 0 1 0 1 ...
##  $ oldpeak : num  1 3.1 2.6 0 1.9 1 4.4 0.8 0.8 3.2 ...
##  $ slope   : int  2 0 0 2 1 1 0 1 2 1 ...
##  $ ca      : int  2 0 0 1 3 0 3 1 0 2 ...
##  $ thal    : int  3 3 3 3 2 2 1 3 3 2 ...
##  $ target  : Factor w/ 2 levels "0","1": 1 1 1 1 1 2 1 1 1 1 ...
# Partir la base de datos
set.seed(123)
renglones_entrenamiento <- createDataPartition(df$target, p=0.8, list=FALSE)
entrenamiento <- df[renglones_entrenamiento, ]
prueba <- df[-renglones_entrenamiento, ]
# Construir el modelo SVM LINEAR
modelo <- svm(target ~ ., data = entrenamiento, kernel = "linear")

resultado_entrenamiento <- predict(modelo,entrenamiento)
resultado_prueba <- predict(modelo,prueba)
resultado_prueba
##    1    6   13   20   26   27   29   31   38   47   52   57   58   61   64   67 
##    0    1    1    1    0    1    1    0    1    1    0    1    1    1    1    1 
##   70   71   77   81   83   88   90   92  104  108  110  113  115  118  125  142 
##    0    0    1    1    0    1    0    1    1    0    0    0    1    0    0    1 
##  161  170  177  187  194  195  196  200  202  205  223  229  233  246  251  253 
##    0    1    0    0    1    0    1    0    1    1    1    1    0    1    0    0 
##  255  260  269  274  278  281  283  286  287  289  296  304  305  309  313  317 
##    0    0    0    0    1    1    1    1    1    1    0    0    1    1    0    1 
##  323  333  341  350  358  360  365  369  379  385  388  390  391  396  399  407 
##    0    1    1    1    0    1    1    1    0    0    0    1    1    1    0    1 
##  410  420  431  432  439  444  446  462  464  465  466  471  473  479  491  492 
##    0    1    1    0    1    1    1    1    1    1    1    1    1    1    1    1 
##  493  497  509  512  521  525  537  542  543  549  558  559  561  563  584  588 
##    0    0    0    0    0    0    1    1    1    1    1    1    1    1    0    0 
##  590  598  627  631  633  640  645  648  654  666  668  674  680  690  693  694 
##    0    1    0    1    1    1    1    0    0    1    1    1    0    1    0    1 
##  696  698  699  708  711  717  720  723  724  727  731  738  744  753  755  756 
##    0    1    0    1    1    0    0    1    1    0    1    0    0    1    1    1 
##  757  758  759  767  780  789  791  801  804  806  809  817  828  837  838  840 
##    0    0    1    0    1    0    0    0    1    0    1    1    1    1    1    1 
##  845  848  860  863  864  869  877  889  894  895  897  910  916  917  920  922 
##    0    0    0    1    0    1    0    0    1    0    0    0    0    0    0    0 
##  928  932  934  935  937  938  939  941  943  946  953  958  959  967  975  977 
##    1    1    0    1    1    1    0    0    1    1    1    1    1    0    1    0 
##  985  990  995  997 1005 1006 1009 1013 1021 1022 1024 1025 
##    0    1    0    0    1    0    1    1    1    0    1    0 
## Levels: 0 1
# Matriz de Confusión
mcre <- confusionMatrix(resultado_entrenamiento, entrenamiento$target) # matriz de confusión del resultado del entrenamiento
mcre
## Confusion Matrix and Statistics
## 
##           Reference
## Prediction   0   1
##          0 301  37
##          1  99 384
##                                           
##                Accuracy : 0.8343          
##                  95% CI : (0.8071, 0.8592)
##     No Information Rate : 0.5128          
##     P-Value [Acc > NIR] : < 2.2e-16       
##                                           
##                   Kappa : 0.6672          
##                                           
##  Mcnemar's Test P-Value : 1.689e-07       
##                                           
##             Sensitivity : 0.7525          
##             Specificity : 0.9121          
##          Pos Pred Value : 0.8905          
##          Neg Pred Value : 0.7950          
##              Prevalence : 0.4872          
##          Detection Rate : 0.3666          
##    Detection Prevalence : 0.4117          
##       Balanced Accuracy : 0.8323          
##                                           
##        'Positive' Class : 0               
## 
mcrp <- confusionMatrix(resultado_prueba,prueba$target) # matriz de confusión del resultado de la prueba
mcrp
## Confusion Matrix and Statistics
## 
##           Reference
## Prediction  0  1
##          0 78 10
##          1 21 95
##                                           
##                Accuracy : 0.848           
##                  95% CI : (0.7913, 0.8944)
##     No Information Rate : 0.5147          
##     P-Value [Acc > NIR] : < 2e-16         
##                                           
##                   Kappa : 0.6948          
##                                           
##  Mcnemar's Test P-Value : 0.07249         
##                                           
##             Sensitivity : 0.7879          
##             Specificity : 0.9048          
##          Pos Pred Value : 0.8864          
##          Neg Pred Value : 0.8190          
##              Prevalence : 0.4853          
##          Detection Rate : 0.3824          
##    Detection Prevalence : 0.4314          
##       Balanced Accuracy : 0.8463          
##                                           
##        'Positive' Class : 0               
## 
resultados <- data.frame("svm lineal" = c(mcre$overall["Accuracy"], mcrp$overall["Accuracy"]))
rownames(resultados) <- c("Precision de entrenamiento", "Precision de prueba")
resultados
##                            svm.lineal
## Precision de entrenamiento  0.8343484
## Precision de prueba         0.8480392
# Obtener predicción
paciente <- data.frame(
  age = 58,
  sex = 0,
  cp = 0,
  trestbps = 100,
  chol = 248,
  fbs = 0,
  restecg = 0,
  thalach = 122,
  exang = 0,
  oldpeak = 1,
  slope = 1,
  ca = 0,
  thal = 2
)
# Hacer la predicción
prediccion <- predict(modelo, paciente)

if(prediccion == 1) {
  print("Tiene enfermedad cardíaca")
} else {
  print("No tiene enfermedad cardíaca")
}
## [1] "Tiene enfermedad cardíaca"

#Conclusión: en conclusion los bosques aleatorios son una herramienta robusta que combina distintos arboles de decision para la prediccion de diagnostico en enfermedades cardiacas

LS0tCnRpdGxlOiAiU1ZNIgphdXRob3I6ICJTb2ZpYSBCZXJyb24iCmRhdGU6ICIyMDI0LTA4LTIyIgpvdXRwdXQ6IAogIGh0bWxfZG9jdW1lbnQ6CiAgICB0b2M6IFRSVUUKICAgIHRvY19mbG9hdDogVFJVRQogICAgY29kZV9kb3dubG9hZDogVFJVRQogICAgdGhlbWU6IGZsYXRseQplZGl0b3Jfb3B0aW9uczogCiAgY2h1bmtfb3V0cHV0X3R5cGU6IGNvbnNvbGUKLS0tCgpgYGB7ciBzZXR1cCwgaW5jbHVkZT1GQUxTRX0Ka25pdHI6Om9wdHNfY2h1bmskc2V0KGVjaG8gPSBUUlVFKQpgYGAKCmBgYHtyfQojIEluc3RhbGFyIHBhcXVldGVzIHkgbGxhbWFyIGxpYnJlcsOtYXMKI2luc3RhbGwucGFja2FnZXMoInJhbmRvbUZvcmVzdCIpCmxpYnJhcnkocmFuZG9tRm9yZXN0KQojaW5zdGFsbC5wYWNrYWdlcygiY2FyZXQiKSAKbGlicmFyeShjYXJldCkKbGlicmFyeShlMTA3MSkKYGBgCgpgYGB7cn0KIyBDcmVhciBsYSBiYXNlIGRlIGRhdG9zCmRmIDwtIHJlYWQuY3N2KCJ+L0Rvd25sb2Fkcy9oZWFydC5jc3YiKQpgYGAKCmBgYHtyfQojIEFuw6FsaXNpcyBleHBsb3JhdG9yaW8Kc3VtbWFyeShkZikKc3RyKGRmKQpkZiR0YXJnZXQgPC0gYXMuZmFjdG9yKGRmJHRhcmdldCkKc3VtbWFyeShkZikKc3RyKGRmKQpgYGAKCmBgYHtyfQojIFBhcnRpciBsYSBiYXNlIGRlIGRhdG9zCnNldC5zZWVkKDEyMykKcmVuZ2xvbmVzX2VudHJlbmFtaWVudG8gPC0gY3JlYXRlRGF0YVBhcnRpdGlvbihkZiR0YXJnZXQsIHA9MC44LCBsaXN0PUZBTFNFKQplbnRyZW5hbWllbnRvIDwtIGRmW3Jlbmdsb25lc19lbnRyZW5hbWllbnRvLCBdCnBydWViYSA8LSBkZlstcmVuZ2xvbmVzX2VudHJlbmFtaWVudG8sIF0KYGBgCgpgYGB7cn0KIyBDb25zdHJ1aXIgZWwgbW9kZWxvIFNWTSBMSU5FQVIKbW9kZWxvIDwtIHN2bSh0YXJnZXQgfiAuLCBkYXRhID0gZW50cmVuYW1pZW50bywga2VybmVsID0gImxpbmVhciIpCgpyZXN1bHRhZG9fZW50cmVuYW1pZW50byA8LSBwcmVkaWN0KG1vZGVsbyxlbnRyZW5hbWllbnRvKQpyZXN1bHRhZG9fcHJ1ZWJhIDwtIHByZWRpY3QobW9kZWxvLHBydWViYSkKcmVzdWx0YWRvX3BydWViYQpgYGAKCmBgYHtyfQojIE1hdHJpeiBkZSBDb25mdXNpw7NuCm1jcmUgPC0gY29uZnVzaW9uTWF0cml4KHJlc3VsdGFkb19lbnRyZW5hbWllbnRvLCBlbnRyZW5hbWllbnRvJHRhcmdldCkgIyBtYXRyaXogZGUgY29uZnVzacOzbiBkZWwgcmVzdWx0YWRvIGRlbCBlbnRyZW5hbWllbnRvCm1jcmUKbWNycCA8LSBjb25mdXNpb25NYXRyaXgocmVzdWx0YWRvX3BydWViYSxwcnVlYmEkdGFyZ2V0KSAjIG1hdHJpeiBkZSBjb25mdXNpw7NuIGRlbCByZXN1bHRhZG8gZGUgbGEgcHJ1ZWJhCm1jcnAKYGBgCgoKYGBge3J9CnJlc3VsdGFkb3MgPC0gZGF0YS5mcmFtZSgic3ZtIGxpbmVhbCIgPSBjKG1jcmUkb3ZlcmFsbFsiQWNjdXJhY3kiXSwgbWNycCRvdmVyYWxsWyJBY2N1cmFjeSJdKSkKcm93bmFtZXMocmVzdWx0YWRvcykgPC0gYygiUHJlY2lzaW9uIGRlIGVudHJlbmFtaWVudG8iLCAiUHJlY2lzaW9uIGRlIHBydWViYSIpCnJlc3VsdGFkb3MKYGBgCgoKYGBge3J9CiMgT2J0ZW5lciBwcmVkaWNjacOzbgpwYWNpZW50ZSA8LSBkYXRhLmZyYW1lKAogIGFnZSA9IDU4LAogIHNleCA9IDAsCiAgY3AgPSAwLAogIHRyZXN0YnBzID0gMTAwLAogIGNob2wgPSAyNDgsCiAgZmJzID0gMCwKICByZXN0ZWNnID0gMCwKICB0aGFsYWNoID0gMTIyLAogIGV4YW5nID0gMCwKICBvbGRwZWFrID0gMSwKICBzbG9wZSA9IDEsCiAgY2EgPSAwLAogIHRoYWwgPSAyCikKYGBgCgpgYGB7cn0KIyBIYWNlciBsYSBwcmVkaWNjacOzbgpwcmVkaWNjaW9uIDwtIHByZWRpY3QobW9kZWxvLCBwYWNpZW50ZSkKCmlmKHByZWRpY2Npb24gPT0gMSkgewogIHByaW50KCJUaWVuZSBlbmZlcm1lZGFkIGNhcmTDrWFjYSIpCn0gZWxzZSB7CiAgcHJpbnQoIk5vIHRpZW5lIGVuZmVybWVkYWQgY2FyZMOtYWNhIikKfQpgYGAKI0NvbmNsdXNpw7NuOiBlbiBjb25jbHVzaW9uIGxvcyBib3NxdWVzIGFsZWF0b3Jpb3Mgc29uIHVuYSBoZXJyYW1pZW50YSByb2J1c3RhIHF1ZSBjb21iaW5hIGRpc3RpbnRvcyBhcmJvbGVzIGRlIGRlY2lzaW9uIHBhcmEgbGEgcHJlZGljY2lvbiBkZSBkaWFnbm9zdGljbyBlbiBlbmZlcm1lZGFkZXMgY2FyZGlhY2FzCgo=