Skip to content

Implementation of NLP transformer with Automatic mixed precision and a few optimizations out of the box

Notifications You must be signed in to change notification settings

Amr-Abdellatif/NLP-Tranformer-from-scratch-with-PyTorch-AMP

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Tranformer from scratch

This is a step by step implementation of Attention is all you need paper issued in 2017 The model was basically coded by Umar-jamil but i did my homework and did a step by step implementation with debugging which wasn't a simple task

preview.mp4

What did I Add ?

  1. Automatic mixed precision for the forward loop in training and validation steps.

  2. The ability to subset the data and try on smaller subset not the entire dataset -> config ['data_subset_ratio'].

  3. added Pin_memory in datalaoder to True to enable faster data transfer to CUDA-enabled GPUs. -> reference ['https://pytorch.org/docs/stable/data.html'].

  4. In validation loop no_inference context manager was used to squeeze every bit of performance -> reference ['https://pytorch.org/docs/stable/notes/autograd.html#inference-mode'].

  5. With Adam optimizer i used fused kernel flag to speed up computation -> reference ['https://pytorch.org/docs/stable/optim.html'].

the application built over the transformer

basically it's a translator for en-it and the dataset was imported from Hugging-Face

About

Implementation of NLP transformer with Automatic mixed precision and a few optimizations out of the box

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages