Skip to main content

The Railtracks Framework for building resilient agentic systems in simple python

Project description

Railtracks

Railtracks


PyPI Version Python Versions Monthly Downloads License GitHub Stars

What is Railtracks?

Railtracks is a Python framework for building agentic systems. Agent behavior, tools, and multi-step flows are defined entirely in standard Python using the control flow and abstractions you already know.

import railtracks as rt

# Define a tool (just a function!)
def get_weather(location: str) -> str:
    return f"It's sunny in {location}!"

# Create an agent with tools
agent = rt.agent_node(
    "Weather Assistant",
    tool_nodes=(rt.function_node(get_weather)),
    llm=rt.llm.OpenAILLM("gpt-4o"),
    system_message="You help users with weather information."
)

# Run it
flow = rt.Flow(name="Weather Flow", entry_point=agent)
result = flow.invoke("What's the weather in Paris?")
# or `await flow.ainvoke("What's the weather in Paris?)` in an async context
print(result.text)  # "Based on the current data, it's sunny in Paris!"

Execution order, branching, and looping are expressed using standard Python control flow.

Why Railtracks?

Pure Python

# Write agents like regular functions
@rt.function_node
def my_tool(text: str) -> str:
    return process(text)
  • No YAML, no DSLs, no magic strings
  • Compatible with standard debuggers
  • Full IDE autocomplete and type checking

Tool-First Architecture

# Any function becomes a tool
agent = rt.agent_node(
    "Assistant",
    tool_nodes=[my_tool, api_call]
)
  • Automatic function-to-tool conversion
  • Seamless API and database integration
  • MCP protocol support

Familiar Interface

# Native Async support
result = await rt.call(agent, query)
  • Standardized call interface, consistent with asyncio patterns
  • Built-in validation, error handling, and retries
  • Automatic parallelization management

Built-in Observability

Railtracks includes a visualizer for inspecting agent runs and evaluations in real-time, run completely locally with no signups required.

See the Observability documentation for setup and usage.

Quick Start

Installation
pip install railtracks 'railtracks[visual]'
Your First Agent
import railtracks as rt

# 1. Create tools (just functions with decorators!)
@rt.function_node
def count_characters(text: str, character: str) -> int:
    """Count occurrences of a character in text."""
    return text.count(character)

@rt.function_node
def word_count(text: str) -> int:
    """Count words in text."""
    return len(text.split())

# 2. Build an agent with tools
text_analyzer = rt.agent_node(
    "Text Analyzer",
    tool_nodes=(count_characters, word_count),
    llm=rt.llm.OpenAILLM("gpt-4o"),
    system_message="You analyze text using the available tools."
)

# 3. Use it to solve the classic "How many r's in strawberry?" problem
text_flow = rt.Flow(
  name="Text Analysis Flow",
  entry_point=text_analyzer
)

text_flow.invoke("How many 'r's are in 'strawberry'?")

LLM Support

Railtracks integrates with major model providers through a unified interface:

# OpenAI
rt.llm.OpenAILLM("gpt-5")

# Anthropic
rt.llm.AnthropicLLM("claude-4-6-sonnet")

# Local models
rt.llm.OllamaLLM("llama3")

Works with OpenAI, Anthropic, Google, Azure, and more. See the full provider list.

Contributing

Railtracks is developed in the open. Contributions, bug reports, and feature requests are welcome via GitHub Issues.

Quick Start Documentation Examples Join Discord


Licensed under MIT · Made by the Railtracks team

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

railtracks-1.3.9.tar.gz (1.6 MB view details)

Uploaded Source

Built Distribution

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

railtracks-1.3.9-py3-none-any.whl (271.8 kB view details)

Uploaded Python 3

File details

Details for the file railtracks-1.3.9.tar.gz.

File metadata

  • Download URL: railtracks-1.3.9.tar.gz
  • Upload date:
  • Size: 1.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.33.1

File hashes

Hashes for railtracks-1.3.9.tar.gz
Algorithm Hash digest
SHA256 6863b571629f7a0f5a776b6421fa47c79ec752c0386c84f7dadfadb3f34445fe
MD5 8a60e152a538c17edb0b4d4c05bee024
BLAKE2b-256 40782ee059bf3d3761361733fc8c642d0bbf238e19b38e2adc78d8491fd59521

See more details on using hashes here.

File details

Details for the file railtracks-1.3.9-py3-none-any.whl.

File metadata

  • Download URL: railtracks-1.3.9-py3-none-any.whl
  • Upload date:
  • Size: 271.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.33.1

File hashes

Hashes for railtracks-1.3.9-py3-none-any.whl
Algorithm Hash digest
SHA256 65c6f5cc448ef622fce248f0e75989b1bbf4e32ff6c5642d6d460defcc56ad4e
MD5 4845a225e9192263fa57745792514adb
BLAKE2b-256 b6235cda5c06f00d23c1c4fe2a2b1fcac39f5c1a37abd51049b5e86c6ac3cfb4

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