Skip to content

Sentence paraphrase generation at the sentence level

License

Notifications You must be signed in to change notification settings

shellydeng/paraphraser

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

84 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Paraphraser

This project providers users the ability to do paraphrase generation for sentences through a clean and simple API. A demo can be seen here: pair-a-phrase

The paraphraser was developed under the Insight Data Science Artificial Intelligence program.

Model

The underlying model is a bidirectional LSTM encoder and LSTM decoder with attention trained using Tensorflow. Downloadable link here: paraphrase model

Prerequisiteis

  • python 3.5
  • Tensorflow 1.4.1
  • spacy

Inference Execution

Download the model checkpoint from the link above and run:

python inference.py --checkpoint=<checkpoint_path/model-171856>

Datasets

The dataset used to train this model is an aggregation of many different public datasets. To name a few:

  • para-nmt-5m
  • Quora question pair
  • SNLI
  • Semeval
  • And more!

I have not included the aggregated dataset as part of this repo. If you're curious and would like to know more, contact me. Pretrained embeddings come from John Wieting's para-nmt-50m project.

Training

Training was done for 2 epochs on a Nvidia GTX 1080 and evaluted on the BLEU score. The Tensorboard training curves can be seen below. The grey curve is train and the orange curve is dev.

TODOs

  • pip installable package
  • Explore deeper number of layers
  • Recurrent layer dropout
  • Greater dataset augmentation
  • Try residual layer
  • Model compression
  • Byte pair encoding for out of set vocabulary

Citations

@inproceedings { wieting-17-millions, 
    author = {John Wieting and Kevin Gimpel}, 
    title = {Pushing the Limits of Paraphrastic Sentence Embeddings with Millions of Machine Translations}, 
    booktitle = {arXiv preprint arXiv:1711.05732}, year = {2017} 
}

@inproceedings { wieting-17-backtrans, 
    author = {John Wieting, Jonathan Mallinson, and Kevin Gimpel}, 
    title = {Learning Paraphrastic Sentence Embeddings from Back-Translated Bitext}, 
    booktitle = {Proceedings of Empirical Methods in Natural Language Processing}, 
    year = {2017} 
}

Additional Setup Requirements

Create the environment in the /paraphraser directory

conda env create -f env.yml

Activate the environment

conda activate paraphraser-env

Download the model checkpoint from above, rename it to "checkpoints", and place it within the /paraphraser/paraphraser directory

Download para-nmt-50m here

  • Rename it to para-nmt-50m and place it inside the /paraphraser directory

You MAY need to run the following three commands (when prompted)

conda install tensorflow==1.14
conda install spacy
python3 -m spacy download en_core_web_sm

Run the inference.py script

cd paraphraser
python inference.py --checkpoint=checkpoints/model-171856

Run the script to generate paraphrases for sentences in the datasets

Notice that this script expects that the following files exists:

  • paraphraser/paraphraser/augmentation/datasets/indomain_train/nat_questions-questions
  • paraphraser/paraphraser/augmentation/datasets/indomain_train/newsqa-questions
  • paraphraser/paraphraser/augmentation/datasets/indomain_train/squad-questions
  • paraphraser/paraphraser/augmentation/datasets/indomain_val/nat_questions-questions
  • paraphraser/paraphraser/augmentation/datasets/indomain_val/newsqa-questions
  • paraphraser/paraphraser/augmentation/datasets/indomain_val/squad-questions
  • paraphraser/paraphraser/augmentation/datasets/oodomain_train/duorc-questions
  • paraphraser/paraphraser/augmentation/datasets/oodomain_train/race-questions
  • paraphraser/paraphraser/augmentation/datasets/oodomain_train/relation_extraction-questions
  • paraphraser/paraphraser/augmentation/datasets/oodomain_val/duorc-questions
  • paraphraser/paraphraser/augmentation/datasets/oodomain_val/race-questions
  • paraphraser/paraphraser/augmentation/datasets/oodomain_val/relation_extraction-questions

To get these files, please refer to the extractQuestions.py script and the README.md file from this robustqa repository on how to generate these files. Each of these files contains a question on each line.

Then to generate paraphrases for the questions, within the paraphraser/paraphraser directory, run the following command:

python inference.py --checkpoint=checkpoints/model-171856 --useFiles=True

Add the --sampleTemp flag to set a sampling temperature value of between 0.0 to 1.0, different from the default value of 0.75. Add the --numPP flag to indicate the number of paraphrases to generate per sentence. The default is 10. The paraphrases will be saved to the file named using the input_path + "-pps-all" suffix (i.e. paraphraser/paraphraser/augmentation/datasets/indomain_train/nat_questions-questionspps-all)

About

Sentence paraphrase generation at the sentence level

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%