An open-source prompt engineering framework.
Project description
Lilypad
[!WARNING] Project is in alpha phase
This means that things like the user interface, database schemas, etc. are still subject to change. We do not yet recommend fully relying on this project in production, but we've found it works quite well for local development in its current stage.
An open-source prompt engineering framework built on these principles:
- Prompt engineering is an optimization process, which requires...
- Automatic versioning and tracing
- Developer-centric prompt template editor
- Proper syncing between prompts and code
[!IMPORTANT] We're looking for early design partners!
We are also working on tooling for improved collaboration between technical and non-technical team members. This is particularly important for involving domain experts who may not have the technical chops to contribute to a code base.
If you're interested, join our community and DM William Bakst :)
There are limited spots.
30 Second Quickstart
Install Lilypad, specifying the provider(s) you intend to use, and set your API key:
pip install "python-lilypad[openai]"
export OPENAI_API_KEY=XXXXX
Create your first synced prompt to recommend a book.
For example, you could use the prompt Recommend a fantasy book
:
lilypad start # initialize local project
lilypad create recommend_book # creates a synced LLM function
lilypad run recommend_book # runs the function (and opens editor)
Once you hit "Submit" you'll see the function run in your shell. Follow the link to see the version and trace in an interactive UI.
Next, try editing the function signature to take a genre: str
argument. When you run the function again it will open the editor and give you access to the {genre}
template variable (with autocomplete).
Usage
We are actively working on this library and it's documentation, which you can find here
Versioning
Lilypad uses Semantic Versioning
License
This project is currently licensed under the terms of the MIT License; however, we expect certain future features to be licensed separately, which we will make extremely clear and evident.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file python_lilypad-0.0.2.tar.gz
.
File metadata
- Download URL: python_lilypad-0.0.2.tar.gz
- Upload date:
- Size: 336.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b18ee9c32ce436f1ef377befb3e82531d3ba687cb461933ed29e36c64946b0b9 |
|
MD5 | 203cfc0ada2967e8496d898a11e9919b |
|
BLAKE2b-256 | e3f324593d521e47340af82a869172e0709a104e3d429f7247a8063cba3f5309 |
File details
Details for the file python_lilypad-0.0.2-py3-none-any.whl
.
File metadata
- Download URL: python_lilypad-0.0.2-py3-none-any.whl
- Upload date:
- Size: 349.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6a43ca9180c2c1e34765a06cb2e30a2ae8a18aa6d2b0511761b675540359fc22 |
|
MD5 | 4be308a53e7be20aa24b299c27da8db1 |
|
BLAKE2b-256 | c38ee108efcc31ac12d4a478ec809ece0d1e33d9aaf64ca52b57e799697ee471 |