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
- You define your workflow stages.
- Store and retrieve context/response examples per stage, for any purpose.
- 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
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 synlrn-0.1.1.tar.gz.
File metadata
- Download URL: synlrn-0.1.1.tar.gz
- Upload date:
- Size: 12.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e6d14430682bb72930717c1d0300a2aef5718592885b742442d733bfa00c5c5f
|
|
| MD5 |
b904c49fc41b78d729ceaf5da4576c87
|
|
| BLAKE2b-256 |
3266929b2f5872e0be623c60d72e8c1b7ab17d23ad416dbe16164da6c1512d14
|
File details
Details for the file synlrn-0.1.1-py3-none-any.whl.
File metadata
- Download URL: synlrn-0.1.1-py3-none-any.whl
- Upload date:
- Size: 10.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e6696bf436f674eb6bc5f63a947339b21a5e0920146199aa881890c94d2c3fe7
|
|
| MD5 |
3a513d581d88abcfaca43410475b6f8b
|
|
| BLAKE2b-256 |
f76d800934fdf82a23f62704b539b226c5cab1a4c1489d080277ab005298fcf4
|