Python client for QDX's Rush platform
Project description
rush-py: Rush Python Client
Installation
Install from PyPI:
pip install rush-py
If you manage dependencies with uv, add it to your project (updates pyproject.toml and uv.lock):
uv add rush-py
Using in Your Project
Add to your pyproject.toml:
[project]
dependencies = [
"rush-py",
]
Rush Setup
Use environment variables to configure access:
RUSH_TOKEN: Put your token's value hereRUSH_PROJECT: Put your project's UUID value here; can find it in the URL once selecting a project in the Rush UIRUSH_ENDPOINT: Use this to choose between staging and prod; if omitted, defaults to prod
You can also put RUSH_TOKEN and RUSH_PROJECT in a .env file instead of exporting them in every terminal session. rush-py looks for a .env file in the current working directory first, then falls back to ~/.rush/.env. Environment variables always take priority over .env values.
# .env
RUSH_TOKEN=your-token-here
RUSH_PROJECT=your-project-id-here
Quick Start
from pathlib import Path
from rush import exess
topology_path = Path.cwd() / "thrombin_1c_t.json"
# For energy, the only mandatory argument is the Topology
run = exess.energy(topology_path)
# Fetch the results for direct access
result = run.fetch()
# Save the results
paths = run.save()
Outputs are saved under <workspace_dir>/<PROJECT_ID>/ (default: current working directory). To customize the workspace location, call rush.session.configure(workspace_dir=Path("...")).
# For interaction_energy, second argument is reference fragment
result = exess.interaction_energy(topology_path, 1).fetch()
# Use export keywords to obtain additional information
result = exess.energy(
topology_path,
frag_keywords=None, # MBE is not supported for CHELPG charges
export_keywords=exess.ExportKeywords(export_chelpg_charges=True)
).fetch()
# QMMM requires Residues too
topology_path = "./6a5j_t.json"
residues_path = "./6a5j_r.json"
# Without calling `.fetch()` or `.save()` the run takes place asynchronously
# and a run object is returned
run = exess.qmmm(
topology_path=topology_path,
residues_path=residues_path,
n_timesteps=500,
qm_fragments=[0],
)
# The output is a QMMMResult object that contains the geometries for each timestep,
# which can be swapped into a Topology's geometry field
result = run.fetch()
# Get the full list of parameters and default arguments for a function
help(exess.energy)
help(exess.interaction_energy)
help(exess.optimization)
help(exess.qmmm)
See the docs for more information!
Development
You can develop this project using pip + venv, or uv.
With pip + venv
git clone git@github.com:talo/rush-py.git
cd rush-py
python -m venv .venv
source .venv/bin/activate
pip install -e .
With uv
git clone git@github.com:talo/rush-py.git
cd rush-py
uv sync
source .venv/bin/activate
Running Tests
Run the full suite with:
uv run pytest
Common focused invocations:
uv run pytest -m "not submits_rush_jobs"
uv run pytest -m submits_rush_jobs --force-run-slow
uv run pytest tests/test_exess_energy.py
uv run pytest tests/test_exess_energy.py --rush-workspace-dir /tmp/rush-py-workspaces
See the Terms of Service for use of the underlying Rush software at https://qdx.co/terms.
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 rush_py-7.1.0.tar.gz.
File metadata
- Download URL: rush_py-7.1.0.tar.gz
- Upload date:
- Size: 56.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
510a9fb2b9d564167adae9282e6c7ed6c0a9864021b53c8ac81f5de93c956887
|
|
| MD5 |
220217b1c1f0a08e088e10b3e7ee4f8a
|
|
| BLAKE2b-256 |
d3570dff031204920e1f3e7ce5d16df5cb69fea8949c721e83e55a56ed2808b2
|
Provenance
The following attestation bundles were made for rush_py-7.1.0.tar.gz:
Publisher:
publish.yml on talo/rush-py
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
rush_py-7.1.0.tar.gz -
Subject digest:
510a9fb2b9d564167adae9282e6c7ed6c0a9864021b53c8ac81f5de93c956887 - Sigstore transparency entry: 1248838131
- Sigstore integration time:
-
Permalink:
talo/rush-py@c935314ad67cf72a286099f060e3440e462c61df -
Branch / Tag:
refs/tags/v7.1.0 - Owner: https://github.com/talo
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@c935314ad67cf72a286099f060e3440e462c61df -
Trigger Event:
push
-
Statement type:
File details
Details for the file rush_py-7.1.0-py3-none-any.whl.
File metadata
- Download URL: rush_py-7.1.0-py3-none-any.whl
- Upload date:
- Size: 71.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
248b11630ae7dea617bb9a4f46619d3124cbc7938719b528a8307c65c5adc8c8
|
|
| MD5 |
3258fe14e6350133a6f3cf9e6dcf8067
|
|
| BLAKE2b-256 |
78253b635a4969f84e38a2c85e8d1e1e7d0b6c68b3043b648c8a161f2f3312b8
|
Provenance
The following attestation bundles were made for rush_py-7.1.0-py3-none-any.whl:
Publisher:
publish.yml on talo/rush-py
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
rush_py-7.1.0-py3-none-any.whl -
Subject digest:
248b11630ae7dea617bb9a4f46619d3124cbc7938719b528a8307c65c5adc8c8 - Sigstore transparency entry: 1248838234
- Sigstore integration time:
-
Permalink:
talo/rush-py@c935314ad67cf72a286099f060e3440e462c61df -
Branch / Tag:
refs/tags/v7.1.0 - Owner: https://github.com/talo
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@c935314ad67cf72a286099f060e3440e462c61df -
Trigger Event:
push
-
Statement type: