IMPORTANT Update and Model information !
A newer, enhanced version of this model is now available: HateSpeech-BETO-cased-v2. This updated version offers significantly improved performance, addressing real-world challenges with greater accuracy and reliability.
We strongly recommend using this other second fine-tuned version, which has been specifically optimized to better detect nuanced forms of hate speech in Spanish. Explore the improved model here: 👉 HateSpeech-BETO-cased-v2.
HateSpeech-BETO-cased-v1
This model is a fine-tuned version of dccuchile/bert-base-spanish-wwm-cased for hate speech detection related to racism, homophobia, sexism, and other forms of discrimination in Spanish text. It is trained on the dataset Paul/hatecheck-spanish.
The text classification task in this model is based on 2 sentiment labels: hateful and non-hateful.
Full classification example:
from transformers import pipeline
pipe = pipeline(model="delarosajav95/HateSpeech-BETO-cased-v1")
inputs = ["El camarero a cargo del bar era demasiado afeminado, se notaba que la manera de moverse no era la propia de un hombre.",
"La manera en que me miraba tan desagradable era porque era una persona del sur.",
"Estoy cansado de que las mujeres se pongan falda y vayan provocando por ahí a toda persona normal y corriente."
]
result = pipe(inputs, return_all_scores=True)
label_mapping = {"LABEL_0": "Hateful", "LABEL_1": "Non-hateful"}
for i, predictions in enumerate(result):
print("==================================")
print(f"Text {i + 1}: {inputs[i]}")
for pred in predictions:
label = label_mapping.get(pred['label'], pred['label'])
score = pred['score']
print(f"{label}: {score:.2%}")
Output:
==================================
Text 1: El camarero a cargo del bar era demasiado afeminado, se notaba que la manera de moverse no era la propia de un hombre.
Hateful: 99.98%
Non-hateful: 0.02%
==================================
Text 2: La manera en que me miraba tan desagradable era porque era una persona del sur.
Hateful: 99.98%
Non-hateful: 0.02%
==================================
Text 3: Estoy cansado de que las mujeres se pongan falda y vayan provocando por ahí a toda persona normal y corriente.
Hateful: 99.84%
Non-hateful: 0.16%
Metrics and results:
It achieves the following results on the evaluation set (last epoch):
- 'eval_loss': 0.03607647866010666
- 'eval_accuracy': 0.9933244325767691
- 'eval_precision_per_label': [1.0, 0.9905123339658444]
- 'eval_recall_per_label': [0.9779735682819384, 1.0]
- 'eval_f1_per_label': [0.9888641425389755, 0.9952335557673975]
- 'eval_precision_weighted': 0.9933877681310691
- 'eval_recall_weighted': 0.9933244325767691
- 'eval_f1_weighted': 0.9933031728530427
- 'eval_runtime': 1.7545
- 'eval_samples_per_second': 426.913
- 'eval_steps_per_second': 53.578
- 'epoch': 4.0
It achieves the following results on the test set:
- 'eval_loss': 0.052769944071769714
- 'eval_accuracy': 0.9933244325767691
- 'eval_precision_per_label': [0.9956140350877193, 0.9923224568138196]
- 'eval_recall_per_label': [0.9826839826839827, 0.9980694980694981]
- 'eval_f1_per_label': [0.9891067538126361, 0.9951876804619827]
- 'eval_precision_weighted': 0.9933376164683867
- 'eval_recall_weighted': 0.9933244325767691
- 'eval_f1_weighted': 0.993312254486016
Training Details and Procedure
Main Hyperparameters:
- evaluation_strategy: "epoch"
- learning_rate: 1e-5
- per_device_train_batch_size: 8
- per_device_eval_batch_size: 8
- num_train_epochs: 4
- optimizer: AdamW
- weight_decay: 0.01
- save_strategy: "epoch"
- lr_scheduler_type: "linear"
- warmup_steps: 449
- logging_steps: 10
Preprocessing and Postprocessing:
- Needed to manually map dataset creating the different sets: train 60%, validation 20%, and test 20%.
- Seed=42
- Num labels = 2
- Needed to manually map dataset's labels, from str ("hateful", "non-hateful") to int (0,1), in order to properly create tensors.
- Dynamic Padding through DataCollator was used.
Framework versions
- Transformers 4.47.0
- Pytorch 2.5.1+cu121
- Datasets 3.2.0
- Tokenizers 0.21.0
CITATION:
@inproceedings{CaneteCFP2020,
title={Spanish Pre-Trained BERT Model and Evaluation Data},
author={Cañete, José and Chaperon, Gabriel and Fuentes, Rodrigo and Ho, Jou-Hui and Kang, Hojin and Pérez, Jorge},
booktitle={PML4DC at ICLR 2020},
year={2020}
}
More Information
- Fine-tuned by Javier de la Rosa Sánchez.
- [email protected]
- https://www.linkedin.com/in/delarosajav95/
- Downloads last month
- 279
Model tree for delarosajav95/HateSpeech-BETO-cased-v1
Base model
dccuchile/bert-base-spanish-wwm-cased