Martin Müller
commited on
Commit
·
589f56d
1
Parent(s):
a391651
Add README
Browse files
README.md
ADDED
@@ -0,0 +1,75 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
---
|
2 |
+
language:
|
3 |
+
- en
|
4 |
+
thumbnail: "https://raw.githubusercontent.com/digitalepidemiologylab/covid-twitter-bert/master/images/COVID-Twitter-BERT_small.png"
|
5 |
+
tags:
|
6 |
+
- Twitter
|
7 |
+
- COVID-19
|
8 |
+
- text-classification
|
9 |
+
- pytorch
|
10 |
+
- tensorflow
|
11 |
+
- bert
|
12 |
+
license: MIT
|
13 |
+
datasets:
|
14 |
+
- mnli
|
15 |
+
pipeline_tag: zero-shot-classification
|
16 |
+
widget:
|
17 |
+
- text: "To stop the pandemic it is important that everyone turns up for their shots."
|
18 |
+
candidate_labels: "health, sport, vaccine, guns"
|
19 |
+
---
|
20 |
+
|
21 |
+
# COVID-Twitter-BERT v2 MNLI
|
22 |
+
|
23 |
+
## Model description
|
24 |
+
This model provides a zero-shot classifier to be used in cases where it is not possible to finetune CT-BERT on a specific task, due to lack of labelled data.
|
25 |
+
|
26 |
+
The technique is based on [Yin et al.](https://arxiv.org/abs/1909.00161).
|
27 |
+
The article describes a very clever way of using pre-trained MNLI models as zero-shot sequence classifiers.
|
28 |
+
The model is already finetuned on 400'000 generaic logical tasks.
|
29 |
+
We can then use it as a zero-shot classifier by reformulating the classification task as a question.
|
30 |
+
|
31 |
+
Let's say we want to classify COVID-tweets as vaccine-related and not vaccine-related.
|
32 |
+
The typical way would be to collect a few hunder pre-annotated tweets and organise them in two classes.
|
33 |
+
Then you would finetune the model on this.
|
34 |
+
|
35 |
+
With the zero-shot mnli-classifier, you can instead reformulate your question as "This text is about vaccines", and use this directly on inference - without any training.
|
36 |
+
|
37 |
+
Find more info about the model on our [GitHub page](https://github.com/digitalepidemiologylab/covid-twitter-bert).
|
38 |
+
|
39 |
+
## Usage
|
40 |
+
Please note that how you formulate the question can give slightly different results.
|
41 |
+
Collecting a training set and finetuning on this, will most likely give you better accuracy.
|
42 |
+
|
43 |
+
The easiest way to try this out is by using the Hugging Face pipeline.
|
44 |
+
This uses the default Enlish template where it puts the text "This example is " in front of the text.
|
45 |
+
|
46 |
+
```python
|
47 |
+
from transformers import pipeline
|
48 |
+
classifier = pipeline("zero-shot-classification", model="digitalepidemiologylab/covid-twitter-bert-v2-mnli")
|
49 |
+
```
|
50 |
+
You can then use this pipeline to classify sequences into any of the class names you specify.
|
51 |
+
```python
|
52 |
+
sequence_to_classify = 'To stop the pandemic it is important that everyone turns up for their shots.'
|
53 |
+
candidate_labels = ['health', 'sport', 'vaccine','guns']
|
54 |
+
hypothesis_template = 'This example is {}.'
|
55 |
+
classifier(sequence_to_classify, candidate_labels, hypothesis_template=hypothesis_template, multi_class=True)
|
56 |
+
```
|
57 |
+
|
58 |
+
## Training procedure
|
59 |
+
The model is finetuned on the 400k large [MNLI-task](https://cims.nyu.edu/~sbowman/multinli/).
|
60 |
+
|
61 |
+
## References
|
62 |
+
```bibtex
|
63 |
+
@article{muller2020covid,
|
64 |
+
title={COVID-Twitter-BERT: A Natural Language Processing Model to Analyse COVID-19 Content on Twitter},
|
65 |
+
author={M{\"u}ller, Martin and Salath{\'e}, Marcel and Kummervold, Per E},
|
66 |
+
journal={arXiv preprint arXiv:2005.07503},
|
67 |
+
year={2020}
|
68 |
+
}
|
69 |
+
```
|
70 |
+
or
|
71 |
+
```
|
72 |
+
Martin Müller, Marcel Salathé, and Per E. Kummervold.
|
73 |
+
COVID-Twitter-BERT: A Natural Language Processing Model to Analyse COVID-19 Content on Twitter.
|
74 |
+
arXiv preprint arXiv:2005.07503 (2020).
|
75 |
+
```
|