Skip to main content

a1facts - precise knowledge for AI agents

Project description

a1facts: The precision layer for AI

a1facts is a powerful Python framework that acts as a verifiable knowledge layer for factual, precise AI. It allows you to define a clear structure (ontology) for your domain, ingest verifiyable 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 AI agents and 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.
  • Verifiable Ingestion: Convert unstructured knowledge 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 high stakes 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.11.tar.gz (29.9 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.11-py3-none-any.whl (34.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: a1facts-0.1.11.tar.gz
  • Upload date:
  • Size: 29.9 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.11.tar.gz
Algorithm Hash digest
SHA256 afbd6d31316ebcd46deab74427917981f8cfece577e934e312f39bab60c9af9a
MD5 38c8c443d4a1ac6f3e311216b98fd164
BLAKE2b-256 75de57ef2691e205de76f6b3449a96067c3aee999857f223badc807fc15417b9

See more details on using hashes here.

File details

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

File metadata

  • Download URL: a1facts-0.1.11-py3-none-any.whl
  • Upload date:
  • Size: 34.7 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.11-py3-none-any.whl
Algorithm Hash digest
SHA256 7bd2aa57a7c698ba369fd6f69ea8eadc8694ef3098cbd71eaa8bd34bc585a6f5
MD5 6de4efe23d790e98c991b41f63d9eb65
BLAKE2b-256 6127d1b82ada6846efdb268ca92d87f4d2566ee4052f9f9e9b836232e1f272c8

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