Skip to main content

MemoryScope is a powerful and flexible long term memory system for LLM chatbots. It consists of a memory database and three customizable system operations, which can be flexibly combined to provide robust long term memory services for your LLM chatbot.

Project description

English

MemoryScope

MemoryScopeLogo

Equip your LLM chatbot with a powerful and flexible long term memory system.


📰 News

  • [2025-01-22] We release MemoryScope v0.1.1.0, which is also available in PyPI!

🌟 What is MemoryScope?

MemoryScope provides LLM chatbots with powerful and flexible long-term memory capabilities, offering a framework for building such abilities. It can be applied to scenarios like personal assistants and emotional companions, continuously learning through long-term memory to remember users' basic information as well as various habits and preferences. This allows users to gradually experience a sense of "understanding" when using the LLM.

Demo

en_demo

Framework

Framework

💾 Memory Database: MemoryScope is equipped with a vector database (default is ElasticSearch) to store all memory fragments recorded in the system.

🔧 Worker Library: MemoryScope atomizes the capabilities of long-term memory into individual workers, including over 20 workers for tasks such as query information filtering, observation extraction, and insight updating.

🛠️ Operation Library: Based on the worker pipeline, it constructs the operations for memory services, realizing key capabilities such as memory retrieval and memory consolidation.

  • Memory Retrieval: Upon arrival of a user query, this operation returns the semantically related memory pieces and/or those from the corresponding time if the query involves reference to time.
  • Memory Consolidation: This operation takes in a batch of user queries and returns important user information extracted from the queries as consolidated observations to be stored in the memory database.
  • Reflection and Re-consolidation: At regular intervals, this operation performs reflection upon newly recorded observations to form and update insights. Then, memory re-consolidation is performed to ensure contradictions and repetitions among memory pieces are properly handled.

⚙️ Best Practices:

  • Based on the core capabilities of long-term memory, MemoryScope has implemented a dialogue interface (API) with long-term memory and a command-line dialogue practice (CLI) with long-term memory.
  • MemoryScope combines currently popular agent frameworks (AutoGen, AgentScope) to provide best practices.

Main Features

⚡ Low response-time (RT) for the user:

  • Backend operations (Memory Consolidation, Reflection and Re-consolidation) are decoupled from the frontend operation (Memory Retrieval) in the system.
  • While backend operations are usually (and are recommended to be) queued or executed at regular intervals, the system's response time (RT) for the user depends solely on the frontend operation, which is only ~500ms.

🌲 Hierarchical and coherent memory:

  • The memory pieces stored in the system are in a hierarchical structure, with insights being the high level information from the aggregation of similarly-themed observations.
  • Contradictions and repetitions among memory pieces are handled periodically to ensure coherence of memory.
  • Fictitious contents from the user are filtered out to avoid hallucinations by the LLM.

⏰ Time awareness:

  • The system is time sensitive when performing both Memory Retrieval and Memory Consolidation. Therefore, it can retrieve accurate relevant information when the query involves reference to time.

💼 Supported Model API

Backend Task Some Supported Models
openai_backend Generation gpt-4o, gpt-4o-mini, gpt-4, gpt-3.5-turbo
Embedding text-embedding-ada-002, text-embedding-3-large, text-embedding-3-small
dashscope_backend Generation qwen-max, qwen-plus, qwen-plus, qwen2-72b-instruct
Embedding text-embedding-v1, text-embedding-v2
Reranker gte-rerank

In the future, we will support more model interfaces and local deployment of LLM and embedding services.

🚀 Installation

For installation, please refer to Installation.md.

🍕 Quick Start

💡 Contribute

Contributions are always encouraged!

We highly recommend install pre-commit hooks in this repo before committing pull requests. These hooks are small house-keeping scripts executed every time you make a git commit, which will take care of the formatting and linting automatically.

pip install -e .
pre-commit install

Please refer to our Contribution Guide for more details.

📖 Citation

Reference to cite if you use MemoryScope in a paper:

@software{MemoryScope,
author = {MemoryScope},
month = {01},
title = {{MemoryScope}},
url = {https://github.com/memoryscope/memoryscope},
year = {2025}
}

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

memoryscope-ai-0.1.1.0.tar.gz (84.0 kB view details)

Uploaded Source

Built Distribution

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

memoryscope_ai-0.1.1.0-py3-none-any.whl (154.4 kB view details)

Uploaded Python 3

File details

Details for the file memoryscope-ai-0.1.1.0.tar.gz.

File metadata

  • Download URL: memoryscope-ai-0.1.1.0.tar.gz
  • Upload date:
  • Size: 84.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.6

File hashes

Hashes for memoryscope-ai-0.1.1.0.tar.gz
Algorithm Hash digest
SHA256 001d20df4646dc134c0cf0eb478cf0bad6dafef6e4ef95e8870a7de8c8cf8037
MD5 5235c93f5f9998f2731c82962f156ccb
BLAKE2b-256 02d1479fbabec810a6efb041ba5b915fe5282139fddf910da465e67cc0d558cb

See more details on using hashes here.

File details

Details for the file memoryscope_ai-0.1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for memoryscope_ai-0.1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e035941ee7eb0fda3075f8a5fc02b0c84b513754bdd8444a8e6dc6aa87912dfe
MD5 c94fc06965763b5e4b1184356258f0bd
BLAKE2b-256 ef91ecc0bfdcd4cc118632d84ddfd414e69d61e349576957b211b031db60c60b

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