Skip to main content

The client for persisting and deploying models to Xplainable cloud.

Project description

xplainable

Real-time explainable machine learning for business optimisation

Xplainable makes tabular machine learning transparent, fair, and actionable.

Why Was Xplainable Created?

In machine learning, there has long been a trade-off between accuracy and explainability. This drawback has led to the creation of explainable ML libraries such as Shap and Lime which make estimations of model decision processes. These can be incredibly time-expensive and often present steep learning curves making them challenging to implement effectively in production environments.

To solve this problem, we created xplainable. xplainable presents a suite of novel machine learning algorithms specifically designed to match the performance of popular black box models like XGBoost and LightGBM while providing complete transparency, all in real-time.

Xplainable Cloud

This Python package is free and open-source. To add more value to data teams within organisations, we also created Xplainable Cloud that brings your models to a collaborative environment.

Preprocessing with Xplainable Cloud

Before modeling, it's essential to preprocess your data. Xplainable Cloud facilitates this process by allowing you to create and manage preprocessors in the cloud.

import xplainable as xp
import os
from xplainable_client.client import Client

# Initialising the client
client = Client(api_key=os.environ['XP_API_KEY'])

# Creating a Preprocessor (creates both ID and version)
preprocessor_id, version_id = client.preprocessing.create_preprocessor(
    preprocessor_name="Preprocessor Name",
    preprocessor_description="Preprocessor Description",
    pipeline=pipeline,  # <-- Pass the pipeline
    df=df  # <-- Pass the raw dataframe
)

# Loading the Preprocessor Client
pp_cloud = client.preprocessing.load_preprocessor(
    preprocessor_id,
    version_id,
)

Modelling with Xplainable Cloud

After preprocessing, the next step is to create and train your model. Xplainable Cloud supports model versioning and ID creation to streamline this process.

# Creating a Model (creates both ID and version)
model_id, version_id = client.models.create_model(
    model=model,
    model_name="Model Name",
    model_description='Model Description',
    x=X_train,
    y=y_train
)

Deployments with Xplainable Cloud

Once your model is ready, deploying it is straightforward with Xplainable Cloud. You can deploy, activate, and manage API keys for your model deployment keys within your IDE or environment.

# Creating a Model Deployment
deployment = client.deployments.deploy(model_version_id=version_id)

# Activating the Deployment
client.deployments.activate_deployment(deployment.deployment_id)

# Generating an API Key
deploy_key = client.deployments.create_deployment_key(
    deployment_id=deployment.deployment_id,
    description='API Key Name',
    expiry_days=7  # Days until expiration
)

# Hitting the endpoint
response = requests.post(
    url="https://inference.xplainable.io/v1/predict",
    headers={'api_key': deploy_key.deploy_key},
    json=body
)

# Obtaining the value response
value = response.json()

CLI

The xp command provides a CLI for all xplainable cloud operations. It outputs JSON by default, making it ideal for scripting and AI agents.

pip install xplainable-client

# Authenticate
export XPLAINABLE_API_KEY=xp_...

# Examples
xp models list                              # List all team models
xp deployments payload dp_xyz | jq .        # Get deployment payload
xp preprocessing create --name "Pipeline" --description "v1" --spec spec.json
xp autotrain summarize data.csv > summary.json
xp --help                                   # Full command reference

See docs/cli.md for the complete command reference and examples.

Release Process

The xplainable-client uses automated release scripts to streamline version management and integrate with the Xplainable MCP Server.

Creating a New Release

Use the automated release scripts in the scripts/ directory:

# Quick patch release (1.2.3 → 1.2.4)
./scripts/release.sh --increment patch

# Minor release with new features (1.2.3 → 1.3.0)
./scripts/release.sh --increment minor

# Major release with breaking changes (1.2.3 → 2.0.0)
./scripts/release.sh --increment major

# Specific version
./scripts/release.sh --version 1.5.0

# Test what would happen (dry run)
./scripts/release.sh --increment patch --dry-run

What Happens During a Release

  1. Validation: Checks git repository state and current version
  2. Cleanup: Removes build artifacts (build/, dist/, *.egg-info/)
  3. Version Update: Updates version in pyproject.toml and other files
  4. Git Operations: Commits changes, creates tag, and pushes to GitHub
  5. Package Build: Creates wheel and source distributions in dist/
  6. PyPI Publish: Uploads to PyPI (if --publish flag used)
  7. GitHub Release: Creates release with changelog (if GitHub CLI available)
  8. 🤖 MCP Server Sync: Automatically triggers MCP server update workflow

When you create a release, the GitHub Actions workflow will automatically:

  • Install the new client version
  • Scan for @mcp_tool() decorated methods
  • Generate updated MCP server tools
  • Create a pull request in the MCP server repository

See scripts/README.md for detailed documentation and troubleshooting.





Thanks for trying xplainable!

Made with ❤️ in Australia


© copyright xplainable pty ltd

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

xplainable_client-1.5.4.tar.gz (87.2 kB view details)

Uploaded Source

Built Distribution

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

xplainable_client-1.5.4-py3-none-any.whl (87.3 kB view details)

Uploaded Python 3

File details

Details for the file xplainable_client-1.5.4.tar.gz.

File metadata

  • Download URL: xplainable_client-1.5.4.tar.gz
  • Upload date:
  • Size: 87.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for xplainable_client-1.5.4.tar.gz
Algorithm Hash digest
SHA256 08bc3df4ffded7e05aad44610bf99ee3e4a5039d2fadeb005aa82b354cbe5772
MD5 1507b8c84061212ddbc39828cd746c6f
BLAKE2b-256 b327b4d2b4ad3d1e0f170d1e13296e8c035245a61ba38c21938aa82c57e88d97

See more details on using hashes here.

File details

Details for the file xplainable_client-1.5.4-py3-none-any.whl.

File metadata

File hashes

Hashes for xplainable_client-1.5.4-py3-none-any.whl
Algorithm Hash digest
SHA256 f603f23e7ea0480292ba4055a65f59a81a42942d6fc7d0b619d54cba457f2895
MD5 9118c57effc82f03be86f39291dd0892
BLAKE2b-256 0796b2dc2d7eb757b0622a3a0a41dad7e6fff23db7e14f4ff93ac7bc35190d64

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