Skip to main content

SDK for Identa - Agent Evaluation

Project description

Identa SDK 🚀

The user-facing toolkit for evaluating and migrating LLM-based agents. Identa provides a zero-friction experience for LangGraph, PydanticAI, and LangChain agents.

Getting Started

1. Installation

pip install identa-sdk

Features

1. Evaluation Engine

The evaluate function executes your agent against test suites and computes metrics across your agent's graph/flow.

import identa

# Define a test suite
suite = [
    {"input": {"query": "Fly to Paris"}, "expected": {"destination": "CDG"}}
]

# Run evaluation with node-level resolution
results = identa.evaluate(
    agent=my_agent, 
    suite=suite,
    metrics=["accuracy", "latency"],
    resolution="node"
)

print(results.report())

2. Tracing Service

Use the context-aware span collector to debug agent execution in real-time.

import identa

# Start a trace session
with identa.trace("flight-booking-flow") as tracer:
    # Any agent calls within this block are automatically spanned
    response = my_agent.run("Book a flight to Tokyo")
    
# Retrieve trace data
spans = tracer.get_spans()

3. Migration Engine

Validate and apply model-binding swaps (e.g., swapping gpt-4o for claude-3-5-sonnet) safely.

from identa.core.domain.migration import MigrationEngine, MigrationPlan

# Validate if a model swap is safe based on structural drift
plan = MigrationPlan(id="swap-to-claude", source_structure_hash="...", changes=[])
plan.replace_model(node="llm_1", to="claude-3-5-sonnet")

results = identa.evaluate(agent=my_agent, suite=suite)
report = MigrationEngine.validate(plan, agent=my_agent, current_structure=results.structure)

if report.ok:
    print("Migration is safe!")

4. Reproduction Engine

Replay previous experiments and detect structural drift between the original run and the current state.

# Replay a previous run with structural parity checks
results = identa.reproduce(
    run_id="run_123",
    agent=my_agent,
    suite=suite
)

CLI

Identa comes with a CLI to manage your runs and view results.

# List all runs in a workspace
identa runs list --workspace travel_agent

# Show details of a specific run
identa runs show <run_id>

Framework Support

Feature LangGraph PydanticAI LangChain
Boundary Eval
Node Tracing
Structural Inspection 🚧
Model Migration 🚧 🚧

Architecture & Contributing Guidelines

To maintain clean architectural boundaries, all contributions must follow these rules:

  • The Adapter Rule: If you are integrating a new third-party framework (e.g., LlamaIndex, LangChain), it goes in identa/sdk/adapters/. If you are adding a new internal domain concept, metric, or tracing algorithm, it goes in identa-core.
  • The Import Rule: Application code (end-users) should only import from identa.sdk. Internal tools (like identa-cli) are permitted to instantiate identa.core commands directly, provided they use the sdk.api.execute() bus for execution.
  • Strict Public API: Only functions explicitly listed in identa/__init__.py's __all__ are considered part of the stable public API.

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

identa_sdk-0.4.9b4.tar.gz (11.9 kB view details)

Uploaded Source

Built Distribution

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

identa_sdk-0.4.9b4-py3-none-any.whl (14.2 kB view details)

Uploaded Python 3

File details

Details for the file identa_sdk-0.4.9b4.tar.gz.

File metadata

  • Download URL: identa_sdk-0.4.9b4.tar.gz
  • Upload date:
  • Size: 11.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for identa_sdk-0.4.9b4.tar.gz
Algorithm Hash digest
SHA256 6889fb0b680743af8d402862bfe30abfd39d19046a731d5c653da04306c8888d
MD5 e8aa0202bc117dfb6fa98fc5c650946a
BLAKE2b-256 042bc4bf3dfa81010faaa9772564b1a52b64592e0f2e9d2e1c64194d79be0f42

See more details on using hashes here.

Provenance

The following attestation bundles were made for identa_sdk-0.4.9b4.tar.gz:

Publisher: release.yml on Identa-agent/Identa

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

File details

Details for the file identa_sdk-0.4.9b4-py3-none-any.whl.

File metadata

  • Download URL: identa_sdk-0.4.9b4-py3-none-any.whl
  • Upload date:
  • Size: 14.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for identa_sdk-0.4.9b4-py3-none-any.whl
Algorithm Hash digest
SHA256 f3ba1c4c6beccdf2e5b1d01bad0bf5bd2b7d2428006227bb65e0f1a35d84c1d9
MD5 48be4515befd30527f2c97f680765f3b
BLAKE2b-256 9a4bb045b651aa078d9fd58f146872ee3c65e7e8f0acf573add7c53dd7df6bba

See more details on using hashes here.

Provenance

The following attestation bundles were made for identa_sdk-0.4.9b4-py3-none-any.whl:

Publisher: release.yml on Identa-agent/Identa

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