--- license: mit model-index: - name: xlm-roberta-base-offensive-text-detection-da results: [] widget: - text: "Din store idiot" --- # Danish Offensive Text Detection based on XLM-Roberta-Base This model is a fine-tuned version of [xlm-roberta-base](https://huggingface.co/xlm-roberta-base) on a dataset consisting of approximately 5 million Facebook comments on [DR](https://dr.dk/)'s public Facebook pages. The labels have been automatically generated using weak supervision, based on the [Snorkel](https://www.snorkel.org/) framework. The model achieves SOTA on a test set consisting of 600 Facebook comments annotated using majority vote by three annotators, of which 35.8% were labelled as offensive: | **Model** | **Precision** | **Recall** | **F1-score** | **F2-score** | | :-------- | :------------ | :--------- | :----------- | :----------- | | `alexandrainst/xlm-roberta-base-offensive-text-detection-da` (this) | 74.81% | **89.77%** | **81.61%** | **86.32%** | | [`alexandrainst/electra-small-offensive-text-detection-da`](https://huggingface.co/alexandrainst/electra-small-offensive-text-detection-da) | 74.13% | 89.30% | 81.01% | 85.79% | | [`A&ttack`](https://github.com/ogtal/A-ttack) | **97.32%** | 50.70% | 66.67% | 56.07% | | [`DaNLP/da-electra-hatespeech-detection`](https://huggingface.co/DaNLP/da-electra-hatespeech-detection) | 86.43% | 56.28% | 68.17% | 60.50% | | [`Guscode/DKbert-hatespeech-detection`](https://huggingface.co/Guscode/DKbert-hatespeech-detection) | 75.41% | 42.79% | 54.60% | 46.84% | ## Using the model You can use the model simply by running the following: ```python >>> from transformers import pipeline >>> offensive_text_pipeline = pipeline(model="xlm-roberta-base-offensive-text-detection-da") >>> offensive_text_pipeline("Din store idiot") [{'label': 'offensive', 'score': 0.9874388575553894}] ``` Processing multiple documents at the same time can be done as follows: ```python >>> offensive_text_pipeline(["Din store idiot", "ej hvor godt :)"]) [{'label': 'offensive', 'score': 0.9874388575553894}, {'label': 'not offensive', 'score': 0.999760091304779}] ``` ## Training procedure ### Training hyperparameters The following hyperparameters were used during training: - learning_rate: 2e-05 - train_batch_size: 32 - eval_batch_size: 32 - gradient_accumulation_steps: 1 - total_train_batch_size: 32 - seed: 4242 - optimizer: Adam with betas=(0.9,0.999) and epsilon=1e-08 - lr_scheduler_type: linear - max_steps: 500000 - fp16: True - eval_steps: 1000 - early_stopping_patience: 100 ### Framework versions - Transformers 4.20.1 - Pytorch 1.11.0+cu113 - Datasets 2.3.2 - Tokenizers 0.12.1