Image-to-Image
PyTorch
android

Real-ESRGAN-x4plus: Optimized for Qualcomm Devices

Real-ESRGAN is a machine learning model that upscales an image with minimal loss in quality. The implementation is a derivative of the Real-ESRGAN-x4plus architecture, a larger and more powerful version compared to the Real-ESRGAN-general-x4v3 architecture.

This is based on the implementation of Real-ESRGAN-x4plus 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.45, ONNX Runtime 1.25.0 Download
ONNX w8a8 Universal QAIRT 2.45, ONNX Runtime 1.25.0 Download
QNN_DLC float Universal QAIRT 2.45 Download
QNN_DLC w8a8 Universal QAIRT 2.45 Download
TFLITE float Universal QAIRT 2.45 Download
TFLITE w8a8 Universal QAIRT 2.45 Download

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

Model Details

Model Type: Model_use_case.super_resolution

Model Stats:

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

Performance Summary

Model Runtime Precision Chipset Inference Time (ms) Peak Memory Range (MB) Primary Compute Unit
Real-ESRGAN-x4plus ONNX float Snapdragon® X2 Elite 136.301 ms 207 - 207 MB NPU
Real-ESRGAN-x4plus ONNX float Snapdragon® X Elite 65.486 ms 149 - 149 MB NPU
Real-ESRGAN-x4plus ONNX float Snapdragon® 8 Gen 3 Mobile 51.33 ms 7 - 737 MB NPU
Real-ESRGAN-x4plus ONNX float Snapdragon® 8 Gen 1 Mobile 118.077 ms 7 - 733 MB NPU
Real-ESRGAN-x4plus ONNX float Qualcomm® QCS8550 (Proxy) 66.97 ms 0 - 45 MB NPU
Real-ESRGAN-x4plus ONNX float Qualcomm® QCS8450 118.077 ms 7 - 733 MB NPU
Real-ESRGAN-x4plus ONNX float Snapdragon® 8 Elite Mobile 38.495 ms 7 - 357 MB NPU
Real-ESRGAN-x4plus ONNX float Snapdragon® 8 Elite Gen 5 Mobile 25.959 ms 7 - 356 MB NPU
Real-ESRGAN-x4plus ONNX float Qualcomm® QCS9075 107.039 ms 6 - 51 MB NPU
Real-ESRGAN-x4plus ONNX float Qualcomm® QCS8750 38.495 ms 7 - 357 MB NPU
Real-ESRGAN-x4plus ONNX float Qualcomm® QCS7181 65.486 ms 149 - 149 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Snapdragon® X2 Elite 10.551 ms 212 - 212 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Snapdragon® X Elite 25.945 ms 181 - 181 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Snapdragon® 8 Gen 3 Mobile 17.005 ms 2 - 769 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Snapdragon® 8 Gen 1 Mobile 39.689 ms 2 - 794 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Qualcomm® QCS6490 110.058 ms 1 - 47 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Qualcomm® QCS8550 (Proxy) 24.858 ms 0 - 32 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Qualcomm® QCS8450 39.689 ms 2 - 794 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Snapdragon® 8 Elite Gen 5 Mobile 9.252 ms 1 - 508 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Snapdragon® 7 Gen 4 Mobile 38.782 ms 2 - 557 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Qualcomm® QCM6690 468.326 ms 1 - 513 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Qualcomm® QCS9075 31.791 ms 1 - 47 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Snapdragon® 8 Elite Mobile 12.637 ms 2 - 495 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Qualcomm® QCS7790 38.782 ms 2 - 557 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Qualcomm® QCS8750 12.637 ms 2 - 495 MB NPU
Real-ESRGAN-x4plus ONNX w8a8 Qualcomm® QCS7181 25.945 ms 181 - 181 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Snapdragon® X2 Elite 53.833 ms 0 - 0 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Snapdragon® X Elite 65.232 ms 0 - 0 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Snapdragon® 8 Gen 3 Mobile 48.653 ms 0 - 703 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Snapdragon® 8 Gen 1 Mobile 124.62 ms 0 - 710 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Qualcomm® QCS8275 452.126 ms 1 - 352 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Qualcomm® QCS8550 (Proxy) 63.65 ms 0 - 3 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Qualcomm® QCS8450 124.62 ms 0 - 710 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Snapdragon® 8 Elite Mobile 37.606 ms 0 - 333 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Qualcomm® SA8295P 111.262 ms 1 - 358 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Snapdragon® 8 Elite Gen 5 Mobile 24.76 ms 0 - 335 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Qualcomm® SA7255P 452.126 ms 1 - 352 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Qualcomm® QCS9075 108.205 ms 0 - 5 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Qualcomm® QCS8750 37.606 ms 0 - 333 MB NPU
Real-ESRGAN-x4plus QNN_DLC float Qualcomm® QCS7181 65.232 ms 0 - 0 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Snapdragon® X2 Elite 14.375 ms 0 - 0 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Snapdragon® X Elite 26.038 ms 0 - 0 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Snapdragon® 8 Gen 3 Mobile 16.755 ms 0 - 686 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Snapdragon® 8 Gen 1 Mobile 38.032 ms 0 - 714 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Qualcomm® QCS6490 110.287 ms 0 - 3 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Qualcomm® QCS8275 69.006 ms 0 - 486 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Qualcomm® QCS8550 (Proxy) 24.51 ms 0 - 4 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Qualcomm® QCS8450 38.032 ms 0 - 714 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Snapdragon® 8 Elite Gen 5 Mobile 9.092 ms 0 - 441 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Snapdragon® 7 Gen 4 Mobile 38.623 ms 0 - 486 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Qualcomm® QCM6690 475.22 ms 0 - 460 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Qualcomm® QCS9075 30.676 ms 0 - 2 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Qualcomm® SA7255P 69.006 ms 0 - 486 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Snapdragon® 8 Elite Mobile 12.54 ms 0 - 425 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Qualcomm® SA8295P 36.465 ms 0 - 494 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Qualcomm® QCS7790 38.623 ms 0 - 486 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Qualcomm® QCS8750 12.54 ms 0 - 425 MB NPU
Real-ESRGAN-x4plus QNN_DLC w8a8 Qualcomm® QCS7181 26.038 ms 0 - 0 MB NPU
Real-ESRGAN-x4plus TFLITE float Snapdragon® 8 Gen 3 Mobile 50.134 ms 0 - 739 MB NPU
Real-ESRGAN-x4plus TFLITE float Snapdragon® 8 Gen 1 Mobile 118.455 ms 4 - 731 MB NPU
Real-ESRGAN-x4plus TFLITE float Qualcomm® QCS8275 452.69 ms 4 - 393 MB NPU
Real-ESRGAN-x4plus TFLITE float Qualcomm® QCS8550 (Proxy) 64.931 ms 3 - 6 MB NPU
Real-ESRGAN-x4plus TFLITE float Qualcomm® SA8775P 12250.274 ms 2 - 43 MB GPU
Real-ESRGAN-x4plus TFLITE float Qualcomm® SA8650P 12250.274 ms 2 - 43 MB GPU
Real-ESRGAN-x4plus TFLITE float Qualcomm® SA8255P 12250.274 ms 2 - 43 MB GPU
Real-ESRGAN-x4plus TFLITE float Qualcomm® QCS8450 118.455 ms 4 - 731 MB NPU
Real-ESRGAN-x4plus TFLITE float Snapdragon® 8 Elite Mobile 38.026 ms 3 - 373 MB NPU
Real-ESRGAN-x4plus TFLITE float Qualcomm® SA8295P 110.47 ms 3 - 393 MB NPU
Real-ESRGAN-x4plus TFLITE float Snapdragon® 8 Elite Gen 5 Mobile 26.07 ms 0 - 363 MB NPU
Real-ESRGAN-x4plus TFLITE float Qualcomm® SA7255P 452.69 ms 4 - 393 MB NPU
Real-ESRGAN-x4plus TFLITE float Qualcomm® QCS9075 109.872 ms 3 - 46 MB NPU
Real-ESRGAN-x4plus TFLITE float Qualcomm® QCS8750 38.026 ms 3 - 373 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Snapdragon® 8 Gen 3 Mobile 13.877 ms 1 - 654 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Snapdragon® 8 Gen 1 Mobile 38.238 ms 1 - 661 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® QCS6490 93.434 ms 1 - 26 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® QCS8275 64.856 ms 1 - 449 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® QCS8550 (Proxy) 18.582 ms 1 - 4 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® SA8775P 12520.672 ms 2 - 53 MB GPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® SA8650P 12520.672 ms 2 - 53 MB GPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® SA8255P 12520.672 ms 2 - 53 MB GPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® QCS8450 38.238 ms 1 - 661 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Snapdragon® 8 Elite Gen 5 Mobile 7.606 ms 1 - 507 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Snapdragon® 7 Gen 4 Mobile 32.662 ms 1 - 447 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® QCM6690 442.421 ms 1 - 440 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® QCS9075 25.385 ms 1 - 26 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® SA7255P 64.856 ms 1 - 449 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Snapdragon® 8 Elite Mobile 11.671 ms 1 - 472 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® SA8295P 34.542 ms 1 - 448 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® QCS7790 32.662 ms 1 - 447 MB NPU
Real-ESRGAN-x4plus TFLITE w8a8 Qualcomm® QCS8750 11.671 ms 1 - 472 MB NPU

License

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

Space using qualcomm/Real-ESRGAN-x4plus 1

Paper for qualcomm/Real-ESRGAN-x4plus