pipeline_tag: text-classification
language:
- nl
tags:
- text classification
- sentiment analysis
- domain adaptation
widget:
- text: De NMBS heeft recent de airconditioning in alle treinen vernieuwd.
example_title: POS-NMBS
- text: De wegenwerken langs de E34 blijven al maanden aanhouden.
example_title: NEG-AWV
- text: Natuur en Bos is erin geslaagd 100 hectaren bosgebied te beschermen.
example_title: POS-ANB
- text: Het FWO financiert te weinig excellent onderzoek.
example_title: NEG-FWO
- text: De Lijn is op zoek naar nieuwe buschauffeurs.
example_title: NEU-De Lijn
RePublic
Model description
RePublic (reputation analyzer for public service organizations) is a Dutch BERT model based on BERTje (De Vries, 2019). The model was designed to predict the sentiment in Dutch-language news article text about public agencies. RePublic was developed by CLiPS in collaboration with Prof. Dr. Jan Boon.
How to use
The model can be loaded and used to make predictions as follows:
from transformers import pipeline
model_path = 'clips/republic'
pipe = pipeline(task="text-classification",
model=model_path, tokenizer=model_path)
text = … # load your text here
output = pipe(text)
prediction = output[0]['label'] # 0=”neutral”; 1=”positive”; 2=”negative”
Training data and procedure
RePublic was domain-adapted on 91 661 Flemish news articles from three popular Flemish news providers between 2000 and 2020 (“Het Laatste Nieuws”, “Het Nieuwsblad” and “De Morgen”). These articles mention at least one out of a pre-defined list of 24 public service organizations, which contains, a.o., De Lijn (public transport organization), VDAB (Flemish job placement service), and Agentschap Zorg en Gezondheid (healthcare service). The domain adaptation was achieved by performing BERT’s language modeling tasks (masked language modeling & next sentence prediction).
The model was then fine-tuned on a sentiment classification task (“positive”, “negative”, “neutral”). The supervised data consisted of 4404 annotated sentences mentioning Flemish public agencies of which 1257 sentences were positive, 1485 sentences were negative and 1662 sentences were neutral. Fine-tuning was performed for 4 epochs using a batch size of 8 and a learning rate of 5e-5. In order to evaluate the model, a 10-fold cross validation experiment was conducted. The results of this experiment can be found below.
Class | Precision (%) | Recall (%) | F1-score (%) |
---|---|---|---|
Positive | 87.3 | 88.6 | 88.0 |
Negative | 86.4 | 86.5 | 86.5 |
Neutral | 85.3 | 84.2 | 84.7 |
Macro-averaged | 86.3 | 86.4 | 86.4 |