Skip to main content

kg-chat

Project description

kg-chat

LLM-based chatbot that queries and visualizes KGX nodes and edges TSV files loaded into either DuckDB (default) or neo4j database backend.

LLMs Supported

LLM Provider Models
OpenAI - 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 - claude-3-5-sonnet-20240620
- claude-3-opus-20240229
- claude-3-sonnet-20240229
- claude-3-haiku-20240307
Ollama - llama3.1
LBNL-hosted models via CBORG - lbl/llama-3
- openai/gpt-4o-mini
- anthropic/claude-haiku
- anthropic/claude-sonnet
- anthropic/claude-opus

:warning:

  • OpenAI: Ensure OPENAI_API_KEY is set as an environment variable.

  • Anthropic: Ensure ANTHROPIC_API_KEY is set as an environment variable.

  • Ollama: Better results if the llama 3.1 405b model is used. Needs GPU.

    • No API key required.
    • Download the application from here and install it locally.
    • Get any model of your choice but make sure the model has the Tools badge for it to work. Here's an example:
          ollama run llama3.1:405b
      
  • Models hosted by Lawrence Berkeley National Laboratory via CBORG: Ensure CBORG_API_KEY is set as an environment variable.

    • The list of modes can be found here listed under "LBNL_Hosted Models".

How to set the API key as an environment variable?

One quick way is

    export OPENAI_API_KEY=XXXXXX
    export ANTHROPIC_API_KEY=XXXXX
    export CBORG_API_KEY=XXXX

But if you want these to persist permanently

    vi ~/.bash_profile

OR

    vi ~/.bashrc

Add the 2 lines exporting the variables above and then

    source ~/.bash_profile

OR

    source ~/.bashrc

Setup

For Neo4j Backend (Optional)

  1. Install Neo4j desktop from here.
  2. Create a new project and database, then start it.
  3. Install the APOC plugin in Neo4j Desktop.
  4. Update settings to match neo4j_db_settings.conf.

General Setup

For Developers

  1. Clone this repository.
  2. Create a virtual environment and install dependencies:
    cd kg-chat
    pip install poetry
    poetry install
    
  3. Replace data/nodes.tsv and data/edges.tsv with desired KGX files if needed.

For using kg-chat as a dependency

pip install kg-chat

OR

poetry add kg-chat@latest

Supported Backends

  • DuckDB [default]
  • Neo4j

Commands

  1. Import KG: Load nodes and edges into a database (default: duckdb).

    poetry run kg import --data-dir data
    
  2. Test Query: Run a test query.

    :warning: --data-dir is a required parameter for all commands. This is the path for the directory which contains the nodes.tsv and edges.tsv file. The filenames are expected to be exactly that.

    poetry run kg test-query --data-dir data
    
  3. QnA: Ask questions about the data.

    poetry run kg qna "how many nodes do we have here?" --data-dir data
    
  4. Chat: Start an interactive chat session.

    poetry run kg chat --data-dir data
    
  5. App: Deploy a local web application.

    poetry run kg app --data-dir data
    

Visualization

Use show me in prompts for KG visualization.

kg-app


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

kg_chat-0.1.4.tar.gz (423.0 kB view details)

Uploaded Source

Built Distribution

kg_chat-0.1.4-py3-none-any.whl (424.9 kB view details)

Uploaded Python 3

File details

Details for the file kg_chat-0.1.4.tar.gz.

File metadata

  • Download URL: kg_chat-0.1.4.tar.gz
  • Upload date:
  • Size: 423.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.0 CPython/3.12.5

File hashes

Hashes for kg_chat-0.1.4.tar.gz
Algorithm Hash digest
SHA256 d1fa59836d3aab2320ce3c1435981b8bead0e11c39df3a72b51b79df9e61bbb3
MD5 af08b2909806370dccab566fdd5f16f6
BLAKE2b-256 f89b2ace584540604c6cbab21ba76c799bfeb48703c97987ecce3c1ecae6eded

See more details on using hashes here.

File details

Details for the file kg_chat-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: kg_chat-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 424.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.0 CPython/3.12.5

File hashes

Hashes for kg_chat-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 94413590da1b99b2d9dfb0b71bbc48f88539197da3bd77e8c7ea90a2b539cf89
MD5 f2dfc5e7234d14a57bf807c22659d3cb
BLAKE2b-256 0c1288523c942e11e6e7695d139da7fecb1ace86ed98365724415a0d81ba8c52

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