Skip to main content

a1facts - precise knowledge for AI agents

Project description

a1facts: An Ontology-Driven Knowledge Graph System

a1facts is a powerful Python framework for building and interacting with knowledge graphs. It allows you to define a clear structure (ontology) for your data, ingest information from various sources, and use natural language to get precise, reliable answers. By grounding your AI agents in a structured knowledge graph, a1facts helps eliminate hallucinations and ensures that your agent's responses are based on verified facts.

This project uses a Neo4j backend to manage and query the graph data, providing a robust and scalable solution for your knowledge management needs.

Architecture

Key Features

  • Ontology-Driven: Define your knowledge domain with simple YAML files. a1facts uses this ontology to automatically create the tools and structures needed to interact with your data.
  • Structured Data Ingestion: Convert unstructured text into structured entities and relationships within your knowledge graph, ensuring data quality and consistency.
  • Natural Language Queries: Ask questions in plain English. a1facts translates your queries into precise graph traversals to retrieve the information you need.
  • Reliable AI Agents: Build AI agents that can provide accurate and trustworthy answers by grounding them in the factual data of the knowledge graph.
  • Neo4j Backend: Utilizes the power of Neo4j for efficient storage and complex querying of your knowledge base.

Usage Scenario: Building AI Agents with Precise Answers

In many applications, it's critical for AI agents to provide answers that are not just plausible but also precise and factually correct. Standard large language models (LLMs) can sometimes "hallucinate" or generate incorrect information, which can be a major issue in domains like finance, legal, or scientific research.

a1facts addresses this problem by grounding your AI agent in a knowledge graph. Here's how it works:

  1. Define Your Domain: You start by creating an ontology that describes the key concepts and relationships in your specific domain. For example, in finance, you might define entities like Company, Product, and Market, and relationships like competes_with or operates_in.

    Ontology Example

  2. Populate the Graph: You then ingest data from different sources into the knowledge graph. This could be from internal documents, databases, external APIs, or the web. a1facts ensures that this data is structured according to your ontology, but also that it's factual by triangulating facts from different sources.

    Example Knowledge Graph

  3. Query with Confidence: When your AI agent receives a question, it doesn't just rely on its internal training data. Instead, it uses a1facts to query the knowledge graph. This means the agent's answers are based on the structured, verified data.

    Query Example

By using a1facts, you can build an AI agent that is not only intelligent but also trustworthy, providing precise and reliable answers every time.

Getting Started

Follow these steps to get the a1facts Knowledge Graph running on your local machine.

Prerequisites

  • Python 3.13+
  • uv - An extremely fast Python package installer.
  • A running Neo4j Database instance.

Installation

  1. Clone the repository:

    git clone https://github.com/shadi-fsai/a1facts.git
    cd a1facts
    
  2. Create a virtual environment and install dependencies:

    # Create the virtual environment
    uv venv
    
    # Activate the virtual environment
    # On Windows: .venv\Scripts\activate
    # On macOS/Linux: source .venv/bin/activate
    .venv\Scripts\activate
    
    # Install dependencies
    uv pip install -e .
    

Configuration

You'll need to provide credentials to connect to your Neo4j database and other services.

  1. Create a .env file in the root of the project.
  2. Add your API keys and Neo4j credentials to the file:
    OPENAI_API_KEY="your_openai_api_key"
    EXA_API_KEY="your_exa_api_key"
    NEO4J_URI="bolt://localhost:7687"
    NEO4J_AUTH="your_neo4j_password"
    

Cookbook

The cookbook/ directory contains practical examples of how to use a1facts.

The cookbook/example/ directory shows how to build a financial analyst agent that can answer questions about companies. To run this example, navigate to the directory and run:

python cookbook/example/infoagent.py

You can modify this script to experiment with different data, queries, or other functionalities of the knowledge graph.

Privacy Notice

We collect minimal usage statistics (number of times the library is run) to help improve the project. You can opt-out by setting the environment variable A1FACTS_TELEMETRY_DISABLED=1.

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

a1facts-0.1.6.tar.gz (25.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

a1facts-0.1.6-py3-none-any.whl (31.2 kB view details)

Uploaded Python 3

File details

Details for the file a1facts-0.1.6.tar.gz.

File metadata

  • Download URL: a1facts-0.1.6.tar.gz
  • Upload date:
  • Size: 25.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for a1facts-0.1.6.tar.gz
Algorithm Hash digest
SHA256 761dca1ac30ae282ff80138cb1cd7bcbe3c70d3e87665655523f045fc25d21c8
MD5 55660b0998c8a80ccab2155877987801
BLAKE2b-256 806a4f075447578f526838922b1b68534f1a21f85bcf13b766e3a40ed23118bc

See more details on using hashes here.

File details

Details for the file a1facts-0.1.6-py3-none-any.whl.

File metadata

  • Download URL: a1facts-0.1.6-py3-none-any.whl
  • Upload date:
  • Size: 31.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for a1facts-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 9af5c9d6b53242449af8c31a7c8c8f9ec5f67186aa355f55fd475709d3378f1d
MD5 9911a217e13f216fd3d6b7ea89d840d1
BLAKE2b-256 ddeb346a2169b9e92b11e49e06279fe188f82e5821dff964c0381a010ec26dfc

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page