You're now at the training phase. So far, you have handcrafted some prompts and
responses, and used ilab generate
to synthesize those prompt/response pairs
into a new data set.
If you have a Mac Silicon (M1 or newer), we strongly recommend using
ilab train
locally, and only proceed here if you hit issues.
Also, there is active work being done to support Linux, so if you have access to a Linux machine with GPUs, that might also be a better option.
Next, you'll get to fine-tune a LoRA (Low-Rank Adaptation of Large Language Models) using a Jupyter notebook and (preferably) Google Colab platform or if unable to use Colab, unmaintained instructions for Kaggle.
We've laid out the steps to get started with either platform below.
Pre-requisites:
- Google Colab
- A Gmail account that you're logged into. This will allow you to use Google Colab, which in the free tier will give you access to an NVidia T4 x 15GB GPU.
The notebook in this folder will walk you through:
- Open the notebook in Google Colab
- Uploading the output of
ilab generate
(a synthetic dataset created based on your hand written prompts/responses). - Checking the base model before training
- Setting up and training a LoRA. A LoRA uses Parameter Efficient Fine-tuning (PEFT) methods to fine-tune a model on a small subset of the overall parameters, allowing you to conduct fine-tuning in a fraction of the time, on a fraction of the hardware required. The resultant model should be updated and better handle your queries than the base model.
- Inspecting the output model to make sure the LoRA training had the desired effect (i.e. the output has improved).
Once you have finished training and the output looks good, we encourage you go to stage, Testing the fine-tuned model
Using a Kaggle Notebook and the NVIDIA P100 provided in the free tier, we will fine tune a LoRA.
- You'll need a Kaggle account, which you can create by visiting Kaggle's Sign-up Page.
- To use Kaggle's accelerators, you'll have to verify your account with a phone number. Visit the account settings page and select "Phone Verification".
[!NOTE] At present, you'll need to download the notebook and upload it to Kaggle. The following steps will walk you through uploading the notebook. Once this repository is open sourced, we will make an 'Open in Colab' button**
Once you have Kaggle properly configured, you can then run this notebook by following this process:
- At the top-left of the Kaggle page, click the "Create" button
- Then, select "Notebook" from the Dropdown menu.
- This will create a new notebook with some example data inside of it already. From here, select "File" at the top left corner.
- Then, select "Import notebook". This will prompt you to upload a file from a local disk (you can also use GitHub).
- With the notebook uploaded, we'll then need to click the three vertical dots on the top right to open the accelerator options.
- Then select the P100 GPU Accelerator. The other accelerator options will not work (yet).
- Finally, make sure to click "Restart & Clear Cell Outputs" before you run. KAGGLE WILL NOT LET YOU RUN NOTEBOOKS OVER 1 MEGABYTE IN SIZE