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
- Found in the docs directory
- Quick install:
pip install typeagent - Download the PyBay '25 PowerPoint slides
- Download the PyBay '25 slides as PDF
- Watch the PyBay '25 video
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2b56ac502e9e6a073f83142db155fc5b9e68a932bb3ff6dff4fd4fd1cd2373bf
|
|
| MD5 |
e1b962357a596b5e173627c3dfb9d988
|
|
| BLAKE2b-256 |
c195e0a5dc49f7c856741d779870ee929c1e22064820954dead3f672dbf41bae
|
Provenance
The following attestation bundles were made for momex-0.2.2.tar.gz:
Publisher:
release-py.yml on xiaoyu-work/momex
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
momex-0.2.2.tar.gz -
Subject digest:
2b56ac502e9e6a073f83142db155fc5b9e68a932bb3ff6dff4fd4fd1cd2373bf - Sigstore transparency entry: 1256192574
- Sigstore integration time:
-
Permalink:
xiaoyu-work/momex@8f157d47daa154ab32f7bb3bda76f9ee22936e2c -
Branch / Tag:
refs/tags/v0.2.2 - Owner: https://github.com/xiaoyu-work
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-py.yml@8f157d47daa154ab32f7bb3bda76f9ee22936e2c -
Trigger Event:
push
-
Statement type:
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
66d85b0f572a1c6b224c93cef791a1c892ec1890d15a9661bd56bd39efa77c0e
|
|
| MD5 |
bbab46970a87b5cd54c83a590046299d
|
|
| BLAKE2b-256 |
5dd27c6b75794d884060bda79b8b7e03b0f9e4fae240e48196b4ad1728fcea23
|
Provenance
The following attestation bundles were made for momex-0.2.2-py3-none-any.whl:
Publisher:
release-py.yml on xiaoyu-work/momex
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
momex-0.2.2-py3-none-any.whl -
Subject digest:
66d85b0f572a1c6b224c93cef791a1c892ec1890d15a9661bd56bd39efa77c0e - Sigstore transparency entry: 1256192653
- Sigstore integration time:
-
Permalink:
xiaoyu-work/momex@8f157d47daa154ab32f7bb3bda76f9ee22936e2c -
Branch / Tag:
refs/tags/v0.2.2 - Owner: https://github.com/xiaoyu-work
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-py.yml@8f157d47daa154ab32f7bb3bda76f9ee22936e2c -
Trigger Event:
push
-
Statement type: