dgx-spark-playbooks/nvidia/pytorch-fine-tune/README.md

87 lines
2.0 KiB
Markdown
Raw Normal View History

2025-10-05 17:01:34 +00:00
# Fine tune with Pytorch
> Use Pytorch to fine-tune models locally
## Table of Contents
- [Overview](#overview)
- [Instructions](#instructions)
---
## Overview
## Basic Idea
2025-10-06 15:35:14 +00:00
This playbook guides you through setting up and using Pytorch for fine-tuning large language models on NVIDIA Spark devices.
2025-10-05 17:01:34 +00:00
## What you'll accomplish
2025-10-06 15:35:14 +00:00
You'll establish a complete fine-tuning environment for large language models (1-70B parameters) on your NVIDIA Spark device. By the end, you'll have a working installation that supports parameter-efficient fine-tuning (PEFT) and supervised fine-tuning (SFT)
2025-10-05 17:01:34 +00:00
## What to know before starting
## Prerequisites
2025-10-06 15:35:14 +00:00
recipes are specifically for DIGITS SPARK. Please make sure that OS and drivers are latest.
2025-10-05 17:01:34 +00:00
## Ancillary files
2025-10-06 15:35:14 +00:00
ALl files required for finetuning are included.
2025-10-05 17:01:34 +00:00
## Time & risk
2025-10-06 15:35:14 +00:00
**Time estimate:** 30-45 mins for setup and runing finetuning. Finetuning run time varies depending on model size
2025-10-05 17:01:34 +00:00
2025-10-06 15:35:14 +00:00
**Risks:** Model downloads can be large (several GB), ARM64 package compatibility issues may require troubleshooting.
2025-10-05 17:01:34 +00:00
**Rollback:**
## Instructions
2025-10-06 15:35:14 +00:00
## Step 1. Pull the latest Pytorch container
2025-10-05 17:01:34 +00:00
```bash
2025-10-06 15:35:14 +00:00
docker pull nvcr.io/nvidia/pytorch:25.09-py3
2025-10-05 17:01:34 +00:00
```
2025-10-06 15:35:14 +00:00
## Step 2. Launch Docker
2025-10-05 17:01:34 +00:00
```bash
2025-10-06 15:35:14 +00:00
docker run --gpus all -it --rm --ipc=host \
-v $HOME/.cache/huggingface:/root/.cache/huggingface \
-v ${PWD}:/workspace -w /workspace \
nvcr.io/nvidia/pytorch:25.09-py3
2025-10-05 17:01:34 +00:00
```
2025-10-06 15:35:14 +00:00
## Step 3. Install dependencies inside the contianer
2025-10-05 17:01:34 +00:00
```bash
2025-10-06 15:35:14 +00:00
pip install transformers peft datasets "trl==0.19.1" "bitsandbytes==0.48"
2025-10-05 17:01:34 +00:00
```
2025-10-06 15:35:14 +00:00
## Step 4: authenticate with huggingface
2025-10-06 15:32:36 +00:00
2025-10-06 14:46:10 +00:00
```bash
2025-10-06 15:35:14 +00:00
huggingface-cli login
##<input your huggingface token.
##<Enter n for git credential>
2025-10-06 15:32:36 +00:00
2025-10-06 15:35:14 +00:00
```
To run LoRA on Llama3 use the following command:
2025-10-06 15:32:36 +00:00
2025-10-06 15:35:14 +00:00
```bash
python Llama3_8B_LoRA_finetuning.py
2025-10-06 14:46:10 +00:00
```
2025-10-06 15:32:36 +00:00
2025-10-06 15:35:14 +00:00
To run qLoRA finetuning on llama3-70B use the following command:
```bash
python Llama3_70B_qLoRA_finetuning.py
```
To run full finetuning on llama3-3B use the following command:
```bash
python Llama3_3B_full_finetuning.py
```