Skip to main content

RushTI - Parallel TM1 TurboIntegrator Process Execution

Project description

RushTI

Parallel TI execution engine for IBM Planning Analytics

PyPI Python License


RushTI transforms sequential TurboIntegrator execution into intelligent, parallel workflows. Define task dependencies as a DAG, and RushTI schedules them across multiple workers — starting each task the moment its predecessors complete.

What's New in 2.0

  • DAG Execution — True dependency-based scheduling replaces wait-based sequencing
  • JSON Task Files — Structured format with metadata, settings, and stages
  • Self-Optimization — EWMA-based learning reorders tasks from historical performance
  • Checkpoint & Resume — Automatic progress saving with failure recovery
  • Exclusive Mode — Prevents concurrent runs on shared TM1 servers
  • SQLite Statistics — Persistent execution history with dashboards and analysis
  • TM1 Integration — Read tasks from and write results to a TM1 cube
  • 100% Backwards Compatible — Legacy TXT task files work without changes

Installation

pip (recommended)

pip install rushti

For the latest beta:

pip install rushti --pre

uv

uv pip install rushti

Executable (no Python required)

Download rushti.exe from GitHub Releases — includes all dependencies.

Quick Start

1. Configure TM1 connection

# config/config.ini
[tm1-finance]
address = localhost
port = 12354
ssl = true
user = admin
password = apple

2. Create a task file

{
  "version": "2.0",
  "tasks": [
    { "id": "1", "instance": "tm1-finance", "process": "Extract.GL.Data" },
    { "id": "2", "instance": "tm1-finance", "process": "Extract.FX.Rates" },
    {
      "id": "3",
      "instance": "tm1-finance",
      "process": "Transform.Currency",
      "predecessors": ["1", "2"]
    },
    {
      "id": "4",
      "instance": "tm1-finance",
      "process": "Build.Reports",
      "predecessors": ["3"]
    }
  ]
}

3. Validate and run

rushti tasks validate --tasks daily-refresh.json --skip-tm1-check
rushti run --tasks daily-refresh.json --max-workers 4

Documentation

Full documentation is available at cubewise-na.github.io/rushti-dev/docs

Website

Visit cubewise-na.github.io/rushti-dev for interactive demos, feature overviews, and architecture visualizations.

Links

Built With

TM1py — Python interface to the TM1 REST API

License

MIT — see LICENSE for details.

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

rushti-2.0.0b5.tar.gz (122.6 kB view details)

Uploaded Source

Built Distribution

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

rushti-2.0.0b5-py3-none-any.whl (130.7 kB view details)

Uploaded Python 3

File details

Details for the file rushti-2.0.0b5.tar.gz.

File metadata

  • Download URL: rushti-2.0.0b5.tar.gz
  • Upload date:
  • Size: 122.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for rushti-2.0.0b5.tar.gz
Algorithm Hash digest
SHA256 48b8e18d70c2e97e367c7e2d806ae670323784bb9fcc83c8bb4b86f0d1bc9fa4
MD5 f7b4e2028ccd568ebe68c2c037f1bdc2
BLAKE2b-256 7c123745a3a6bb0c3685086435d4b5f87499338a5400bea1b781682974744871

See more details on using hashes here.

Provenance

The following attestation bundles were made for rushti-2.0.0b5.tar.gz:

Publisher: publish-pypi.yml on cubewise-na/rushti-dev

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

File details

Details for the file rushti-2.0.0b5-py3-none-any.whl.

File metadata

  • Download URL: rushti-2.0.0b5-py3-none-any.whl
  • Upload date:
  • Size: 130.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for rushti-2.0.0b5-py3-none-any.whl
Algorithm Hash digest
SHA256 6e0b4a65d23c76cac4f2f7ef4b9c7d7923f35aa262f374526bc7b6045781ad8e
MD5 95f0e224931153a0c34fc718da5e7990
BLAKE2b-256 d8f99c7e9a50fbcccb42f0db2b4c393ed19e7663f2edd30a7d0d48becea165a2

See more details on using hashes here.

Provenance

The following attestation bundles were made for rushti-2.0.0b5-py3-none-any.whl:

Publisher: publish-pypi.yml on cubewise-na/rushti-dev

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