/texar-docker

Toolkit for Machine Learning and Text Generation, in TensorFlow

Primary LanguagePythonApache License 2.0Apache-2.0




pypi Build Status Documentation Status License

(Note: this is a forked implementation from asyml/texar to provide ready-to-use openkbs/texar-docker with this GIT repo source code (and examples) inside the container image for trying out)

Run (recommended for easy-start)

Image is pulling from openkbs/texar-docker

./run.sh

Test

To enter the container, run the command:

./shell.sh

Once you are in the container, you can try the Texar installation with the comand:

python -c "import texar as tx;print(tx.data)"

And, you will see outcome as below:

<module 'texar.tf.data' from '/opt/texar/texar/tf/data/__init__.py'>

Build

You can build your own image locally.

./build.sh

Credits

  • The Docker build is adopted from Tony Nong's pull request.
  • This fork is from asyml/texar.

Issues

Texar is a toolkit aiming to support a broad set of machine learning, especially natural language processing and text generation tasks. Texar provides a library of easy-to-use ML modules and functionalities for composing whatever models and algorithms. The tool is designed for both researchers and practitioners for fast prototyping and experimentation.

Key Features

  • Two Versions, (Mostly) Same Interfaces. Texar-TensorFlow (this repo) and Texar-PyTorch have mostly the same interfaces. Both further combine the best design of TF and PyTorch:
    • Interfaces and variable sharing in PyTorch convention
    • Excellent factorization and rich functionalities in TF convention.
  • Rich Pre-trained Models, Rich Usage with Uniform Interfaces. BERT, GPT2, XLNet, etc, for encoding, classification, generation, and composing complex models with other Texar components!
  • Fully Customizable at multiple abstraction level -- both novice-friendly and expert-friendly.
    • Free to plug in whatever external modules, since Texar is fully compatible with the native TF/PyTorch APIs.
  • Versatile to support broad tasks, models, algorithms, data processing, evaluation, etc.
    • encoder(s) to decoder(s), sequential- and self-attentions, memory, hierarchical models, classifiers...
    • maximum likelihood learning, reinforcement learning, adversarial learning, probabilistic modeling, ...
  • Modularized for maximal re-use and clean APIs, based on principled decomposition of Learning-Inference-Model Architecture.
  • Distributed model training with multiple GPUs.
  • Clean, detailed documentation and rich examples.


Library API Example

Builds an encoder-decoder model, with maximum likelihood learning:

import texar.tf as tx

# Data 
data = tx.data.PairedTextData(hparams=hparams_data) # a dict of hyperparameters 
iterator = tx.data.DataIterator(data)
batch = iterator.get_next()                         # get a data mini-batch

# Model architecture
embedder = tx.modules.WordEmbedder(data.target_vocab.size, hparams=hparams_emb)
encoder = tx.modules.TransformerEncoder(hparams=hparams_enc)
outputs_enc = encoder(inputs=embedder(batch['source_text_ids']),  # call as a function
                      sequence_length=batch['source_length'])
                      
decoder = tx.modules.TransformerDecoder(
    output_layer=tf.transpose(embedder.embedding) # tie input embedding w/ output layer
    hparams=hparams_decoder)
outputs, _, _ = decoder(memory=output_enc, 
                        memory_sequence_length=batch['source_length'],
                        inputs=embedder(batch['target_text_ids']),
                        sequence_length=batch['target_length']-1,
                        decoding_strategy='greedy_train')    # teacher-forcing decoding
                        
# Loss for maximum likelihood learning
loss = tx.losses.sequence_sparse_softmax_cross_entropy(
    labels=batch['target_text_ids'][:, 1:],
    logits=outputs.logits,
    sequence_length=batch['target_length']-1)  # automatic sequence masks

# Beam search decoding
outputs_bs, _, _ = tx.modules.beam_search_decode(
    decoder,
    embedding=embedder,
    start_tokens=[data.target_vocab.bos_token_id]*num_samples,
    end_token=data.target_vocab.eos_token_id)

The same model, but with adversarial learning:

helper = tx.modules.GumbelSoftmaxTraingHelper( # Gumbel-softmax decoding
    start_tokens=[BOS]*batch_size, end_token=EOS, embedding=embedder)
outputs, _ = decoder(helper=helper)            # automatic re-use of the decoder variables

discriminator = tx.modules.BertClassifier(hparams=hparams_bert)        # pre-trained model

G_loss, D_loss = tx.losses.binary_adversarial_losses(
    real_data=data['target_text_ids'][:, 1:],
    fake_data=outputs.sample_id,
    discriminator_fn=discriminator)

The same model, but with RL policy gradient learning:

agent = tx.agents.SeqPGAgent(samples=outputs.sample_id,
                             logits=outputs.logits,
                             sequence_length=batch['target_length']-1,
                             hparams=config_model.agent)

Many more examples are available here

Installation

Texar requires:

After tensorflow and tensorflow_probability are installed, install Texar from PyPI:

pip install texar

To use cutting-edge features or develop locally, install from source:

git clone https://github.com/asyml/texar.git
cd texar
pip install .

Getting Started

Reference

If you use Texar, please cite the tech report with the following BibTex entry:

Texar: A Modularized, Versatile, and Extensible Toolkit for Text Generation
Zhiting Hu, Haoran Shi, Bowen Tan, Wentao Wang, Zichao Yang, Tiancheng Zhao, Junxian He, Lianhui Qin, Di Wang, Xuezhe Ma, Zhengzhong Liu, Xiaodan Liang, Wanrong Zhu, Devendra Sachan and Eric Xing
ACL 2019

@inproceedings{hu2019texar,
  title={Texar: A Modularized, Versatile, and Extensible Toolkit for Text Generation},
  author={Hu, Zhiting and Shi, Haoran and Tan, Bowen and Wang, Wentao and Yang, Zichao and Zhao, Tiancheng and He, Junxian and Qin, Lianhui and Wang, Di and others},
  booktitle={ACL 2019, System Demonstrations}
  year={2019}
}

License

Apache License 2.0

Packages

Package                Version   Location  
---------------------- --------- ----------
absl-py                0.7.1     
asn1crypto             0.24.0    
astor                  0.8.0     
attrs                  19.1.0    
certifi                2019.6.16 
cffi                   1.12.3    
chardet                3.0.4     
cloudpickle            1.2.1     
conda                  4.7.11    
conda-package-handling 1.3.11    
cryptography           2.7       
decorator              4.4.0     
funcsigs               1.0.2     
gast                   0.2.2     
google-pasta           0.1.7     
grpcio                 1.22.0    
h5py                   2.9.0     
idna                   2.8       
Keras-Applications     1.0.8     
Keras-Preprocessing    1.1.0     
libarchive-c           2.8       
Markdown               3.1.1     
numpy                  1.16.4    
packaging              19.1      
pip                    19.1.1    
protobuf               3.9.1     
pycosat                0.6.3     
pycparser              2.19      
pyOpenSSL              19.0.0    
pyparsing              2.4.2     
PySocks                1.7.0     
PyYAML                 5.1.2     
requests               2.22.0    
ruamel-yaml            0.15.46   
setuptools             41.0.1    
six                    1.12.0    
tensorboard            1.14.0    
tensorflow             1.14.0    
tensorflow-estimator   1.14.0    
tensorflow-gpu         1.14.0    
tensorflow-probability 0.7.0     
termcolor              1.1.0     
texar                  0.2.2     /opt/texar
tqdm                   4.32.1    
urllib3                1.24.2    
Werkzeug               0.15.5    
wheel                  0.33.4    
wrapt                  1.11.2