Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/christianconchari/tp_final_amq1_fraud_dataset
https://github.com/christianconchari/tp_final_amq1_fraud_dataset
Last synced: about 1 month ago
JSON representation
- Host: GitHub
- URL: https://github.com/christianconchari/tp_final_amq1_fraud_dataset
- Owner: ChristianConchari
- Created: 2024-06-22T15:36:12.000Z (7 months ago)
- Default Branch: master
- Last Pushed: 2024-06-23T22:25:54.000Z (7 months ago)
- Last Synced: 2024-06-24T04:19:38.238Z (7 months ago)
- Language: Jupyter Notebook
- Size: 34.7 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# TP Final Aprendizaje de Máquina I - IEEE-CIS Fraud Detection
Este repositorio contiene el trabajo práctico final de la materia Aprendizaje de Máquina I de la Especialización en Inteligencia Artificial (CEIA) de la Facultad de Ingeniería de la Universidad de Buenos Aires (FIUBA).
Para este trabajo práctico se abordó la tarea de la predicción de transacciones fraudulentas en tarjetas de crédito. El dataset utilizado es provisto por Vesta Corporation y contiene un conjunto de datos de transacciones de comercio electrónico, con el objetivo de predecir si una transacción es fraudulenta o no. El dataset fue obtenido de la competencia de Kaggle [IEEE-CIS Fraud Detection](https://www.kaggle.com/c/ieee-fraud-detection) [1].
# Estrategia de resolución
Para resolver el problema de clasificación de transacciones fraudulentas, se implementaron diferentes modelos de aprendizaje supervisado. Se realizaron tareas de preprocesamiento y exploración de datos, ingeniería de features, selección de modelos y ajuste de hiperparámetros. De esa manera, se utilizaron varios notebooks para dividir el trabajo en diferentes etapas.
0. [Análisis del Caso de Estudio](case_study_analysis.md): En este archivo markdown se buscó describir el problema y se detallar las características del dataset. También se justificó la elección de la métrica de evaluación bajo el contexto del problema de detección de fraudes y el desbalanceo de clases en el dataset.
1. [Análisis exploratorio de datos](notebooks/data_exploration_notebook.ipynb): En este notebook se realizó un análisis exploratorio de los datos, se identificaron patrones y se visualizaron las distribuciones de las variables. Se analizaron las variables categóricas y numéricas, se estudiaron las correlaciones y se identificaron posibles features relevantes para la predicción.
2. [Ingeniería de features](notebooks/feature_engineering_notebook.ipynb): En este notebook se realizaron tareas de preprocesamiento y limpieza de datos. Se crearon nuevas features a partir de las variables existentes, se imputaron valores faltantes y se codificaron las variables categóricas.
3. [LightGBM](notebooks/lightgbm_model_notebook.ipynb): En este notebook se implementó un modelo de Gradient Boosting utilizando la librería LightGBM. Se empleo el dataset de entrenamiento dividido en un conjunto de entrenamiento y otro de validación para ajustar los hiperparámetros del modelo. También se obtuvo el archivo [submission_lightgbm.csv](submissions/submission_lightgbm.csv) con las predicciones del modelo en el conjunto de test.
4. [XGBoost](notebooks/xgboost_notebook.ipynb): En este notebook se implementó un modelo de Gradient Boosting utilizando la librería XGBoost. De manera similar al caso anterior, se ajustaron los hiperparámetros del modelo y se obtuvo el archivo [submission_xgboost.csv](submissions/submission_xgboost.csv) con las predicciones del modelo en el conjunto de test.
# Resultados del Modelo
### Comparación de Modelos en el Dataset IEEE-CIS Fraud
| Métrica | Modelo LightGBM | Modelo XGBoost |
|---------------------|------------------|-----------------------|
| Exactitud | 0.9792 | 0.9854 |
| Precisión (Clase 0) | 0.9807 | 0.9872 |
| Recall (Clase 0) | 0.9981 | 0.9979 |
| F1-Score (Clase 0) | 0.9893 | 0.9925 |
| Precisión (Clase 1) | 0.8956 | 0.9169 |
| Recall (Clase 1) | 0.4581 | 0.6424 |
| F1-Score (Clase 1) | 0.6062 | 0.7555 |
| AUC de Validación | 0.9409 | 0.9587 |
| Tiempo de Inferencia| 5.726 segundos | 50.936 segundos |
| Tamaño del Modelo | 0.82 MB | 22.21 MB |### Curvas ROC de los Modelos
LightGBM
XGBoost
### Resultados empleando el conjunto de prueba
Para evaluar los modelos empleando el conjunto de test provisto por la competencia de Kaggle, se realizo la carga de los archivos de predicciones y se obtuvieron los siguientes resultados:
| Archivo | Private Score | Public Score |
|---------------------------|---------------|--------------|
| submission_lightgbm.csv | 0.885567 | 0.918826 |
| submission_xgboost.csv | 0.863551 | 0.903624 |# Conclusiones
En este trabajo práctico se abordó el problema de la detección de fraudes en transacciones de tarjetas de crédito utilizando un dataset provisto por Vesta Corporation. Se implementaron dos modelos de Gradient Boosting, LightGBM y XGBoost, para clasificar transacciones como fraudulentas o no fraudulentas. Tras realizar preprocesamiento, ingeniería de features y ajuste de hiperparámetros, se obtuvieron resultados prometedores en términos de métricas de evaluación y curvas ROC.
El modelo LightGBM obtuvo un AUC de 0.9409 en el conjunto de validación, con un tiempo de inferencia de 5.726 segundos y un tamaño de modelo de 0.82 MB. Por otro lado, el modelo XGBoost logró un AUC de 0.9587, un tiempo de inferencia de 52.976 segundos y un tamaño de modelo de 22.21 MB. Aunque ambos modelos presentan un buen rendimiento, el modelo LightGBM se destaca por su menor tiempo de inferencia y tamaño de modelo. Además, en el conjunto de test, LightGBM mostró un mejor desempeño en comparación con XGBoost.
Es importante notar que el desbalanceo de clases en el dataset puede afectar el rendimiento de los modelos, particularmente en términos de recall y F1-Score para la clase minoritaria. En este aspecto, XGBoost presenta un mejor rendimiento en recall y F1-Score para la clase minoritaria, aunque con un mayor costo en tiempo de inferencia y tamaño de modelo.
En conclusión, ambos modelos son efectivos en la detección de fraudes. Sin embargo, LightGBM es preferible debido a su menor tiempo de inferencia y tamaño de modelo, manteniendo un buen rendimiento en la métrica de evaluación principal, el AUC. Por lo tanto, se considera que LightGBM es la mejor opción para este trabajo práctico.
# References
[1] A. Howard, B. Bouchon-Meunier, IEEE CIS, inversion, J. Lei, Lynn@Vesta, Marcus2010, and Prof. H. Abbass, "IEEE-CIS Fraud Detection," Kaggle, 2019. [Online]. Available: https://kaggle.com/competitions/ieee-fraud-detection.