This repository was created to follow the well-structured course provided by ARENA, which covers the basics of AI programming and explores technical research in AI safety.
I will update this repository with my progress, using the resources from ARENA, including notebooks and exercises.
A big thanks to ARENA for their support and for providing the resources to help me develop my skills in this field.
The material on this page covers the first five days of the curriculum. It can be seen as a grounding in all the fundamentals necessary to complete the more advanced sections of this course (such as RL, transformers, mechanistic interpretability, training at scale, and generative models).
Some highlights from this chapter include:
- Building your own 1D and 2D convolution functions
- Building and loading weights into a Residual Neural Network, and finetuning it on a classification task
- Working with weights and biases to optimise hyperparameters
- Implementing your own backpropagation mechanism
- Building your own GANs and VAEs, and using them to generate images
The material on this page covers transformers (what they are, how they are trained, how they are used to generate output) as well as mechanistic interpretability (what it is, what are some of the most important results in the field so far, why it might be important for alignment) and other topics related to interpretability (function vectors & model steering).
Some highlights from this chapter include:
- Building your own transformer from scratch, and using it to sample autoregressive output
- Using the TransformerLens library developed by Neel Nanda to locate induction heads in a 2-layer model
- Finding a circuit for indirect object identification in GPT-2 small
- Intepreting model trained on toy tasks, e.g. classification of bracket strings, or modular arithmetic
- Replicating Anthropic's results on superposition, and training sparse autoencoders to recover features from superposition
- Using steering vectors to induce behavioural changes in GPT2-XL
Unlike the first chapter (where all the material was compulsory), all sections of this chapter are optional extensions other than the first two exercise sets. In these first two sets you will build and train transformers, and gain a basic understanding of mechanistic interpretability of transformer models which includes induction heads & use of TransformerLens. After this, you can pick any of the other six sets of exercises you want - there are no prerequisites!
If you've finished the compulsory material and are choosing between the other six sets of exercises, we weakly recommend choosing one of the first three (IOI, superposition, and function vectors). IOI should appeal to the experimentalists, superposition to the theorists / mathematicians, and function vectors to the engineers, so there's something for everyone!
Additionally, each optional set of exercises includes a lot of suggested bonus material / further exploration once you've finished, including suggested papers to read and replicate.
Reinforcement learning is an important field of machine learning. It works by teaching agents to take actions in an environment to maximise their accumulated reward.
In this chapter, you will be learning about some of the fundamentals of RL, and working with OpenAI’s Gym environment to run your own experiments.
Some highlights from this chapter include:
- Building your own agent to play the multi-armed bandit problem, implementing methods from Sutton & Barto
- Implementing a Deep Q-Network (DQN) and Proximal Policy Optimization (PPO) to play the CartPole game
- Applying RLHF to autoregressive transformers like the ones you built in the previous chapter
Additionally, the later exercise sets include a lot of suggested bonus material / further exploration once you've finished, including suggested papers to read and replicate.