Skip to article frontmatterSkip to article content

Setup

Authors
Affiliations
University of Wisconsin-Madison
prefix.dev GmbH
NVIDIA

Hardware (optional)

This tutorial focuses on hardware acceleration for CUDA environments which require an NVIDIA GPU to use. While an NVIDIA GPU is not required to be able to work through the tutorial, access to one will be required to run the examples.

Software

This tutorial requires minimal software to be installed in advance:

Web Platforms (optional, but encouraged)

For this tutorial we would like you to create your own Git repository where you add the results of your work as you move through the tutorial so that you have a sharable form of what you have learned by the end. It doesn’t need to be GitHub (GitLab.com or some other alternative exist) but for the sake of consistency, the instructions will assume you are using GitHub.

Installation

Pixi

To install Pixi follow the installation instructions for your particular machine and then restart your shell.

Unix (Linux and macOS) and Windows Terminal
Windows PowerShell
curl -fsSL https://pixi.sh/install.sh | sh

Pixi Shell completions

Additionally, install the Pixi shell completions for your particular shell choice.

Git

You probably already have Git installed on your machine. You can check with

command -v git

If the command doesn’t return a filepath to the git executable, first make sure you have Pixi installed, as described above, and then run

pixi global install git

You can now use the Git anywhere on your machine.

GitHub CLI (gh)

If you are not already familiar with git and GitHub, we recommend installing the GitHub CLI to simplify the workflow. To install the GitHub CLI, first make sure you have Pixi installed, as described above, and then run

pixi global install gh

Then log in to your GitHub account with

gh auth login

You can now use the GitHub CLI anywhere on your machine.

Brev

Brev CLI

For the portion of the tutorial where GPUs will be used we’ll be working on an NVIDIA Brev instance. To install the CLI API for Brev, we’ll use pixi global so make sure you first have Pixi installed, as described above, and then run

pixi global install brev

You can now use the Brev CLI anywhere on your machine. Check out the CLI options with

brev --help

Setup a Personal GitHub Repository

To share your work from this tutorial, we will create a GitHub repository to store your code and results. This will allow you to easily share your work with others and keep track of your progress, or share it with the Brev instance.

  1. Create a personal GitHub account if you don’t have one yet.
  2. Add a new repository to your account through this link: Create a new repository.
  3. Name the new repository reproducible-ml-scipy-2025, make it public, and give it a README and an open source license (e.g. MIT License).

To streamline this we recommend using the GitHub CLI to create the repository.

Feel free to change any of the options below to suit your needs, but the following command will create a new public repository with a README, a Python .gitignore, and an MIT license:

gh repo create reproducible-ml-scipy-2025 \
   --public \
   --description "Reproducible Machine Learning Workflows for Scientists with Pixi at SciPy 2025" \
   --add-readme \
   --gitignore Python \
   --license MIT \
   --clone

Because of the --clone option, this will also clone the newly created repository to your local machine. Now you can navigate to the newly created repository directory:

cd reproducible-ml-scipy-2025

Now you have a GitHub repository set up to store your work from this tutorial.

Prepare Brev Instance

Create an NVIDIA Brev account

To access the NVIDIA Brev instance you’ll also need to create an NVIDIA Brev account.

Login to Brev account with Brev CLI

To validate your Brev account and your Brev CLI install, login to your Brev account from the command line with brev login.

brev login

Prepare an NVIDIA Brev instance

Later on in the SciPy 2025 tutorial, we’ll use a coupon code to provision a new Brev GPU instance environment.

The particular configuration we’ll be using is:

You can select it from the Brev new environment page

brev-new-environment

OR run the following command to create a new instance with the same configuration:

brev create pixi-cuda --gpu g2-standard-4:nvidia-l4:1

Access the NVIDIA Brev instance on your machine

Once the instance is created, get access to it with the following command:

# Open the instance in vscode:
brev open pixi-cuda
# Or start an ssh session into the instance
brev shell pixi-cuda

Prepare your Brev instance

Once you have access to the Brev instance, you can use it like any other Linux machine and install any additional software you need. Please install the following software on your Brev instance:

# Pixi
curl -fsSL https://pixi.sh/install.sh | sh
echo -e '\neval "$(pixi completion --shell bash)"' >> ~/.bashrc
source ~/.bashrc
# Additional tools
pixi global install gh