readme.md 12.2 KB
Newer Older
V
Varuna Jayasiri 已提交
1
[![Twitter](https://img.shields.io/twitter/follow/labmlai?style=social)](https://twitter.com/labmlai)
V
Varuna Jayasiri 已提交
2
[![Sponsor](https://img.shields.io/static/v1?label=Sponsor&message=%E2%9D%A4&logo=GitHub&color=%23fe8e86)](https://github.com/sponsors/labmlai)
V
Varuna Jayasiri 已提交
3

A
Aarsh Chaube 已提交
4
# [labml.ai Deep Learning Paper Implementations](https://nn.labml.ai/index.html)
V
readme  
Varuna Jayasiri 已提交
5

V
Varuna Jayasiri 已提交
6 7 8
This is a collection of simple PyTorch implementations of
neural networks and related algorithms.
These implementations are documented with explanations,
V
Varuna Jayasiri 已提交
9

V
urls  
Varuna Jayasiri 已提交
10
[The website](https://nn.labml.ai/index.html)
V
Varuna Jayasiri 已提交
11 12 13
renders these as side-by-side formatted notes.
We believe these would help you understand these algorithms better.

V
light  
Varuna Jayasiri 已提交
14
![Screenshot](https://nn.labml.ai/dqn-light.png)
V
Varuna Jayasiri 已提交
15

V
Varuna Jayasiri 已提交
16 17
We are actively maintaining this repo and adding new 
implementations almost weekly.
V
Varuna Jayasiri 已提交
18
[![Twitter](https://img.shields.io/twitter/follow/labmlai?style=social)](https://twitter.com/labmlai) for updates.
V
Varuna Jayasiri 已提交
19

V
Varuna Jayasiri 已提交
20
## Paper Implementations
V
readme  
Varuna Jayasiri 已提交
21

V
urls  
Varuna Jayasiri 已提交
22
#### ✨ [Transformers](https://nn.labml.ai/transformers/index.html)
V
readme  
Varuna Jayasiri 已提交
23

V
links  
Varuna Jayasiri 已提交
24 25
* [Multi-headed attention](https://nn.labml.ai/transformers/mha.html)
* [Transformer building blocks](https://nn.labml.ai/transformers/models.html) 
V
Varuna Jayasiri 已提交
26 27
* [Transformer XL](https://nn.labml.ai/transformers/xl/index.html)
    * [Relative multi-headed attention](https://nn.labml.ai/transformers/xl/relative_mha.html)
V
Varuna Jayasiri 已提交
28
* [Rotary Positional Embeddings](https://nn.labml.ai/transformers/rope/index.html)
V
Varuna Jayasiri 已提交
29
* [Attention with Linear Biases (ALiBi)](https://nn.labml.ai/transformers/alibi/index.html)
V
links  
Varuna Jayasiri 已提交
30
* [RETRO](https://nn.labml.ai/transformers/retro/index.html)
V
Varuna Jayasiri 已提交
31
* [Compressive Transformer](https://nn.labml.ai/transformers/compressive/index.html)
V
urls  
Varuna Jayasiri 已提交
32 33 34 35 36
* [GPT Architecture](https://nn.labml.ai/transformers/gpt/index.html)
* [GLU Variants](https://nn.labml.ai/transformers/glu_variants/simple.html)
* [kNN-LM: Generalization through Memorization](https://nn.labml.ai/transformers/knn)
* [Feedback Transformer](https://nn.labml.ai/transformers/feedback/index.html)
* [Switch Transformer](https://nn.labml.ai/transformers/switch/index.html)
V
readme  
Varuna Jayasiri 已提交
37
* [Fast Weights Transformer](https://nn.labml.ai/transformers/fast_weights/index.html)
V
Varuna Jayasiri 已提交
38
* [FNet](https://nn.labml.ai/transformers/fnet/index.html)
V
Varuna Jayasiri 已提交
39
* [Attention Free Transformer](https://nn.labml.ai/transformers/aft/index.html)
V
Varuna Jayasiri 已提交
40
* [Masked Language Model](https://nn.labml.ai/transformers/mlm/index.html)
V
Varuna Jayasiri 已提交
41
* [MLP-Mixer: An all-MLP Architecture for Vision](https://nn.labml.ai/transformers/mlp_mixer/index.html)
V
Varuna Jayasiri 已提交
42
* [Pay Attention to MLPs (gMLP)](https://nn.labml.ai/transformers/gmlp/index.html)
V
vit  
Varuna Jayasiri 已提交
43
* [Vision Transformer (ViT)](https://nn.labml.ai/transformers/vit/index.html)
V
Varuna Jayasiri 已提交
44
* [Primer EZ](https://nn.labml.ai/transformers/primer_ez/index.html)
V
url fix  
Varuna Jayasiri 已提交
45
* [Hourglass](https://nn.labml.ai/transformers/hour_glass/index.html)
V
Varuna Jayasiri 已提交
46

V
links  
Varuna Jayasiri 已提交
47 48 49 50
#### ✨ [Eleuther GPT-NeoX](https://nn.labml.ai/neox/index.html)
* [Generate on a 48GB GPU](https://nn.labml.ai/neox/samples/generate.html)
* [Finetune on two 48GB GPUs](https://nn.labml.ai/neox/samples/finetune.html)
* [LLM.int8()](https://nn.labml.ai/neox/utils/llm_int8.html)
V
Varuna Jayasiri 已提交
51

V
links  
Varuna Jayasiri 已提交
52
#### ✨ [Diffusion models](https://nn.labml.ai/diffusion/index.html)
V
readme  
Varuna Jayasiri 已提交
53

V
links  
Varuna Jayasiri 已提交
54 55 56 57
* [Denoising Diffusion Probabilistic Models (DDPM)](https://nn.labml.ai/diffusion/ddpm/index.html)
* [Denoising Diffusion Implicit Models (DDIM)](https://nn.labml.ai/diffusion/stable_diffusion/sampler/ddim.html)
* [Latent Diffusion Models](https://nn.labml.ai/diffusion/stable_diffusion/latent_diffusion.html)
* [Stable Diffusion](https://nn.labml.ai/diffusion/stable_diffusion/index.html)
V
Varuna Jayasiri 已提交
58

V
urls  
Varuna Jayasiri 已提交
59
#### ✨ [Generative Adversarial Networks](https://nn.labml.ai/gan/index.html)
V
readme  
Varuna Jayasiri 已提交
60 61 62 63
* [Original GAN](https://nn.labml.ai/gan/original/index.html)
* [GAN with deep convolutional network](https://nn.labml.ai/gan/dcgan/index.html)
* [Cycle GAN](https://nn.labml.ai/gan/cycle_gan/index.html)
* [Wasserstein GAN](https://nn.labml.ai/gan/wasserstein/index.html)
V
Varuna Jayasiri 已提交
64
* [Wasserstein GAN with Gradient Penalty](https://nn.labml.ai/gan/wasserstein/gradient_penalty/index.html)
V
Varuna Jayasiri 已提交
65
* [StyleGAN 2](https://nn.labml.ai/gan/stylegan/index.html)
V
readme  
Varuna Jayasiri 已提交
66

V
links  
Varuna Jayasiri 已提交
67
#### ✨ [Recurrent Highway Networks](https://nn.labml.ai/recurrent_highway_networks/index.html)
68

V
links  
Varuna Jayasiri 已提交
69
#### ✨ [LSTM](https://nn.labml.ai/lstm/index.html)
70

V
links  
Varuna Jayasiri 已提交
71 72 73 74 75 76 77 78 79
#### ✨ [HyperNetworks - HyperLSTM](https://nn.labml.ai/hypernetworks/hyper_lstm.html)

#### ✨ [ResNet](https://nn.labml.ai/resnet/index.html)

#### ✨ [ConvMixer](https://nn.labml.ai/conv_mixer/index.html)

#### ✨ [Capsule Networks](https://nn.labml.ai/capsule_networks/index.html)

#### ✨ [U-Net](https://nn.labml.ai/unet/index.html)
80

V
urls  
Varuna Jayasiri 已提交
81
#### ✨ [Sketch RNN](https://nn.labml.ai/sketch_rnn/index.html)
V
Varuna Jayasiri 已提交
82

V
Varuna Jayasiri 已提交
83 84 85
#### ✨ Graph Neural Networks

* [Graph Attention Networks (GAT)](https://nn.labml.ai/graphs/gat/index.html)
V
Varuna Jayasiri 已提交
86
* [Graph Attention Networks v2 (GATv2)](https://nn.labml.ai/graphs/gatv2/index.html)
V
Varuna Jayasiri 已提交
87

V
links  
Varuna Jayasiri 已提交
88 89 90 91 92 93
#### ✨ [Counterfactual Regret Minimization (CFR)](https://nn.labml.ai/cfr/index.html)

Solving games with incomplete information such as poker with CFR.

* [Kuhn Poker](https://nn.labml.ai/cfr/kuhn/index.html)

V
urls  
Varuna Jayasiri 已提交
94 95 96 97 98 99
#### ✨ [Reinforcement Learning](https://nn.labml.ai/rl/index.html)
* [Proximal Policy Optimization](https://nn.labml.ai/rl/ppo/index.html) with
 [Generalized Advantage Estimation](https://nn.labml.ai/rl/ppo/gae.html)
* [Deep Q Networks](https://nn.labml.ai/rl/dqn/index.html) with
 with [Dueling Network](https://nn.labml.ai/rl/dqn/model.html),
 [Prioritized Replay](https://nn.labml.ai/rl/dqn/replay_buffer.html)
V
readme  
Varuna Jayasiri 已提交
100
 and Double Q Network.
V
Varuna Jayasiri 已提交
101

V
urls  
Varuna Jayasiri 已提交
102 103 104 105 106 107 108
#### ✨ [Optimizers](https://nn.labml.ai/optimizers/index.html)
* [Adam](https://nn.labml.ai/optimizers/adam.html)
* [AMSGrad](https://nn.labml.ai/optimizers/amsgrad.html)
* [Adam Optimizer with warmup](https://nn.labml.ai/optimizers/adam_warmup.html)
* [Noam Optimizer](https://nn.labml.ai/optimizers/noam.html)
* [Rectified Adam Optimizer](https://nn.labml.ai/optimizers/radam.html)
* [AdaBelief Optimizer](https://nn.labml.ai/optimizers/ada_belief.html)
V
links  
Varuna Jayasiri 已提交
109
* [Sophia-G Optimizer](https://nn.labml.ai/optimizers/sophia.html)
V
Varuna Jayasiri 已提交
110

V
links  
Varuna Jayasiri 已提交
111 112
#### ✨ [Normalization Layers](https://nn.labml.ai/normalization/index.html)
* [Batch Normalization](https://nn.labml.ai/normalization/batch_norm/index.html)
V
Varuna Jayasiri 已提交
113
* [Layer Normalization](https://nn.labml.ai/normalization/layer_norm/index.html)
V
Varuna Jayasiri 已提交
114 115
* [Instance Normalization](https://nn.labml.ai/normalization/instance_norm/index.html)
* [Group Normalization](https://nn.labml.ai/normalization/group_norm/index.html)
V
links  
Varuna Jayasiri 已提交
116
* [Weight Standardization](https://nn.labml.ai/normalization/weight_standardization/index.html)
V
Varuna Jayasiri 已提交
117
* [Batch-Channel Normalization](https://nn.labml.ai/normalization/batch_channel_norm/index.html)
V
Varuna Jayasiri 已提交
118
* [DeepNorm](https://nn.labml.ai/normalization/deep_norm/index.html)
V
links  
Varuna Jayasiri 已提交
119

V
Varuna Jayasiri 已提交
120 121
#### ✨ [Distillation](https://nn.labml.ai/distillation/index.html)

V
Varuna Jayasiri 已提交
122 123 124 125
#### ✨ [Adaptive Computation](https://nn.labml.ai/adaptive_computation/index.html)

* [PonderNet](https://nn.labml.ai/adaptive_computation/ponder_net/index.html)

126 127 128 129
#### ✨ [Uncertainty](https://nn.labml.ai/uncertainty/index.html)

* [Evidential Deep Learning to Quantify Classification Uncertainty](https://nn.labml.ai/uncertainty/evidence/index.html)

V
Varuna Jayasiri 已提交
130 131 132 133
#### ✨ [Activations](https://nn.labml.ai/activations/index.html)

* [Fuzzy Tiling Activations](https://nn.labml.ai/activations/fta/index.html)

V
links  
Varuna Jayasiri 已提交
134
#### ✨ [Langauge Model Sampling Techniques](https://nn.labml.ai/sampling/index.html)
V
Varuna Jayasiri 已提交
135 136 137 138 139
* [Greedy Sampling](https://nn.labml.ai/sampling/greedy.html)
* [Temperature Sampling](https://nn.labml.ai/sampling/temperature.html)
* [Top-k Sampling](https://nn.labml.ai/sampling/top_k.html)
* [Nucleus Sampling](https://nn.labml.ai/sampling/nucleus.html)

140 141
#### ✨ [Scalable Training/Inference](https://nn.labml.ai/scaling/index.html)
* [Zero3 memory optimizations](https://nn.labml.ai/scaling/zero3/index.html)
V
Varuna Jayasiri 已提交
142

V
Varuna Jayasiri 已提交
143 144
## Highlighted Research Paper PDFs

V
Varuna Jayasiri 已提交
145
* [FlashAttention: Fast and Memory-Efficient Exact Attention with IO-Awareness](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/2205.14135.pdf)
V
Varuna Jayasiri 已提交
146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168
* [Autoregressive Search Engines: Generating Substrings as Document Identifiers](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/2204.10628.pdf)
* [Training Compute-Optimal Large Language Models](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/2203.15556.pdf)
* [ZeRO: Memory Optimizations Toward Training Trillion Parameter Models](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/1910.02054.pdf)
* [PaLM: Scaling Language Modeling with Pathways](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/2204.02311.pdf)
* [Hierarchical Text-Conditional Image Generation with CLIP Latents](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/dall-e-2.pdf)
* [STaR: Self-Taught Reasoner Bootstrapping Reasoning With Reasoning](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/2203.14465.pdf)
* [Improving language models by retrieving from trillions of tokens](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/2112.04426.pdf)
* [NeRF: Representing Scenes as Neural Radiance Fields for View Synthesis](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/2003.08934.pdf)
* [Attention Is All You Need](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/1706.03762.pdf)
* [Denoising Diffusion Probabilistic Models](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/2006.11239.pdf)
* [Primer: Searching for Efficient Transformers for Language Modeling](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/2109.08668.pdf)
* [On First-Order Meta-Learning Algorithms](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/1803.02999.pdf)
* [Learning Transferable Visual Models From Natural Language Supervision](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/2103.00020.pdf)
* [The Sensory Neuron as a Transformer: Permutation-Invariant Neural Networks for Reinforcement Learning](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/2109.02869.pdf)
* [Meta-Gradient Reinforcement Learning](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/1805.09801.pdf)
* [ETA Prediction with Graph Neural Networks in Google Maps](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/google_maps_eta.pdf)
* [PonderNet: Learning to Ponder](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/ponder_net.pdf)
* [Mastering Atari, Go, Chess and Shogi by Planning with a Learned Model](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/muzero.pdf)
* [GANs N’ Roses: Stable, Controllable, Diverse Image to Image Translation (works for videos too!)](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/gans_n_roses.pdf)
* [An Image is Worth 16X16 Word: Transformers for Image Recognition at Scale](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/vit.pdf)
* [Deep Residual Learning for Image Recognition](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/resnet.pdf)
* [Distilling the Knowledge in a Neural Network](https://github.com/labmlai/annotated_deep_learning_paper_implementations/blob/master/papers/distillation.pdf)

V
readme  
Varuna Jayasiri 已提交
169 170 171
### Installation

```bash
V
Varuna Jayasiri 已提交
172
pip install labml-nn
V
readme  
Varuna Jayasiri 已提交
173 174
```

V
Varuna Jayasiri 已提交
175
### Citing
V
readme  
Varuna Jayasiri 已提交
176

V
Varuna Jayasiri 已提交
177
If you use this for academic research, please cite it using the following BibTeX entry.
V
readme  
Varuna Jayasiri 已提交
178 179 180 181

```bibtex
@misc{labml,
 author = {Varuna Jayasiri, Nipun Wijerathne},
V
Varuna Jayasiri 已提交
182
 title = {labml.ai Annotated Paper Implementations},
V
readme  
Varuna Jayasiri 已提交
183
 year = {2020},
V
Varuna Jayasiri 已提交
184
 url = {https://nn.labml.ai/},
V
readme  
Varuna Jayasiri 已提交
185
}
V
Varuna Jayasiri 已提交
186
```
V
links  
Varuna Jayasiri 已提交
187 188 189 190 191 192 193 194 195 196

### Other Projects

#### [🚀 Trending Research Papers](https://papers.labml.ai/)

This shows the most popular research papers on social media. It also aggregates links to useful resources like paper explanations videos and discussions.


#### [🧪 labml.ai/labml](https://github.com/labmlai/labml)

J
Jeroen Van Goey 已提交
197
This is a library that let's you monitor deep learning model training and hardware usage from your mobile phone. It also comes with a bunch of other tools to help write deep learning code efficiently.
V
links  
Varuna Jayasiri 已提交
198