Skip to main content

A tool to link the code with large language models.

Project description

CodeLinker : Link your code with Language Models

CodeLinker aims to provide functions to link your code with language models. It builds on top of the Pydatic library and Tool Calling abilities introduced by OpenAI, which enabling models to generate content according to Json Schema.

Usage

The core concept of this package is to treat language models as a function handler. By defining a schema for return value of the function, we can call the function and let the model generate the return value.

To start with, we need to first define the configuration that will be used during exection:

config = CodeLinkerConfig(api_keys={
    "gpt-3.5-turbo-16k":[{
        "api_key": "your api key here",
        "model": "model name alias here"
    }]
})
cl = CodeLinker(config)

Learn more about the configuration in the Configuration page.

Structured Generation

Currently, the package support two types of structured generation with language models: Function Definition and Return Declearation.

Function Definition

You can define the schema of the return value with pydantic package:

class HelloWorldSchema(BaseModel):
    message: str = Field(description="the message to be returned")

Then we can use the cl object to wrap the function you want to call:

@cl.smartFunc()
def hello_world() -> HelloWorldSchema:
    """Say hello to the world"""

The function's docstring will be passed to models as instruction about what this function should do. Now we can call the function and let the model generate the return value:

result = hello_world()
print(result.message)
# sample output:
# Hello, World!

Return Declearation

Other wise, if you do not want to define the function, you can use the exec method to call the function:

result = await cl.exec(return_type=HelloWorldSchema)

To be noticed, the exec method is an async method, so you need to use await to call it.

More details about structured generation can be found in the Structured Generation page.

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

codelinker-0.3.24.tar.gz (18.1 kB view details)

Uploaded Source

Built Distribution

codelinker-0.3.24-py3-none-any.whl (21.9 kB view details)

Uploaded Python 3

File details

Details for the file codelinker-0.3.24.tar.gz.

File metadata

  • Download URL: codelinker-0.3.24.tar.gz
  • Upload date:
  • Size: 18.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: poetry/1.8.4 CPython/3.10.14 Linux/6.5.0-1025-azure

File hashes

Hashes for codelinker-0.3.24.tar.gz
Algorithm Hash digest
SHA256 c9f53f41eed05ce38b421e8ccdb792ae0dd516355c34bab0c97e519db5259b4b
MD5 dfe7efa6abb59e4a8a63b7bc18c8044c
BLAKE2b-256 9f4b40b4be541f6269830820706cff8bb79a0470630bd737759d820835f0610f

See more details on using hashes here.

File details

Details for the file codelinker-0.3.24-py3-none-any.whl.

File metadata

  • Download URL: codelinker-0.3.24-py3-none-any.whl
  • Upload date:
  • Size: 21.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: poetry/1.8.4 CPython/3.10.14 Linux/6.5.0-1025-azure

File hashes

Hashes for codelinker-0.3.24-py3-none-any.whl
Algorithm Hash digest
SHA256 7521e153014d6d350cc9fcb5fddb5d15fa278edc96d4b20b03b6ede552c28c92
MD5 09bb176818ce682f58d16b7a0e7f6786
BLAKE2b-256 30a6e58e749f781e2b44c388a6adaab6c48c56ad4cc8e93a1d525c8ed4f6fcfc

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