Skip to main content

Sinapsis tool to convert models from one framework to another and can be used in AOT and JIT modes

Project description

sp




Sinapsis Framework Converter

Templates for conversion between deep learning frameworks.

🐍 Installation🚀 Features 📙 Documentation🔍 License

The sinapsis-framework-converter module allows for the conversion between some of the most popular deep learning frameworks in the community:

  • Keras -> Tensorflow
  • Tensorflow -> ONNX
  • Pytorch -> TensorRT
  • Pytorch -> ONNX
  • ONNX -> TensorRT

🐍 Installation

[!NOTE] CUDA-based templates in Sinapsis-framework-converter require NVIDIA driver version to be 550 or higher.

Install using your package manager of choice. We encourage the use of uv

Example with uv:

uv pip install sinapsis-framework-converter --extra-index-url https://pypi.sinapsis.tech

or with raw pip:

pip install sinapsis-framework-converter --extra-index-url https://pypi.sinapsis.tech

[!IMPORTANT] Templates in each package may require extra dependencies. For development, we recommend installing the package with all the optional dependencies:

Example with uv:

uv pip install sinapsis-framework-converter[all] --extra-index-url https://pypi.sinapsis.tech

or with raw pip:

pip install sinapsis-framework-converter[all] --extra-index-url https://pypi.sinapsis.tech

[!IMPORTANT] To enable tensorflow with cuda support please install tensorflow as follows:

uv pip install tensorflow[and-cuda]==2.18.0

or

pip install tensorflow[and-cuda]==2.18.0

🚀 Features

Templates Supported

The Sinapsis Framework Converter module provides multiple templates for deep learning framework conversion.

  • KerasTensorFlowConverter: Converts Keras models to TensorFlow.
  • ONNXTRTConverter: Converts ONNX models to TensorRT.
  • TensorFlowONNXConverter: Converts TensorFlow models to ONNX.
  • TorchONNXConverter: Converts PyTorch models to ONNX.
  • TorchTRTConverter: Converts PyTorch models to TensorRT.
▶️ Example Usage

The following example demonstrates how to use the TorchONNXConverter template to convert a PyTorch model into the ONNX format. The configuration sets up an agent with the necessary templates to load a model, convert it, and store the converted file. Below is the full YAML configuration, followed by a breakdown of each component.

agent:
  name: conversion_agent

templates:
- template_name: InputTemplate
  class_name: InputTemplate
  attributes: {}

- template_name: TorchONNXConverter
  class_name: TorchONNXConverter
  template_input: InputTemplate
  attributes:
    model_name: resnet50
    save_model_path: true
    force_compilation: true
    opset_version: 12
    height: 224
    width: 224

This configuration defines an agent and a sequence of templates to perform model conversion.

  1. Input Handling (InputTemplate): This serves as the initial template.
  2. Model Conversion (TorchONNXConverter): Loads a PyTorch model (e.g., resnet50) and converts it to ONNX format. The template:
    • Uses the model_name attribute to specify which PyTorch model to convert.
    • Applies the opset_version attribute to define the ONNX operator set version (e.g., 12).
    • Adjusts the input tensor dimensions using height and width.
    • Enables force_compilation to ensure the model is recompiled if needed.
  3. Saving the Converted Model: The save_model_path attribute is set to true, ensuring that the output ONNX model path is saved in the DataContainer.

📙 Documentation

Documentation is available on the sinapsis website

Tutorials for different projects within sinapsis are available at sinapsis tutorials page

🔍 License

This project is licensed under the AGPLv3 license, which encourages open collaboration and sharing. For more details, please refer to the LICENSE file.

For commercial use, please refer to our official Sinapsis website for information on obtaining a commercial license.

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

sinapsis_framework_converter-0.1.10.tar.gz (29.1 kB view details)

Uploaded Source

Built Distribution

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

sinapsis_framework_converter-0.1.10-py3-none-any.whl (35.1 kB view details)

Uploaded Python 3

File details

Details for the file sinapsis_framework_converter-0.1.10.tar.gz.

File metadata

File hashes

Hashes for sinapsis_framework_converter-0.1.10.tar.gz
Algorithm Hash digest
SHA256 f4be86070a8912cebe2e53f271d2e2d9375ac4cd3b1d3f8eb11a7a85261e118c
MD5 f03744204bb1873a47f5d5d19677a343
BLAKE2b-256 4ac5447d22a36dabc39d9828f84ba40d038ef76f19fa8a4cdc9bdcf7aa90a08b

See more details on using hashes here.

File details

Details for the file sinapsis_framework_converter-0.1.10-py3-none-any.whl.

File metadata

File hashes

Hashes for sinapsis_framework_converter-0.1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 e898a8e29e2da4a6420897dd5a8f2d4c4992ccebfccbd9b3781612d90e2bdf9a
MD5 04a8962d9563d379090d7e6eb0965c23
BLAKE2b-256 4a46060c05b9b49f0ca14cb4a483569bee435911f670bfff2dff956082f57617

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