deep perceptual resampling and super resolution with antspyx
Project description
SIQ: Super-Resolution Image Quantification
SIQ is a powerful and flexible Python library for deep learning-based image super-resolution, with a focus on medical imaging applications. It provides a comprehensive toolkit for every stage of the super-resolution workflow, from data generation and model training to robust inference and evaluation.
The library is built on TensorFlow/Keras
and ANTSpy
and is designed to handle complex, real-world challenges such as anisotropic super-resolution (where different upsampling factors are needed for each axis) and multi-task learning (e.g., simultaneously upsampling an image and its segmentation mask).
Key Features
SIQ is more than just an inference tool; it's a complete framework that facilitates:
- Flexible Data Generation: Automatically create paired low-resolution and high-resolution patches for training with
siq.image_generator
. Includes support for multi-channel data (e.g., image + segmentation) viasiq.seg_generator
. - Advanced Model Architectures: Easily instantiate powerful Deep Back-Projection Networks (DBPN) for 2D and 3D with
siq.default_dbpn
, customized for any upsampling factor and multi-task outputs. - Perceptual Loss Training: Go beyond simple Mean Squared Error. SIQ includes tools for using pre-trained feature extractors (
siq.get_grader_feature_network
,siq.pseudo_3d_vgg_features_unbiased
) to optimize for perceptual quality. - Intelligent Loss Weighting: Automatically balance complex, multi-component loss functions (e.g., MSE + Perceptual + Dice) with a single command (
siq.auto_weight_loss
,siq.auto_weight_loss_seg
) to ensure stable training. - End-to-End Training Pipelines: Train models from start to finish with the high-level
siq.train
andsiq.train_seg
functions, which handle data generation, validation, and model saving. - Robust Inference: Apply your trained models to new images with
siq.inference
, including specialized logic for region-wise and blended super-resolution when guided by a segmentation mask. - Comprehensive Evaluation: Systematically benchmark and compare model performance with
siq.compare_models
, which calculates PSNR, SSIM, and Dice metrics against baseline methods.
Installation
You can install the official release directly from PyPI:
pip install siq
To install the latest development version from this repository:
git clone https://github.com/stnava/siq.git
cd siq
pip install .
Quick Start: A 5-Minute Example
The examples demonstrate the core workflow: training a model on publicly available data and using it for inference.
tests/test.py
tests/test_seg.py
Pre-trained Models and Compatibility
We provide a collection of pre-trained models to get you started without requiring you to train from scratch.
Important Note on Keras/TensorFlow Versions
The deep learning ecosystem evolves quickly. Models saved with older versions of TensorFlow/Keras (as .h5
files) may have trouble loading in newer versions (TF >= 2.16) due to the transition to the .keras
format.
If you encounter issues loading a legacy .h5
model, we provide a robust conversion script. This utility will convert your old .h5
files into the modern .keras
format.
Usage:
import siq
# Define the directory containing your old .h5 models
source_dir = "~/.antspymm/" # Or wherever you downloaded the models
output_dir = "./converted_keras_models"
# Convert the models
siq.convert_h5_to_keras_format(
search_directory=source_dir,
output_directory=output_dir,
exclude_patterns=["*weights.h5"] # Skips files that are just weights
)
After running this, you can load the converted models from the converted_keras_models
directory using siq.read_srmodel
or tf.keras.models.load_model
.
For Developers
Setting Up the Environment
This package is tested with Python 3.11 and TensorFlow 2.17. For optimal CPU performance, especially on Linux, you may want to set these environment variables:
export TF_ENABLE_ONEDNN_OPTS=1
export ITK_GLOBAL_DEFAULT_NUMBER_OF_THREADS=8
export TF_NUM_INTRAOP_THREADS=8
export TF_NUM_INTEROP_THREADS=8
Publishing a New Release
To publish a new version of siq
to PyPI:
# Ensure build and twine are installed
python3 -m pip install build twine
# Clean previous builds
rm -rf build/ siq.egg-info/ dist/
# Build the package
python3 -m build .
# Upload to PyPI
python3 -m twine upload --repository siq dist/*
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file siq-0.4.1.tar.gz
.
File metadata
- Download URL: siq-0.4.1.tar.gz
- Upload date:
- Size: 31.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 |
83f7c2ec3d0f1eec359a22f9cf670391ab9ad964a4a0b488ccf01c0154012690
|
|
MD5 |
029d4cc73f755c18af68f5c96a413693
|
|
BLAKE2b-256 |
0ce30491e518edc22af52a85a9e3d206e566c6e8070b61ec8f9f8d78b5275d5b
|
File details
Details for the file siq-0.4.1-py3-none-any.whl
.
File metadata
- Download URL: siq-0.4.1-py3-none-any.whl
- Upload date:
- Size: 26.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 |
986815b5f2776c5b458ceec26831c315f90d4024ac5ba6c3c7df9102ec50c0df
|
|
MD5 |
3d4438f6f48769d14dfcb608508dcb59
|
|
BLAKE2b-256 |
b170273a7477ab444788462f298b1b97602cd11c8ad04313e7b9534ace3c9a9c
|