|
--- |
|
language: |
|
- en |
|
license: apache-2.0 |
|
base_model: |
|
- FacebookAI/roberta-base |
|
pipeline_tag: token-classification |
|
library_name: transformers |
|
--- |
|
|
|
# Training |
|
This model is designed for token classification tasks, enabling it to extract aspect terms and predict the sentiment polarity associated with the extracted aspect terms. |
|
The extracted aspect terms will be the span(s) from the input text on which a sentiment is being expressed. |
|
|
|
## Datasets |
|
This model has been trained on the following datasets: |
|
|
|
1. Aspect Based Sentiment Analysis SemEval Shared Tasks ([2014](https://aclanthology.org/S14-2004/), [2015](https://aclanthology.org/S15-2082/), [2016](https://aclanthology.org/S16-1002/)) |
|
2. Multi-Aspect Multi-Sentiment [MAMS](https://aclanthology.org/D19-1654/) |
|
|
|
# Use |
|
|
|
* Making token level inferences with Auto classes |
|
```python |
|
from transformers import AutoTokenizer, AutoModelForTokenClassification |
|
model_id = "gauneg/roberta-base-absa-ate-sentiment" |
|
tokenizer = AutoTokenizer.from_pretrained(model_id) |
|
model = AutoModelForTokenClassification.from_pretrained(model_id) |
|
|
|
|
|
# the sequence of labels used during training |
|
label = {"B-neu": 1, "I-neu": 2, "O": 0, "B-neg": 3, "B-con": 4, "I-pos": 5, "B-pos": 6, "I-con": 7, "I-neg": 8, "X": -100} |
|
id2lab = {idx: lab for lab, idx in labels.items()} |
|
lab2id = {lab: idx for lab, idx in labels.items()} |
|
|
|
|
|
# making one prediction at a time (should be padded/batched and truncated for efficiency) |
|
text_input = "Been here a few times and food has always been good but service really suffers when it gets crowded." |
|
tok_inputs = tokenizer(text_input, return_tensors="pt") |
|
|
|
|
|
y_pred = model(**tok_inputs) # predicting the logits |
|
|
|
y_pred_fin = y_pred.logits.argmax(dim=-1)[0] # selecting the most favoured labels for each token from the logits |
|
|
|
decoded_pred = [id2lab[logx.item()] for logx in y_pred_fin] |
|
|
|
|
|
## displaying the input tokens with predictions and skipping <s> and </s> tokens at the beginning and the end respectively |
|
|
|
tok_levl_pred = list(zip(tokenizer.convert_ids_to_tokens(tok_inputs['input_ids'][0]), decoded_pred))[1:-1] |
|
|
|
``` |
|
|
|
* results in `tok_level_pred` variable |
|
|
|
```bash |
|
[('Be', 'O'), |
|
('en', 'O'), |
|
('Ġhere', 'O'), |
|
('Ġa', 'O'), |
|
('Ġfew', 'O'), |
|
('Ġtimes', 'O'), |
|
('Ġand', 'O'), |
|
('Ġfood', 'B-pos'), |
|
('Ġhas', 'O'), |
|
('Ġalways', 'O'), |
|
('Ġbeen', 'O'), |
|
('Ġgood', 'O'), |
|
('Ġbut', 'O'), |
|
('Ġservice', 'B-neg'), |
|
('Ġreally', 'O'), |
|
('Ġsuffers', 'O'), |
|
('Ġwhen', 'O'), |
|
('Ġit', 'O'), |
|
('Ġgets', 'O'), |
|
('Ġcrowded', 'O'), |
|
('.', 'O')] |
|
``` |
|
|
|
# OR |
|
|
|
* Using the pipeline directly for end-to-end inference: |
|
```python |
|
from transformers import pipeline |
|
|
|
ate_sent_pipeline = pipeline(task='ner', |
|
aggregation_strategy='simple', |
|
model="gauneg/roberta-base-absa-ate-sentiment") |
|
|
|
text_input = "Been here a few times and food has always been good but service really suffers when it gets crowded." |
|
ate_sent_pipeline(text_input) |
|
``` |
|
* pipeline output: |
|
```bash |
|
[{'entity_group': 'pos', |
|
'score': 0.8447307, |
|
'word': ' food', |
|
'start': 26, |
|
'end': 30}, |
|
{'entity_group': 'neg', |
|
'score': 0.81927896, |
|
'word': ' service', |
|
'start': 56, |
|
'end': 63}] |
|
|
|
``` |