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 memory API for AI agents, built on TypeAgent's Structured RAG.

What's New

  • Hybrid search - Structured RAG + embedding similarity in parallel for best recall
  • Structured memory - Entity/action/topic extraction via LLM, term-based indexing
  • Embedding-only mode - search_by_embedding() for fast similarity search without LLM
  • 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 Memory, MomexConfig, LLMConfig

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

    # Create a memory collection
    memory = Memory(collection="user:xiaoyuzhang", config=config)

    # Add memories — automatically extracts entities, actions, topics
    await memory.add("My name is Xiaoyu, I love Python programming")

    # Search — returns structured results you can feed to your own agent
    results = await memory.search("Python")
    for item in results:
        print(f"[{item.type}] {item.text}")

asyncio.run(main())

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.2.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.2-py3-none-any.whl (204.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: momex-0.2.2.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.2.tar.gz
Algorithm Hash digest
SHA256 2b56ac502e9e6a073f83142db155fc5b9e68a932bb3ff6dff4fd4fd1cd2373bf
MD5 e1b962357a596b5e173627c3dfb9d988
BLAKE2b-256 c195e0a5dc49f7c856741d779870ee929c1e22064820954dead3f672dbf41bae

See more details on using hashes here.

Provenance

The following attestation bundles were made for momex-0.2.2.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.2-py3-none-any.whl.

File metadata

  • Download URL: momex-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 204.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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 66d85b0f572a1c6b224c93cef791a1c892ec1890d15a9661bd56bd39efa77c0e
MD5 bbab46970a87b5cd54c83a590046299d
BLAKE2b-256 5dd27c6b75794d884060bda79b8b7e03b0f9e4fae240e48196b4ad1728fcea23

See more details on using hashes here.

Provenance

The following attestation bundles were made for momex-0.2.2-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