|  | 11 months ago | |
|---|---|---|
| .. | ||
| README.md | 11 months ago | |
| download.py | 1 year ago | |
| eval.py | 1 year ago | |
| generate.py | 1 year ago | |
| inference.py | 1 year ago | |
| plot.py | 1 year ago | |
| run_e2e.sh | 1 year ago | |
In this directory, we run an experiment answering the question:
If we run enough Llama models in parallel, can they outperform GPT-4o on HumanEval?
It seeks to increase model performance not through scaling parameters, but by scaling compute time.
This experiment built by the team at Modal, and is described in the following blog post:
Beat GPT-4o at Python by searching with 100 small Llamas
The experiment has since been upgraded to use the Llama 3.2 3B Instruct model, and runnable end-to-end using the Modal serverless platform.
From within your virtual environment, run:
pip install modal
And if you're new to Modal, authenticate with:
modal setup
# or if that doesn't work, try 
# python -m modal setup
That's all!
This CLI will execute your modal apps, which build and run containers on the cloud, on your GPU of choice.
To download the model, you'll first need to accept the Llama 3.2 License on HuggingFace and be approved for access.
Then, create a modal secret named huggingface, to which you'll add your HF_TOKEN as an environment variable.
This command will run every step for you:
bash run_e2e.sh
Or if you prefer to run it manually, you can step through each of the modal commands in the script.
This will execute:
The resulting plots of the evals will be saved locally to:
/tmp/plot-pass-k.jpeg/tmp/plot-fail-k.jpeg/tmp/plot-pass-k.jpeg shows pass@k for the Llama 3.2 3B Instruct model vs pass@1 for GPT-4o.
You'll see that at 100 generations, the Llama model is able to perform on-par with GPT-4o. At higher scale, the Llama model will outperform GPT-4o.
/tmp/plot-fail-k.jpeg shows fail@k across a log-scale, showing smooth scaling of this method.