Skip to content

Computes masked cross-correlation of two images using fast Fourier methods. Compatible with OpenCV!

License

Notifications You must be signed in to change notification settings

woodychow/masked_normxcorr

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

38 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DESCRIPTION

Build Status

masked_normxcorr efficiently computes the cross-correlation between two images, each of which can be independently masked, using fast Fourier techniques. In simple signal processing terms, we are computing the cross-correlation of a 2D discrete signal with a larger 2D discrete signal, while also allowing the user to specify arbitrarily shaped supports --- henceforth referred to as masks --- for each signal. This computation can be executed directly in the spatial domain, but the Fourier Transform makes it possible to do this computation much faster. Our procedure follows the algorithms described in the following paper:

Dirk Padfield. "Masked Object Registration in the Fourier Domain". 
IEEE Transactions on Image Processing, vol.21(5), pp. 2706-2718, 2012. 

Dr. Padfield provides implementations in ITK and MATLAB. Our contribution is to provide an implementation that is compatible with OpenCV, and we hope to integrate this code within OpenCV, as it addresses a need that is currently unmet.

INSTALLATION

Requirements: opencv, boost, cmake

On Mac OS X:

# Homebrew installation: http://brew.sh/
brew tap homebrew/science
brew install opencv boost cmake

On Debian systems:

# OpenCV installation: https://help.ubuntu.com/community/OpenCV
sudo apt-get install libopencv-dev cmake
sudo apt-get install libboost-program-options-dev
sudo apt-get install libboost-system-dev
sudo apt-get install libboost-filesystem-dev

On Windows systems:

Download the latest stable version of OpenCV library from official site http://opencv.org/ and install it.
Download and install boost from http://www.boost.org/.
Add CMake option `CMAKE_PREFIX_PATH` or `OpenCV_DIR` to locate OpenCV:
  -DCMAKE_PREFIX_PATH=<...>\opencv\build
Add CMake options `BOOST_ROOT` to locate Boost:
  -DBOOST_ROOT=<...>

Procedure for building code using CMake:

[masked_normxcorr]$ cmake -H. -Bbuild -DCMAKE_BUILD_TYPE=Release
[masked_normxcorr]$ cmake --build build --config Release

Afterwards, the tree structure should look like this:

[~/masked_normxcorr]$ tree -L 2
.
├── CMakeLists.txt
├── README.md
├── build
│   ├── CMakeCache.txt
│   ├── CMakeFiles
│   ├── Makefile
│   ├── cmake_install.cmake
│   └── src
└── src
    ├── CMakeLists.txt
    ├── Doxyfile
    ├── masked_normxcorr.cpp
    ├── normxcorr2_masked.cpp
    └── normxcorr2_masked.hpp

(For more information on using CMake, check out http://www.cmake.org/cmake/help/cmake_tutorial.html)

EXAMPLES

In this example, we will use maximization of masked cross-correlations to locate the Batman logo in a scene. The images we will use for this example are shown below, and can be found in data folder.

Run result executable masked_normxcorr with test images from data folder by ctest:

[masked_normxcorr]$ cd build
[masked_normxcorr/build]$ ctest -VV -C Release

This is equivalent to:

[masked_normxcorr/build]$ ./masked_normxcorr -F ../data/fixedImage.jpg -f ../data/fixedMask.png -M ../data/movingImage.jpg -m ../data/movingMask.png

Type ./masked_normxcorr -h for a full help menu.

fixedImage.jpg (scene):

Screenshot

fixedMask.png (scene mask):

Screenshot

movingImage.jpg (template):

Screenshot

movingMask.png (template mask):

Screenshot

Note that the Batman logo in the template does not exactly match the logo on Batman's chest in the scene. Also, the Batman logo in the template is red outside of the oval logo, which would throw off a standard cross-correlator that uses rectangular supports. The oval template mask allows us to ignore this red area.

Masked normalized cross-correlation using Fourier methods:

Fixed image (scene): fixedImage.jpg: [690 x 800]
Fixed mask (scene mask): fixedMask.png: [690 x 800]
Moving image (template): movingImage.jpg: [104 x 63]
Moving mask (template mask): movingMask.png: [104 x 63]
Dimensions of combined image: 862 x 793
Optimal larger dimensions for fast DFT: 864 x 800
    Calculated cross-correlation for one channel in 806.512 ms
    Calculated cross-correlation for one channel in 776.407 ms
    Calculated cross-correlation for one channel in 768.965 ms
Total cross-correlation time for all channels: 2451.68 ms

Results for channel 0 ...
#1: 0.750705 (220,404)
#2: 0.746034 (219,404)
#3: 0.727210 (219,405)
#4: 0.720789 (219,403)
#5: 0.719367 (220,405)
maximum value: 0.750705 @ (y,x)=(404,220)
minimum value: -0.383996 @ (y,x)=(398,349)
Writing image xcorr_0.jpg ... 
Writing numerical matrices xcorr_0_correlation_matrix.tsv and xcorr_0_overlap_matrix.tsv ... 

Results for channel 1 ...
#1: 0.858291 (219,404)
#2: 0.840575 (219,405)
#3: 0.825339 (220,404)
#4: 0.821008 (219,403)
#5: 0.803989 (220,405)
maximum value: 0.858291 @ (y,x)=(404,219)
minimum value: -0.482819 @ (y,x)=(389,197)
Writing image xcorr_1.jpg ... 
Writing numerical matrices xcorr_1_correlation_matrix.tsv and xcorr_1_overlap_matrix.tsv ... 

Results for channel 2 ...
#1: 0.877009 (219,404)
#2: 0.853381 (219,405)
#3: 0.848980 (220,404)
#4: 0.841817 (219,403)
#5: 0.824849 (220,405)
maximum value: 0.877009 @ (y,x)=(404,219)
minimum value: -0.552982 @ (y,x)=(390,200)
Writing image xcorr_2.jpg ... 
Writing numerical matrices xcorr_2_correlation_matrix.tsv and xcorr_2_overlap_matrix.tsv ... 

Writing blended correlation matrix xcorr.jpg ...
#1: 0.827111 (219,404)
#2: 0.808342 (220,404)
#3: 0.807056 (219,405)
#4: 0.794538 (219,403)
#5: 0.782735 (220,405)
maximum value: 0.827111 @ (y,x)=(404,219)
minimum value: -0.441289 @ (y,x)=(398,347)

The resulting output images are shown below. Note that we ignore all areas where the intersection of the template mask with the scene mask has an area smaller than that of the template mask.

xcorr_0.jpg (cross-correlation for blue channel):

Screenshot

xcorr_1.jpg (cross-correlation for green channel):

Screenshot

xcorr_2.jpg (cross-correlation for red channel):

Screenshot

Lastly, here is a composite image that averages the cross-correlation images from all three color channels:

xcorr.jpg (average of cross-correlation matrix from all 3 channels)

Screenshot

LICENSE

/***********************************************************************

  • Software License Agreement (BSD License)
  • (c) 2013 Quantitative Engineering Design (http://qed.ai)
  • Authors: William Wu, Jiehua Chen, Zhang Zhiming, Michał Łazowik
  • Primary Contact: William Wu ([email protected])
  • THE BSD LICENSE
  • Redistribution and use in source and binary forms, with or without
  • modification, are permitted provided that the following conditions
  • are met:
    1. Redistributions of source code must retain the above copyright
  • notice, this list of conditions and the following disclaimer.
    1. Redistributions in binary form must reproduce the above copyright
  • notice, this list of conditions and the following disclaimer in the
  • documentation and/or other materials provided with the distribution.
  • THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  • IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  • OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  • IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  • INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  • NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  • DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  • THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  • (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  • THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *************************************************************************/

AUTHORS

William Wu, Jiehua Chen, Zhang Zhiming, Michał Łazowik

Primary contact: [email protected]

About

Computes masked cross-correlation of two images using fast Fourier methods. Compatible with OpenCV!

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 97.5%
  • CMake 2.5%