Prerequisites
Before beginning this guide, make sure you’ve:- Completed setup and installation
- Read through Trainer Essentials and Trainer Configuration which cover the basics of running models in Model Zoo.
Configure the Run
This page will cover the two main flows you can employ to perform pretraining. One using a YAML configuration file and a training script that is packaged in the Cerebras ModelZoo. The other using pure Python to run on your own. They will be presented side-by-side so that you can compare the two flows as you progress through this tutorial. If you aren’t interested in seeing the break down of the configuration, you can skip ahead to the Putting It All Together section to see the full configuration.Configure the Wafer-Scale Cluster
Let’s first figure out how much resources you’ll want to use for this pretraining job. In this example, let’s use a 16 node Wafer-Scale Cluster. To configure this, you can specify the number of Cerebras systems to use.num_csx to scale the run without making any changes to the model itself.
Configure the Model
Here you will be pretraining the LLaMA3 model class that comes packaged inside of the Cerebras ModelZoo. The LLaMA3 model by default will compute the accuracy and perplexity metrics during upstream validation.- YAML: To configure the LLaMA3 8B model, you specify the following parameters to the model key.
- 
Python: To configure the LLaMA3 8B model, you construct the model inside a lambda to take advantage of the Trainer’s efficient weight initialization feature. LLaMA3 is just a configuration of GPT2, hence why you are importing and initializing a Gpt2Modelclass.
Configure the Optimizer
Here you will be using theAdamW optimizer to optimize our model during pretraining.
- 
YAML: To configure the AdamWkey. Note, you don’t specify a learning rate here as you will configure a learning rate scheduler, just below.
- 
Python: Note, you specified a placeholder learning rate of 0.01here as you will configure a learning rate scheduler, just below.
Configure a Learning Rate Scheduler
Here you will be using aCosineDecayLR learning rate scheduler.
To configure the CosineDecayLR key.
Configure Mixed Precision and Gradient Scaling
To get better performance, let’s use mixed precision in the run. More specifically, let’s configure the cluster to usecbfloat16 as the lower precision type (see CB16 Half-Precision for more details on the cbfloat16 data format).
Since a lower precision is being used for activations, you’ll want to scale the gradients to prevent underflowing. Let’s use dynamic loss scaling for this run.
In addition, to prevent gradients from exploding, let’s also clip the gradients based on its norm.
- YAML: To configure the precision type and gradient scaling, you can specify the following parameters to the precision key.
- 
Python: To configure the precision type and gradient scaling, you can construct a MixedPrecisionobject as follows.
Configure the Training/Validation Loop
For this tutorial, let’s pre-train the model for 10k steps and run validation every 1k steps.- YAML: To configure the number of training and validation steps you can specify the following parameters to the loop key.
- 
Python: To configure the number of training and validation steps, you can construct a TrainingLoopobject as follows.
Configure Checkpointing
In case you want to restart training from some point in the middle with different hyperparameters, let’s save a checkpoint every 1000 steps of training. This conveniently lines up nicely with the validation frequency you specified above so that you’ll know how well the model was performing at each checkpoint.- YAML: To configure how often checkpoints are taken, you specify the following parameters to the checkpoint key.
- 
Python: To configure how often checkpoints are taken, you can construct a Checkpointobject as follows.
Configure Callbacks
The following steps are completely optional. For this pretraining run, let’s keep track of the gradient norms to make sure that the model numerics are stable. In addition, let’s ensure that the loss values that the model is outputting are valid (i.e. notNaN or inf).
Finally, since upstream validation is being run, let’s make sure that the validation metrics that are computed are being logged.
- YAML: To configure these checks, you can specify the following callbacks to the callbacks key.
- Python: To configure these checks, you can construct the following callbacks and pass them to the trainer.
Configure Loggers
To keep track of the progress of our run, let’s also employ the use of the progress logger as well as the TensorBoard logger.- YAML: To configure these loggers, you can specify the following to the loggers key.
- Python: To configure these loggers, you can construct the following and pass them to the trainer.
Reproducibility
In order to make the pretraining run reproducible, you must set the Trainer’s seed.- YAML: You can do this by specifying the [seed](/model-zoo/trainer-configuration-overview key.
- Python: You can do this by specifying the seed argument to the Trainer’s constructor as follows.
Setting different seeds across different runs of the same model may cause multiple compiles.
Configure Dataloaders
Now that you’ve constructed theTrainer object, you’re almost ready to start the pretraining run.
One of the only things left to do is to configure the training and validation dataloaders you’ll be using.
- YAML: To configure the training and validation dataloaders, you can specify the following to the [train_dataloader](/model-zoo/trainer-configuration-overview key).
- 
Python: To configure the training and validation dataloaders, you can construct DataLoaderobjects and pass them into the Trainer’sfitmethod as follows.
Please make sure to change the 
data_dir arguments to point to the actual directories containing the data.Putting It All Together
That is all there is to configuring the pretraining run! Let’s take a moment to step back and look at the full configuration that you’ve put together thus far.Start Pretraining
Now that you have a fully configured Trainer, all there is to do now is to kick off the run and start pretraining.- 
YAML: Let’s assume that the YAML configuration that you put together above is written to a file called ./pretrain_llama_8b.yaml. To run pretraining, use the CLI command.
- 
Python: Let’s assume that the python code that you put together above is written to a file called ./pretrain_llama_8b.py. To run pretraining, execute that python script.
Monitor the Run
Once compilation finishes and the Wafer-Scale Cluster is programmed for execution, you should start seeing progress logs that look likeThe performance numbers that you get will vary depending on how many Cerebras systems you are using and which generation systems you are using.


