Skip to main content

llm-change-agent

Project description

LLM Change Agent

DOI

Overview

LLM Change Agent is a command-line tool designed to generate knowledge graph change language (KGCL) commands that request changes in a knowledge graph such as an ontology. It generates KGCL commands using specified large language models and providers via prompts. The prompts can be GitHub issue description/comments or natural language text.

Features

  • Given a prompt relevant to making ontology resource changes, the agent responds with KGCL change statements.
  • Supports OpenAI, Ollama, Anthropic and CBORG (LBNL-hosted) models.

:warning: OpenAI, Anthropic and CBORG model use require availability of corresponding keys as environment variables locally.

Installation

To install the dependencies, run:

pip install llm-change-agent

Usage

The CLI provides several commands to interact with the language models.

List Available Models

To list all available models from supported providers:

llm-change list-models

OpenAI models:
  gpt-4o-2024-08-06
  gpt-4o-mini
  gpt-4o-mini-2024-07-18
  gpt-4o-2024-05-13
  gpt-4o
  gpt-4-turbo-2024-04-09
  gpt-4-turbo
  gpt-4-turbo-preview
Anthropic models:
  claude-3-5-sonnet-20240620
  claude-3-opus-20240229
  claude-3-sonnet-20240229
  claude-3-haiku-20240307
Ollama models:
  llama3.1
LBL-CBORG models:
  lbl/cborg-chat:latest
  lbl/cborg-chat-nano:latest
  openai/gpt-3.5-turbo
  openai/gpt-4o
  openai/gpt-4o-mini
  anthropic/claude-haiku
  anthropic/claude-sonnet
  anthropic/claude-opus
  google/gemini-pro
  google/gemini-flash

Generate Text

To generate text using a specified model and provider:

llm-change execute --model <MODEL_NAME> --provider <PROVIDER_NAME> --prompt "<YOUR_PROMPT>"

Replace <MODEL_NAME>, <PROVIDER_NAME>, and <YOUR_PROMPT> with your desired values.

Examples

  • Generate text using CBORG's lbl/llama-3 model with a custom prompt:
llm-change execute --model lbl/llama-3 --prompt "I want to change the definition of class ABC:123 to 'foo bar' and also create a new class labelled 'bar foo' with the curie DEF:123."

OR

llm-change execute --provider cborg --prompt "I want to change the definition of class ABC:123 to 'foo bar' and also create a new class labelled 'bar foo' with the curie DEF:123."

generates

Final Answer: 

[
  "change definition of ABC:123 to 'foo bar'",
  "create class DEF:123 'bar foo'"
]

Evaluations

Input

The project also contains input data for evaluations in the form of YAML files for the following ontologies:

Expected changes

The expected changes for specific pull requests are listed ontologywise below:

Actual results

The actual results for some of the LLM models evaluated are here and corresponding metrics here

Development

To run the project locally, clone the repository and navigate to the project directory:

git clone https://github.com/yourusername/llm-change-agent.git
cd llm-change-agent
poetry install

Make sure you have poetry installed in your system.

Contributing

Contributions are welcome! Please submit a pull request or open an issue to discuss any changes.

License

This project is licensed under the MIT License. See the LICENSE file for details.


Acknowledgements

This cookiecutter project was developed from the monarch-project-template template and will be kept up-to-date using cruft.

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

llm_change_agent-0.0.9.tar.gz (4.1 MB view details)

Uploaded Source

Built Distribution

llm_change_agent-0.0.9-py3-none-any.whl (4.2 MB view details)

Uploaded Python 3

File details

Details for the file llm_change_agent-0.0.9.tar.gz.

File metadata

  • Download URL: llm_change_agent-0.0.9.tar.gz
  • Upload date:
  • Size: 4.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for llm_change_agent-0.0.9.tar.gz
Algorithm Hash digest
SHA256 aca6c255744e8464333d2e5590b36547b7058d52bf5a2e765f37732ccfd2ccef
MD5 2fb3b3c00c4c5559dd11e390887238b1
BLAKE2b-256 6481c6817113de082eabb508cb94d8fe1659fc2bce20c83e7ed32b423dce4486

See more details on using hashes here.

File details

Details for the file llm_change_agent-0.0.9-py3-none-any.whl.

File metadata

File hashes

Hashes for llm_change_agent-0.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 9e4d81c619ca27a68bda99dbc1489d46cd97cd7532f9b2c9ddb8490ffe54ff8c
MD5 30a9da617ff7d985256993e6f1212191
BLAKE2b-256 5ea56e8750f53464d246fdaf532384d6a9139fc698aa6f6aec2828bd648cbf03

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