Skip to main content

A configurable, typed AI framework with swappable LLM, classifier, handlers, and optional memory

Project description

StruktX Logo
StruktX

A configurable, typed AI framework with swappable LLM, classifier, handlers, and memory for Natural Language to Action apps

Python 3.8+ License: MIT

Quick Install

Using uv (Recommended)

# Install with core dependencies only
uv pip install struktx-ai

# Install with LLM support (LangChain)
uv pip install struktx-ai[llm]

# Install with vector store support
uv pip install struktx-ai[vector]

# Install with all optional dependencies
uv pip install struktx-ai[all]

# Install for development
uv pip install struktx-ai[dev]

Using pip

# Install with core dependencies only
pip install struktx-ai

# Install with LLM support (LangChain)
pip install struktx-ai[llm]

# Install with vector store support
pip install struktx-ai[vector]

# Install with all optional dependencies
pip install struktx-ai[all]

Source

# Create virtual env
uv venv

# Activate environment
source .venv/bin/activate

# Sync and install pyproject dependencies
uv sync

# Install finall Strukt package
uv pip install struktx-ai[all]

Quick Start with LangChain

from strukt import create, StruktConfig, HandlersConfig, LLMClientConfig, ClassifierConfig
from strukt.classifiers.llm_classifier import DefaultLLMClassifier
from strukt.prompts import DEFAULT_CLASSIFIER_TEMPLATE
from strukt.examples.time_handler import TimeHandler

from langchain_openai import ChatOpenAI
from strukt.langchain_helpers import LangChainLLMClient

# Create LangChain LLM client
langchain_llm = ChatOpenAI(api_key="your-openai-api-key")
llm = LangChainLLMClient(langchain_llm)

app = create(StruktConfig(
    llm=LLMClientConfig(llm),
    classifier=ClassifierConfig(
        factory=DefaultLLMClassifier(
            llm=llm,
            prompt_template=DEFAULT_CLASSIFIER_TEMPLATE,
            allowed_types=["time_service", "weather", "general"],
            max_parts=4,
        )
    ),
    handlers=HandlersConfig(
        registry={"time_service": TimeHandler(llm)},
        default_route="general",
    ),
))

app.invoke("What is the time in Tokyo?")

What is StruktX?

StruktX is a Python framework for building AI applications with focus on natural language -> actions

  • 🔄 Swappable Components: LLM clients, classifiers, handlers, and memory engines
  • 📝 Type Safety: Full type hints and Pydantic models
  • ⚙️ Configurable: Factory-based configuration system
  • 🔌 Extensible: Easy to add custom components
  • 🧠 Memory Support: Optional conversation memory
  • 🔧 Middleware: Pre/post processing hooks

Features

  • LLM Integration: Support for any LLM via the LLMClient interface
  • Query Classification: Route requests to appropriate handlers
  • Structured Outputs: Pydantic model integration
  • Memory Engines: Conversation history and context
  • Middleware System: Pre/post processing hooks
  • LangChain Helpers: Easy integration with LangChain ecosystem

Requirements

  • Python 3.10+
  • Core: pydantic>=2.0.0, python-dotenv>=1.0.0
  • Optional: LangChain packages, vector stores, etc.

License

MIT License - see LICENSE file for details.

Contributing

Contributions are welcome! Please report any issues, bugs, improvements, or features on GitHub.

Support

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

struktx_ai-0.0.3b0.tar.gz (60.6 kB view details)

Uploaded Source

Built Distribution

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

struktx_ai-0.0.3b0-py3-none-any.whl (79.9 kB view details)

Uploaded Python 3

File details

Details for the file struktx_ai-0.0.3b0.tar.gz.

File metadata

  • Download URL: struktx_ai-0.0.3b0.tar.gz
  • Upload date:
  • Size: 60.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for struktx_ai-0.0.3b0.tar.gz
Algorithm Hash digest
SHA256 2cda6dd4bdfb2cd1840d79c79e1189efe7a2a4f57d5e5d2a96e07b63b407a215
MD5 21cfca25311a2b5f4a68f7e6a6dbeb22
BLAKE2b-256 b8090a61350822e78736d26fcc617e80e0b550999766ab5379143fe408b1e7d4

See more details on using hashes here.

File details

Details for the file struktx_ai-0.0.3b0-py3-none-any.whl.

File metadata

  • Download URL: struktx_ai-0.0.3b0-py3-none-any.whl
  • Upload date:
  • Size: 79.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for struktx_ai-0.0.3b0-py3-none-any.whl
Algorithm Hash digest
SHA256 4031a87dbcecd2ea7cb686a8d70c2bf68e5b8f27fce0e93b1be0fdfe297bea79
MD5 526dce13f9c7a42022312fe9111be9ac
BLAKE2b-256 d2449c34e9c21b4cef1d8a0a597ee75d58cbccd7b0de99dc63ec6d508679fcb2

See more details on using hashes here.

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