image-hdr

Crates.ioimage-hdr
lib.rsimage-hdr
version0.5.1
sourcesrc
created_at2022-11-29 17:36:29.813926
updated_at2024-09-15 13:24:10.812827
descriptionAn implementation of HDR Radiance Estimation using Poisson Photon Noise Estimator for creating HDR image from a set of images
homepagehttps://github.com/anshap1719/image-hdr
repositoryhttps://github.com/anshap1719/image-hdr
max_upload_size
id725569
size89,200
Anshul Sanghi (anshap1719)

documentation

README

image-hdr

This is a rust library which implements the HDR merging algorithm for camera images taken with different exposure times (or with bracketing). It uses the algorithms described in https://www.cl.cam.ac.uk/research/rainbow/projects/noise-aware-merging/2020-ppne-mle.pdf, and uses "Poisson Photon Noise Estimator" equations to estimate final radiances at each pixel position.

Current State

The library is still in early stages of development, but aims to provide a crate that can handle all HDR merging needs. Towards that end, the following todos are the top priority:

  • Tone mapping algorithm implementations.
  • Improve performance.

Dependencies

  • image-rs: Uses DynamicImage as the output format and storage format between calculations.
  • rawloader: For supporting RAW image formats.
  • rayon: For doing point calculations in parallel.
  • kamadak-exif: For getting image's metadata, specifically exposure time and gain (ISO).

Usage

let paths = vec!["src/image1.tif", "src/image2.tif", "src/image3.tif"];
let hdr_merge = image_hdr::hdr_merge_images(paths);
let stretched = apply_histogram_stretch(&fusion);

stretched
    .to_rgba16()
    .save(format!("src/hdr_merged.tiff"))
    .unwrap();

Samples

Given the following 3 exposures:

alt "1/640s" alt "1/4000s" alt "1/80s"

Resulting unprocessed image:

alt "Merged image"

After basic processing (Levels and Contrast):

alt "Processed image"

Contributing

Bug reports and pull requests welcome at https://github.com/anshap1719/image-hdr

Citations

Commit count: 24

cargo fmt