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:
- aerial images with fiducial (or pseudo fiducial) markers, such as from:
- the aerial photo single frame dataset of USGS Earth Explorer (EE)
- the North American Glacier Photography (NAGAP) database from https://arcticdata.io/
- declassified US reconnaissance satellite images, in particular:
- KH-9 Hexagon panoramic camera images, i.e. Declass 3 dataset from EE
- KH-9 Hexagon mapping camera images, i.e. Declass 2 dataset from EE (to be included)
- KH-4/4A/4B Corona images, i.e. Declass 1 dataset from EE (to be included)
- Download of imagery is supported through our sister package usgsxplore.
-
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)
- Computes the appropriate geometric transformation between detected and calibrated fiducial positions:
See this notebook for example.
-
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.
pip install hipphipp is distributed under the terms of the Apache-2.0 license.
The data you create with hipp depend on the input datasets you use.


