SciELO - Scientific Electronic Library Online

 
vol.1 número24DETERMINACIÓN DE PUNTOS DE OPTIMIZACIÓN A TRAVÉS DE BALANCE DE EXERGÍA EN LA PLANTA DE PASTEURIZACIÓN DE LECHE “ESTACIÓN EXPERIMENTAL TUNSHI (RIOBAMBA - ECUADOR)”DIAGNÓSTICO SOCIOECONÓMICO DE LA PARROQUIA PUNGALÁ índice de autoresíndice de materiabúsqueda de artículos
Home Pagelista alfabética de revistas  

Servicios Personalizados

Revista

Articulo

Indicadores

Links relacionados

  • No hay articulos similaresSimilares en SciELO

Compartir


Perfiles

versión On-line ISSN 2477-9105

Perfiles vol.1 no.24 Riobamba jul./dic. 2020

https://doi.org/10.47187/perf.v1i24.75 

Articles

SMOTEMD: UN ALGORITMO DE BALANCEO DE DATOS MIXTOS PARA BIG DATA EN R

SMOTEMD: a mixed data balancing algorithm for Big Data in R

Víctor Morales-Oñate1 

Luis Moreta2 

Bolívar Morales-Oñate3 

1Banco Solidario, Riesgos, Analítica de Datos, Quito, Ecuador.

2Escuela Politécnica Nacional, Facultad de Ciencias, Departamento de Economía Cuantitativa, Quito, Ecuador.

3Escuela Superior Politécnica de Chimborazo, Facultad de Ciencias, Ingeniería Química/Grupo de investigación Data Science Research Group, Riobamba, Ecuador.


RESUMEN

Analizar muestras con datos desbalanceados es un desafío para quien debe utilizarlos en términos de modelización. Un contexto en el que esto sucede es cuando la variable de respuesta es binaria y una de sus clases es muy pequeña en proporción respecto al total. Para la modelización de variables binarias se suele usar modelos de probabilidad como logit o probit. No obstante, estos modelos presentan problemas cuando la muestra no es balanceada y se desea elaborar la matriz de confusión de donde se evalúa el poder predictivo del modelo. Una técnica que permite balancear los datos observados es el algoritmo SMOTE, el cual trabaja con datos numéricos exclusivamente. Este trabajo es una extensión de SMOTE tal que permite el uso de datos mixtos (numéricos y categóricos). Al usar datos mixtos, la presente propuesta también permite superar la barrera de 65536 observaciones que tiene el software R cuando trabaja con distancias de datos categóricos. Mediante un estudio de simulación, se logra verificar las bondades del algoritmo propuesto: SMOTEMD para datos mixtos.

Palabras Claves: SMOTE; Clasificación; Muestras desbalanceadas

ABSTRAC

Analyzing samples with unbalanced data is a challenge for those who should use them in terms of modeling. A context in which this happens is when the response variable is binary and one of its classes is very small in proportion to the total. For the modeling of binary variables, probability models such as logit or probit are usually used. However, these models present problems when the sample is not balanced and it is desired to elaborate the confusion matrix from which the predictive power of the model is evaluated. One technique that allows the observed data to be balanced is the SMOTE algorithm, which works with numerical data exclusively. This work is an extension of SMOTE such that it allows the use of mixed data (numerical and categorical). By using mixed data, this proposal also makes it possible to overcome the barrier of 65536 observations that the R software has when working with categorical data distances. Through a simulation study, it is possible to verify the benefits of the proposed algorithm: SMOTEMD for mixed data.

Keywords: SMOTE; Classification; Unbalanced samples.

I. INTRODUCCIÓN

En ocasiones el investigador se enfrenta a situaciones donde la variable dependiente es observada con muy poca frecuencia como, por ejemplo, en el caso de fraudes bancarios 1, análisis de resultados de ecosistemas donde habita fauna en peligro de extinción 2 o el análisis de países en conflicto 3. El conjunto de datos que se utiliza en este contexto se le conoce como datos desbalanceados 4.

Existen diversos campos en los que los eventos de poca frecuencia (raros) o datos desbalanceados tienen gran relevancia, no solo por el evento en sí mismo, sino también por el alto costo que puede implicar el equivocarse en su predicción 5. Dentro de este marco, cuando se realiza un modelo de predicción con variable de respuesta binaria como la regresión logística, autores como 3 muestran que existe una distorsión en la probabilidad de que ocurra el evento raro dado un vector de características, es decir que Pr(Yi=1|xi )=πi será generalmente menor para los eventos raros, por tanto πi (1-xi) de igual manera es más pequeño para los eventos raros y la varianza es mucho mayor.

Por otro lado, autores como 6 mencionan que en los modelos de predicción con eventos raros existe un alto grado de error en las clases minoritarias. En virtud de que estas clases son relativamente pequeñas, entonces la afectación en ciertos criterios de evaluación como la precisión o exactitud es inadecuada. Por ejemplo, si tomamos el caso de una muestra desbalanceada en donde existe un total de 98% de casos donde la variable dependiente es igual a cero y 2% de los casos son iguales a uno (clase minoritaria), cuando el modelo predice a todos los casos que son igual a cero, entonces tendría una exactitud del 98%. En principio parece ser una exactitud alta, sin embargo, el total de los casos raros están mal clasificados. Es por esto que también se utiliza una evaluación distinta de los diferentes modelos como la Curva ROC y su área bajo la curva AUC 7. La curva ROC se forma al graficar la Tasa de Verdaderos Positivos (TPR = verdaderos positivos / positivos) contra la Tasa de Falsos Positivos (FPR= falsos positivos / positivos). Por ejemplo, si tenemos 10 individuos en una muestra donde 9 de ellos son positivos y 1 es negativo, entonces TPR=1 y FPR = 1. Esto representa un par ordenado sobre la diagonal indicando una mala clasificación debido a la muestra desbalanceada.

Al identificarse las distorsiones que pueden conllevar una muestra desbalanceada para modelos de predicción como Logit, se han generado alternativas que tratan de solucionar estos problemas, estas soluciones abordan el desbalance desde diferentes visiones.

Muchas alternativas se han presentado con respecto a las muestras desbalanceadas y una de las pioneras en buscar una solución a este problema es SMOTE (Synthetic Minority Over-sampling Technique) 6, donde se combinan enfoques de sobre-muestreo y sub-muestreo. No obstante, han surgido diferentes variantes de SMOTE que buscan mejorar el rendimiento de este algoritmo desde distintos puntos de vista y modificaciones. Una de estas propuestas es la de 8 donde el algoritmo ADASYN (Adaptive Synthetic) utiliza una distribución no uniforme para la creación de individuos sintéticos de la clase minoritaria en función de la proporción del número de vecinos cercanos que encuentra por individuo. Otro enfoque para tratar de contrarrestar los efectos de los datos desbalanceados son las matrices de costo, es decir, ponderar los costos de predecir mal una clase. El trabajo de 9 analiza este punto de vista basándose en técnicas de curvas de costo donde se modifica el sobre-muestreo y el sub-muestreo con algoritmos de aprendizaje basados en un árbol de decisión.

SMOTE: Synthetic Minority Over-sampling Technique

Cuando se trabaja con muestras en el que la falta de datos de interés clasificados con uno es escasa, se dificulta la detección de regularidades dentro de los casos raros (clase minoritaria) 6. Es por esto que en 10 se propone una metodología que combina el sobre-muestreo y el sub-muestreo de las diferentes clases. SMOTE es un algoritmo donde lo que prima es la creación de individuos sintéticos a partir de individuos de la clase minoritaria. Esto se realiza determinando, en primera instancia, una vecindad entre los individuos cercanos. Un nuevo individuo es creado al tomar la distancia entre los individuos de la misma vecindad y esta distancia se multiplica por un valor aleatorio entre 0 y 1. Por un lado, como resultado se obtiene una clase minoritaria aumentada dependiendo el número de individuos sintéticos que se escoja aumentar por cada individuo observado. Por otro lado, se puede sub muestrear a la clase mayoritaria de forma que se escoge una muestra aleatoria menor de esta clase lo que a la final equilibra las proporciones de las diferentes clases y así se eliminan las distorsiones por el no balanceo de las clases.

El algoritmo de SMOTE ha demostrado tener un mejor rendimiento medido con el indicador de la curva ROC y el área bajo la curva AUC con respecto a la multiplicación aleatoria de los individuos de la clase minoritaria. Esto debido a que entre sus ventajas se destaca el que permite hacer que el clasificador construya regiones de decisión más grandes que contienen puntos cercanos de la clase minoritaria. Esto facilita al modelo crear regiones de decisión más amplias, esto conlleva a una mayor cobertura de la clase minoritaria 10.

Corrección previa.

Dentro del análisis de eventos raros para modelos logit, en 3 se menciona la corrección de previa. Aquí se aborda a las muestras desbalanceadas desde un enfoque post estimación. Los autores mencionan una corrección del término constante en donde se calcula un nuevo β0 en función de la proporción de la clase minoritaria τ y el promedio del y ȳ estimado 11. La correción de la constante se muestra en la ecuación (1):

Una de las ventajas de la implementación de esta corrección es la facilidad de implementación. Además, todos sus parámetros pueden ser calculados de forma sencilla. Sin embargo, se ha mostrado que en caso de que no exista una correcta especificación en el modelo los estimadores βi son menos robustos 12.

Enfoque al Big Data.

En la actualidad las mejoras tecnológicas en infraestructura y la reducción de los costos de recolección de datos han permitido que se puedan generar bases con un gran número de datos 13. La minería de datos se genera en diferentes sitios cada día como es el caso de Redes Sociales 14 o Centro Meteorológicos 15. Por lo tanto, muchos investigadores están trabajando en la creación de nuevos y mejores algoritmos de agrupamiento que buscan manejar datos más complejos y extensos en que se reduzca el costo computacional y por tanto aumentar la escalabilidad y la velocidad de procesamiento 16.

Los problemas de datos desbalanceados también pueden afectar a las grandes bases de datos, y por tanto la aplicación de técnicas estadísticas puede ser desafiante 17. No obstante, el problema puede no solo presentarse por el costo computacional sino también por la naturaleza del problema que causa el desbalance. Esto se plantea en 18 donde se menciona que en las futuras investigaciones sobre datos desbalanceados se deberá tener en cuenta el abordar el problema de Big Data y a su vez la descomposición de múltiples clases. Para el problema multiclase, en 19 proponen usar diferentes esquemas de binarización y ad-hoc, pero esto puede limitar el panorama multiclase.

Como se ha mencionado, el algoritmo SMOTE utiliza un tipo de clustering que busca los k vecinos más cercanos (KNN) entre los individuos de la clase minoritaria 20. En 21 se menciona que SMOTE es uno de los algoritmos más populares para abordar las bases de datos desbalanceadas. La lógica de elaborar clusters con KNN utiliza la distancia euclidiana, la cual no trabaja con variables categóricas. Es por esto que este trabajo presenta una alternativa para trabajar con variables mixtas (cuantitativas y cualitativas) y también con un volumen grande de datos. En 22 se presenta un algoritmo llamado CLARABD para el lenguaje R 23 donde se utiliza un agrupamiento de k-medoides y la implementación de la distancia de Gower que trabaja con datos mixtos, al mismo tiempo que permite superar la barrera de 65536 observaciones que actualmente tiene el software para k-medoides.

En este contexto, la propuesta de este trabajo, SMOTEMD, permite balancear muestras desbalanceadas con datos mixtos (de ahí el sufijo MD, de Mixed Data, agregado a SMOTE) y superar la limitante de 65536 observaciones que tiene el software R para la clase minoritaria.

II. MATERIALES Y MÉTODOS

SMOTEMD es una extensión del algoritmo SMOTE para datos mixtos al mismo tiempo que permite trabajar con más de 65536 observaciones en la clase minoritaria de los datos desbalanceados.

La Tabla 1 muestra una matriz de confusión como ejemplo para ilustrar SMOTEMD.

Tabla 1. Matriz de confusión 

De la Tabla 1 se puede obtener los siguientes indicadores de clasificación:

  • • Precisión = 80/(10+70)=80%

  • • Especificidad = 15/(15+70) = 18%

  • • Sensibilidad = 10/(10+5)=67%.

Una inspección ingenua de estos resultados tomaría en cuenta únicamente los resultados de la precisión, pese a que claramente un indicador más adecuado para este ejemplo es la especificidad. Es decir, debido a que se trata de datos no balanceados (15% de observaciones igual a 1), se presenta una paradoja en el indicador de precisión debido a que es muy elevado, pero no recoge la realidad de los datos analizados.

Para solventar este problema, SMOTE y SMOTEMD realizan un sobre muestreo de la clase minoritaria (cuando la respuesta es igual a 1 en el ejemplo) tal que se generan individuos sintéticos. La Figura 1 muestra el problema inicial, donde el color rojo es la clase minoritaria.

Figura 1 Tiempo de Retardo y Dimensión de Encaje 

Luego, la Figura 2 muestra los individuos sintéticos que son generados mediante combinaciones lineales convexas de los individuos más cercanos. De la distancia que separa a los vecinos más cercanos se toma un valor aleatorio con distribución uniforme entre 0 y 1 para obtener observaciones sintéticas (puntos rojos ubicados sobre las lineas de los datos originales).

Figura 2 Dispersión de puntos que ilustra la clase minoritaria y la generación de datos sintéticos 

El algoritmo SMOTE únicamente permite trabajar con datos numéricos, mientras que con SMOTEMD es posible usar datos mixtos usando la distancia de Gower. Esta distancia realiza una estandarización específica para cada tipo de variable (cualitativa o cuantitativa) y luego se calcula un promedio de todas las variables estandarizadas 24.

III. RESULTADOS

Para estudiar la propuesta SMOTEMD, se realizan dos escenarios de simulación. En el primer experimento de simulación se evalúa la sensibilidad y especificidad de los modelos: logit, corrección de constante y SMOTEMD. En el segundo experimento se realizan varias estimaciones del estadístico Kolmogorov Smirknov (KS) para tener una referencia del poder de discriminación de SMOTEMD.

Simulación A

En este experimento se simulan 50000 datos con dos covariables categóricas donde la tasa de respuesta de la variable dependiente es 1.6% que representa los datos no balanceados. Esta configuración se itera 1000 veces para obtener distribuciones de los indicadores estudiados. Las Figuras 3 y 4 muestran los resultados de los indicadores de sensibilidad y especificidad para los modelos logit (Original), corrección de constante (Corregido) y SMOTEMD.

Figura 3 Densidad del indicador de sensibilidad 

Figura 4 Densidad del indicador de especificidad 

La Tabla 2 muestra los promedios de cada indicador.

Tabla 2. Promedio de indicadores de Sensibilidad (Sen) y Especificidad (Esp). 

Por un lado, se puede apreciar que el indicador de sensibilidad es ligeramente menor para SMOTEMD. Por otro lado, la ganancia adquirida en especificidad es muy superior que sus competidores. Al comparar estas evidencias, se puede concluir que SMOTEMD es un algoritmo superior para trabajar con datos desbalanceados.

Simulación B

En este experimento se simulan 100000 datos con cinco covariables numéricas donde la tasa de respuesta de la variable dependiente es 0.1%, 2.1% y 6.1% que representa los datos no balanceados y se puede apreciar la sensibilidad de los métodos ante cambios en la tasa de respuesta. Esta configuración se itera 300 veces para obtener distribuciones del estadístico KS para evaluar el poder de discriminación de los métodos. Las Figuras 5, 6 y 7 muestran los resultados para cada tasa de respuesta.

Figura 5 Histograma del estadístico KS con tasa de respuesta 0.1% 

Figura 6 Histograma del estadístico KS con tasa de respuesta 2.1% 

Figura 7 Histograma del estadístico KS con tasa de respuesta 6.1% 

La Figura 5 muestra que, para una tasa de respuesta de 0.1%, SMOTEMD tiene valores menores que SMOTE y ligeramente superior al enfoque logit (Original). Las Figuras 6 y 7 favorecen al algoritmo SMOTEMD debido a que el KS resultante es mayor o presenta menor varianza que sus competidores.

IV. DISCUSIÓN

La simulación 1 se alinea con los resultados obtenidos en 10 debido a que los indicadores de sensibilidad y especificidad son mejores al usar SMOTEMD.

La eficiencia computacional de SMOTEMD depende de, al menos, dos elementos. Por un lado, si se trabaja con menos de 65536 observaciones, el tiempo de cómputo está acotado por la eficiencia del cálculo de la distancia de Gower en R. Por otro lado, al superar este número de observaciones, depende del número de submuestras y su tamaño. Esto puede ser potenciado mediante el uso de funciones wrappers donde se use lenguajes de más bajo nivel como C o Fortran.

Se pudo apreciar que SMOTEMD tiene un rendimiento ligeramente mejor en tasas de respuesta pequeñas. Esto puede deberse al proceso de estandarización que tienen las variables ayudando a la reducción de la volatilidad observada.

Un posible escenario desfavorable para SMOTEMD es el aumento en la tasa de respuesta. Tal parece que, al aumentarla, se aprecia cada vez menos su diferencia con el algoritmo tradicional SMOTE. No obstante, el manejo de datos mixtos de SMOTEMD seguiría siendo un aporte.

Cabe indicar que, para efectos de replicabilidad, el código de programación para obtener los resultados de ambas simulaciones se encuentra disponibles en https://github.com/vmoprojs/ArticleCodes.

V. CONCLUSIONES

Se ha mostrado la superioridad del algoritmo SMOTEMD en cuanto a sensibilidad y especificidad. Esta propiedad es heredada de manera directa por SMOTE.

En el caso de que se requiera balancear los datos para realizar predicciones, en términos generales el estadístico KS que se estudia en la simulación 2 presenta mejores propiedades en SMOTEMD que sus competidores, tanto en media como en varianza. No obstante, para el escenario donde la tasa de respuesta es de 0.1%, el algoritmo SMOTE original es mejor.

Es importante notar que SMOTEMD puede ser usado cuando se tiene más de 65536 observaciones, lo cual es una propiedad que lo enmarca en un contexto Big Data en R.

VI. AGRADECIMIENTOS

Los autores agradecen al grupo de investigación Data Science Research Group CIDED de la Escuela Superior Politécnica de Chimborazo. Víctor Morales-Oñate y Bolívar Morales-Oñate pertenecen al grupo.

REFERENCIAS

1. Wei W, Li J, Cao L, Ou Y, Chen J. Effective detection of sophisticated online banking fraud on extremely imbalanced data. World Wide Web. Internet. 16, 449-475. 2013. Disponible en: https://doi.org/10.1007/s11280-012-0178-0. [ Links ]

2. Van Deusen P, Irwin L. A robust weighted EM algorithm for use-availability. Environ Ecol Stat. Internet. 19, 205-217 (2012). Disponible en: https://doi.org/10.1007/s10651-011-0182-z. [ Links ]

3. King G, Zeng L. Logistic Regression in Rare Events Data. The Society for Political Methodology. Internet. 9 (2) 2001. 137-163. Disponible en: 10.1093/oxfordjournals.pan.a004868 [ Links ]

4. Kitchenham BA procedure for analyzing unbalanced datasets. IEEE transactions on Software Engineering. Internet. 24 (4) 1998: 278-301. Disponible en: 10.1109/32.677185. [ Links ]

5. Baesens B, Van Vlasselaer V, Verbeke W. Fraud analytics using descriptive, predictive, and social network techniques: a guide to data science for fraud detection. Estados Unidos: John Wiley & Sons, 2015. [ Links ]

6. Weiss GM. Mining with rarity: a unifying framework. ACM SIGKDD Explorations Newsletter. Internet. 2004: 7-19. Disponible en: https://doi.org/10.1145/1007730.1007734 [ Links ]

7. Bradley AP. The use of the area under the ROC curve in the evaluation of machine learning algorithms. Pattern recognition. Internet. 30 (7) 1997: 1145-1159. Disponible en: https://doi.org/10.1016/S0031-3203(96)00142-2 [ Links ]

8. He H, Bai Y, Garcia EA, Li S. ADASYN: Adaptive Synthetic Sampling Approach for Imbalanced Learning. International Joint Conference on Neural Networks. 2008: 1322-1328. Internet Disponible en: 10.1109/IJCNN.2008.4633969 [ Links ]

9. Drummond C, Holte RC. C4.5, Class Imbalance, and Cost Sensitivity: Why Under-Sampling beats Over-Sampling. Workshop on learning from imbalanced datasets II.. Washington, DC: Citeseer. 2003. Internet Disponible en: https://api.semanticscholar.org/CorpusID:204083391Links ]

10. Chawla NV, Bowyer KW, Hall LO, Philip-Kegelmeye W. SMOTE: Synthetic Minority Over-sampling Technique. Journal of Artificial Intelligence Research. Internet. 2002: 321-357. Disponible en: https://doi.org/10.1613/jair.953 [ Links ]

11. Manski C, Lerman S. The Estimation of Choice Probabilities from Choice Based Samples. Econometrica 45 (8). 1977: 1977-1988. Disponible en: https://doi.org/10.2307/1914121 [ Links ]

12. He H, García EA. Learning from imbalanced data. IEEE Transactions on knowledge and data engineering. Internet. 21 (9) 2009: 1263-1284. Disponible en: 10.1109/TKDE.2008.239 [ Links ]

13. Lynch C. How do your data grow?. Nature. 455, 28-29 (2008). https://doi.org/10.1038/455028a. [ Links ]

14. Hurtado J, Taweewitchakreeya N, Kong X, Zhu X. A Classifier Ensembling Approach For Imbalanced Social Link Prediction. International Conference on Machine Learning and Applications.. USA, Miami, FL. 2013, 436-439. Internet Disponible en: 10.1109/ICMLA.2013.88. [ Links ]

15. Yoon HJ. Development of Contents on the Marine Meteorology Service by Meteorology and Climate Big Data. The Journal of the Korea institute of electronic communication sciences. Internet. 11(2):125-138. 2016. Disponible en: 10.13067/JKIECS.2016.11.2.125 [ Links ]

16. Shirkhorshidi AS, Aghabozorgi S, Wah TY, Herawan T. Big Data Clustering: A Review. Murgante B. et al. (eds) Computational Science and Its Applications - ICCSA 2014. Internet. Vol. 8583. Disponible en: https://doi.org/10.1007/978-3-319-09156-3_49 [ Links ]

17. Sahin Y, Duman E. Detecting credit card fraud by ANN and logistic regression. International Symposium on Innovations in Intelligent Systems and Applications. Istanbul, Turkey. 2011: 315-319. Internet Disponible en: 10.1109/INISTA.2011.5946108 [ Links ]

18. Krawczyk B. Learning from imbalanced data: open challenges and future directions. Prog Artif Intell. Internet. 5, 221-232. 2016. Disponible en: https://doi.org/10.1007/s13748-016-0094-0. [ Links ]

19. Fernández A, López V, Galar M, del Jesus MJ, Herrera F. Analysing the classification of imbalanced data-sets with multiple classes: Binarization techniques and ad-hoc approaches. Knowledge-Based Systems. Internet. 2013: 97-110. Disponible en: doi.org/10.1016/j.knosys.2013.01.018. [ Links ]

20. Silverman BW, Jones MC. An important contribution to nonparametric discriminant analysis and density estimation: Commentary on Fix and Hodges (1951). International Statistical Review/Revue Internationale de Statistique. Internet. 57 (3) 1989: 233-238. Disponible en: https://doi.org/10.2307/1403796 [ Links ]

21. Skryjomski P, Krawczyk B. Influence of minority class instance types on SMOTE imbalanced data oversampling. Proceedings of Machine Learning Research. Internet. 74. 7-21. 2017. Disponible en: https://proceedings.mlr.press/v74/skryjomski17a.html. [ Links ]

22. Morales-Oñate V, Morales-Oñate B. A robust clustering technique for a Big Data approach: CLARABD for Mixed data types. Perfiles. Internet. 2020. Disponible en: http://dspace.espoch.edu.ec/handle/123456789/11225Links ]

23. R.C. Team. R: A language and environment for statistical computing. Vienna. Internet. 2014. Disponible en: https://www.R-project.org/. [ Links ]

24. Borra B, Rohit T, Nilanjan D. Satellite Image Analysis: Clustering and Classification. de Satellite Image Analysis: Clustering and Classification. Internet. Estados Unidos, Springer. 2019: 53-81. Disponible en: https://doi.org/10.1007/978-981-13-6424-2 [ Links ]

25. Bischl B, Lang M, Kotthoff M, Schiffner J, Richter J, Studerus E, Casalicchio G, Jones Z. OpenML: An R package to connect to the machine learning platform OpenML. Comput Stat. Internet. 34, 977-991 (2019). Disponible en: https://doi.org/10.1007/s00180-017-0742-2 [ Links ]

Recibido: 18 de Enero de 2020; Aprobado: 31 de Marzo de 2020

Creative Commons License Este es un artículo publicado en acceso abierto bajo una licencia Creative Commons