Visualizing the size of Large Language Models 💻

Anil George
7 min readAug 1, 2023

--

The 3 Important factors that determine the size of a Language model are:

  1. Model Size
  2. Training Size
  3. Compute Size

🎛 Visualizing Model Size

The Model Size depends on the number of learnable parameters in the Model.

  • These parameters comprise the weights (and biases) linked to the individual neurons in the Model’s neural network.
  • Before training, these parameters are set to random values. As the training process proceeds, they get updated to optimize the Model’s performance on a specific task.
  • In the analogy of “Dials” and “Knobs” — this can be likened to adjusting the various dials in a device to tune it correctly.

Once training is complete, the final parameter values can be envisioned as cell values stuffed into a “Giant Excel sheet”.

Model Parameters = Values in a Giant Excel Sheet

Model Size in terms of Football Fields

  • If we assume each Excel cell is (1cm x 1cm) in size.
  • A single Football field-sized Excel sheet (100m x 60m) will contain approx. 60 million parameters. This is roughly equal to the number of parameters in the original Transformer model released in 2017.
1 Football Field = 60 million parameters
  • GPT-1, released in 2018, contained about 117 million parameters. Equivalent to an Excel sheet the size of 2 Football Fields (2FFs).
  • The recent PALM 1, 2 (340M-540M) models from Google can be visualized as a giant Excel sheet the size of 6000–7000 Football Fields!
List of LLMs by Model Size and Release Year
-------------------------------------------

2017 - Original Transformer - 65 Million Parameters ( or 1 Football field)

2018 - GPT 1 - 117 Million Parameters ( or 2 FFs)

2019 - GPT 2 - 1500 Million Parameters ( or 20 FFs)

2020 - GPT 3 - 175,000 Million Parameters ( or 2500 FFs)

2021 - Gopher - 280,000 Million Parameters ( or 4000 FFs)

2022 - PALM - 540,000 Million Parameters ( or 7700 FFs)
Model Parameters vs Release Year (Log Scale)

📚 Visualizing Training Size

The Training Size depends on the number of Tokens in the Training dataset.

  • A Token can be a word, sub-word, or character — depending on how the training text is divided into tokens (Tokenization).
  • The Training dataset is split into Batches, tokens within each Batch are processed together before updating the Model’s parameters.
  • A single pass of the entire Training dataset through the Model is called an Epoch.
  • Most recent language models, have Epoch = 1. Consequently, such Models “see” a Token in the Training dataset only once.

Training Size in terms of Library Shelves 🗄️

  • The Training process can be visualized as the Model “reading” words from a large Collection of Books.
  • If we assume a typical Book contains ~100,000 Tokens and a typical Library shelf holds ~100 books. Each Library shelf would contain about 10 million Tokens.
1 Library Shelf = 10 million tokens
  • The original Transformer model for English to German translation used the WMT dataset with 4.5 million sentence pairs (~100 million tokens or 10 Library shelves).
  • GPT-1 was trained on 7000 books from the Book Corpus dataset (~600 million tokens or 60 Library shelves).
  • The recent PALM models from Google were trained on 780 billion tokens, equivalent to 78,000 Library shelves!
List of LLMs by Training Size and Release Year 
---------------------------------------------

2017 - Original Transformer - 100 Million Tokens ( or 10 Library shelves)

2018 - GPT 1 - 600 Million Tokens ( or 60 shelves)

2019 - GPT 2 - 28000 Million Tokens ( or 2800 shelves)

2020 - GPT 3 - 300,000 Million Tokens ( or 30,000 shelves)

2021 - Gopher - 300,000 Million Tokens ( or 30,000 shelves)

2022 - PALM - 780,000 Million Tokens ( or 78,000 shelves)
Training Tokens vs Release Year (Log Scale)

🧮 Visualizing Compute Size

The Compute size depends on the number of floating-point operations (FLOPs), or computations required during different stages of Model Training.

Typical FLOPs capacity for Different Devices at FP32 precision 
(1GFLOP = 1 Billion FLOPs = 1E+9 FLOPs)

1. 💻 A Modern mid-size laptop ~ 100 GFLOPs

2. 📱 Apple iPhone 14 Pro ~ 2000 GFLOPs

3. 🎮 Sony PlayStation 5 ~ 10000 GFLOPs

4. 🖥️ Nvidia H100 NVL GPU ~ 134,000 GFLOPs

Stages during Training include:

  1. Forward Pass — Model takes a sequence of Training tokens as Input and makes a Prediction. (e.g., the next word in the sequence).
  2. Loss Computation — The difference between the Predicted value and Actual value is computed through a Loss Function.
  3. Backpropagation and Parameter Update — The gradient of the Loss Function is computed (via Backpropagation) and is used to update the Model parameters to minimize the Loss.
  4. Multiple Epochs — The process of forward pass, loss computation, backpropagation, and parameter update are repeated for all batches in the training dataset across multiple ‘runs’ or Epochs.
  5. In most Modern LLMs, Epoch is equal to 1, which means the Model processes the entire training dataset just once.

The approximate number of Computations required for the entire Training process is given by the below thumb rule:

Ct ~ 6.N.D 

where Ct = Number of Training Computations
N = Number of Model Parameters
D = Number of Training Tokens

Using the 6ND formula for Training computations:

  1. The original Transformer model (for English to German task) would have consumed 3.9 E+16 FLOPs for 1 Epoch, assuming 10 Epochs we get 3.9 E+17 FLOPs. (Equivalent to 45 days training time on a Midsize Laptop = 100GFLOPs)
  2. GPT-1 would have consumed 4.2 E+17 FLOPs for 1 Epoch, assuming 100 Epochs we get 4.2 E+19 FLOPs. (Equivalent to 13 years training time on a Midsize Laptop)
  3. GPT-2 would have consumed 2.5 E+20 FLOPs for 1 Epoch , assuming 20 Epochs we get 5 E+21 FLOPs. (Equivalent to 1600 years training time on a Midsize Laptop)
  4. The more recent PALM model would have consumed 2.53 E+24 FLOPs assuming Epoch = 1. (Equivalent to 800,000 years training time on a Midsize Laptop!)

Inference Computations: The approx. number of computations required at Inference time is given by the below thumb rule:

Ci ~ 2.N.l 

where Ci = Number of Inference Computations
N = Number of Model Parameters
l = Input\Output length
Typical Laptop = 100 GFLOPs = 1.0 E+11 FLOPs
List of LLMs by Training Compute Size and Release Year 
---------------------------------------------

2017 - Original Transformer - 3.9E+17 FLOPs ( ~ 45 Days avg. Laptop)

2018 - GPT 1 - 4.21E+19 FLOPs ( ~ 13 Years on avg. Laptop)

2019 - GPT 2 - 5.04E+21 FLOPs ( ~ 1600 Years on avg. Laptop)

2020 - GPT 3 - 3.15E+23 FLOPs ( ~ 99900 Years on avg. Laptop)

2021 - Gopher - 5.04E+23 FLOPs ( ~ 160000 Years on avg. Laptop)

2022 - PALM - 2.53E+24 FLOPs ( ~ 800000 Years on avg. Laptop)

Bonus: Visualizing GPT4 Model Size

Below information on GPT4 architecture is based on a leaked report by SemiAnalysis:

Model Size 🎛

  • GPT4 employs a Mixture of Experts (MoE) model with 16 experts (111 billion parameters per expert) for a total of ~1.8 trillion Parameters.
  • To fit GPT4 parameters in a giant Excel Sheet, it will need to be the size of 30,000 Football Fields or 180 square kms (more than the size of Mumbai City!)

Training Size 📚

  • GPT4 was trained on ~13 trillion tokens (across Multiple Epochs).
  • This is equivalent to reading all books contained within 1.3 million Library Shelves or 650 Km long line of Library Shelves!

Compute Size 🧮

  • Estimated Training FLOPs for GPT 4 ~ 2.15 E25 FLOPs.
  • To train GPT4 on mid-size Laptop (100GFLOPs) it will take 7 million years!

Estimated Training Cost ~ $ 64 Million

Estimated Inference Cost ~ 0.3 cents for 1000 input & output tokens

GPT4 Model Estimates

--

--