A metacognitive runtime for Python agents: the Witness pattern.
Project description
Sakshi
Sakshi (साक्षी) is the Vedantic name for the consciousness that observes consciousness without acting.
A metacognitive runtime for Python agents: the Witness pattern. A watching process embedded in your agent that monitors plan execution, evaluates against expectations, and steers cognition without doing the cognition itself.
Status
0.10.0 pre-1.0. The typed Witness surface is present and package-local tests cover the main DTO, goal, plan, interpret, meta, motivation, trust, uncertainty, and guard primitives. The public API may still change in 0.x minor releases; production hosts must verify their adapters before relying on a new minor version.
⚠ The defaults are inert.
NoOpEventBus,NoOpBasinHook, andAlwaysPermitWriteGuardare intentional no-ops for tests and the quickstart below. A production host must inject real implementations ofEventBus,GoalStateStore, andWriteGuard— otherwise events drop on the floor, world state never resolves, and every Sakshi-originated write is silently permitted. Seesakshi.protocolsfor the interfaces and your host's adapter layer for examples.
Install
Sakshi is published to PyPI under the distribution name pysakshi. The
importable module is still sakshi:
pip install pysakshi
import sakshi
The bare name sakshi is reserved by an unrelated PyPI account with no
releases; once that name is recovered, pysakshi will become an alias.
To install the latest unreleased commit from source:
pip install git+https://github.com/bionicbutterfly13/sakshi
Release process: see docs/release-checklist.md.
What it is
The Witness pattern means the host keeps control of cognition while Sakshi observes it through typed seams. The host owns the planner, memory system, tool runtime, world model, and side effects. Sakshi receives declared expectations and runtime records, checks what happened against those expectations, and emits typed signals a host can route to dashboards, gates, audits, or meta-control policies.
That boundary is useful because it makes an agent inspectable without making Sakshi the agent's brain. Hosts can add contract monitoring, confidence calibration, goal lineage, motivation envelopes, risk records, trust repair recommendations, and defensive guards while keeping their domain logic and runtime dependencies outside the package.
Sakshi exposes a small, opinionated set of seams a host application supplies:
- An
EventBusfor emitting cycle and goal events. - A
Clockfor deterministic time. - A
GoalStateStorefor fetching world state and recording goal outcomes. - An optional
BasinHookfor hosts that maintain an attractor-basin field. - A
WriteGuardfor routing Sakshi-originated writes through the host's safety policy.
Around these protocols Sakshi assembles a generic six-phase cognitive cycle (PERCEIVE, INTERPRET, EVAL, INTEND, PLAN, ACT) and a meta-loop (MONITOR, ASSESS, CONTROL) framed as general metacognitive phases.
Quickstart
import asyncio
from sakshi.registries import PhaseRegistry
from sakshi.protocols import NoOpEventBus
async def main() -> None:
registry = PhaseRegistry(event_bus=NoOpEventBus())
await registry.start_cycle("cycle-001")
await registry.record_phase_output("PERCEIVE", {"basins": ["attention"]})
await registry.record_phase_output("INTERPRET", {"confidence": 0.82})
trace = await registry.finalize_cycle()
print(trace.cycle_id)
print([phase.phase_name for phase in trace.phase_results])
asyncio.run(main())
Hosts that need production side effects implement the small protocols in
sakshi.protocols and pass those implementations into Sakshi runtime classes.
Influences
Sakshi draws inspiration from MIDCA-style metacognitive control loops, active-inference monitoring, and production cognitive-runtime experience. See INSPIRATION.md for the full provenance.
Sakshi is not a MIDCA implementation, MIDCA-compatible, or a fork of any MIDCA codebase. The MIDCA reference architecture is one influence among several.
License
Apache-2.0. See LICENSE.
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 pysakshi-0.10.0.tar.gz.
File metadata
- Download URL: pysakshi-0.10.0.tar.gz
- Upload date:
- Size: 82.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c0ce45d5d97ce6f5561b300dd0f5077086fd57abefc729a8e7dcfd74d5e877d3
|
|
| MD5 |
e4edc7fbab6eda642c1d639607f267ce
|
|
| BLAKE2b-256 |
6d38efd3f94db491819671a5e79381678203a386d32def946cd32bdf3e4a99d4
|
Provenance
The following attestation bundles were made for pysakshi-0.10.0.tar.gz:
Publisher:
release.yml on bionicbutterfly13/sakshi
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pysakshi-0.10.0.tar.gz -
Subject digest:
c0ce45d5d97ce6f5561b300dd0f5077086fd57abefc729a8e7dcfd74d5e877d3 - Sigstore transparency entry: 1464936598
- Sigstore integration time:
-
Permalink:
bionicbutterfly13/sakshi@97b12157d137194861aa39222f0a35f46f795bc3 -
Branch / Tag:
refs/tags/v0.10.0 - Owner: https://github.com/bionicbutterfly13
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@97b12157d137194861aa39222f0a35f46f795bc3 -
Trigger Event:
push
-
Statement type:
File details
Details for the file pysakshi-0.10.0-py3-none-any.whl.
File metadata
- Download URL: pysakshi-0.10.0-py3-none-any.whl
- Upload date:
- Size: 109.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3c824bfdf51afc03edcc6e8f1af1ef9f652838bed16a060a0326c8a3d87740dd
|
|
| MD5 |
26205b18bfd62006ce93c84abb5642a9
|
|
| BLAKE2b-256 |
da399654ad1c4cf83fa3645fc24b67dc0bfe78c9d9c6a68447bc8c4e31e24d2e
|
Provenance
The following attestation bundles were made for pysakshi-0.10.0-py3-none-any.whl:
Publisher:
release.yml on bionicbutterfly13/sakshi
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pysakshi-0.10.0-py3-none-any.whl -
Subject digest:
3c824bfdf51afc03edcc6e8f1af1ef9f652838bed16a060a0326c8a3d87740dd - Sigstore transparency entry: 1464936666
- Sigstore integration time:
-
Permalink:
bionicbutterfly13/sakshi@97b12157d137194861aa39222f0a35f46f795bc3 -
Branch / Tag:
refs/tags/v0.10.0 - Owner: https://github.com/bionicbutterfly13
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@97b12157d137194861aa39222f0a35f46f795bc3 -
Trigger Event:
push
-
Statement type: