/Hatemoji

Testing and training detection models for emoji-based hate speech.

Primary LanguagePythonCreative Commons Attribution 4.0 InternationalCC-BY-4.0

Hatemoji

This repo contains the two datasets from our 2021 paper: Hatemoji: A Test Suite and Adversarially-Generated Dataset for Benchmarking and Detecting Emoji-based Hate. https://arxiv.org/abs/2108.05921. It is licensed under CC-BY-4.0.

The datasets and full dataset cards are on HuggingFace 🤗🤗🤗

Content Warning

Please be warned that this repository contains datasets on hate speech. The authors oppose any use of hateful language.

Citation

If you use either of these datasets please cite as 'Kirk, H. R., Vidgen, B., Rottger, P., Thrush, T., & Hale, S. A. (2021). Hatemoji: A Test Suite and Adversarially-Generated Dataset for Benchmarking and Detecting Emoji-based Hate.'

Contact Hannah if you have feedback or queries: hannah.kirk@oii.ox.ac.uk.

HatemojiCheck

  • HatemojiCheck is a test suite of 3,930 test cases covering seven functionalities of emoji-based hate and six identities.
  • test contains the text for each test case and its gold-standard label from majority agreement of three annotators. We provide labels by target of hate.
  • HatemojiCheck can be used to evaluate the robustness of hate speech classifiers to constructions of emoji-based hate.

HatemojiBuild

  • HatemojiBuild is a dataset of 5,912 adversarially-generated examples created on Dynabench using a human-and-model-in-the-loop approach. We collect data in three consecutive rounds.
  • Our work follows on from Vidgen et al (2021) Learning from the Worst: Dynamically Generated Datasets to Improve Online Hate Detection (http://arxiv.org/abs/2012.15761) who collect four rounds of textual adversarial examples. The R1-R4 data is avaliable at https://github.com/bvidgen/Dynamically-Generated-Hate-Speech-Dataset.
  • The entries in HatemojiBuild are labeled by round (R5-7). The text of each entry is given with its gold-standard label from majority agreement of three annotators. Each original entry is associated with a perturbation so each row of the .csv matches these two cases. We also provide granular labels of type and target for hateful entries.
  • HatemojiBuild can be used to train, develop and test models on emoji-based hate with challenging adversarial examples and perturbations.
  • train, validation and test contains the data in each split.

Columns in HatemojiCheck:

case_id: The unique ID of the test case (assigned to each of the 3,930 cases generated)

templ_id: The unique ID of the template (original=.0, identity perturbation=.1, polarity perturbation=.2, emoji perturbation = .3) from which the test case was generated

test_grp_id: The ID of the set of templates (original, identity perturbation, polarity perturbation, no emoji perturbation) from which the test case was generated.

text: The text of the test case.

target: Where applicable, the protected group targeted or referenced by the test case. We cover six protected groups in the test suite: women, trans people, gay people, black people, disabled people and Muslims.

functionality: The shorthand for the functionality tested by the test case.

set: Whether the test case is an original statement, a identity perturbation, a polarity perturbation or a no emoji perturbation.

label_gold: The gold standard label ({1: "hateful", 0: "non-hateful"}) of the test case. All test cases within a given functionality have the same gold standard label.

unrealistic_flags: The number of annotators (/3) who flagged the test case as unrealistic.

included_in_test_suite: Indicator for whether test case is included in final HatemojiCheck test suite. All 3,930 test cases are included.

Columns in HatemojiBuild:

entry_id: The unique ID of the entry (assigned to each of the 5,912 cases generated).

text: The text of the entry.

type: The type of hate assigned to hateful entries.

target: The target of hate assigned to hateful entries.

round.base: The round where the entry was generated.

round.set: The round and whether the entry came from an original statement (a) or a perturbation (b).

set: Whether the entry is an original or perturbation.

split: The randomly-assigned train/dev/test split using in our work (80:10:10).

label_gold: The gold standard label ({1: "hateful", 0: "non-hateful"}) of the test case.

matched_text: The text of the paired perturbation. Each original entry has one perturbation.

matched_id: The unique entry ID of the paired perturbation.

Code

All training and evaluation was implemented using the HuggingFace Transformers library, and run on the JADE2 supercomputing cluster. The environment used is replicated in /Code/environment.yml.

We outline core steps of our process:

  • Loading the Data:

    • load_data.py demonstrates how the train, dev and test sets can be downloaded, cleaned and combined for R0-R7. Note that R0 data is not publicly released by Vidgen et al., (2021). Please email the authors for more information.
    • It contains the function for upsampling the training data of the current round which we do at each iteration of model training. Running this script will save the modelling data in hiercharial folder structures in /Code/train_step/.
    • It also loads and saves the multiple test sets we use to evaluate our models, including HatemojiCheck and HateCheck. Running this script will save the evaluation data in hierarhical folder structures in /Code/eval_step/.
    • The .sh scripts for training and evaluating models rely on the data being loaded first.
  • Training Models:

    • We train our models using the HuggingFace Transformers run_glue.py script.
    • We launch the training process from train_deberta.sh.
    • Different upsampled train sets are loaded from job files so tasks can be run as slurm array. These job files are pre-created in /Code/train_step/jobs/ but can be created by navigating to this directory in Terminal then running echo "upsample1" > 0, echo "upsample5" > 1 etc.
  • Evaluating Models:

    • We evaluate our models using a modified version of the HuggingFace Transformers run_glue.py script: run_glue_eval.py. Specifically, we change the test metrics.
    • We launch the evaluation process from evaluate_models.sh.
    • Different test sets are loaded from job files so tasks can be run as slurm array. These job files are pre-created in /Code/eval_step/jobs/ but can be created by navigating to this directory in Terminal then running echo "hatecheck" > 0, echo "hatemojicheck" > 1 etc.

For any questions on the training or evaluation processes, please email hannah.kirk@oii.ox.ac.uk ☺️☺️☺️