File size: 4,388 Bytes
cf5e25c d10bbc5 cf5e25c d10bbc5 cf5e25c d10bbc5 f92b969 7a0b1ff d10bbc5 f92b969 d10bbc5 f92b969 d10bbc5 7a0b1ff d10bbc5 f92b969 d10bbc5 f92b969 d10bbc5 f92b969 d10bbc5 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 |
---
datasets:
- thehamkercat/telegram-spam-ham
- ucirvine/sms_spam
- SetFit/enron_spam
base_model:
- FacebookAI/roberta-base
pipeline_tag: text-classification
license: mit
language:
- en
metrics:
- accuracy
results:
- task:
type: text-classification
dataset:
name: ucirvine/sms_spam
metrics:
- name: Accuracy
type: Test-Data Accuracy
value: 95.03%
source:
name: Validation via ucirvine/sms_spam dataset in Google Collab
library_name: transformers
---
# Is Spam all we need? A RoBERTa Based Approach To Spam Detection
## Intro
This is inspired largely by mshenoda's roberta spam huggingFace model (https://huggingface.co/mshenoda/roberta-spam).
However, instead of fine-tuning it on all the data sources that the original author had, I only finetuned using the telegram and enron spam/ham datasets. The idea behind this was a more diversified data source, preventing overfitting to the original distribution, and just a fun NLP exploratory experiment. This was fine-tuned by replicating the sentiment analysis Google collab example provided in the Roberta resources page (https://huggingface.co/docs/transformers/main/en/model_doc/roberta#resources) Google collab example.
**NOTE**: This was done for an interview project, so if you find this by chance... hopefully it helps you too, but know there's **definitely** better resources out there... and that this was done in the span of one evening.
## Metrics
**Accuracy**: 0.9503
Thrilling, I know, I also just got the chills, especially since my performance is arguably worse than the original authors 😂
Granted, I only ran it for one epoch, and the data is taken from different distributions. I'm sure it would've been more "accurate" if I had just trained it on the SMS data, but diversity is good. And, it's fun to see how stuff impacts the final result!
## Model Output
- 0 is ham
- 1 is spam
## Dataset(s)
The dataset is composed of messages labeled by ham or spam (0 or 1), merged from *two* data sources:
1. Telegram Spam Ham https://huggingface.co/datasets/thehamkercat/telegram-spam-ham/tree/main
2. Enron Spam: https://huggingface.co/datasets/SetFit/enron_spam/tree/main (only used message column and labels)
The dataset used for testing was the original kaggle competition (as part of the interview project that this was for)
1. SMS Spam Collection https://www.kaggle.com/datasets/uciml/sms-spam-collection-dataset
## Dataset Class Distribution
| | Total | Training | Testing |
|:--------:|:-----:|:--------------:|:-----------:|
| Counts | 59267 | 53693 (90.6% ) | 5574 (9.4%) |
| | Total | Spam | Ham | Set | % Total |
|:--------:|:-----:|:-------------:|:-------------:|:-----:|:-------:|
| Enron | 33345 | 16852 (50.5%) | 16493 (49.5%) | Train | 56.2% |
| Telegram | 20348 | 6011 (29.5%) | 14337 (70.5%) | Train | 43.8% |
| SMS | 5574 | 747 (13.5%) | 4827 (86.5%) | Test | 100% |
| | Distribution of number of characters per class label (100 bins) | Distribution of number of words per class label (100 bins) |
|:--------:|:---------------------------------------------------------------:|:----------------------------------------------------------:|
| SMS | ![image/png ](https://cdn-uploads.huggingface.co/production/uploads/644ef0eb1565b54e4a656946/OjLvujmQyeQPlowW5lI5A.png) | ![image/png](https://cdn-uploads.huggingface.co/production/uploads/644ef0eb1565b54e4a656946/RFs92xoeIUDAsry6T1Ec4.png) |
| Enron (limiting a few outliers) | ![image/png](https://cdn-uploads.huggingface.co/production/uploads/644ef0eb1565b54e4a656946/Gd7le3W2U05DaQtjb971o.png) | ![image/png](https://cdn-uploads.huggingface.co/production/uploads/644ef0eb1565b54e4a656946/A40RySWIPWAcwSyKGh-rm.png) |
| Telegram | ![image/png](https://cdn-uploads.huggingface.co/production/uploads/644ef0eb1565b54e4a656946/ZqMEzunZbhwqOkBUpzv81.png) | ![image/png](https://cdn-uploads.huggingface.co/production/uploads/644ef0eb1565b54e4a656946/v0Y3MRgXUjRUX0prULu0v.png) |
^ Note the tails, very interesting distributions. But more so, good to see [Benford's law](https://en.wikipedia.org/wiki/Benford's_law) is alive and well in these.
## Architecture
The model is fine tuned RoBERTa
roberta-base: https://huggingface.co/roberta-base
paper: https://arxiv.org/abs/1907.11692
## Code
TODO: Include Jupyter / code on Github |