Skip to main content

Declarai, turning Python code into LLM tasks, easy to use, and production-ready.

Project description

versions license Tests Pypi version Pypi downloads Discord invite Open In Colab

Logo - declarai.png


Documentation 📖: https://declarai.com

Source Code 💻 : https://github.com/vendi-ai/declarai


What is Declarai 🤔?

Declarai turns your Python code into LLM tasks, allowing you to easily integrate LLM into your existing codebase. It operates on a simple principle: just define a Python function/class. By annotating this function with docstrings and type hints, you provide a clear instruction set for the AI model without any additional effort.

Once you've declared your function, Declarai intelligently compiles the function's docstrings and type hints into a prompt for the AI model, ensuring the model understands exactly what's required.

After executing the task, Declarai retrieves the AI's response and parses it, translating it back into the declared return type of your Python function. This eliminates any manual parsing or post-processing on your part.

Declarai Keeps It Native: At its core, Declarai is about embracing native Python practices. You don't need to learn a new syntax or adapt to a different coding paradigm. Just write Python functions as you always have, and let Declarai handle the AI integration seamlessly.


Main Components 🧩

Tasks 💡

AI tasks are used for any business logic or transformation.

import declarai

gpt_35 = declarai.openai(model="gpt-3.5-turbo")

@gpt_35.task 
def rank_by_severity(message: str) -> int:
    """
    Rank the severity of the provided message by it's urgency.
    Urgency is ranked on a scale of 1-5, with 5 being the most urgent.
    :param message: The message to rank
    :return: The urgency of the message
    """


rank_by_severity(message="The server is down!")

>>> 5

rank_by_severity(message="How was your weekend?"))

>>> 1

Chat 🗣

AI Chats are used for an iterative conversation with the AI model, where the AI model can remember previous messages and context.

import declarai

gpt_35 = declarai.openai(model="gpt-3.5-turbo")

@gpt_35.experimental.chat
class SQLBot:
    """
    You are a sql assistant. You help with SQL related questions 
    """


sql_bot = SQLBot()
sql_bot.send("When should I use a LEFT JOIN?")

> "You should use a LEFT JOIN when you want to return all rows from ....

Features:

  • 🖍 Intelligent Prompts: Automatically generate prompts using type hints and docstrings.
  • 🚄 Conversational AI: Chat interface equipped with memory and context management.
  • Real-time streaming: Stream LLM responses that take longer to complete.
  • 🔥 Pydantic Model Parsing: Seamlessly parse llm responses into Pydantic models.
  • 🐍 Pythonic: Native understanding and parsing of llm responses into Python primitives.
  • 💾 Multiple AI Backends: Integrated with OpenAI & Azure AI llm providers.
  • 🛠 Middleware: Adapt and extend tasks behavior with a modular middleware system.
  • 🤗 Coming Soon: Integration with HuggingFace hub

Quickstart 🚀

Installation

pip install declarai

Setup

export OPENAI_API_KEY=<your openai token>

or pass the token when initializing the declarai object

import declarai

gpt_35 = declarai.openai(model="gpt-3.5-turbo", openai_token="<your-openai-key>")

💡 Basic Usage

Craft AI-powered functionalities with ease using the @task decorator. Just add some type hints and a bit of documentation, and watch Declarai do its magic!

import declarai

gpt_35 = declarai.openai(model="gpt-3.5-turbo")

@gpt_35.task
def generate_poem(title: str) -> str:
    """
    Write a 4 line poem on the provided title
    """


res = generate_poem(
    title="Declarai, the declarative AI framework for LLMs"
)
print(res)
# Declarai, the AI framework,
# Empowers LLMs with declarative power,
# Efficiently transforming data and knowledge,
# Unlocking insights in every hour.

Not the best poem out there, but hey! You've written your first declarative AI code!

Declarai aims to promote clean and readable code by enforcing the use of doc-strings and typing. The resulting code is readable and easily maintainable.

Tasks with python native output parsing

Python primitives

import declarai

gpt_35 = declarai.openai(model="gpt-3.5-turbo")

@gpt_35.task
def rank_by_severity(message: str) -> int:
    """
    Rank the severity of the provided message by it's urgency.
    Urgency is ranked on a scale of 1-5, with 5 being the most urgent.
    :param message: The message to rank
    :return: The urgency of the message
    """


rank_by_severity(message="The server is down!")

>>> 5
rank_by_severity(message="How was your weekend?"))

>>> 1

Python Lists/Dicts etc..

from typing import List
import declarai

gpt_35 = declarai.openai(model="gpt-3.5-turbo")

@gpt_35.task
def multi_value_extraction(text: str) -> List[str]:
    """
    Extract the phone numbers from the provided text
    :param text: content to extract phone number from
    :return: The phone numbers that where identified in the input text
    """


multi_value_extraction(
    text="Hey jenny,\nyou can call me at 124-3435-132.\n"
         "you can also reach me at +43-938-243-223"
)
>>> ['124-3435-132', '+43-938-243-223']

Python complex objects

from datetime import datetime
import declarai

gpt_35 = declarai.openai(model="gpt-3.5-turbo")

@gpt_35.task
def datetime_parser(raw_date: str) -> datetime:
    """
    Parse the input into a valid datetime string of the format YYYY-mm-ddThh:mm:ss
    :param raw_date: The provided raw date
    :return: The parsed datetime output
    """


datetime_parser(raw_date="Janury 1st 2020"))

>>> 2020-01-01 00:00:00

Pydantic models

from pydantic import BaseModel
from typing import List, Dict
import declarai


class Animal(BaseModel):
    name: str
    family: str
    leg_count: int

gpt_35 = declarai.openai(model="gpt-3.5-turbo")

@gpt_35.task
def suggest_animals(location: str) -> Dict[int, List[Animal]]:
    """
    Create a list of numbers from 0 to 5
    for each number, suggest a list of animals with that number of legs
    :param location: The location where the animals can be found
    :return: A list of animal leg count and for each count, the corresponding animals
    """


suggest_animals(location="jungle")

>>> {
       0: [
           Animal(name='snake', family='reptile', leg_count=0)
       ], 
       2: [
           Animal(name='monkey', family='mammal', leg_count=2), 
           Animal(name='parrot', family='bird', leg_count=2)
       ], 
       4: [
          Animal(name='tiger', family='mammal', leg_count=4), 
          Animal(name='elephant', family='mammal', leg_count=4)
       ]
 }

Jinja templates 🥷

import declarai

gpt_35 = declarai.openai(model="gpt-3.5-turbo")

@gpt_35.task
def sentiment_classification(string: str, examples: List[str, int]) -> int:
    """
    Classify the sentiment of the provided string, based on the provided examples.
    The sentiment is ranked on a scale of 1-5, with 5 being the most positive.
    {% for example in examples %}
    {{ example[0] }} // {{ example[1] }}
    {% endfor %}
    {{ string }} //
    """
    
sentiment_classification(string="I love this product but there are some annoying bugs",
                         examples=[["I love this product", 5], ["I hate this product", 1]])

>>> 4

Simple Chat interface

import declarai

gpt_35 = declarai.openai(model="gpt-3.5-turbo")

@gpt_35.experimental.chat
class CalculatorBot:
    """
    You a calculator bot,
    given a request, you will return the result of the calculation
    """

    def send(self, message: str) -> int: ...


calc_bot = CalculatorBot()
calc_bot.send(message="1 + 1")

>>> 2

📚 For a thorough introduction, features, and best practices, explore our official documentation and beginner's guide.

Contributing 💼

Join our mission to make declarative AI even better together! Check out our contributing guide to get started.

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

declarai-0.1.13.tar.gz (40.6 kB view details)

Uploaded Source

Built Distribution

declarai-0.1.13-py3-none-any.whl (58.0 kB view details)

Uploaded Python 3

File details

Details for the file declarai-0.1.13.tar.gz.

File metadata

  • Download URL: declarai-0.1.13.tar.gz
  • Upload date:
  • Size: 40.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.11.0 Linux/6.2.0-1012-azure

File hashes

Hashes for declarai-0.1.13.tar.gz
Algorithm Hash digest
SHA256 e3dec986bcb9dde4a3180d55a08dae0176356894b9c63be62848d746072374b5
MD5 433cda9f26278a98fa9e57f842ec7c89
BLAKE2b-256 44718a6fb8513036633d9d2b97f96d96f1533dd1de139637466b53a9ed82b049

See more details on using hashes here.

File details

Details for the file declarai-0.1.13-py3-none-any.whl.

File metadata

  • Download URL: declarai-0.1.13-py3-none-any.whl
  • Upload date:
  • Size: 58.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.11.0 Linux/6.2.0-1012-azure

File hashes

Hashes for declarai-0.1.13-py3-none-any.whl
Algorithm Hash digest
SHA256 2b06b3c6db05f3a0a71460bc93adbba2a5a9199f1cd83573413ae035929c124c
MD5 5826d6d073e8dec1c270d001bd1edcd3
BLAKE2b-256 e97ffcf729242660ad4fbbe84629a84e9e039ffafabc155a5be2b0a265e19654

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