Skip to main content

Mirix Client - Lightweight Python client for Mirix server

Project description

Mirix Logo

MIRIX - Multi-Agent Personal Assistant with an Advanced Memory System

Your personal AI that builds memory through screen observation and natural conversation

Important Update: 0.1.4 (Main) vs 0.1.3 (Desktop Agent)
Starting with 0.1.4, the main branch is a brand-new release line where Mirix is a pure memory system that can be plugged into any existing agents. The desktop personal assistant (frontend + backend) has been deprecated and is no longer shipped on main. If you need the earlier desktop application with the built-in agent, use the desktop-agent branch.

| 🌐 Website | 📚 Documentation | 📄 Paper | 💬 Discord


Key Features 🔥

  • Multi-Agent Memory System: Six specialized memory components (Core, Episodic, Semantic, Procedural, Resource, Knowledge) managed by dedicated agents
  • Screen Activity Tracking: Continuous visual data capture and intelligent consolidation into structured memories
  • Privacy-First Design: All long-term data stored locally with user-controlled privacy settings
  • Advanced Search: PostgreSQL-native BM25 full-text search with vector similarity support
  • Multi-Modal Input: Text, images, voice, and screen captures processed seamlessly

Quick Start

Local Development (No Docker)

Step 1: Backend & Dashboard:

pip install -r requirements.txt

In terminal 1:

python scripts/start_server.py

In terminal 2:

cd dashboard
npm install
npm run dev

Step 2: Create an API key in the dashboard (http://localhost:5173) and set as the environmental variable MIRIX_API_KEY.

Step 3: Client (Python, mirix-client, https://pypi.org/project/mirix-client/):

pip install mirix-client

In terminal 3:

python samples/run_client.py

Build and Publish the Client to PyPI

# Build (already done if you ran this)
bash ./scripts/packaging/build_client.sh -v 0.1.6

# Set PyPI token
export TWINE_USERNAME=__token__
export TWINE_PASSWORD=pypi-AgEIcHlwaS5vcmcCJDQ4MWYwNTNhLWQyNWMtNDY1OS04NmFiLWExNzZhZDUyMDcxZQACDVsxLFsibWlyaXgiXV0AAixbMixbImIzNDFlYzRkLTQ0Y2UtNDAxZC1hN2Y3LTQxZDEyZjNiYzY4MCJdXQAABiDj1gF5z5aw4TugRYwfnJkFuVeuR8lR3_5iNpMXFy8FZg

# Optional: check package
twine check dist/*

# Upload client
twine upload dist/mirix-client-0.1.6*

Docker Compose (Local)

docker compose up -d

Database Setup (for Neon PostgreSQL)

1. Install required Python packages (if not already installed)

pip install sqlalchemy psycopg2-binary python-dotenv

2. Run the setup script

python scripts/setup_neon_database.py

Production Deployment

See DEPLOYMENT_GUIDE.md for complete deployment guide with SSL/TLS encryption.

Quick deploy:

# Upload to server, then:
cp env.production.template .env.production
nano .env.production  # Configure settings
./scripts/deploy.sh

Now you are ready to go! See the example below:

from mirix import MirixClient

client = MirixClient(
    api_key="your-api-key",
)

client.initialize_meta_agent(
    config={
        "llm_config": {
            "model": "gpt-4o-mini",
            "model_endpoint_type": "openai",
            "model_endpoint": "https://api.openai.com/v1",
            "context_window": 128000,
        },
        "build_embeddings_for_memory": True,
        "embedding_config": {
            "embedding_model": "text-embedding-3-small",
            "embedding_endpoint": "https://api.openai.com/v1",
            "embedding_endpoint_type": "openai",
            "embedding_dim": 1536,
        },
        "meta_agent_config": {
            "agents": [
                "core_memory_agent",
                "resource_memory_agent",
                "semantic_memory_agent",
                "episodic_memory_agent",
                "procedural_memory_agent",
                "knowledge_memory_agent",
                "reflexion_agent",
                "background_agent",
            ],
            "memory": {
                "core": [
                    {"label": "human", "value": ""},
                    {"label": "persona", "value": "I am a helpful assistant."},
                ],
                "decay": {
                    "fade_after_days": 30,
                    "expire_after_days": 90,
                },
            },
        },
    }
)

client.add(
    user_id="demo-user",
    messages=[
        {"role": "user", "content": [{"type": "text", "text": "The moon now has a president."}]},
        {"role": "assistant", "content": [{"type": "text", "text": "Noted."}]},
    ],
)

memories = client.retrieve_with_conversation(
    user_id="demo-user",
    messages=[
        {"role": "user", "content": [{"type": "text", "text": "What did we discuss on MirixDB in last 4 days?"}]},
    ],
    limit=5,
)
print(memories)

For more API examples, see samples/run_client.py.

License

Mirix is released under the Apache License 2.0. See the LICENSE file for more details.

Contact

For questions, suggestions, or issues, please open an issue on the GitHub repository or contact us at founders@mirix.io

Join Our Community

Connect with other Mirix users, share your thoughts, and get support:

💬 Discord Community

Join our Discord server for real-time discussions, support, and community updates: https://discord.gg/FXtXJuRf

🎯 Weekly Discussion Sessions

We host weekly discussion sessions where you can:

  • Discuss issues and bugs
  • Share ideas about future directions
  • Get general consultations and support
  • Connect with the development team and community

📅 Schedule: Friday nights, 8-9 PM PST
🔗 Zoom Link: https://ucsd.zoom.us/j/96278791276

📱 WeChat Group

You can add the account ari_asm so that I can add you to the group chat.

Acknowledgement

We would like to thank Letta for open-sourcing their framework, which served as the foundation for the memory system in this project.

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

mirix-0.1.6.tar.gz (86.7 kB view details)

Uploaded Source

Built Distribution

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

mirix-0.1.6-py3-none-any.whl (109.1 kB view details)

Uploaded Python 3

File details

Details for the file mirix-0.1.6.tar.gz.

File metadata

  • Download URL: mirix-0.1.6.tar.gz
  • Upload date:
  • Size: 86.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.9

File hashes

Hashes for mirix-0.1.6.tar.gz
Algorithm Hash digest
SHA256 07eeacb423b4f51a1e28f4b0432414d9b105752c765267fee80d49a591dfe833
MD5 c2f1eddfd5282fc47db747baf1561e7f
BLAKE2b-256 675f2b29a73efbef8d4114ca00e990bd56fdf5b04b7d4d537062bfa8c27680d8

See more details on using hashes here.

File details

Details for the file mirix-0.1.6-py3-none-any.whl.

File metadata

  • Download URL: mirix-0.1.6-py3-none-any.whl
  • Upload date:
  • Size: 109.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.9

File hashes

Hashes for mirix-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 fd2ac849189089277def4185d259e71e8fc1352e72c19a2e1b26ce7c7aa3c4ae
MD5 010dd4dc733b82f984c720faeb39ca3b
BLAKE2b-256 5b253059b6b0b3da046b8af3ec5e84f9c8b30243fd5b56727ea90365e297736b

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