Skip to main content

A modern way to allow your AI to learn from every interaction

Project description


SynLrn – Modular Multi-Stage Learning for AI (No Naming or Structure Restrictions)

Overview

SynLrn is a production-ready, modular system for context-based learning memory and retrieval—designed for any AI or agent workflow. SynLrn supports any number of custom learning stages, adapts to your data, and makes context recall fast and simple—no naming, schema, or vendor constraints.

Highlights:

  • Any learning stages you want: Use any stage names or workflow steps (thinking, clarifying, etc.)
  • No format restrictions: Structure your learned data and knowledge base how you want.
  • No external server: Everything runs locally, uses fast SQLite and RapidFuzz.
  • Plug-in knowledge base: Start empty or preload with your own examples.
  • Works with all frameworks: Use SynLrn in any Python project, agent, or LLM pipeline.

Why SynLrn?

Traditional “memory” frameworks force you to:

  • Use their schema, stage names, or folder structures.
  • Fit your workflow to their definitions.
  • Often require a server, specific model, or fixed APIs.

SynLrn:

  • Lets you define your own learning flow—no hard-coded stage names, no schema lock-in.
  • Loads any data, any way: Add, group, and recall examples however you want.
  • Keeps you in control: Your workflow, your code, your memory.

Key Features

  • Flexible stage loading: Use any number of workflow stages.
  • Pluggable knowledge base: Point to your own Python modules or classes.
  • Context-based retrieval: RapidFuzz for fast, fuzzy example recall.
  • Low token use: Matches and retrievals use minimal tokens, ideal for LLMs instead of providing full examples. in one shot SynLrn retrieves relevant examples based on context.
  • Minimal, direct API: No setup bloat or function call ceremony.

Example Layout (ALL valid)

project_root/
├── SLKnowledgebase/
│   └── Knowledgebase.py  # Your example base (optional)
├── .env
├── app.py
└── ...

Or any layout you prefer—no requirements.


How It Works

  1. You define your workflow stages.
  2. Store and retrieve context/response examples per stage, for any purpose.
  3. Recall examples by context (with fallbacks if needed).

Example Usage

from SynLrn import SynLrn

stages = [
    "thinking", "clarifying", "gathering",
    "defining", "refining", "reflecting", "decision"
]

fallbacks = {
    "thinking": [
        "user:\nWhat can you do?\n\nassistant:\nI can help with a wide variety of tasks, including..."
    ]
}

learn = SynLrn(stages=stages, fallbacks=fallbacks)

# Add a new memory/example
learn.addToLearned("thinking", "How do you work?", "I process your requests by reasoning over ...")

# Retrieve similar examples
results = learn.retrieveStage("How do you work?", "thinking")
for entry in results:
    print(entry)

See full code and more examples on GitHub.


Customization

  • Knowledge base: Optionally preload with your own class/module, any structure, any naming—SynLrn will find your example data automatically.

  • Fallbacks: Pass a dict or a callable for custom fallback responses per stage.

  • Storage: All learning is stored locally (SQLite, configurable directory).


FAQ

Q: Do I have to follow any naming or folder structure? A: No. Use any stage names, directory layout, or file names you want.

Q: Can I use this in any Python agent, RAG, or LLM workflow? A: Yes.

Q: Do I need a server, or does SynLrn require a specific cloud provider? A: No. Everything is local, pure Python.


Code Examples

You can find code examples on my GitHub repository.


License

This project is licensed under the Apache License, Version 2.0. Copyright 2025 Tristan McBride Sr.


Acknowledgements

Project by:

  • Tristan McBride Sr.
  • Sybil

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

synlrn-0.0.2.tar.gz (7.8 kB view details)

Uploaded Source

Built Distribution

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

synlrn-0.0.2-py3-none-any.whl (7.3 kB view details)

Uploaded Python 3

File details

Details for the file synlrn-0.0.2.tar.gz.

File metadata

  • Download URL: synlrn-0.0.2.tar.gz
  • Upload date:
  • Size: 7.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.3

File hashes

Hashes for synlrn-0.0.2.tar.gz
Algorithm Hash digest
SHA256 0a956fca11988d0bd70eab3a27bf826317976f3facd758e1401c86efe775e4b4
MD5 d28fb020805170dcb6450ed0267505e7
BLAKE2b-256 054dc4a2a553d5a0f878c3f9709f27c1f78a44febac4e2648d2fc0005d1474c8

See more details on using hashes here.

File details

Details for the file synlrn-0.0.2-py3-none-any.whl.

File metadata

  • Download URL: synlrn-0.0.2-py3-none-any.whl
  • Upload date:
  • Size: 7.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.3

File hashes

Hashes for synlrn-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 dc22e1fb160e9657e157916ccbfe756bfc608eb5534dbfddb917876853ddee26
MD5 cfeb7a62fe6102586d595ef82543bf64
BLAKE2b-256 7434088c0411c5b292acdb81131515b4299f6c63eeffeb4e77987dee0dcd5a6b

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