Skip to main content

Fast IIQ converter for Phase One iXM-GS120 (120MP) raw images

Project description

iiq2img

Fast converter for Phase One iXM-GS120 (120 MP) IIQ raw files. Outputs JPEG, PNG, or TIFF with full EXIF/GPS/XMP metadata and optional georeferencing.

Quick start

# Install from PyPI
pip install iiq2img

# Or install the latest dev version from git
uv pip install git+https://github.com/DPIRD-DMA/iiq2img.git

# Or clone and install locally
git clone https://github.com/DPIRD-DMA/iiq2img.git && cd iiq2img
uv sync

# Convert (uses fast pipeline by default)
iiq2img photo.IIQ                     # single file
iiq2img batch ./raw ./out             # batch directory
iiq2img photo.IIQ --libraw            # use LibRaw PPG instead

Pipelines

Pipeline End-to-end Speedup Quality
default (fast) ~1.0 s 3.6x Mean diff ~7/255 vs reference
--libraw (LibRaw PPG) ~3.3 s baseline Reference

The fast pipeline uses cv2 edge-aware demosaic + numba parallel LUTs with BT.709 gamma, matched to LibRaw's output. See FINDINGS.md for how.

Python API

from iiq2img import convert_iiq, read_iiq, batch_convert

# Single file (fast pipeline is the default)
out_path = convert_iiq("photo.IIQ", "output.jpg")

# Read as NumPy array (no file written)
rgb = read_iiq("photo.IIQ")

# Batch (parallel)
results = batch_convert("./raw", "./out", workers=8)

# Georeferenced output (requires `pip install iiq2img[geo]`)
out_path = convert_iiq("photo.IIQ", "output.tif", output_format="tiff", georef=True)
Option Default Description
thumbnail False Extract embedded JPEG thumbnail instead of converting
output_format "jpg" Output format: jpg, png, or tiff
compress_quality 90 JPEG/PNG compression quality (1-100)
max_dimension None Downscale longest edge to this size
rotate 0 Rotate output: 0, 90, 180, 270
georef False Write georeferenced GeoTIFF (requires [geo] extra)
extract_meta True Copy EXIF/GPS/XMP metadata to output
pipeline "fast" Demosaic pipeline: fast or libraw

CLI

# Single file (outputs photo.jpg next to the original)
iiq2img photo.IIQ
iiq2img photo.IIQ --libraw            # use LibRaw PPG instead of fast

# Batch convert a directory (parallel)
iiq2img batch ./raw ./out                           # defaults: jpg, q=90, fast
iiq2img batch ./raw ./out --format tiff --workers 8 # tiff, q=90, 8 workers
iiq2img batch ./raw ./out --format jpg --quality 75 --workers 4 --libraw

# Benchmark all pipelines on a sample file
iiq2img benchmark photo.IIQ

Changelog

See CHANGELOG.md for version history.

Contributing

git clone https://github.com/DPIRD-DMA/iiq2img.git && cd iiq2img
uv sync --dev
pre-commit install

Pre-commit hooks run ruff (lint + format) and pytest on every commit. To run them manually:

uv run ruff check .                  # lint
uv run ruff format .                 # format
uv run pytest                        # tests
uv run iiq2img benchmark photo.IIQ   # timing comparison

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

iiq2img-0.5.0.tar.gz (2.0 MB view details)

Uploaded Source

Built Distribution

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

iiq2img-0.5.0-py3-none-any.whl (21.9 kB view details)

Uploaded Python 3

File details

Details for the file iiq2img-0.5.0.tar.gz.

File metadata

  • Download URL: iiq2img-0.5.0.tar.gz
  • Upload date:
  • Size: 2.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for iiq2img-0.5.0.tar.gz
Algorithm Hash digest
SHA256 7e4679e8d1be2fe56a659948e9eba8c2f5760e9b5effe57bec539ca9c601da9f
MD5 744483ba20c808767d04b1fa29899ca3
BLAKE2b-256 26ffc5fb7514279518c9b65384ce50b90b731868d49e5903e1a8b92842de7b64

See more details on using hashes here.

Provenance

The following attestation bundles were made for iiq2img-0.5.0.tar.gz:

Publisher: publish.yml on DPIRD-DMA/iiq2img

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file iiq2img-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: iiq2img-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 21.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for iiq2img-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 16c82bcd904b9d9a99606c36b69584a92acceca4f39a3ae0dcce80d57655a5a4
MD5 c0e9d3fae434cbb4ea70dd48a2d82e98
BLAKE2b-256 4893cf5219e5dcee48b2476ec63db682dd03b71d268e3f2b69d58b40cef1782a

See more details on using hashes here.

Provenance

The following attestation bundles were made for iiq2img-0.5.0-py3-none-any.whl:

Publisher: publish.yml on DPIRD-DMA/iiq2img

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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