Continuous learning system that tracks agent interactions, detects patterns, and provides improvement recommendations.
Project description
Socratic Learning
Why Socratic Learning?
Most AI platforms treat learning as an afterthought. Socratic Learning makes continuous improvement built-in:
- Interaction Tracking - Capture and store all agent interactions with full context for analysis
- Pattern Detection - Automatically identify recurring patterns in agent behaviors and model outputs
- Performance Monitoring - Track success rates, response times, and costs across all interactions
- Data-Driven Recommendations - Get actionable improvement suggestions based on detected patterns
- Fine-Tuning Ready - Export interaction data in industry-standard formats for model fine-tuning
A continuous learning system for AI agents that tracks interactions, detects patterns, and provides data-driven improvement recommendations.
Features
- Interaction Tracking - Capture and store all agent interactions with context
- Pattern Detection - Identify recurring patterns in agent behaviors and LLM outputs
- Performance Metrics - Monitor agent effectiveness with success rates, response times, costs
- User Feedback Integration - Collect and analyze user feedback on agent responses
- Learning Recommendations - Generate actionable improvement suggestions
- Fine-Tuning Export - Export interaction data for model fine-tuning
- Analytics & Reporting - JSON-based insights and metrics
- Framework Integration - Works with Openclaw and LangChain
Installation
# Core package
pip install socratic-learning
# With Socratic Agents integration
pip install socratic-learning[agents]
# With all optional dependencies
pip install socratic-learning[all]
# For development
pip install socratic-learning[dev]
Quick Start
from socratic_learning import LearningManager
from socratic_agents import SocraticCounselor
# Initialize learning manager
learning = LearningManager(storage="sqlite", db_path="learning.db")
# Create a tracking session
session_id = learning.create_session(
user_id="user123",
context={"environment": "production"}
)
# Track agent interactions
counselor = SocraticCounselor()
result = counselor.guide("recursion", level="beginner")
learning.track_interaction(
session_id=session_id,
agent_name="SocraticCounselor",
input_data={"topic": "recursion", "level": "beginner"},
output_data=result,
model_name="claude-opus-4",
provider="anthropic",
input_tokens=150,
output_tokens=500,
duration_ms=1200.0,
)
# Add user feedback
learning.add_feedback(
interaction_id=interaction.interaction_id,
rating=5,
feedback="Very helpful explanation!"
)
# Get metrics
metrics = learning.get_metrics(agent_name="SocraticCounselor")
print(f"Success rate: {metrics.success_rate}%")
print(f"Avg rating: {metrics.avg_rating}/5")
# Detect patterns
patterns = learning.detect_patterns(agent_name="SocraticCounselor")
for pattern in patterns:
print(f"Pattern: {pattern.name} (confidence: {pattern.confidence})")
# Get recommendations
recommendations = learning.get_recommendations(agent_name="SocraticCounselor")
for rec in recommendations:
print(f"Recommendation: {rec.title}")
# Export for fine-tuning
learning.export_for_finetuning(
output_path="finetuning_data.jsonl",
agent_name="SocraticCounselor",
min_rating=4,
format="openai"
)
Core Concepts
Interaction
Represents a single agent interaction with input, output, performance metrics, and optional user feedback.
Pattern
A detected recurring pattern in agent behaviors (e.g., error patterns, topic-specific behaviors).
Metric
Aggregated performance metrics (success rate, average response time, user satisfaction, costs).
Recommendation
An actionable improvement suggestion based on detected patterns and metrics.
Architecture
- Core Models - Dataclass-based models with serialization
- Storage Layer - Abstract interface with SQLite backend
- Tracking - Interaction logger with session management
- Analytics - Pattern detection and metrics collection
- Integrations - Openclaw skills and LangChain tools
Documentation
- Maturity Calculation System - Complete guide to the confidence-weighted maturity scoring system, including core algorithms, category definitions, and API reference
- See examples/ for complete working examples
Testing
# Run all tests
pytest
# Run with coverage
pytest --cov=src/socratic_learning --cov-report=html
# Run specific test file
pytest tests/unit/test_models.py -v
Code Quality
# Format with Black
black src/ tests/
# Lint with Ruff
ruff check src/ tests/
# Type check with MyPy
mypy src/
License
MIT
Contributing
Contributions welcome! Please open an issue or submit a PR.
Support Development
If you find this package useful, consider supporting development:
- Become a Sponsor - Get early access to new features
- Star on GitHub - Shows your appreciation
- Report Issues - Help improve the package
Your support helps fund development of the entire Socratic ecosystem.
Status
Phase 1 - Core foundation complete (v0.1.0 development)
- ✅ Core data models
- ✅ SQLite storage
- ✅ Unit tests
- 🚀 Phase 2-6 planned
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 socratic_learning-0.1.4.tar.gz.
File metadata
- Download URL: socratic_learning-0.1.4.tar.gz
- Upload date:
- Size: 39.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6c04612f59b5115e8194e849a164754a2f6ad3eccf596d368b8cb8d13d8a4061
|
|
| MD5 |
82f27bd8e607945ba61ec331f8c3c851
|
|
| BLAKE2b-256 |
5d15575c17f38e70b0641e18d231507d3dff3864030008d10725021d21cc6024
|
File details
Details for the file socratic_learning-0.1.4-py3-none-any.whl.
File metadata
- Download URL: socratic_learning-0.1.4-py3-none-any.whl
- Upload date:
- Size: 50.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8ff8a4d54996d5a0db986be20b6d11ccb8356e8be6628f2f3acd2b4967f0d8fe
|
|
| MD5 |
4d941b04f1a44da04b485a38c1840ac6
|
|
| BLAKE2b-256 |
b563b74a1ecb98c1277ccbbd9b1512dbc80873441998ffb6b6e3056d5196d9a6
|