Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

https://github.com/facebookresearch/pytext

A natural language modeling framework based on PyTorch
https://github.com/facebookresearch/pytext

Last synced: about 2 months ago
JSON representation

A natural language modeling framework based on PyTorch

Lists

README

        


⚠️ Please migrate to torchtext ⚠️



PyText is deprecated and will no longer be actively maintained. Please check out torchtext and contribute there!

# Overview

[![Support Ukraine](https://img.shields.io/badge/Support-Ukraine-FFD500?style=flat&labelColor=005BBB)](https://opensource.fb.com/support-ukraine)
[![CircleCI](https://circleci.com/gh/facebookresearch/pytext.svg?style=svg&circle-token=2e0e0cb6dc686b646df887c2e0f07a8429712243)](https://circleci.com/gh/facebookresearch/pytext)

PyText is a deep-learning based NLP modeling framework built on PyTorch. PyText addresses the often-conflicting requirements of enabling rapid experimentation and of serving models at scale. It achieves this by providing simple and extensible interfaces and abstractions for model components, and by using PyTorch’s capabilities of exporting models for inference via the optimized Caffe2 execution engine. We are using PyText in Facebook to iterate quickly on new modeling ideas and then seamlessly ship them at scale.

**Core PyText features:**
- Production ready models for various NLP/NLU tasks:
- Text classifiers
- [Yoon Kim (2014): Convolutional Neural Networks for Sentence Classification](https://arxiv.org/abs/1408.5882)
- [Lin et al. (2017): A Structured Self-attentive Sentence Embedding](https://arxiv.org/abs/1703.03130)
- Sequence taggers
- [Lample et al. (2016): Neural Architectures for Named Entity Recognition](https://www.aclweb.org/anthology/N16-1030)
- Joint intent-slot model
- [Zhang et al. (2016): A Joint Model of Intent Determination and Slot Filling for Spoken Language Understanding](https://www.ijcai.org/Proceedings/16/Papers/425.pdf)
- Contextual intent-slot models
- Distributed-training support built on the new C10d backend in PyTorch 1.0
- Mixed precision training support through [APEX](https://github.com/NVIDIA/apex) (trains faster with less GPU memory on [NVIDIA Tensor Cores](https://developer.nvidia.com/tensor-cores))
- Extensible components that allows easy creation of new models and tasks
- Reference implementation and a pretrained model for the paper: [Gupta et al. (2018): Semantic Parsing for Task Oriented Dialog using Hierarchical Representations](http://aclweb.org/anthology/D18-1300)
- Ensemble training support
- Reference implementation for the paper: [Babu et al. 2021: Non-autoregressive Semantic Parsing for Compositional Task Oriented Dialog](https://github.com/facebookresearch/pytext/tree/master/pytext/models/seq_models/benchmarks/nar_top.json)

# Installing PyText

### PyText requires Python 3.6.1 or above.

*To get started on a Cloud VM, check out [our guide](https://pytext.readthedocs.io/en/master/installation.html#cloud-vm-setup)*.

Get the source code:
```
$ git clone https://github.com/facebookresearch/pytext
$ cd pytext
```
Create a virtualenv and install PyText:

```
$ python3 -m venv pytext_venv
$ source pytext_venv/bin/activate
(pytext_venv) $ pip install pytext-nlp
```

Detailed instructions and more installation options can be found in our [Documentation](https://pytext.readthedocs.io/en/master/installation.html). If you encounter issues with missing dependencies during installation, please refer to [OS Dependencies](https://pytext.readthedocs.io/en/master/installation.html#os-dependencies).

# Train your first text classifier

For this first example, we'll train a CNN-based text-classifier that classifies text utterances, using the examples in `tests/data/train_data_tiny.tsv`. The data and configs files can be obtained either by cloning the repository or by downloading the files manually from GitHub.

```
(pytext_venv) $ pytext train < demo/configs/docnn.json
```

By default, the model is created in `/tmp/model.pt`

Now you can export your model as a caffe2 net:

```
(pytext_venv) $ pytext export < demo/configs/docnn.json
```

You can use the exported caffe2 model to predict the class of raw utterances like this:

```
(pytext_venv) $ pytext --config-file demo/configs/docnn.json predict <<< '{"text": "create an alarm for 1:30 pm"}'
```

More examples and tutorials can be found in [Full Documentation](https://pytext.readthedocs.io/en/master/).

# Join the community

* Facebook group: https://www.facebook.com/groups/pytext/

# License
PyText is BSD-licensed, as found in the LICENSE file.