Skip to main content

smolagents Tool subclasses for the Ejentum Reasoning Harness. Four tools (harness_reasoning, harness_code, harness_anti_deception, harness_memory) an agent calls before generating. Each call returns a task-matched cognitive operation engineered in two layers: a natural-language procedure plus an executable reasoning topology (graph DAG with gates, parallel branches, and meta-cognitive exits).

Project description

smolagents-ejentum

smolagents integration for the Ejentum Reasoning Harness. Four Tool subclasses an agent calls before generating, plus an ejentum_tools() factory that returns all four with shared config.

Each operation in the Ejentum library (679 of them, organized across four harnesses) is engineered in two layers:

  • a natural-language procedure the model can read, naming the steps to take and the failure pattern to refuse, and
  • an executable reasoning topology: a graph-shaped plan over those steps. The plan names explicit decision points where the model branches, parallel branches that run and rejoin, bounded loops that run until convergence, named meta-cognitive moments where the model is asked to stop, look at its own working, and re-enter at a specific step, plus escape paths for when the prescribed plan stops fitting the task at hand.

The natural-language layer tells the model what to do. The topology layer pins down how those steps connect: where to decide, where to loop, where to stop and look at itself. Together they act as a persistent attention anchor that survives long context windows and multi-turn execution chains, which is precisely where a model's own reasoning template typically decays.

Installation

pip install smolagents-ejentum

Configuration

Get an Ejentum API key at https://ejentum.com/pricing (free and paid tiers) and set it in your environment:

export EJENTUM_API_KEY="zpka_..."

Usage

Drop-in: all four tools

from smolagents import CodeAgent, InferenceClientModel
from smolagents_ejentum import ejentum_tools

model = InferenceClientModel(model_id="meta-llama/Llama-3.3-70B-Instruct")
agent = CodeAgent(tools=ejentum_tools(), model=model)  # reads EJENTUM_API_KEY from env

agent.run(
    "We've spent three months on the GraphQL gateway. "
    "Should we keep going or pivot to REST?"
)

The agent reads each tool's description and picks ejentum_harness_anti_deception on the sunk-cost framing, ejentum_harness_reasoning on a clean analytical question, etc.

Pick one tool

from smolagents import CodeAgent, InferenceClientModel
from smolagents_ejentum import EjentumAntiDeceptionTool

tool = EjentumAntiDeceptionTool()  # reads EJENTUM_API_KEY from env

agent = CodeAgent(tools=[tool], model=InferenceClientModel("..."))

Explicit API key

from smolagents_ejentum import ejentum_tools

tools = ejentum_tools(api_key="zpka_...")

The four tools

Class Tool name Best for Library size
EjentumReasoningTool ejentum_harness_reasoning Analytical, diagnostic, planning, multi-step tasks spanning abstraction, time, causality, simulation, spatial, and metacognition 311 operations
EjentumCodeTool ejentum_harness_code Code generation, refactoring, review, and debugging across the software-engineering layer 128 operations
EjentumAntiDeceptionTool ejentum_harness_anti_deception Prompts that pressure the agent to validate, certify, or soften an honest assessment 139 operations
EjentumMemoryTool ejentum_harness_memory Sharpening an observation already formed about cross-turn drift. Filter-oriented, not write-oriented. Format query as "I noticed X. This might mean Y. Sharpen: Z." 101 operations

What an injection looks like

A real reasoning mode response on the query investigate why our nightly ETL job has started failing intermittently over the past two weeks; nothing in the code or schema has changed:

[NEGATIVE GATE]
The server's response time was accepted as average, despite a suspicious
rhythm break in its timing pattern.

[PROCEDURE]
Step 1: Establish baseline timing profiles by extracting historical
durations and intervals for each event type. Step 2: Compare each observed
timing against its baseline and compute deviation magnitude. Step 3:
Classify anomalies as too fast, too slow, too early, or too late, and rank
by severity. ... Step 5: If deviation exceeds two standard deviations,
probe root cause by tracing upstream dependencies. ...

[REASONING TOPOLOGY]
S1:durations -> FIXED_POINT[baselines] -> N{dismiss_timing_deviations_
without_investigation} -> for_each: S2:compare -> S3:deviation ->
G1{>2sigma?} --yes-> S4:classify -> S5:probe_cause -> FLAG -> continue --no->
S6:validate -> continue -> all_checked -> OUT:anomaly_report

[TARGET PATTERN]
Establish timing baselines by extracting historical response intervals.
Compare current server response time to this baseline. ...

[FALSIFICATION TEST]
If no event timing is flagged as suspiciously fast or slow relative to
baseline, temporal anomaly detection was not active.

Amplify: timing baseline comparison; anomaly classification; security
context elevation
Suppress: average timing acceptance; outlier normalization

The agent reads both the natural-language [PROCEDURE] and the graph-logic [REASONING TOPOLOGY] before generating its user-facing answer. The bracketed labels are instructions to the agent, not content to display.

API reference

# Per-tool
EjentumReasoningTool(
    api_key: str | None = None,
    api_url: str = "https://ejentum-main-ab125c3.zuplo.app/logicv1/",
    timeout_seconds: float = 10.0,
)
# (same constructor on EjentumCodeTool, EjentumAntiDeceptionTool, EjentumMemoryTool)

# Factory
ejentum_tools(
    api_key: str | None = None,
    api_url: str = "https://ejentum-main-ab125c3.zuplo.app/logicv1/",
    timeout_seconds: float = 10.0,
) -> list[Tool]

Every tool exposes name, description, inputs={"query": {...}}, output_type="string". Errors are returned as human-readable strings from forward (no exceptions cross the tool boundary, so an agent step never crashes the run).

MCP alternative. This package wraps the Logic API REST gateway. smolagents also has a first-class MCP client (MCPClient, ToolCollection.from_mcp) that can consume the hosted Ejentum MCP endpoint at https://api.ejentum.com/mcp with Bearer auth. The PyPI package skips MCP setup and keeps the import surface tiny.

Hub-shareable tools constraint. smolagents' Hub-share convention requires __init__ to take only self. These tools are distributed via PyPI, not the Hub, so they take constructor args freely. If you fork and push_to_hub, refactor to hard-code config as class attributes.

Compatibility

  • Python 3.10+
  • smolagents>=1.0.0
  • requests>=2.31.0

Resources

License

MIT

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

smolagents_ejentum-0.1.0.tar.gz (11.2 kB view details)

Uploaded Source

Built Distribution

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

smolagents_ejentum-0.1.0-py3-none-any.whl (10.4 kB view details)

Uploaded Python 3

File details

Details for the file smolagents_ejentum-0.1.0.tar.gz.

File metadata

  • Download URL: smolagents_ejentum-0.1.0.tar.gz
  • Upload date:
  • Size: 11.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for smolagents_ejentum-0.1.0.tar.gz
Algorithm Hash digest
SHA256 1b9a51d0431e52534f39d13d823545211745e9c290378b6348137eaa45da7bc2
MD5 8d347b27595277d136f7a52488136827
BLAKE2b-256 cff3cb2addb1d17cc7f277f7ea59ad4357abd9210801711d2840561ba41648f5

See more details on using hashes here.

Provenance

The following attestation bundles were made for smolagents_ejentum-0.1.0.tar.gz:

Publisher: release.yml on ejentum/smolagents-ejentum

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file smolagents_ejentum-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for smolagents_ejentum-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 876aae7a04bb63f58c07fc3802ebe0c82275757a8d853c7a1eeba95a6cdf6150
MD5 a8217e124a61d8ca67e516951057deee
BLAKE2b-256 33d58d966a9360473366002d080a680dbed29473d5a457c71f1c1c59965bc2d4

See more details on using hashes here.

Provenance

The following attestation bundles were made for smolagents_ejentum-0.1.0-py3-none-any.whl:

Publisher: release.yml on ejentum/smolagents-ejentum

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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