trustgraph

trustgraph

Discover the Knowledge Trapped in Data Silos with a Fully Agentic, No-code AI Systemโšก๐Ÿš€

Stars: 219

Visit
 screenshot

TrustGraph is a tool that deploys private GraphRAG pipelines to build a RDF style knowledge graph from data, enabling accurate and secure `RAG` requests compatible with cloud LLMs and open-source SLMs. It showcases the reliability and efficiencies of GraphRAG algorithms, capturing contextual language flags missed in conventional RAG approaches. The tool offers features like PDF decoding, text chunking, inference of various LMs, RDF-aligned Knowledge Graph extraction, and more. TrustGraph is designed to be modular, supporting multiple Language Models and environments, with a plug'n'play architecture for easy customization.

README:

TrustGraph banner

Discover the Knowledge Trapped in Data Silos

PyPI version Discord

๐Ÿš€ Getting Started โš™๏ธ API Docs ๐Ÿง‘โ€๐Ÿ’ป CLI Docs ๐Ÿ“บ YouTube ๐Ÿ’ฌ Discord ๐Ÿ“– Blog ๐Ÿ“‹ Use Cases

TrustGraph is a fully agentic AI system for complex unstructured data. Extract your documents to knowledge graphs and vector embeddings with customizable data extraction agents. Deploy AI agents that analyze your data to understand the complex relationships scattered across data silos.

Key Features

  • ๐Ÿ“„ Document Extraction: Bulk ingest documents such as .pdf,.txt, and .md
  • ๐Ÿช“ Adjustable Chunking: Choose your chunking algorithm and parameters
  • ๐Ÿ” No-code LLM Integration: Anthropic, AWS Bedrock, AzureAI, AzureOpenAI, Cohere, Google AI Studio, Google VertexAI, Llamafiles, Ollama, and OpenAI
  • ๐Ÿ“– Entity, Topic, and Relationship Knowledge Graphs
  • ๐Ÿ”ข Mapped Vector Embeddings
  • โ”No-code GraphRAG Queries: Automatically perform a semantic similiarity search and subgraph extraction for the context of LLM generative responses
  • ๐Ÿค– Agent Flow: Define custom tools used by a ReAct style Agent Manager that fully controls the response flow including the ability to perform GraphRAG requests
  • ๐Ÿ“š Multiple Knowledge Graph Options: Full integration with Memgraph, Neo4j, or Cassandra
  • ๐Ÿงฎ Multiple VectorDB Options: Full integration with Pinecone, Qdrant, or Milvus
  • ๐ŸŽ›๏ธ Production-Grade reliability, scalability, and accuracy
  • ๐Ÿ” Observability: get insights into system performance with Prometheus and Grafana
  • ๐Ÿ—„๏ธ AI Powered Data Warehouse: Load only the subgraph and vector embeddings you use most often
  • ๐Ÿชด Customizable and Extensible: Tailor for your data and use cases
  • ๐Ÿ–ฅ๏ธ Configuration UI: Build the YAML configuration with drop down menus and selectable parameters

Getting Started

There are four ways of interacting with TrustGraph:

The TrustGraph CLI installs the commands for interacting with TrustGraph while running along with the Python SDK. The Configuration UI enables customization of TrustGraph deployments prior to launching. The REST API can be accessed through port 8088 of the TrustGraph host machine with JSON request and response bodies.

Install the TrustGraph CLI

pip3 install trustgraph-cli==0.17.16

[!NOTE] The TrustGraph CLI version must match the desired TrustGraph release version.

Configuration UI

TrustGraph is endlessly customizable by editing the YAML launch files. The Configuration UI provides a quick and intuitive tool for building a custom configuration that deploys with Docker, Podman, Minikube, or Google Cloud. There is a Configuration UI for the both the lastest and stable TrustGraph releases.

The Configuration UI has three sections:

  • Component Selection โœ…: Choose from the available deployment platforms, LLMs, graph store, VectorDB, chunking algorithm, chunking parameters, and LLM parameters
  • Customization ๐Ÿงฐ: Customize the prompts for the LLM System, Data Extraction Agents, and Agent Flow
  • Finish Deployment ๐Ÿš€: Download the launch YAML files with deployment instructions

The Configuration UI will generate the YAML files in deploy.zip. Once deploy.zip has been downloaded and unzipped, launching TrustGraph is as simple as navigating to the deploy directory and running:

docker compose up -d

[!TIP] Docker is the recommended container orchestration platform for first getting started with TrustGraph.

When finished, shutting down TrustGraph is as simple as:

docker compose down -v

Example TrustGraph Notebooks

Prebuilt Configuration Files

TrustGraph YAML files are available here. Download deploy.zip for the desired release version.

Release Type Release Version
Latest 0.18.7
Stable 0.17.16

TrustGraph is fully containerized and is launched with a YAML configuration file. Unzipping the deploy.zip will add the deploy directory with the following subdirectories:

  • docker-compose
  • minikube-k8s
  • gcp-k8s

[!NOTE] As more integrations have been added, the number of possible combinations of configurations has become quite large. It is recommended to use the Config UI to build your deployment configuration. Each directory contains YAML configuration files for the default component selections.

Docker:

docker compose -f <launch-file.yaml> up -d

Kubernetes:

kubectl apply -f <launch-file.yaml>

Architecture

architecture

TrustGraph is designed to be modular to support as many LLMs and environments as possible. A natural fit for a modular architecture is to decompose functions into a set of modules connected through a pub/sub backbone. Apache Pulsar serves as this pub/sub backbone. Pulsar acts as the data broker managing data processing queues connected to procesing modules.

Pulsar Workflows

  • For processing flows, Pulsar accepts the output of a processing module and queues it for input to the next subscribed module.
  • For services such as LLMs and embeddings, Pulsar provides a client/server model. A Pulsar queue is used as the input to the service. When processed, the output is then delivered to a separate queue where a client subscriber can request that output.

Data Extraction Agents

TrustGraph extracts knowledge documents to an ultra-dense knowledge graph using 3 automonous data extraction agents. These agents focus on individual elements needed to build the knowledge graph. The agents are:

  • Topic Extraction Agent
  • Entity Extraction Agent
  • Relationship Extraction Agent

The agent prompts are built through templates, enabling customized data extraction agents for a specific use case. The data extraction agents are launched automatically with the loader commands.

PDF file:

tg-load-pdf <document.pdf>

Text or Markdown file:

tg-load-text <document.txt>

GraphRAG Queries

Once the knowledge graph and embeddings have been built or a knowledge core has been loaded, RAG queries are launched with a single line:

tg-query-graph-rag -q "Write a blog post about the 5 key takeaways from SB1047 and how they will impact AI development."

Agent Flow

Invoking the Agent Flow will use a ReAct style approach the combines GraphRAG and text completion requests to think through a problem solution.

tg-invoke-agent -v -q "Write a blog post about the 5 key takeaways from SB1047 and how they will impact AI development."

[!TIP] Adding -v to the agent request will return all of the agent manager's thoughts and observations that led to the final response.

API documentation

Developing on TrustGraph using APIs

Deploy and Manage TrustGraph

๐Ÿš€๐Ÿ™ Full Deployment Guide ๐Ÿš€๐Ÿ™

TrustGraph Developer's Guide

Developing for TrustGraph

For Tasks:

Click tags to check more tools for each tasks

For Jobs:

Alternative AI tools for trustgraph

Similar Open Source Tools

For similar tasks

For similar jobs