Skip to content

Latest commit

 

History

History
 
 

Optional Setup Instructions

This document lists different approaches for setting up your machine and using the code in this repository. I recommend browsing through the different sections from top to bottom and then deciding which approach best suits your needs.

 

Quickstart

If you already have a Python installation on your machine, the quickest way to get started is to install the package requirements from the ../requirements.txt file by executing the following pip installation command from the root directory of this code repository:

pip install -r requirements.txt

 

Local Setup

This section provides recommendations for running the code in this book locally. Note that the code in repository is designed to run on conventional laptops within a reasonable timeframe and does not require specialized hardware. I tested all code on an M3 MacBook Pro Max laptop. Additionally, if your laptop or desktop computer has an NVIDIA GPU, the code will automatically take advantage of it.

 

Setting up Python

If you don't have Python set up on your machine yet, I have written about my personal Python setup preferences in the following directories:

The Using DevContainers section below outlines an alternative approach for installing project dependencies on your machine.

 

Using Docker DevContainers

As an alternative to the Setting up Python section above, if you prefer a development setup that isolates a project's dependencies and configurations, using Docker is a highly effective solution. This approach eliminates the need to manually install software packages and libraries and ensures a consistent development environment. You can find more instructions for setting up Docker and using a DevContainer:

 

Visual Studio Code Editor

There are many good options for code editors. My preferred choice is the popular open-source Visual Studio Code (VSCode) editor, which can be easily enhanced with many useful plugins and extensions (see the VSCode Extensions section below for more information). Download instructions for macOS, Linux, and Windows can be found on the main VSCode website.

 

VSCode Extensions

If you are using Visual Studio Code (VSCode) as your primary code editor, you can find recommended extensions in the .vscode subfolder. These extensions provide enhanced functionality and tools helpful for this repositoy.

To install these, open this "setup" folder in VSCode (File -> Open Folder...) and then click the "Install" button in the pop-up menu on the lower right.

Alternatively, you can move the .vscode extension folder into the root directory of this GitHub repository:

mv setup/.vscode ./

Then, VSCode automatically checks if the recommended extensions are already installed on your system every time you open the Building-an-LLM-From-Scratch main folder.

 

Cloud Resources

This section describes cloud alternatives for running the code presented in this book.

While the code can run on conventional laptops and desktop computers without a dedicated GPU, cloud platforms with NVIDIA GPUs can substantially improve the runtime of the code, especially in parts 4 to 6.

 

Using Lightning Studio

For a smooth development experience in the cloud, I recommend the Lightning AI Studio platform, which allows users to set up a persistent environment and use both VSCode and Jupyter Lab on cloud CPUs and GPUs.

Once you start a new Studio, you can open the terminal and execute the following setup steps to clone the repository and install the dependencies:

git clone https://github.com/Sangwan70/Building-an-LLM-From-Scratch.git
cd Building-an-LLM-From-Scratch
pip install -r requirements.txt

(In contrast to Google Colab, these only need to be executed once since the Lightning AI Studio environments are persistent, even if you switch between CPU and GPU machines.)

Then, navigate to the Python script or Jupyter Notebook you want to run. Optionally, you can also easily connect a GPU to accelerate the code's runtime, for example, when you are pretraining the LLM in part 4 or finetuning it in part 5 and 6.

 

Questions?

If you have any questions, please don't hesitate to reach out via the Discussions forum in this GitHub repository.