Prompt Versioning and Management
When working with non-technical team members, it’s important that they can iterate on prompts without needing to involve the engineering team unless absolutely necessary.
Lilypad provides a simple way to version and manage prompts, so that you can use them in your generations and ensure specific versions are used. This also enables swapping prompt versions without reploying your code.
First, navigate to the “Prompts” section in the app to create a new answer_question_prompt
.
data:image/s3,"s3://crabby-images/bac1e/bac1eed0040445157cd20820bf5a428c4cb2f48a" alt="create prompt"
Add a new input question
and set the prompt template to Answer this question: {question}
. Hit “Save”.
data:image/s3,"s3://crabby-images/21a66/21a66cee1cdb38c49d18bf2f015589866ced48ef" alt="answer question prompt"
Click on the “Code” button and copy the code. It should look like this:
data:image/s3,"s3://crabby-images/db95f/db95f39bf0d1f4190f70a8182b7485464fbebf09" alt="answer question prompt code"
Now add the prompt to your answer_question
generation:
import lilypad
from openai import OpenAI
client = OpenAI()
@lilypad.prompt()
def answer_question_prompt(question: str): ...
@lilypad.generation()
def answer_question(question: str) -> str:
prompt = answer_question_prompt(question)
completion = client.chat.completions.create(
model="gpt-4o-mini",
messages=prompt.messages("openai"),
)
return str(completion.choices[0].message.content)
if __name__ == "__main__":
lilypad.configure()
answer = answer_question("What is the meaning of life?")
print(answer)
Now when you run main.py
, the answer_question
generation will use the active version of the prompt with a matching hash.
You can also go to the “Generation” section in the app to select which version you would like that generation to use.
data:image/s3,"s3://crabby-images/9bcee/9bceee6760ad798658e921c45560e1284e9bd984" alt="answer question generation v2 with prompt"
Set Active
button to swap which version is being used.