Skip to content

Latest commit

 

History

History
88 lines (72 loc) · 2.85 KB

README.md

File metadata and controls

88 lines (72 loc) · 2.85 KB

llm-coin-flip

About

  • How random can an LLM be when asked to flip a coin?
  • How do parameters such as prompt, temperature, and model affect these results?
  • Would the LLM produce weighted results, or would there be a fairly even probability of getting heads or tails?

This project aims to answer these questions by providing two command line tools powered by OpenAI's GPT.

coinflip.py is the base program. It is a simple tool that provides the user with either 'heads' or 'tails' when run. It also supports flipping a coin multiple times in a row for convenience.

The program experiment.py expands on the functionality of coinflip.py. It can run a large series of trials while tallying the number of heads and tails produced by a given model, temperature, and prompt. This tool also keeps track of the "failure rate", which is the percentage of times GPT produced a non heads or tails output.

For more information about experiment.py and my experimental findings, click here.

Setup

git clone https://github.com/Slangborgh16/llm-coin-flip.git
cd llm-coin-flip

Requirements

This project uses Python 3.11 and requires the following libraries:

Run the following command to install the dependencies.

pip install -r requirements.txt

OpenAI API Key

You will need to have an OpenAI API key to use this project. Check out the OpenAI Website to set one up. Next, follow one of the two methods below.

Method 1: Project .env File

Create a file in the project directory called .env.

touch .env

Using Vim (or your favorite text editor, I guess), add the following line to .env. Replace the placeholder text with your API secret key.

OPENAI_API_KEY=YOUR_SECRET_KEY_GOES_HERE

Method 2: Set an Environment Variable

In your .bashrc file or the equivalent for your system, add the following line. Replace the placeholder text with your API secret key.

export OPENAI_API_KEY="YOUR_SECRET_KEY_GOES_HERE"

Then run source ~/.bashrc.

Using coinflip.py

Positional Arguments

Argument Description Required
Trials Number of coin flips to run (Default: 1) No

Options

Option Description Required
-m MODEL, --model MODEL GPT model to use (Default: gpt-3.5-turbo) No
-t TEMP, --temperature TEMP LLM temperature to use (Default: 1.5) No
-h, --help Display the help message No

Usage Examples

Run a single coin flip with all the default settings.

python3 coinflip.py

Run 10 trials with gpt-4 and a temperature of 1.1.

python3 coinflip.py -m gpt-4 -t 1.1 10