0 / 0
Deploying models converted to ONNX format
Last updated: Jan 21, 2025
Deploying models converted to ONNX format

You can deploy and inference machine learning models from PyTorch or TensorFlow that are saved in different formats and converted to the Open Neural Network Exchange (ONNX) format. ONNX is an open-source format for representing deep learning models. Developers can use the ONNX format to train their models in one framework, such as PyTorch or TensorFlow, and then export it to run in another environment with different performance characteristics. The ONNX format provides a powerful solution for converting a machine learning model to ONNX and perform inferencing by using the ONNX runtime.

Benefits of converting models to ONNX runtime

Converting a model to ONNX runtime offers several benefits, especially in the context of machine learning and deep learning applications. Some of the advantages of converting models to ONNX runtime are as follows:

  • Cross-platform compatibility: ONNX provides a standard format for representing machine learning models, which makes it easier to deploy models across different frameworks such as PyTorch or Tensorflow. You can train models in one frameworks and deploy them in another framework that supports ONNX runtime.

  • Improved performance: ONNX runtime optimizes models for inferencing by applying various hardware and software-specific optimizaitons, such as graph optimizations. Also, it supports execution on diverse hardware, such as CPUs and GPUs, ensuring efficient utilization of resources.

  • Interoperability: ONNX provides a way to train models, such as PyTorch, TensorFlow, and scikit-learn in one framework and then export them to run in another environment, which streamlines the workflows. It breaks down the barriers between different deep learning frameworks, allowing developers to leverage the strengths of different libraries without getting locked into a single ecosystem.

Supported frameworks for conversion

You can convert machine learning models that use the following frameworks to ONNX format:

  1. PyTorch
  2. TensorFlow
  3. CatBoost
  4. LightGBM

Converting PyTorch models to ONNX format

Follow this process to convert your trained model in PyTorch to the ONNX format:

  1. Import libraries: Start by importing the essential libraries, such as onnxruntime for running the model, torch for PyTorch functionalities, and other libraries required for your application.

  2. Create or download PyTorch model: You can create a PyTorch model by using your own data set or use models provided by external open source model repositories like Hugging Face.

  3. Convert PyTorch model to ONNX format: To convert the PyTorch model to ONNX format:

    a. Prepare the model: Ensure that your PyTorch model is in evaluation mode by using model.eval() function. You may need a dummy input tensor to match the shape of the model.

    b. Export the model: Use the torch.onnx.export function to convert the model to ONNX format.

  4. Verify the conversion: After converting the model, verify that the model is functioning as expected by using the onnx library.

Converting TensorFlow models to ONNX format

Follow this process to convert your model TensorFlow to the ONNX format:

  1. Import libraries: Start by importing the essential libraries, such as tf2onnx to facilitate conversion of TensorFlow models to ONNX, and other libraries required for your application.

  2. Download TensorFlow model: You must download the externally created TensorFlow model and the data that is used for training the model.

  3. Convert TensorFlow model to ONNX format: Use the tf2onnx.convert command to convert your TensorFlow model that is created in the SavedModel format to ONNX format. If you want to convert a TensorFlow Lite model, use the --tflite flag instead of the --saved-model flag.

Note:

Keras models and tf functions can be directly converted within Python by using the tf2onnx.convert.from_keras or tf2onnx.convert.from_function functions.

  1. Verify the conversion: After converting the model, verify that the model is functioning as expected by using the onnx library.

Converting CatBoost models to ONNX format

Follow this process to convert your trained model in CatBoost to the ONNX format:

  1. Import libraries: Start by importing the essential libraries, such as onnxruntime for running the model, catboost for CatBoost functionalities, and other libraries required for your application.

  2. Create or download CatBoost model: You can create a CatBoost model by using your own data set or use models provided by external open source model repositories like Hugging Face.

  3. Convert CatBoost model to ONNX format: To convert the CatBoost model to ONNX format:

    a. Load the CatBoost model: You can load the CatBoost model by using libraries such as pickle:

    catboost_model = pickle.load(file)
    

    b. Export the model: Use the catboost_model.save_model function with format parameter set to onnx to convert the model to ONNX format.

    catboost_model.save_model(
        onnx_model_name,
        format="onnx",
        export_parameters={
            'onnx_domain': 'ai.catboost',
            'onnx_model_version': 1,
            'onnx_doc_string': 'test model for Regressor',
            'onnx_graph_name': 'CatBoostModel_for_Regression'
        }
    )
    

    c. Verify the conversion: After converting the model, verify that the model is functioning as expected by using the onnx library.

Converting LightGBM models to ONNX format

Follow this process to convert your trained model in LightGBM to the ONNX format:

  1. Import libraries: Start by importing the essential libraries, such as onnxruntime for running the model, lightgbm for LightGBM functionalities, and onnxmltools for conversion and other libraries required for your application.

  2. Create or download LGBM model: You can create a LightGBM model by using your own data set or use models provided by external open source model repositories like Hugging Face.

  3. Convert LGBM model to ONNX format: To convert the LightGBM model to ONNX format:

    a. Load the LightGBM model: You can load the LightGBM model by using libraries such as pickle:

    lgbm_model = pickle.load(file)
    

    b. Export the model: Use the convert_lightgbm function to convert the model to ONNX format.

    from onnxmltools import convert_lightgbm
    from skl2onnx.common.data_types import FloatTensorType
    from onnxmltools.utils import save_model      
    
    initial_types = [("float_input", FloatTensorType([None, lgbm_model.num_feature()]))]
    onnx_model = convert_lightgbm(model=lgbm_model, initial_types=initial_types)
    onnx_model_filename = "lgbm_model.onnx"
    save_model(onnx_model, onnx_model_filename)
    
    Tip:

    For troubleshooting problems with converting LightGBM models to ONNX format, see Troubleshooting watsonx.ai Runtime.

  4. Verify the conversion: After converting the model, verify that the model is functioning as expected by using the onnx library.

Additional considerations

Here are some additional considerations for converting your models to ONNX format:

  • Dynamic axes: Dynamic axes can be used by a model to handle variable input shapes, such as dynamic batch sizes or sequence lengths, which is useful for models deployed in application where the input dimensions may vary. Use dynamic axes if your model handles variable input sizes, such as dynamic batch size or sequence length.

    Dynamic axes also reduce memory overhead as they can be used with multiple inputs and outputs to adapt dynamically without re-exporting the model. You can specify the dynamic axes during model export in PyTorch or TensorFlow.

  • Opset version: The opset version in ONNX determines the set of operations and their specifications that are supported by the model. It is a critical factor during model conversion and deployment.

    Different ONNX runtimes and frameworks support specific opset versions. Older opset versions may lack features or optimizations present in newer versions. Incompatibility between a model's opset version and the ONNX runtime can cause errors during inferencing. You must ensure that the ONNX opset version that you choose is supported by your target runtime.

Deploying models converted to ONNX format

Use the onnxruntime_opset_19 software specification to deploy your machine learning model converted to ONNX format. You must specify the software specification and model type when you store the model to the watsonx.ai Runtime repository. For more information, see Supported software specifications.

To deploy models converted to ONNX format from the user interface, follow these steps:

  1. In your deployment space, go to the Assets tab.

  2. Find your model in the asset list, click the Menu icon Menu icon, and select Deploy.

  3. Select the deployment type for your model. Choose between online and batch deployment options.

  4. Enter a name for your deployment and optionally enter a serving name, description, and tags.

    Note:
    • Use the Serving name field to specify a name for your deployment instead of deployment ID.
    • The serving name must be unique within the namespace.
    • The serving name must contain only these characters: [a-z,0-9,_] and must be a maximum 36 characters long.
    • In workflows where your custom foundation model is used periodically, consider assigning your model the same serving name each time you deploy it. This way, after you delete and then re-deploy the model, you can keep using the same endpoint in your code.

  5. Select a hardware specification for your model.

  6. Select a configuration and a software specification for your model.

  7. Click Create.

Testing the model

Follow these steps to test your deployed models converted to ONNX format:

  1. In your deployment space, open the Deployments tab and click the deployment name.
  2. Click the Test tab to input prompt text and get a response from the deployed asset.
  3. Enter test data in one of the following formats, depending on the type of asset that you deployed:
    • Text: Enter text input data to generate a block of text as output.
    • JSON: Enter JSON input data to generate output in JSON format.
  4. Click Generate to get results that are based on your prompt.

Sample notebooks

The following sample notebooks demonstrate how to deploy machine learning models converted from PyTorch or TensorFlow to the ONNX format by using the Python client library:

Sample notebooks
Notebook Framework Description
Convert ONNX neural network from fixed axes to dynamic axes and use it with ibm-watsonx-ai ONNX Set up the environment
Create and export basic ONNX model
Convert model from fixed axes to dynamic axes
Persist converted ONNX model
Deploy and score ONNX model
Clean up
Summary and next steps
Use ONNX model converted from PyTorch with ibm-watsonx-ai ONNX Create PyTorch model with dataset.
Convert PyTorch model to ONNX format
Persist converted model in Watson Machine Learning repository.
Deploy model for online scoring using client library.
Score sample records using client library.
Use ONNX model converted from TensorFlow to recognize hand-written digits with ibm-watsonx-ai ONNX Download an externally trained TensorFlow model with dataset.
Convert TensorFlow model to ONNX format
Persist converted model in Watson Machine Learning repository.
Deploy model for online scoring using client library.
Score sample records using client library.
Use ONNX model converted from CatBoost ONNX Trained CatBoost model.
Convert CatBoost model to ONNX format.
Persist converted model in Watson Machine Learning repository.
Deploy model for online scoring using client library.
Score sample records using client library.
Use ONNX model converted from LightGBM ONNX Train a LightGBM model
Convert the LightGBM model to ONNX format
Persist the converted model in the watsonx.ai Runtime repository
Deploy the model for online scoring using client library
Score sample records using the client library

Parent topic: Deploying machine learning assets

Generative AI search and answer
These answers are generated by a large language model in watsonx.ai based on content from the product documentation. Learn more