Skip to content

Inilien/treelstm.pytorch

 
 

Repository files navigation

Tree-Structured Long Short-Term Memory Networks

A PyTorch based implementation of Tree-LSTM from Kai Sheng Tai's paper Improved Semantic Representations From Tree-Structured Long Short-Term Memory Networks.

Comment from author of forked repository:

Fixed a lot of bugs and now results are similar to those of the original paper.

Requirements

  • PyTorch
  • tqdm
  • Java >= 8 (for Stanford CoreNLP utilities)
  • Python >= 3 (tested on 3.5)
  • (Python 2.7 for data downloading)

Usage

First run the script ./fetch_and_preprocess.sh, which downloads:

The preprocessing script also generates dependency parses of the SICK dataset using the Stanford Neural Network Dependency Parser.

To try the Dependency Tree-LSTM from the paper to predict similarity for pairs of sentences on the SICK dataset, run python main.py to train and test the model, and have a look at config.py for command-line arguments.
Note: You may want to change default folder in which GLOVE vectors are expected by the model specifying the path --glove "data/glove"

The first run takes a few minutes because the GLOVE embeddings for the words in the SICK vocabulary will need to be read and stored to a cache for future runs. In later runs, only the cache is read in during later runs.

This code with default configs gives a Pearson's coefficient of 0.859269 and a MSE of 0.273632, as opposed to a Pearson's coefficient of 0.8676 and a MSE of 0.2532 in the original paper. There are several differences in default configs compared to the original paper:

  • optimizer: adam vs adagrad
  • wd: 0 vs 1e-4
  • lr: 1e-3 vs 0.1

Notes

PyTorch 0.1.12 has support for sparse tensors in both CPU and GPU modes. This means that nn.Embedding can now have sparse updates, potentially reducing memory usage. Enable this by the --sparse argument, but be warned of two things:

  • Sparse training has not been tested by me. The code works, but performance has not been benchmarked for this code.
  • Weight decay does not work with sparse gradients/parameters.

Acknowledgements

Shout-out to Kai Sheng Tai for the original LuaTorch implementation, and to the Pytorch team for the fun library.

Original author

Riddhiman Dasgupta

This is my first PyTorch based implementation, and might contain bugs. Please let me know if you find any!

License

MIT

About

Tree LSTM implementation in PyTorch

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 74.9%
  • Java 24.7%
  • Shell 0.4%