Skip to main content

Python Runtime for ONNX models, other helpers to convert machine learned models in C++.

Project description

https://github.com/sdpython/mlprodict/blob/master/_doc/sphinxdoc/source/phdoc_static/project_ico.png?raw=true

mlprodict

Build status Build Status Windows https://circleci.com/gh/sdpython/mlprodict/tree/master.svg?style=svg https://dev.azure.com/xavierdupre3/mlprodict/_apis/build/status/sdpython.mlprodict https://badge.fury.io/py/mlprodict.svg MIT License Requirements Status https://codecov.io/github/sdpython/mlprodict/coverage.svg?branch=master GitHub Issues Notebook Coverage Downloads Forks Stars https://mybinder.org/badge_logo.svg

The packages explores ways to productionize machine learning predictions. One approach uses ONNX and tries to implement a runtime in python / numpy or wraps onnxruntime into a single class. The package provides tools to compare predictions, to benchmark models converted with sklearn-onnx. The second approach consists in converting a pipeline directly into C and is not much developed.

from sklearn.linear_model import LinearRegression
from sklearn.datasets import load_iris
from mlprodict.onnxrt import OnnxInference, measure_relative_difference
import numpy

iris = load_iris()
X = iris.data[:, :2]
y = iris.target
lr = LinearRegression()
lr.fit(X, y)

# Predictions with scikit-learn.
expected = lr.predict(X[:5])
print(expected)

# Conversion into ONNX.
from mlprodict.onnxrt import to_onnx
model_onnx = to_onnx(lr, X.astype(numpy.float32))

# Predictions with onnxruntime
oinf = OnnxInference(model_onnx, runtime='onnxruntime1')
ypred = oinf.run({'X': X[:5]})
print(ypred)

# Measuring the maximum difference.
print(measure_relative_difference(expected, ypred))

Installation

The project relies on sklearn-onnx which is in active development. Continuous integration relies on a specific branch of this project to benefit from the lastest changes:

pip install git+https://github.com/xadupre/sklearn-onnx.git@jenkins

The project is currently in active development. It is safer to install the package directly from github:

pip install git+https://github.com/sdpython/mlprodict.git

On Linux and Windows, the package must be compiled with openmp. Full instructions to build the module and run the documentation are described in config.yml for Linux. When this project becomes more stable, it will changed to be using official releases. Experiments with float64 are not supported with sklearn-onnx <= 1.5.0. The code is available at GitHub/mlprodict and has online documentation.

History

current - 2019-08-28 - 0.00Mb

  • 42: Adds a graph which visually summarize the validating benchmark (ONNX). (2019-08-27)

  • 41: Enables to test multiple number of features at the same time (ONNX) (2019-08-27)

  • 40: Add a parameter to change the number of featuress when validating a model (ONNX). (2019-08-26)

  • 39: Add a parameter to dump all models even if they don’t produce errors when being validated (ONNX) (2019-08-26)

  • 24: support double for TreeEnsembleClassifier (python runtime ONNX) (2019-08-23)

  • 38: See issue on onnxmltools. https://github.com/onnx/onnxmltools/issues/321 (2019-08-19)

  • 35: Supports parameter time_kwargs in the command line (ONNX) (2019-08-09)

  • 34: Add intervals when measuring time ratios between scikit-learn and onnx (ONNX) (2019-08-09)

  • 31: Implements shape inference for the python runtime (ONNX) (2019-08-06)

  • 15: Tells operator if the execution can be done inplace for unary operators (ONNX). (2019-08-06)

  • 27: Bug fix (2019-08-02)

  • 23: support double for TreeEnsembleRegressor (python runtime ONNX) (2019-08-02)

0.2.363 - 2019-08-01 - 0.11Mb

  • 26: Tests all converters in separate processeses to make it easier to catch crashes (2019-08-01)

  • 25: Ensures operator clip returns an array of the same type (ONNX Python Runtime) (2019-07-30)

  • 22: Implements a function to shake an ONNX model and test float32 conversion (2019-07-28)

  • 21: Add customized converters (2019-07-28)

  • 20: Enables support for TreeEnsemble operators in python runtime (ONNX). (2019-07-28)

  • 19: Enables support for SVM operators in python runtime (ONNX). (2019-07-28)

  • 16: fix documentation, visual graph are not being rendered in notebooks (2019-07-23)

  • 18: implements python runtime for SVM (2019-07-20)

0.2.272 - 2019-07-15 - 0.09Mb

  • 17: add a mechanism to use ONNX with double computation (2019-07-15)

  • 13: add automated benchmark of every scikit-learn operator in the documentation (2019-07-05)

  • 12: implements a way to measure time for each node of the ONNX graph (2019-07-05)

  • 11: implements a better ZipMap node based on dedicated container (2019-07-05)

  • 8: implements runtime for decision tree (2019-07-05)

  • 7: implement python runtime for scaler, pca, knn, kmeans (2019-07-05)

  • 10: implements full runtime with onnxruntime not node by node (2019-06-16)

  • 9: implements a onnxruntime runtime (2019-06-16)

  • 6: first draft of a python runtime for onnx (2019-06-15)

  • 5: change style highlight-ipython3 (2018-01-05)

0.1.11 - 2017-12-04 - 0.03Mb

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

mlprodict-0.2.452.tar.gz (134.9 kB view details)

Uploaded Source

File details

Details for the file mlprodict-0.2.452.tar.gz.

File metadata

  • Download URL: mlprodict-0.2.452.tar.gz
  • Upload date:
  • Size: 134.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Python-urllib/3.7

File hashes

Hashes for mlprodict-0.2.452.tar.gz
Algorithm Hash digest
SHA256 b9f07fff8cff5e139a565ad6e1f9917ec87fdc1e29b10566bd0373a87e3412a0
MD5 357c7324be829eba7e68c58b1a2df0e6
BLAKE2b-256 d80fadac4339d443b3505bcc382c6bbf9b4b6509426e351236058d9ce3a94618

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page