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.26.tar.gz (18.1 kB view details)

Uploaded Source

Built Distribution

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

Uploaded Python 3

File details

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

File metadata

  • Download URL: codelinker-0.3.26.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.26.tar.gz
Algorithm Hash digest
SHA256 580321e1e56c6e02c285b0001e7fa78ba9af6bcdec5a7a05ff6dfa3d6c56995b
MD5 e8bbdfa70fe2590972f1d6504037e74b
BLAKE2b-256 54620c7eea9b2844835c72b127cadef88b729b808ebd02de81ceea5147489a12

See more details on using hashes here.

File details

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

File metadata

  • Download URL: codelinker-0.3.26-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.26-py3-none-any.whl
Algorithm Hash digest
SHA256 a000674ab35ada72756e3ddec8447c6fc9305b08cee171e3d12accfd9feb52aa
MD5 1324b52fa4831490037f46b990fb1038
BLAKE2b-256 6787ec3cc6417b6cbfc0ec813a69a418bd0dd626d83ece4fda852cad3c76ddcd

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