The following notebook walks the user through an implementation of a computer vision-based horizon detection that uses a two-stage objective that greatly reduces computational overhead compared to an exhaustive search approach.
The first objective ("global") attempts to find a narrow range of combinations of "pitch" and "roll" (attitude and angle) corresponding to a halfplane that likely subdivdes the sky from the rest of the image. The second objective ("local") searches exhaustively through these combinations to find the halfplane that maximizes the difference in average intensity of the two halfplanes in the immediate viscinity of the halfplane.
Compared with an exhaustive search of pitch and roll combinations performed at the outset, this method obtains perfect accuracy on our datset with a full order-of-magnitute less computations. This method benefits from the assumption that a "sky" as represented by image data has higher intensity values than the ground pixels (higher mean), and that the sky has higher consistency of representation (lower variance). A "coefficient of variance" calculation (ratio of mean to variance) performed on the full range of angle/attitude for all images in the set suggests that--at least for our data--the optimization surface is approximately convex, allowing for confident use of subsampling in the global objective.
Exhaustive search over the second objective for our dataset in the data exploration phase however reveals numerous local maxima- therefore we must employ exhaustive search over the subregion identified in the global objective in runtime. Regardless, we observe no loss of accuracy on our output.
The method is demonstrated on a selection of maritime images whose time-of-day, glare effects, and ground-truth horizon location within the frame and varied. Our method also allows us to ignore color information that is typically used to booster similar vision-based horizon detection methods.
- Python 2.7.11
- Jupyter Notebook 4.2.2
- Numpy 1.11.2
- matplotlib 1.5.2
- OpenCV 3.2.0
This repository demonstrates a novel solution to horizon detection for video streams of maritime images that reduces computational requirements as compared with common exhaustive approaches, such as that outlined by Ettinger et al.
- Solve global objective by optimizing attitute/angle objective surface.
- Solve local objective by exhaustive search over range defined in (1).
We begin with the assumption that the horizon line lies in the exhaustive search space that contains all pitch and angle combinations. In order to better work with the pitch/angle nomenclature, we reparameterize the cartesian version of a horizon line equation into a set of polar coordinates with the caveat that the 'distance' measure is a percentage of pitch from 0% to 100% that "fits" into the rectangular views of most video streams.
In the global objective, we perform our global search on a downsampled image, using a coarse resolution that samples both angle and pitch at a factor of 5 (5%, 10%, 15%, ..., 100% pitch, and -90°, -85°, ..., -5°, 0°, 5°, ..., 90° angle) for a total search space size of 20 x 40 = 800. Our approach assumes the "sky" has higher intensity value mean than the "ground", and that the sky has less information, which we represent in the objective as its variance. Thus, the global objective maximizes the difference in the sky and ground mean, while minimizing the sky's variance.
To define a region for the second objective, we simply select the outlying combinations of angle in pitch from the global search. Again, we are able to do this due to the approximetely convex nature of the global optimization surface for our dataset (for other approaches, see "Challenges" below). Note that our subsample method does not ensure consistent search space in the second objective across images.
In the second objective, we exhaustively search over the subregion identified in the global objective. Our optimization objective in the "local search" is to maximize the squared difference in the average sky and ground intensity values in the region immediately surrounding the candidate horizon line, again adjusted by the sky's variance.
Using the global objective in front of the local objective, we were able to reduce our search to 1,700 pitch/angle combinations for this sample, compared to an exhuastive optimization of the local objective at the outset which would have yielded the evaluation of 18,000 combinations.
File | Purpose |
---|---|
two_objectives_horizon_detection.ipynb | iPython Notebook for user-friendly implementation and data exploration. |
two_objectives_horizon_detection.py | Python file containing main, preprocessing steps and subroutines. |
While in the two_objectives_horizon_detection
directory, enter the following in the command line:
ipython notebook two_objectives_horizon_detection.ipynb