sidebar_position | description | title |
---|---|---|
12 |
Using the web based application https://platform.grid.ai |
Typical Workflow (Web User) |
import Video from "@site/src/components/Video";
:::tip For all code snippets you can modify the instance type yo suit your needs. Please see the billings page for machine options and price and the machines page for recommended machine types. :::
The goal of this tutorial is to walk through a typical workflow using the Grid Web app.
For users who prefer the command-line (CLI) this is the mirror tutorial for the CLI
:::note Grid has a 1:1 match in functionality with the CLI. :::
We'll use image classification as an example to illustrate the key ideas. The typical workflow goes like this:
Note a few things:
- The dataset is small so the tutorial can be quick. But the workflow doesn't change for large-scale data.
- We'll use PyTorch Lightning for simplicity, but the framework can be any of your choice.
- If you are signed into Grid with Google, make sure to link a Github account to your profile before launching your first run!
time | step |
---|---|
2 minutes | Preparing the dataset |
2 minutes | Creating a Datastore |
2 minutes | Starting a Session |
5 minutes | develop the model |
1 minute | Pause the Session |
1 minute | Run (hyperparameter sweep) |
3 minutes | Bonus: Become a power user |
Term | Description |
---|---|
CIFAR-5 | A dataset with 5 classes (airplane, automobile, ship, truck, bird). |
grid datastore | High-performance, low-latency, auto-versioned dataset. |
grid run | Runs a model (or many models) on a cloud machine (hyperparam sweep) |
grid session | A LIVE machine with 1 or more GPUs for developing models |
An experiment | A single model with a given configuration |
A run | A collection of experiments |
ssh | A way to connect from a local machine to a remote machine |
For this tutorial we'll be using CIFAR-5. This is a subset of CIFAR-10 that we've chosen to make the models train faster.
The goal is to teach a small neural network to classify these 5 sets of classes.
(Time: 2 minutes)
If your dataset is already is in zip/tar/tar.gz format you can create a datastore by simply pasting it into the UI.
But for the sake of simulating a non-trivial workflow where you already have the data locally or on a cluster, go ahead and download the dataset to your machine and unzip it.
- DOWNLOAD CIFAR-5
- unzip it
You should now have a folder with this structure:
Now that we all have the same data, let's start the real tutorial!
(Time: 2 minutes)
:::note
Use the datastore name cifar5
in order to complete the tutorial successfully.
:::
In a realistic workflow, we would start here. The first thing you want to do is to create a DATASTORE on Grid with your dataset. The datastore will optimize your data for low-latency, and high-availability to any machine you run on Grid.
Let's create the datastore:
:::note For datasets 1 GB or larger, use the CLI :::
(Time: 2 minutes)
Now that your data has been uploaded the next step in a real workflow is to spend time doing any of the following:
- Develop/Debug the model
- Prototyping it on multiple GPUs
- Adjusting the batch size to maximize GPU usage
- Using the model for analysis, which might require GPUs
- Explore and visualize the model
This is exactly what Sessions were created for.
Start a Session named resnet-debugging with 2 M60 GPUs on it and attach our CIFAR-5 dataset.
Sessions really shine with huge datasets. The automatic mounting feature means you can jump straight to work without waiting a long time for your data to be available.
:::note TIP: If you prefer to ssh directly or use VSCode (instead of using JupyterLab), the other icons have setup instructions. :::
(Time: 5 minutes)
Now that you have your data, code, and 2 GPUs, we get to the fun part! Let's develop the model
For this tutorial, I'm going to use a non-trivial project structure that is representative of realistic use cases [code link].
The project has this structure
This folder is complicated on purpose to showcase that Grid is designed for realistic deep learning workloads. I'm purposely avoiding simple projects (code reference) that look like this (since those are trivial for Grid to handle.)
:::note For best practices structuring machine learning projects in general, read our guide. (Coming Soon) :::
On the session you would normally:
- debug
- develop
- tune batch size
- etc...
We're going to run the model using the following instructions. This GIF illustrates what we are about to do).
Clone the project on the interactive Session
git clone https://github.com/PyTorchLightning/grid-tutorials.git
Install requirements + project
cd grid-tutorials/getting-started
pip install -r requirements.txt
now run the following command to train a resnet50 on 2 GPUs
python flash-image-classifier.py \
--data_dir /datastores/cifar5 \
--gpus 2 \
--epochs 4
At this step (in a real workflow) you would code the model, debug, tune batch size, etc...
Grid even lets you do this from your local VSCode (read this guide to set that up).
Once you're ready, commit your changes so we can train at scale
git commit -am "changes"
git push
(Time: 1 minute)
Great! now that our model is ready to run at scale, we can pause the session. Pausing keeps your environment as is so you don't have to rebuild it next time you want to work on this model.
It's a good idea to use a different session per project you're working on, so it's easy to pick up where you left off.
:::note Paused Sessions don't cost you money! :::
(Time: 1 minute)
Once your model is ready to go, you usually want to train it to convergence. If you already know a good set of hyperparameters then your run will be very simple since it will train a single model.
If you'd like to find better hyperparameters for your model, a RUN can launch multiple variations of your model to try all hyperparameters at once.
First commit all your changes and push to GitHub
git commit -am "ready to run"
git push
Now let's kick off the RUN.
First, paste this link in the run page.
https://github.com/PyTorchLightning/grid-tutorials/blob/main/getting-started/flash-image-classifier.py
Add the following args to spin up 5 different experiments
--data_dir /datastores/cifar5 \
--gpus 2 \
--epochs 4 \
--learning_rate "uniform(1e-5, 1e-1, 5)"