The Railtracks Framework for building resilient agentic systems in simple python
Project description
Railtracks
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)
|
Tool-First Architecture# Any function becomes a tool
agent = rt.agent_node(
"Assistant",
tool_nodes=[my_tool, api_call]
)
|
Familiar Interface# Native Async support
result = await rt.call(agent, query)
|
Built-in ObservabilityRailtracks 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[cli]'
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.
Licensed under MIT · Made by the Railtracks team
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 railtracks-1.3.7.tar.gz.
File metadata
- Download URL: railtracks-1.3.7.tar.gz
- Upload date:
- Size: 1.6 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.33.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2e13edc9bea7279519b15cfb56e4098aaee670b453b8462c845cb1a5d42b9579
|
|
| MD5 |
188296b1f77364d91b92b0b94fa20b61
|
|
| BLAKE2b-256 |
66f98979ab941a088b39a3af4a1c226838536a7a532ef415a369c4dca757de00
|
File details
Details for the file railtracks-1.3.7-py3-none-any.whl.
File metadata
- Download URL: railtracks-1.3.7-py3-none-any.whl
- Upload date:
- Size: 252.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.33.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
260b9e76fd72846e81f000e1800029420b8cf20c64cc318a94662d57ebd7b84a
|
|
| MD5 |
83cafe0e59828d1038c33158c4d4bc87
|
|
| BLAKE2b-256 |
5a2a30f4b360b6c154bfc0ba494441b50f02078328a35543bf80ba0af8787ba5
|