OpenAI-Clip: Optimized for Qualcomm Devices

Contrastive Language-Image Pre-Training (CLIP) uses a ViT like transformer to get visual features and a causal language model to get the text features. Both the text and visual features can then be used for a variety of zero-shot learning tasks.

This is based on the implementation of OpenAI-Clip found here. This repository contains pre-exported model files optimized for Qualcomm® devices. You can use the Qualcomm® AI Hub Models library to export with custom configurations. More details on model performance across various devices, can be found here.

Qualcomm AI Hub Models uses Qualcomm AI Hub Workbench to compile, profile, and evaluate this model. Sign up to run these models on a hosted Qualcomm® device.

Getting Started

There are two ways to deploy this model on your device:

Option 1: Download Pre-Exported Models

Below are pre-exported model assets ready for deployment.

Runtime Precision Chipset SDK Versions Download
ONNX float Universal QAIRT 2.42, ONNX Runtime 1.25.0 Download
QNN_DLC float Universal QAIRT 2.45 Download
TFLITE float Universal QAIRT 2.45 Download

For more device-specific assets and performance metrics, visit OpenAI-Clip on Qualcomm® AI Hub.

Option 2: Export with Custom Configurations

Use the Qualcomm® AI Hub Models Python library to compile and export the model with your own:

  • Custom weights (e.g., fine-tuned checkpoints)
  • Custom input shapes
  • Target device and runtime configurations

This option is ideal if you need to customize the model beyond the default configuration provided here.

See our repository for OpenAI-Clip on GitHub for usage instructions.

Model Details

Model Type: Model_use_case.image_classification

Model Stats:

  • Model checkpoint: ViT-B/16
  • Image input resolution: 224x224
  • Text context length: 77
  • Number of parameters: 150M
  • Model size (float): 571 MB

Performance Summary

Model Runtime Precision Chipset Inference Time (ms) Peak Memory Range (MB) Primary Compute Unit
OpenAI-Clip ONNX float Snapdragon® 8 Elite Gen 5 Mobile 8.25 ms 1 - 630 MB NPU
OpenAI-Clip ONNX float Snapdragon® X2 Elite 9.306 ms 211 - 211 MB NPU
OpenAI-Clip ONNX float Snapdragon® X Elite 18.778 ms 292 - 292 MB NPU
OpenAI-Clip ONNX float Snapdragon® 8 Gen 3 Mobile 12.671 ms 1 - 729 MB NPU
OpenAI-Clip ONNX float Qualcomm® QCS8550 (Proxy) 18.5 ms 0 - 323 MB NPU
OpenAI-Clip ONNX float Snapdragon® 8 Elite For Galaxy Mobile 10.229 ms 1 - 659 MB NPU
OpenAI-Clip ONNX float Qualcomm® QCS9075 22.922 ms 1 - 46 MB NPU
OpenAI-Clip ONNX float Qualcomm® QCS8750 10.229 ms 1 - 659 MB NPU
OpenAI-Clip ONNX float Qualcomm® QCS7181 18.778 ms 292 - 292 MB NPU
OpenAI-Clip QNN_DLC float Snapdragon® 8 Elite Gen 5 Mobile 8.725 ms 0 - 416 MB NPU
OpenAI-Clip QNN_DLC float Snapdragon® X2 Elite 9.695 ms 1 - 1 MB NPU
OpenAI-Clip QNN_DLC float Snapdragon® X Elite 21.373 ms 1 - 1 MB NPU
OpenAI-Clip QNN_DLC float Snapdragon® 8 Gen 3 Mobile 14.531 ms 0 - 769 MB NPU
OpenAI-Clip QNN_DLC float Qualcomm® QCS8550 (Proxy) 19.891 ms 1 - 3 MB NPU
OpenAI-Clip QNN_DLC float Qualcomm® SA8775P 23.046 ms 1 - 568 MB NPU
OpenAI-Clip QNN_DLC float Qualcomm® SA8650P 23.046 ms 1 - 568 MB NPU
OpenAI-Clip QNN_DLC float Qualcomm® SA8255P 23.046 ms 1 - 568 MB NPU
OpenAI-Clip QNN_DLC float Qualcomm® QCS8450 (Proxy) 24.204 ms 0 - 609 MB NPU
OpenAI-Clip QNN_DLC float Qualcomm® SA8295P 24.595 ms 1 - 514 MB NPU
OpenAI-Clip QNN_DLC float Snapdragon® 8 Elite For Galaxy Mobile 11.352 ms 1 - 586 MB NPU
OpenAI-Clip QNN_DLC float Qualcomm® QCS9075 23.131 ms 3 - 5 MB NPU
OpenAI-Clip QNN_DLC float Qualcomm® QCS8750 11.352 ms 1 - 586 MB NPU
OpenAI-Clip QNN_DLC float Qualcomm® QCS7181 21.373 ms 1 - 1 MB NPU
OpenAI-Clip TFLITE float Snapdragon® 8 Elite Gen 5 Mobile 8.705 ms 0 - 430 MB NPU
OpenAI-Clip TFLITE float Snapdragon® 8 Gen 3 Mobile 14.252 ms 0 - 768 MB NPU
OpenAI-Clip TFLITE float Qualcomm® QCS8275 59.429 ms 0 - 566 MB NPU
OpenAI-Clip TFLITE float Qualcomm® QCS8550 (Proxy) 20.285 ms 0 - 4 MB NPU
OpenAI-Clip TFLITE float Qualcomm® SA8775P 23.065 ms 0 - 565 MB NPU
OpenAI-Clip TFLITE float Qualcomm® SA8650P 23.065 ms 0 - 565 MB NPU
OpenAI-Clip TFLITE float Qualcomm® SA8255P 23.065 ms 0 - 565 MB NPU
OpenAI-Clip TFLITE float Qualcomm® QCS8450 (Proxy) 24.29 ms 0 - 617 MB NPU
OpenAI-Clip TFLITE float Qualcomm® SA8295P 24.567 ms 0 - 518 MB NPU
OpenAI-Clip TFLITE float Snapdragon® 8 Elite For Galaxy Mobile 11.368 ms 0 - 600 MB NPU
OpenAI-Clip TFLITE float Qualcomm® QCS9075 23.343 ms 0 - 296 MB NPU
OpenAI-Clip TFLITE float Qualcomm® SA7255P 59.429 ms 0 - 566 MB NPU
OpenAI-Clip TFLITE float Qualcomm® QCS8750 11.368 ms 0 - 600 MB NPU

License

  • The license for the original implementation of OpenAI-Clip can be found here.

References

Community

Downloads last month

-

Downloads are not tracked for this model. How to track
Inference Providers NEW
This model isn't deployed by any Inference Provider. 🙋 Ask for provider support

Paper for qualcomm/OpenAI-Clip