Theus Agentic Framework (formerly POP SDK) - Industrial Grade Process-Oriented Programming
Project description
Theus (formerly POP SDK)
The "Operating System" for AI Agents and Complex Systems.
Theus (Process-Oriented Programming) is a paradigm shift designed for building robust, stateful AI agents. Unlike OOP which encapsulates state and behavior, Theus decouples them completely to ensure:
- Transactional Integrity: Every action is atomic.
- Safety by Default: Inputs are immutable; outputs are strictly contracted.
- Observability: Every state change is logged and reversible.
🌟 Key Features
🛡️ Safety & Security
- Context Locking ("The Vault"): Prevents accidental state mutation from external code (
main.py). Warning mode by default, Strict mode (crash) for CI. - Frozen Inputs: Process inputs are wrapped in
FrozenList/FrozenDict. Side-effects are blocked at runtime. - Strict Contracts: Explicit
@process(inputs=[...], outputs=[...])decorators prevent "State Spaghetti".
⚡ Developer Experience
- POP CLI: Bootstrap new projects instantly with
pop init. - Hybrid Guard: Friendly warnings for rapid dev, Strict enforcement for interaction.
- Zero-Dependency Core: Pure Python. Compatible with PyTorch, TensorFlow, or any other library.
📦 Installation
pip install theus
🚀 Quick Start (CLI)
The fastest way to start is using the CLI tool.
Note: We recommend using
python -m popto ensure compatibility across all operating systems (Windows/Linux/Mac) without worrying about PATH configuration.
# 1. Initialize a new project
python -m pop init my_agent
# 2. Enter directory
cd my_agent
# 3. Run the skeleton agent
python main.py
Arguments:
python -m pop init <name>: Create a new project folder.python -m pop init .: Initialize in current directory.
(You can also use the short command pop init if your Python Scripts directory is in your system PATH).
📚 Manual Usage
1. Define Context (Data)
from dataclasses import dataclass
from pop import BaseGlobalContext, BaseDomainContext, BaseSystemContext
@dataclass
class MyGlobal(BaseGlobalContext):
counter: int = 0
@dataclass
class MySystem(BaseSystemContext):
global_ctx: MyGlobal
# ... domain_ctx ...
2. Define Process (Logic)
from pop import process
@process(
inputs=['global.counter'],
outputs=['global.counter']
)
def increment(ctx):
# Valid: Declared in outputs
ctx.global_ctx.counter += 1
return "Incremented"
@process(inputs=['global.counter'], outputs=[])
def illegal_write(ctx):
# INVALID: Read-Only Input
# Raises ContractViolationError
ctx.global_ctx.counter += 1
3. Run Engine
from pop import POPEngine
system = MySystem(MyGlobal(), ...)
engine = POPEngine(system) # Default: Warning Mode
engine.register_process("inc", increment)
engine.run_process("inc")
⚙️ Configuration
You can control strictness via Environment Variables (supported in .env files):
| Variable | Values | Description |
|---|---|---|
POP_STRICT_MODE |
1, true |
Enabled: Raises LockViolationError on unsafe external mutation. Disabled (Default): Logs WARNING but allows mutation. |
Safe External Mutation
To modify context from main.py without triggering warnings/errors, use the explicit API:
with engine.edit() as ctx:
ctx.domain.my_var = 100
📄 License
MIT License. See LICENSE for details.
Project details
Release history Release notifications | RSS feed
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 theus-0.1.0.tar.gz.
File metadata
- Download URL: theus-0.1.0.tar.gz
- Upload date:
- Size: 29.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ffff5118a8f3774f261e467e4f79fcc8e8af8759ac4e9a18f9c6cb573ef14623
|
|
| MD5 |
cdc42578175c1f651fbd25643ce66503
|
|
| BLAKE2b-256 |
306dcd8e250d1fc83596b3ab17e2fbb07f73347c9e9c602f297bb6f7bb0c4832
|
File details
Details for the file theus-0.1.0-py3-none-any.whl.
File metadata
- Download URL: theus-0.1.0-py3-none-any.whl
- Upload date:
- Size: 25.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dfe951325dabe428e921ee233fc1c6282a6b2c6830513991051368b8d2ab5d17
|
|
| MD5 |
441e81fd9e294b1c0d732d32e44976ab
|
|
| BLAKE2b-256 |
73e4af1a3def6ad2918c51b3c313cb8ee538868cc18b8850e04d722f6ac75756
|