ESRGAN: Optimized for Qualcomm Devices

ESRGAN is a machine learning model that upscales an image with minimal loss in quality.

This is based on the implementation of ESRGAN 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.24.3 Download
ONNX w8a16 Universal QAIRT 2.42, ONNX Runtime 1.24.3 Download
QNN_DLC float Universal QAIRT 2.43 Download
QNN_DLC w8a16 Universal QAIRT 2.43 Download
TFLITE float Universal QAIRT 2.43, TFLite 2.19.1 Download

For more device-specific assets and performance metrics, visit ESRGAN 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 ESRGAN on GitHub for usage instructions.

Model Details

Model Type: Model_use_case.super_resolution

Model Stats:

  • Model checkpoint: ESRGAN_x4
  • Input resolution: 128x128
  • Number of parameters: 16.7M
  • Model size (float): 63.9 MB

Performance Summary

Model Runtime Precision Chipset Inference Time (ms) Peak Memory Range (MB) Primary Compute Unit
ESRGAN ONNX float Snapdragon® 8 Elite Gen 5 Mobile 27.797 ms 7 - 353 MB NPU
ESRGAN ONNX float Snapdragon® X2 Elite 34.403 ms 37 - 37 MB NPU
ESRGAN ONNX float Snapdragon® X Elite 65.477 ms 37 - 37 MB NPU
ESRGAN ONNX float Snapdragon® 8 Gen 3 Mobile 49.525 ms 6 - 791 MB NPU
ESRGAN ONNX float Qualcomm® QCS8550 (Proxy) 66.552 ms 0 - 44 MB NPU
ESRGAN ONNX float Qualcomm® QCS9075 107.596 ms 6 - 9 MB NPU
ESRGAN ONNX float Snapdragon® 8 Elite For Galaxy Mobile 38.299 ms 8 - 352 MB NPU
ESRGAN ONNX w8a16 Snapdragon® 8 Elite Gen 5 Mobile 17.399 ms 3 - 1057 MB NPU
ESRGAN ONNX w8a16 Snapdragon® X2 Elite 21.944 ms 29 - 29 MB NPU
ESRGAN ONNX w8a16 Snapdragon® X Elite 43.608 ms 26 - 26 MB NPU
ESRGAN ONNX w8a16 Snapdragon® 8 Gen 3 Mobile 31.699 ms 3 - 1274 MB NPU
ESRGAN ONNX w8a16 Qualcomm® QCS6490 15055.988 ms 201 - 206 MB CPU
ESRGAN ONNX w8a16 Qualcomm® QCS8550 (Proxy) 42.325 ms 0 - 801 MB NPU
ESRGAN ONNX w8a16 Qualcomm® QCS9075 45.715 ms 3 - 6 MB NPU
ESRGAN ONNX w8a16 Qualcomm® QCM6690 7963.163 ms 185 - 206 MB CPU
ESRGAN ONNX w8a16 Snapdragon® 8 Elite For Galaxy Mobile 26.406 ms 0 - 904 MB NPU
ESRGAN ONNX w8a16 Snapdragon® 7 Gen 4 Mobile 7728.283 ms 146 - 164 MB CPU
ESRGAN QNN_DLC float Snapdragon® 8 Elite Gen 5 Mobile 24.936 ms 0 - 328 MB NPU
ESRGAN QNN_DLC float Snapdragon® X2 Elite 34.236 ms 0 - 0 MB NPU
ESRGAN QNN_DLC float Snapdragon® X Elite 64.893 ms 0 - 0 MB NPU
ESRGAN QNN_DLC float Snapdragon® 8 Gen 3 Mobile 49.293 ms 0 - 753 MB NPU
ESRGAN QNN_DLC float Qualcomm® QCS8275 (Proxy) 451.991 ms 0 - 347 MB NPU
ESRGAN QNN_DLC float Qualcomm® QCS8550 (Proxy) 62.242 ms 0 - 5 MB NPU
ESRGAN QNN_DLC float Qualcomm® SA8775P 105.52 ms 0 - 347 MB NPU
ESRGAN QNN_DLC float Qualcomm® QCS9075 107.092 ms 0 - 5 MB NPU
ESRGAN QNN_DLC float Qualcomm® QCS8450 (Proxy) 123.008 ms 0 - 758 MB NPU
ESRGAN QNN_DLC float Qualcomm® SA7255P 451.991 ms 0 - 347 MB NPU
ESRGAN QNN_DLC float Qualcomm® SA8295P 111.348 ms 0 - 357 MB NPU
ESRGAN QNN_DLC float Snapdragon® 8 Elite For Galaxy Mobile 37.688 ms 0 - 328 MB NPU
ESRGAN QNN_DLC w8a16 Snapdragon® 8 Elite Gen 5 Mobile 16.41 ms 0 - 986 MB NPU
ESRGAN QNN_DLC w8a16 Snapdragon® X2 Elite 22.037 ms 0 - 0 MB NPU
ESRGAN QNN_DLC w8a16 Snapdragon® X Elite 43.187 ms 0 - 0 MB NPU
ESRGAN QNN_DLC w8a16 Snapdragon® 8 Gen 3 Mobile 31.208 ms 0 - 1189 MB NPU
ESRGAN QNN_DLC w8a16 Qualcomm® QCS6490 241.752 ms 0 - 3 MB NPU
ESRGAN QNN_DLC w8a16 Qualcomm® QCS8275 (Proxy) 132.668 ms 0 - 668 MB NPU
ESRGAN QNN_DLC w8a16 Qualcomm® QCS8550 (Proxy) 41.514 ms 0 - 3 MB NPU
ESRGAN QNN_DLC w8a16 Qualcomm® SA8775P 37.748 ms 0 - 668 MB NPU
ESRGAN QNN_DLC w8a16 Qualcomm® QCS9075 44.358 ms 0 - 3 MB NPU
ESRGAN QNN_DLC w8a16 Qualcomm® QCM6690 1136.334 ms 0 - 641 MB NPU
ESRGAN QNN_DLC w8a16 Qualcomm® QCS8450 (Proxy) 75.6 ms 0 - 1277 MB NPU
ESRGAN QNN_DLC w8a16 Qualcomm® SA7255P 132.668 ms 0 - 668 MB NPU
ESRGAN QNN_DLC w8a16 Qualcomm® SA8295P 64.953 ms 0 - 712 MB NPU
ESRGAN QNN_DLC w8a16 Snapdragon® 8 Elite For Galaxy Mobile 28.325 ms 0 - 840 MB NPU
ESRGAN QNN_DLC w8a16 Snapdragon® 7 Gen 4 Mobile 94.984 ms 0 - 707 MB NPU
ESRGAN TFLITE float Snapdragon® 8 Elite Gen 5 Mobile 27.209 ms 3 - 371 MB NPU
ESRGAN TFLITE float Snapdragon® 8 Gen 3 Mobile 51.995 ms 0 - 795 MB NPU
ESRGAN TFLITE float Qualcomm® QCS8275 (Proxy) 452.182 ms 3 - 392 MB NPU
ESRGAN TFLITE float Qualcomm® QCS8550 (Proxy) 60.474 ms 3 - 5 MB NPU
ESRGAN TFLITE float Qualcomm® SA8775P 105.57 ms 3 - 391 MB NPU
ESRGAN TFLITE float Qualcomm® QCS9075 107.977 ms 3 - 46 MB NPU
ESRGAN TFLITE float Qualcomm® QCS8450 (Proxy) 114.636 ms 4 - 799 MB NPU
ESRGAN TFLITE float Qualcomm® SA7255P 452.182 ms 3 - 392 MB NPU
ESRGAN TFLITE float Qualcomm® SA8295P 111.388 ms 3 - 396 MB NPU
ESRGAN TFLITE float Snapdragon® 8 Elite For Galaxy Mobile 38.154 ms 3 - 364 MB NPU

License

  • The license for the original implementation of ESRGAN 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/ESRGAN