Skip to content

shippp/hipp

Repository files navigation

hipp

PyPI - Version PyPI - Python Version Hatch project Static Badge Ruff

HIPP (Historical Image Pre-Processing) is a python library to pre-process scanned historical (film based) aerial and satellite images in preparation for Structure from Motion surface reconstruction and photogrammetric analysis.

Examples of images that are currently supported or planned to be supported include:


Gallery of supported pictures

Aerial color image of Casa Grande, Arizona acquired on 6 Sep 1978 (quickview)

aerial_casa_grande

KH-9 panoramic camera image (B/W) of South Iceland, acquired on 22 Aug 1980 (quickview)

D3C1216-200533A022

KH-9 mapping camera image (B/W) of South Iceland, acquired on 22 Aug 1980 (quickview)

KH9_mc

Features

Data query and download

  • Download of imagery is supported through our sister package usgsxplore.

Preprocessing of Aerial Images

  • Detection of fiducial markers

    • Built-in application to generate fiducial marker templates
    • Detection of fiducial marker coordinates using OpenCV template matching
    • Sub-pixel accuracy for fiducial detection
    • Supports detection of 4 midside and/or 4 corner fiducials
    • Filtering of low-confidence matches
    • Estimates the principal point based on valid fiducials
    • Quality Control Outputs:
      • Cropped windows around detected fiducials for visual inspection
      • Distribution plots of principal point deviations and individual fiducial coordinates
      • Matching score distributions
      • RMSE of fiducial coordinates before and after affine transformation
  • Detection of fiducial marker proxies (pseudo-fiducial) (feature in development)

  • Image Restitution

    • Computes the appropriate geometric transformation between detected and calibrated fiducial positions:
      • 1 point → Translation
      • 2 points → Similarity transformation
      • 3+ points → Affine transformation
    • Crops the image around the estimated principal point to a standard size
    • Applies CLAHE (Contrast Limited Adaptive Histogram Equalization) to enhance features in the image
    • Computes the full affine transformation matrix (including crop transformation)

See this notebook for example.

Preprocessing of KH-9 Panoramic Camera Satellite Images

  • Image Joining

    • Joins split images into a single composite image
    • Requires input images named sequentially (e.g. ImageId_a, ImageId_b, ImageId_c, …)
    • A small overlap between image parts is required for proper stitching
    • Performs stitching using matched keypoints and successive affine transformations for robust, geometry-aware merging.
  • Image Restitutions

    • Estimates the top and bottom collimation lines using a second-degree polynomial fit.
    • Determines the vertical boundaries (x1 and x2) of the region of interest (ROI).
    • Computes the geometric transformation needed to crop and restitute the ROI using a Thin Plate Spline (TPS) deformation model.

See this notebook for example of full preprocessing.

See this notebook for a detailed example of collimation rectification.

Preprocessing of KH-9 Mapping Camera Satellite Images (feature in development)


Installation

pip install hipp

License

hipp is distributed under the terms of the Apache-2.0 license.

The data you create with hipp depend on the input datasets you use.

About

Historical Image Pre-Processing

Resources

License

Contributing

Stars

Watchers

Forks

Packages

 
 
 

Contributors