|
# Parrot |
|
|
|
## 1. What is Parrot? |
|
Parrot is a paraphrase based utterance augmentation framework purpose built to accelerate training NLU models. A paraphrase framework is more than just a paraphrasing model. Please refer to the [github page](https://github.com/PrithivirajDamodaran/Parrot) |
|
|
|
|
|
### Installation |
|
```python |
|
pip install git+https://github.com/PrithivirajDamodaran/Parrot.git |
|
``` |
|
|
|
### Quickstart |
|
```python |
|
|
|
from parrot import Parrot |
|
import torch |
|
import warnings |
|
warnings.filterwarnings("ignore") |
|
|
|
''' |
|
uncomment to get reproducable paraphrase generations |
|
def random_state(seed): |
|
torch.manual_seed(seed) |
|
if torch.cuda.is_available(): |
|
torch.cuda.manual_seed_all(seed) |
|
|
|
random_state(1234) |
|
''' |
|
|
|
#Init models (make sure you init ONLY once if you integrate this to your code) |
|
parrot = Parrot(model_tag="prithivida/parrot_paraphraser_on_T5", use_gpu=False) |
|
|
|
phrases = ["Can you recommed some upscale restaurants in Rome?", |
|
"What are the famous places we should not miss in Russia?" |
|
] |
|
|
|
for phrase in phrases: |
|
print("-"*100) |
|
print("Input_phrase: ", phrase) |
|
print("-"*100) |
|
para_phrases = parrot.augment(input_phrase=phrase) |
|
for para_phrase in para_phrases: |
|
print(para_phrase) |
|
``` |
|
|
|
``` |
|
----------------------------------------------------------------------------- |
|
Input_phrase: Can you recommed some upscale restaurants in Rome? |
|
----------------------------------------------------------------------------- |
|
"which upscale restaurants are recommended in rome?" |
|
"which are the best restaurants in rome?" |
|
"are there any upscale restaurants near rome?" |
|
"can you recommend a good restaurant in rome?" |
|
"can you recommend some of the best restaurants in rome?" |
|
"can you recommend some best restaurants in rome?" |
|
"can you recommend some upscale restaurants in rome?" |
|
----------------------------------------------------------------------------- |
|
Input_phrase: What are the famous places we should not miss in Russia |
|
----------------------------------------------------------------------------- |
|
"which are the must do places for tourists to visit in russia?" |
|
"what are the best places to visit in russia?" |
|
"what are some of the most visited sights in russia?" |
|
"what are some of the most beautiful places in russia that tourists should not miss?" |
|
"which are some of the most beautiful places to visit in russia?" |
|
"what are some of the most important places to visit in russia?" |
|
"what are some of the most famous places of russia?" |
|
"what are some places we should not miss in russia?" |
|
``` |
|
|
|
### How to get syntactic and phrasal diversity/variety in your paraphrases using parrot? |
|
|
|
You can play with the do_diverse knob (check out the next section for more knobs). |
|
Consider this example: do_diverse = False (default) |
|
|
|
``` |
|
------------------------------------------------------------------------------ |
|
Input_phrase: The ultimate test of your knowledge is your capacity to convey it to another. |
|
------------------------------------------------------------------------------ |
|
'the final test of knowledge is your capacity to impart it ' |
|
'the ultimate test of a person's knowledge is his ability to transmit it to another ' |
|
'the ultimate test of knowledge is the ability to communicate it to another ' |
|
'the ultimate test of knowledge is your ability to communicate it to others ' |
|
'the test of your knowledge is your capacity to communicate it to others ' |
|
'the ultimate test for knowledge is the capacity to show it to another ' |
|
'the ultimate test of your knowledge is your ability to transmit to others ' |
|
'the ultimate test of a knowledge is your capacity to communicate it to another ' |
|
'the ultimate test of knowledge is your capacity to transmit it to another ' |
|
'the final test of your knowledge is your ability to convey it to another ' |
|
``` |
|
do_diverse = True |
|
``` |
|
------------------------------------------------------------------------------ |
|
Input_phrase: The ultimate test of your knowledge is your capacity to convey it to another. |
|
------------------------------------------------------------------------------ |
|
'one of the ultimate tests of knowledge is your ability to communicate it to another person ' |
|
'one of the ultimate tests of knowledge is your ability to transmit it to another person ' |
|
'one of the ultimate tests of knowledge is your ability to communicate it to another ' |
|
'one of the greatest tests of knowledge is your ability to convey it to another ' |
|
'one of the ultimate tests of knowledge is your ability to transmit it to another ' |
|
'one of the ultimate tests of knowledge is your ability to convey it to another person ' |
|
'one of the ultimate tests of knowledge is the ability to convey it to another ' |
|
'the ultimate test of your knowledge is your ability to communicate it to another ' |
|
'the ultimate test of your knowledge is your ability to transmit it to another ' |
|
``` |
|
|
|
### Knobs |
|
|
|
```python |
|
|
|
para_phrases = parrot.augment(input_phrase=phrase, |
|
diversity_ranker="levenshtein", |
|
do_diverse=False, |
|
max_return_phrases = 10, |
|
max_length=32, |
|
adequacy_threshold = 0.99, |
|
fluency_threshold = 0.90) |
|
|
|
``` |
|
|
|
|
|
|
|
|
|
|
|
## 2. Why Parrot? |
|
**Huggingface** lists [12 paraphrase models,](https://huggingface.co/models?pipeline_tag=text2text-generation&search=paraphrase) **RapidAPI** lists 7 fremium and commercial paraphrasers like [QuillBot](https://rapidapi.com/search/paraphrase?section=apis&page=1), Rasa has discussed an experimental paraphraser for augmenting text data [here](https://forum.rasa.com/t/paraphrasing-for-nlu-data-augmentation-experimental/27744), Sentence-transfomers offers a [paraphrase mining utility](https://www.sbert.net/examples/applications/paraphrase-mining/README.html) and [NLPAug](https://github.com/makcedward/nlpaug) offers word level augmentation with a [PPDB](http://paraphrase.org/#/download) (a multi-million paraphrase database). While these attempts at paraphrasing are great, there are still some gaps and paraphrasing is NOT yet a mainstream option for text augmentation in building NLU models....Parrot is a humble attempt to fill some of these gaps. |
|
|
|
**What is a good paraphrase?** Almost all conditioned text generation models are validated on 2 factors, (1) if the generated text conveys the same meaning as the original context (Adequacy) (2) if the text is fluent / grammatically correct english (Fluency). For instance Neural Machine Translation outputs are tested for Adequacy and Fluency. But [a good paraphrase](https://www.aclweb.org/anthology/D10-1090.pdf) should be adequate and fluent while being as different as possible on the surface lexical form. With respect to this definition, the **3 key metrics** that measures the quality of paraphrases are: |
|
- **Adequacy** (Is the meaning preserved adequately?) |
|
- **Fluency** (Is the paraphrase fluent English?) |
|
- **Diversity (Lexical / Phrasal / Syntactical)** (How much has the paraphrase changed the original sentence?) |
|
|
|
*Parrot offers knobs to control Adequacy, Fluency and Diversity as per your needs.* |
|
|
|
**What makes a paraphraser a good augmentor?** For training a NLU model we just don't need a lot of utterances but utterances with intents and slots/entities annotated. Typical flow would be: |
|
- Given an **input utterance + input annotations** a good augmentor spits out N **output paraphrases** while preserving the intent and slots. |
|
- The output paraphrases are then converted into annotated data using the input annotations that we got in step 1. |
|
- The annotated data created out of the output paraphrases then makes the training dataset for your NLU model. |
|
|
|
But in general being a generative model paraphrasers doesn't guarantee to preserve the slots/entities. So the ability to generate high quality paraphrases in a constrained fashion without trading off the intents and slots for lexical dissimilarity makes a paraphraser a good augmentor. *More on this in section 3 below* |
|
|
|
## 3. Scope |
|
|
|
In the space of conversational engines, knowledge bots are to which **we ask questions** like *"when was the Berlin wall teared down?"*, transactional bots are to which **we give commands** like *"Turn on the music please"* and voice assistants are the ones which can do both answer questions and action our commands. Parrot mainly foucses on augmenting texts typed-into or spoken-to conversational interfaces for building robust NLU models. (*So usually people neither type out or yell out long paragraphs to conversational interfaces. Hence the pre-trained model is trained on text samples of maximum length of 32.*) |
|
|
|
*While Parrot predominantly aims to be a text augmentor for building good NLU models, it can also be used as a pure-play paraphraser.* |
|
|
|
|
|
|