A nanoGPT pipeline packed in a spreadsheet
This is a project that I did to help myself understand how GPT works.
It is pretty fun to play with, especially when you are trying to figure out what exactly is going on inside a transformer.
This helped me to visualize the entire structure and the data flow.
All the mechanisms, calculations, matrices inside are fully interactive and configurable.
While reading about LLMs, I realised that the internal mechanisms of a transformer is basically a range of matrices calculations being connected in a certain order.
I started to wonder if the whole process can be repersented in a spreadsheet since all the calculations are fairly simple.
I'm a visual thinker, I couldn't think of a better way to do it.
Then with some trial and errors, I wrote the full inference pipeline of the nanoGPT architecture into a single spreadsheet.
Forget python, it turned out that spreadsheet is all you need.
This is the full view of the spreadsheet
Zooming into the core of a transformer--self attention
It contains all the transformer components including:
- embedding
- layer norm
- self attention
- projection
- MLP
- softmax
- logits
It is based on Andrej Karpathy's NanoGPT structure which includes roughly 85000 parameters.
It is clearly a very small size, but it is both complex enough for me to understand how it works, and also not too big to crash my computer.
In contrast to chatgpt, this project is a character based prediction system, meaning that each token is a character, and to reduce the complexity, only letter A/B/C are being tokenized.
In the numbers file "nanoGPT.numbers", you will see two tabs, one called "no weights" and one called "random weights".
They are essentially the same thing, only that all the parameters in the "random weights" tab is randomly generated and the parameters in the "no weights" tab is very tidy and it shows weird values down the pipeline, but it is also clearer to help you read it. That's why I kept both.
Due to the internal mechanism of spreadsheet softwares, everytime you update the spreadsheet in the "random weights" tab, all the values will be regenerated again (freezes the computer for a few seconds as it is a lot of calculation which is a bit annoying, but you can avoid it by turning all the values into a static value).
The spreadsheet doesn't contain actual trained weights and parameters, so you should not expect it to calculate the correct result for you before you update the parameters.
You might also be wondering if there is an excel or a google sheets version, unfortunately there isn't one yet.
It is simply because the whole pipeline is too large and I need multiple tables to organize everything, and only numbers can do this.
I will see if I can recreate this in excel in the near future.
Firstly, all the blocks are the values or parameters that is processed through the GPT architecture, they are being color coded as purple, green and orange.
Purple: these are parameters that are supposed be replaced by a trained model's parameter.
Green: these are the values that started from the input and gets transformed into the end results.
Orange: these are just intermediate values that are used for the calculation, they are here so it is less confusing.
Secondly, you should start from the top and work all the way down to the bottom, and there are labels on the left of the page showing what stage you are in.
There are three transformers labeled 0/1/2, each have the same structure and should contain different parameters, data will go through all of them in the sequential order.
Lastly, this demo is built with great help from the LLM visualization project (https://bbycroft.net/llm) by Brendan Bycroft which uses 3D animations to explain transformers.
I kept the example it used which is about sorting letters.
- Read through the whole spreadsheet will help you form a visual impression of what a transformer is.
- Each cell contains the actual calculation, which you can double click to checkout the details(function).
- By selecting the green cells (the values), you can see which other values or parameters are influencing this cell, so that you can get a sense of the mechanism.
- Try to make changes to the parameters and see what might happen.
- If you happen to have the weights of NanoGPT, you can replace the parameters in this spreadsheet to get it working properly.
I wish I could just upload all the tutorials I've watched into chatgpt and ask it to generate this file, but I guess we are not there yet.
Anyone is welcomed if they want to build something more complicated than nanoGPT, although I do feel like nanoGPT in a spreadsheet is already a lot for my M2 chip.
Thanks to the following projects that helped me a lot when creating this spreasheet.
If you are interested in my project, the following links will also be very helpful, much more helpful than spreadsheet is all you need.
- Andrej Karpathy's youtube tutorial "Let's build GPT": https://www.youtube.com/watch?v=kCc8FmEb1nY
- Andrej Karpathy's NanoGPT project: https://github.com/karpathy/nanoGPT
- Brendan Bycroft's 3D visualization of transformers: https://bbycroft.net/llm
- 3Blue1Brown's LLM course: https://youtu.be/eMlx5fFNoYc?si=k40zeuPdM_4cB88o