Skip to main content

Memory system for AI agents with Structured RAG, built on TypeAgent

Project description

Fork Changes

I've been keeping an eye on this repo for a while. I'm also personally interested in personal assistant agents, and I've been trying to find best practices for memory. Structured RAG is a great design, but since this is an experimental project, the feature set isn't complete yet. So I forked the original repo and added more features, aiming to make it work for more general use cases and projects.

This fork adds Momex - a high-level API wrapper for TypeAgent's Structured RAG.

What's New

  • Agent API - High-level chat interface with automatic memory management
  • Short-term memory - Session-based conversation history with persistence
  • Long-term memory - Structured RAG with entity/action/topic extraction
  • Multi-tenant support with hierarchical collections (user:xiaoyuzhang)
  • PostgreSQL backend with pgvector for production deployment

Installation

pip install momex

Quick Start

import asyncio
from momex import Agent, MomexConfig, LLMConfig

async def main():
    config = MomexConfig(
        llm=LLMConfig(
            provider="openai",
            model="gpt-4o",
            api_key="sk-xxx",
        ),
    )

    agent = Agent("user:xiaoyuzhang", config)

    r = await agent.chat("My name is Xiaoyu, I love Python")
    print(r.content)

    r = await agent.chat("What's my name?")
    print(r.content)  # "Your name is Xiaoyu"

asyncio.run(main())

Two API Levels

Level API Description
Level 1 Agent Chat API with automatic memory (recommended)
Level 2 Memory Manual control for custom agents

See docs/momex.md for full documentation.


Python package 'typeagent'

This is an experimental prototype

Working toward a shared understanding of the MVP for structured RAG.

This is sample code

This is an in-progress project aiming at a Pythonic translation of TypeAgent KnowPro and a few related packages from TypeScript to Python.

Warning

This library will send its input to an LLM hosted by a third party. Don't use it to index confidential information.

Documentation

Trademarks

This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft trademarks or logos is subject to and must follow Microsoft's Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship. Any use of third-party trademarks or logos are subject to those third-party's policies.

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

momex-0.2.0.tar.gz (7.6 MB view details)

Uploaded Source

Built Distribution

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

momex-0.2.0-py3-none-any.whl (212.1 kB view details)

Uploaded Python 3

File details

Details for the file momex-0.2.0.tar.gz.

File metadata

  • Download URL: momex-0.2.0.tar.gz
  • Upload date:
  • Size: 7.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for momex-0.2.0.tar.gz
Algorithm Hash digest
SHA256 987704ea6be0b7033747df25ab1f4e92e911ad65ca30baf0c059e5d673729ffd
MD5 95919f7ef20187484fa32ffc7aa5dc57
BLAKE2b-256 f04ce8ea32f1f3df43390f2ff19e63c42c8de7115c10a40ad77aec4f821ad20f

See more details on using hashes here.

Provenance

The following attestation bundles were made for momex-0.2.0.tar.gz:

Publisher: release-py.yml on xiaoyu-work/momex

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file momex-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: momex-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 212.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for momex-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0ebedce282c24020f53c744dde6a3d24b4936f640c21b2556a02debee67f6326
MD5 e49f04a267462bad188b49070d4675fa
BLAKE2b-256 268600c3093e0d09757dda02858fa7c421ae5f418ef592d73987731f429b8e79

See more details on using hashes here.

Provenance

The following attestation bundles were made for momex-0.2.0-py3-none-any.whl:

Publisher: release-py.yml on xiaoyu-work/momex

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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