Skip to main content

Create and parse prompts for large language models.

Project description

Prompt builder

This is a simple prompt builder for OpenAI models. Easy to use and to modify.

Install

pip install AIPrompts@git+https://github.com/TeiaLabs/prompts.git

pip install AIPrompts

Dynamic prompts

template = 'a photo of a <img_label>'
prompt = DynamicPrompt(template)
filled_prompt = prompt.build(img_label='dog')
print(filled_prompt)
# out: "a photo of a dog"

Dynamic prompts from file templates

Build your own prompt by creating a file following a sample.prompt file (yaml format), and use the DynamicPrompt class to parse it:

prompt = DynamicPrompt.from_file('samples/sample.prompt')
str_prompt = prompt.build(
    input_sentence="lets go",
)

You can also access recommended model settings (engine, temperature) that can be fed to the model input (e.g., openai.Completion.create()):

prompt.get_model_settings()

Improve Autocomplete with custom prompts

Alternatively, to get more control and better autocomplete suggestions, you can inherit from the BasePrompt class and override the build method with explicit arguments:

class MyPrompt(BasePrompt):

    def build(self, input_sentence):
        return self.set_prompt_values(
            input_sentence=input_sentence,
        )

Ensembling prompts

To ensemble multiple prompts, you can use the EnsemblePrompt class:

templates = [
    '<label>', 
    'a photo of <label>', 
    'picture of <label>',
]
exp_vars = ['label']
prompt = PromptEnsemble(templates, exp_vars)
prompt.build(label='dog')
# out: ['dog', 'a photo of dog', 'picture of dog']
prompt.build(label='cat')
# out: ['cat', 'a photo of cat', 'picture of cat']

The output is a flattened list with all filled in templates. Note: all templates must be filled with the same expected variables, and all variables must be provided.

You can also build multiple promtps at the same time (useful for classification):

templates = [
    '<label>',
    'a photo of <label>'
]
template_vars = [
    'label'
]
labels = ['dog', 'cat', 't-shirt']
prompt = PromptEnsemble(templates, template_vars)
prompt.build_many(
    label=labels
)
# out: ['dog', 'a photo of dog', 'cat', 'a photo of cat', 't-shirt', 'a photo of t-shirt']

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

AIPrompts-0.1.2.tar.gz (5.8 kB view details)

Uploaded Source

Built Distribution

AIPrompts-0.1.2-py3-none-any.whl (5.2 kB view details)

Uploaded Python 3

File details

Details for the file AIPrompts-0.1.2.tar.gz.

File metadata

  • Download URL: AIPrompts-0.1.2.tar.gz
  • Upload date:
  • Size: 5.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for AIPrompts-0.1.2.tar.gz
Algorithm Hash digest
SHA256 cb332ec1ec2ef30233548fd3731086111427741e8c7e08b99ab3f7391b340c40
MD5 45b432e8dc2c6ee2dd9033b872c150e3
BLAKE2b-256 4113b87a813e2627f04b39b7c54dfadc1d730c740925a0246c236e51f3b8007f

See more details on using hashes here.

File details

Details for the file AIPrompts-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: AIPrompts-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 5.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for AIPrompts-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 8b814ad13ba1048ddbf2941bad9e3feac6a7c9eb0b0a15429cdd151238e6fa49
MD5 f681ec20163b5cb4e18fbb3fec6c53d4
BLAKE2b-256 acd1edc25a63bca362f94aa4702ac8e3affe5c161cebe5ef23d6a3514c7ae006

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page