Introduction
This guide introduces you to machine learning with GitHub Codespaces. You’ll build a simple image classifier, learn about some of the tools that come preinstalled in GitHub Codespaces, configure your development environment for NVIDIA CUDA, and open your codespace in JupyterLab.
Building a simple image classifier
We'll use a Jupyter notebook to build a simple image classifier.
Jupyter notebooks are sets of cells that you can execute one after another. The notebook we'll use includes a number of cells that build an image classifier using PyTorch. Each cell is a different phase of that process: download a dataset, set up a neural network, train a model, and then test that model.
We'll run all of the cells, in sequence, to perform all phases of building the image classifier. When we do this Jupyter saves the output back into the notebook so that you can examine the results.
Creating a codespace
- 
Go to the github/codespaces-jupyter template repository. 
- 
Click Use this template, then click Open in a codespace.  
A codespace for this template will open in a web-based version of Visual Studio Code.
Opening the image classifier notebook
The default container image that's used by GitHub Codespaces includes a set of machine learning libraries that are preinstalled in your codespace. For example, Numpy, pandas, SciPy, Matplotlib, seaborn, scikit-learn, Keras, PyTorch, Requests, and Plotly. For more information about the default image, see "Introduction to dev containers" and the devcontainers/images repository.
- In the VS Code editor, close any "Get Started" tabs that are displayed.
- Open the notebooks/image-classifier.ipynbnotebook file.
Building the image classifier
The image classifier notebook contains all the code you need to download a dataset, train a neural network, and evaluate its performance.
- 
Click Run All to execute all of the notebook’s cells.  
- 
If you are prompted to choose a kernel source, select Python Environments, then select the version of Python at the recommended location.  
- 
Scroll down to view the output of each cell.  
Configuring NVIDIA CUDA for your codespace
Some software requires you to install NVIDIA CUDA to use your codespace’s GPU. Where this is the case, you can create your own custom configuration, by using a devcontainer.json file, and specify that CUDA should be installed. For more information on creating a custom configuration, see "Introduction to dev containers."
Note: For full details of the script that's run when you add the nvidia-cuda feature, see the devcontainers/features repository.
- 
Within the codespace, open the .devcontainer/devcontainer.jsonfile in the editor.
- 
Add a top-level featuresobject with the following contents:JSON "features": { "ghcr.io/devcontainers/features/nvidia-cuda:1": { "installCudnn": true } }For more information about the featuresobject, see the development containers specification.If you are using the devcontainer.jsonfile from the image classifier repository you created for this tutorial, yourdevcontainer.jsonfile will now look like this:{ "customizations": { "vscode": { "extensions": [ "ms-python.python", "ms-toolsai.jupyter" ] } }, "features": { "ghcr.io/devcontainers/features/nvidia-cuda:1": { "installCudnn": true } } }
- 
Save the change. 
- 
Access the VS Code Command Palette (Shift+Command+P / Ctrl+Shift+P), then start typing "rebuild". Click Codespaces: Rebuild Container.  The codespace container will be rebuilt. This will take several minutes. When the rebuild is complete the codespace is automatically reopened. The codespace container will be rebuilt. This will take several minutes. When the rebuild is complete the codespace is automatically reopened.Tip: You may occasionally want to perform a full rebuild to clear your cache and rebuild your container with fresh images. For more information, see "Rebuilding the container in a codespace." 
- 
Publish your change to a repository so that CUDA will be installed in any new codespaces you create from this repository in future. For more information, see "Creating a codespace from a template." 
Opening your codespace in JupyterLab
You can open your codespace in JupyterLab from the "Your codespaces" page at github.com/codespaces, or by using GitHub CLI. For more information, see "Opening an existing codespace."
The JupyterLab application must be installed in the codespace you are opening. The default container image includes JupyterLab, so codespaces created from the default image will always have JupyterLab installed. For more information about the default image, see "Introduction to dev containers" and the devcontainers/images repository. If you're not using the default image in your dev container configuration, you can install JupyterLab by adding the ghcr.io/devcontainers/features/python feature to your devcontainer.json file. You should include the option "installJupyterlab": true. For more information, see the README for the python feature, in the devcontainers/features repository.



 Formed in 2009, the Archive Team (not to be confused with the archive.org Archive-It Team) is a rogue archivist collective dedicated to saving copies of rapidly dying or deleted websites for the sake of history and digital heritage. The group is 100% composed of volunteers and interested parties, and has expanded into a large amount of related projects for saving online and digital history.
 Formed in 2009, the Archive Team (not to be confused with the archive.org Archive-It Team) is a rogue archivist collective dedicated to saving copies of rapidly dying or deleted websites for the sake of history and digital heritage. The group is 100% composed of volunteers and interested parties, and has expanded into a large amount of related projects for saving online and digital history.
