The present disclosure relates to imagery, and more particularly to registration of multiple images such as used in multi-modality and multi-spectral imagery.
Registration between the different bands of multi-spectral imagery, e.g., acquired by an airborne or space sensor, is particularly challenging as the bands that are spectrally far apart do not correlate very well across the image. For example, bands deep in the IR region have both a reflective and an emissive component whereas the bands in the visual region are purely reflective.
Simple phase correlation to obtain the warp is not very effective in these instances. Similarly, registering images acquired using different modalities such as LiDAR, narrow band spectral, and broad band visual photographic imagery present the same issues.
Conventional methods and systems have generally been considered satisfactory for their intended purpose. However, there is still a need in the art for improved image registration for multi-modal and multi-spectral images. The present disclosure provides a solution for this need.
A method for modeling warp for registration of images includes receiving input warp data and performing a fitting process on the input warp data to produce at least one of reduced noise warp data or reduced noise warp uncertainty. The warp for at the at least one of reduced noise warp data or reduced noise warp uncertainty is modeled with components including an offset that varies in time and a non-linear distortion that does not vary with time. The method also includes outputting at the least one of reduced noise warp data or reduced noise warp uncertainty.
The warp can be modeled with components including a slope that varies in time. Performing the fitting process can include modeling the slope and offset as splines. Performing the fitting process can include modeling the non-linear distortion as a polynomial.
The method can include receiving input warp data uncertainty for the input warp data, wherein performing the fitting process includes using the input warp data uncertainty in producing the reduced noise warp data. Performing the fitting process can include correcting errors in the input warp data uncertainty by performing a robust fitting process on the input warp data.
The method can include predicting reduced noise warp uncertainty and utilizing the reduced noise warp uncertainty to generate a refined warp by incorporating motion data, and registering a warped band using the refined warp. It is also contemplated that the method can include predicting reduced noise warp uncertainty using the input warp data uncertainty and utilizing the reduced noise warp uncertainty to generate a refined warp by incorporating motion data, and registering a warped band using the refined warp.
A sensor model can be used to produce warp data from motion and motion warp uncertainty, wherein the refined warp is produced by combining the reduced noise warp, the reduced noise warp uncertainty, the warp data from motion, and the motion warp uncertainty. Combining the reduced noise warp, the reduced noise warp uncertainty, the warp data from motion, and the motion warp uncertainty can include obtaining the refined warp {circumflex over ({right arrow over (h)})} as
{circumflex over ({right arrow over (h)})}(Σ{circumflex over (d)}−1+Σĝ−1)−1(Σ{circumflex over (d)}−1{circumflex over ({right arrow over (d)})}+Σĝ−1{circumflex over ({right arrow over (g)})})
where {circumflex over ({right arrow over (d)})} is the reduced noise warp, Σ{circumflex over (d)} is the reduced noise warp uncertainty, g denotes the warp data from motion, and Σĝ denotes the motion warp uncertainty.
The method can also include:
using the input warp data uncertainty to produce relative input warp data uncertainty;
using the relative input warp data uncertainty in a warp model robust fit to produce fit weights;
using the fit weights and relative input warp data uncertainty to produce corrected relative input warp data uncertainty;
predicting relative reduced noise warp data uncertainty from the corrected relative input warp data uncertainty;
using the reduced noise warp data and the input warp data to estimate input noise variance; and
multiplying the relative reduced noise warp data uncertainty and the input noise variance to produce the reduced noise warp data uncertainty.
A smoothing model for slope and offset spline coefficients can be incorporated in the fitting process. Incorporating a smoothing model in the fitting process can include minimizing curvature of the offset and slope splines. The splines can have non-uniformly placed knots. The splines can be cubic.
The fitting process can include modeling the warp as
d
x(x,y)=sy(y)x+cx(y)+ox(x)
d
y(x,y)=sy(y)x+c(y)+oy(x).
where dx(•,•) and dy(•,•) are x and y components of the warp, respectively, sx(•) and cx(•) denote slope and offset as a function of time for the x component of the warp, sy (•) and cy (•) denote the slope and offset as a function of time for the y component of the warp, and ox(•) and oy (•) denote distortion that is constant in time but varies along a sensor array, and y in the functions denotes time and x in the functions denotes distance along the sensor array.
A method for registration of images includes receiving a reference image and a warped image, correlating the reference and warped images to produce noisy warp data, and performing a fitting process on the noisy warp data to produce reduced noise warp data. The warp for the reduced noise warp data is modeled with components including an offset that varies in time, and a non-linear distortion that does not vary with time. The method also includes resampling the warped image using the reduced noise warp data to produce a registered image that is registered to the reference image.
Correlating the reference and warped images can include producing warp data uncertainty. Performing the fitting process can include generating reduced noise warp uncertainty. The method can include receiving motion data and combining the motion data with the reduced noise warp and the reduced noise warp uncertainty to produce a refined warp, wherein resampling the warped image using the reduced noise warp data includes using the refined warp to produce the registered image.
A system includes a module configured to implement machine readable instructions to perform any embodiment of the methods described above.
These and other features of the systems and methods of the subject disclosure will become more readily apparent to those skilled in the art from the following detailed description of the preferred embodiments taken in conjunction with the drawings.
So that those skilled in the art to which the subject disclosure appertains will readily understand how to make and use the devices and methods of the subject disclosure without undue experimentation, preferred embodiments thereof will be described in detail herein below with reference to certain figures, wherein:
Reference will now be made to the drawings wherein like reference numerals identify similar structural features or aspects of the subject disclosure. For purposes of explanation and illustration, and not limitation, a partial view of an exemplary embodiment of a method in accordance with the disclosure is shown in
Let {xw, yw,} denote the coordinates in a warped band image that correspond to the coordinates {x, y} in a reference band image. Let
d
x(x,y)=xw(x,y)−x (1)
d
y(x,y)=yw(x,y)−y (2)
denote the space varying translation between the warped and the reference band. Assume the images of the reference and warped bands are acquired by two linear sensor arrays displaced from each other spatially. The sensor arrays are mounted on an airborne or space platform and the images are obtained by scanning the arrays in time as the platform moves. The platform motion may not be perfectly uniform in time and this causes a time-dependent warping between the bands. We will use x for the direction along the sensor arrays (fast-scan) and the y for the time dimension (slow-scan.) Given the rigid geometry in the x direction, we expect the warping to be linear in this direction unless there is uncorrected optical distortion. The linear warping in x will be time dependent but the optical distortion will be constant in time. Let sx (•) and cx(•) denote the slope and offset as a function of time for the linear mapping of the warp in the x component. Similarly, let sy (•) and cy (•) denote the slope and offset for the y component of the warp in time. Let ox (•) and oy(•) denote the relative optical distortion between the warped and the reference band along the sensor array for the x and y component respectively. We model the space varying translation between the bands as follows
d
x(x,y)=sx(y)x+cx(y)+ox(x)
d
y(x,y)=sy(y)x+cy(y)+oy(x). (3)
Note that this is nothing but a Taylor series expansion of the delta warp d(x, y) along the x direction with the zeroth and first order coefficients as functions of y (time) and the higher order coefficients constant in time.
In the subsequent treatment, we will use v={x, y} as an index for x or y. Since the equations are similar for the translations in x and y, this makes for compact notation. Assuming the platform motion is more or less steady, the slope and offset, s*(•) and c*(•), will be smooth functions of time, y. We choose to model them as B-splines and they can written as a summation of a set of basis functions as
where ns and nc are the number of basis functions that are chosen for the slope and offset functions respectively. The number of knots and the spline order k determines the number of basis functions. See Sec. 1.1 for generating the set of basis functions Bj,k(•), j=1 . . . n given the order and knot locations.
The optical distortion can either be modeled as a B-spline or a polynomial
where no denotes the number of basis functions and ej, j=1, . . . ,np, denotes the no exponents chosen for the polynomial basis. In the subsequent treatment, we will use Bj,ko(•) either for the spline basis or the polynomial basis.
To generate the B-spline functions, the number and location of the knots need to be specified along with the order of the spline. Let the knots sequence be denoted as t1≦t2≦ . . . ≦tn, where n is the number of knots. Let k denote the order of the spline where k=1 denotes the 0th order spline. The B-spline basis functions for any order k is generated recursively from the previous order basis functions. The knots sequence is augmented for each order k as follows
The recursion of the B-spline at any order k>1 is given as
and is initialized at k=1 as
1.2 Warping model parameter estimation
The unknown spline coefficients for slope, offset, and optical distortion need to estimated. This is achieved by fitting the warping model Eq. (3) to the warping data obtained by the image correlation algorithm at a discrete set of tie points. To obtain the warp data at the tie points, methods such as phase correlation on local images of the warped band and the master band centered on the tie points may be empolyed. Such methods are known to those skilled in the art. Let {xi, yi}, i=1, . . . , m denote a set of m grid points at which the warp has been estimated. To facilitate the estimation of the unknown coefficient, we rewrite Eq. (3) in vector-matrix notation
d=Ap, (10)
where
is a m×n matrix, where np=ns+nc+no, and
are np×2 and m×2 matrices respectively. The matrix p has all the spline coefficients, the matrix d has all the data, and the matrix A is constructed based on the model structure. The spline basis functions have a compact local support and this makes the matrix A to be sparse. Note that bold case letters will be used to represent matrices. Subscripts on matrices will be used to identify rows (first index) and columns (second index) with denoting all indices. For example, Ai*, denotes the ith row and A*j denotes the 1th column of matrix A. The first and second columns of p and d matrices contain the model coefficients and data for x and y respectively. Hence we will also use p*v or d*v with v taking values {x, y} to denote the column vectors corresponding to x and y.
Equation (10) compactly represents the warp model evaluated at the tie point grid where warping data is available either through image correlation or some other means. In general, the data from the image correlation process will be noisy either due to measurement process or correlation model mismatch as the image content may not match very well between the warped band and the master band. We would like to adjust the unknown spline coefficient to minimize the mean square error between the model predictions and the data. The least-squares estimate can be obtained in closed form and is given as
{circumflex over (p)}=(AtA)−1AtA (13)
The solution of Eq. (13) assumes that the noise is uniformly distributed across all the m data points and that the two components in x and y are independent. However, depending on how the data values are obtained for the warping, the noise may be quite variable between the data points and also coupled between the two components. Let W(i) denote the 2×2 weighting matrix for data point i based on the confidence we have on the estimate for that point. The inverse of the noise covariance matrix can be chosen as the weighting matrix. The weighted mean square error across all m data points in vector-matrix notation is given as
where
is a 2×2n matrix and
is a 2n
If the x and y components are uncorrelated (weighting matrices W(i) are diagonal), then Eq. (17) can be simplified since the spline coefficient for x and y can be estimated independently. Let
be the m×m diagonal weighting matrices for x and y components respectively. Then the weighted least-squares solution for the two components is given as
{circumflex over (p)}
*v=(AtWvA)−1AtWvd*v, v={x,y} (19)
Note that until now we have assumed the basis functions are the same for x and y components. This restriction can be easily relaxed by using a different matrix A for the x and y components. For the coupled solution given by Eq. (17), the matrix A(i) can be modified as
where Ax and Ay denotes the A matrix formed from the basis functions for x and y respectively.
The warping model matrix A can end up being badly scaled and ill-conditioned leading to a host of numerical issues in the solution of the model spline coefficients. The problem arises because the range of x and y may be large and quite different from each other. The large range of x makes the basis functions for the optical distortion model given by Eq. (6) to have a very large dynamic range if the polynomial model is chosen. With finite precision, the matrices will become rank deficient making it difficult to fit the data correctly. To overcome this problem, it is advisable to first normalize the range of the x and y between 0 and 1. The warping model is then fitted in the normalized domain and the results scaled back to the original domain for subsequent processing.
Also note the solutions in Eqs. (13), (17), and (19), require a matrix inverse. Although they have been written in that form, it is not advisable to compute the explicit inverse both from a numerical accuracy and performance considerations. Instead, it is better to take the inverted matrix to the other side of the equation and solve the resulting set of linear equations using Gaussian elimination.
The previous Sections assumes that the noise in the data can be modeled as Gaussian. However, in practice if the data are generated using an image correlation procedure, the noise is very much image content dependent. Furthermore, if the image registration is being done between two different imaging modalities or very different spectral bands, the image correlation model may break down. Both of these factors can lead to large impulsive kind of noise that is not very well modeled by a unimodal normal distribution. The quadratic penalty resulting from the Gaussian assumption tends to be overly sensitive to outliers and the resulting least-squares solution can end up significantly biased. Towards this end, we would like to replace the quadratic penalty with alternative penalty functions that reduce the cost the model associates with large outlying values in the data. The optimal shape of the penalty function is given by actual probability distribution function of the noise in the data. In practice, it is difficult to come up with an accurate description of the noise. However, any penalty function that reduces the cost associated with large outlying values will tend to perform better in the case the data is corrupted by impulsive or heavier tail distributions.
One advantage of the weighted least squares method is that the solution comes out to be closed form. This will not be case if an alternative robust penalty function is employed. However, we can leverage the closed form solution for weighted least squares to come up with an iterative solution that assigns varying weights to each data point based on a determination of how well it fits the Gaussian distribution assumption. The weights vary during the iterative process as the model moves to fit the normally distributed data points and reject the outlying data values that do not fit the model very well.
1.2.6 Solution for uncorrelated components
This Section lays out the robust solution when the x and y components are uncorrelated. In this case, the model fitting in x and y can be carried out independently. For notational simplicity, we will drop the subscripts x and y on the matrices in this Section and give the robust solution for the general problem
A{right arrow over (p)}={right arrow over (d)} (21)
where A is the model matrix, {right arrow over (d)} is the data vector and {right arrow over (p)} is the vector of unknown model coefficients. Note that the general formulation given by Eq. (21) includes the case where we have a weighting matrix W. The effect of the weighting is incorporated in the model matrix and the data vector as follows:
A→W
1/2
A, {circumflex over (d)}→W
1/2
{right arrow over (d)}. (22)
The robust fitting method proceeds by assigning weights to each of the data points at each iteration based on its determination of how likely the point is an outlier or not. Let l denote the iteration index and let wi(l) denote the weight associated with the ith data point at iteration l. The weights are all initialized to one at the first iteration, w*(1)=1. The weights at each iteration l are put into a diagonal weighting matrix denoted as W(l). The solution at iteration l is given as
{circumflex over ({right arrow over (p)})}(l)=(AtW(l)A)−1AtW(l){right arrow over (d)} (23)
The model fitting error is given by the residual
{right arrow over (r)}
(l)
=A{circumflex over ({right arrow over (p)})}(l)−{right arrow over (d)} (24)
It can be shown that the covariance of the residuals is given as
E[{right arrow over (r)}{right arrow over (r)}
t]=(I−P)σ2 (25)
where σ2 is the variance of the noise in the data and P is the projection matrix
P=A(AtA)−1At (26)
Given the result of Eq. (25), we can normalize the residuals at each iteration to obtain a unit variance random variable
where {circumflex over (σ)}(l) is an estimate of the noise standard deviation at iteration l. The quantity (1−Pii) is known as the leverage for data sample i. We need to obtain a robust estimate of σ in the presence of outliers. The ML estimate given by the root mean square error is too susceptible to large outlying values. Instead, we choose the median of the absolute deviation as our robust estimate
The factor 1.4826 is chosen such that if the samples are drawn from a Gaussian distribution with no outliers, the robust estimate is equal to the ML estimate.
The normalized residuals are then passed through a weighting function ρ(•) that assigns weights to each data sample. For robustness, we would like to dial down the weights as the normalized residual gets large signaling an outlier. There are numerous functions in the literature that achieve this purpose.
The weights at each iteration l are obtained as
w
i
(l)=ψ(
where scaling factor 4.685 has been chosen to obtain 95% efficiency with respect to the ordinary least square estimate when no outliers are present. This choice basically sets the weights of sample data that is more the 4.685 standard deviations away to zero. Note that the choice of the scaling factor depends on the form of the weighting function and will be different for the Huber and the Cauchy functions shown in
The procedure outlined in this Section is repeated until the estimate of the unknown model coefficients given by Eq. (23) converges or the maximum number of iterations are exceeded.
1.3 Smoothing model
The smoothness of the slope and offset profiles in time is implicitly determined by the choice of the number of spline coefficients and their placement. A small number of evenly spaced knots constrains the profiles to be smooth. Increasing the number of knots frees up the profiles to change more quickly. Ideally, we would like the splines to be flexible enough to fit all the good data. However, choosing a large number of knots can make the results vary wildly in areas where there is no data to constrain the solution. The numerical solutions proposed in Section 1.2 do not guarantee a minimum norm solution.
The implicit specification of smoothing is undesirable since it shifts the difficultly to optimal estimation of the number and placement of knots. Instead, we use an explicit smoothing model in the optimization problem. The original cost function minimized the mean square error between the model and the data. We add to this function a roughness penalty that will favor smoother solutions. We formulate the roughness penalty as the integrated square of the second derivative of the slope and offset functions given as
where λs and λc denote the weights assigned to the roughness terms for the slope and offset respectively. Using Eqs. (4) and (5), we obtain
To make the computation tractable, we approximate the integral in Eq. (31) as a sum by evaluating the second derivatives only at the knot locations. For a cubic spline (k=4) with uniformly distributed knot locations at {t1 . . . , tn}, we have the following approximate relationship if we ignore edge effects
Substituting Eq. (34) in Eqs. (32) and (33), we obtain
Approximating the integral in Eq. (31) with a discrete sum evaluated at the knots locations given by Eqs. (35) and (36), we obtain
Note that the expressions for the integrated squared second derivative in eqs. (37) and (38) are only approximate but they are reasonably accurate for our purposes. To enable us to write the roughness penalty in vector-matrix notation, we define
to be a matrix that operates on a vector of length n and computes the second order finite difference. Note that Dn is approximately a Toeplitz matrix with the first and last rows adjusted to sum to zero. Using Dn, we construct a (ns+nc)×np matrix
that can directly operate on the model parameter vector p*x or p*y to obtain the second order finite differences of the slope and offset spline coefficients. The notation 0n
where
denotes the model matrix augmented by the second derivative matrix and
denotes the data augmented by zeros (constraints for second derivative.) Minimizing the cost function Cv with respect to the parameters yields
If weights (inverse noise covariance) are available for the data points, the cost function is modified as
C
v=(Ap*v−d*v)tWv(Ap*v−d*v)+(Dp*v)t(Dp*v), v={x,y} (46)
The optimal solution is given as
{circumflex over (p)}
*v=(Āt
where
Here In denotes an identity matrix of size n×n.
To obtain a robust solution, the prescription given in Sec. 1.2.6 can be followed using the augmented model matrix Ā and data vector
In this Section, the subscript v denoting x or y will be dropped for notational simplicity as the equations are same for both x and y. E[·] denotes the expectation operator and bold case is used to specify the random variables over which the expectation is computed and for denoting matrices. Since the expectation in this Section is always computed on vectors (denoted with {right arrow over ( )}), there should be no confusion between the two. Estimated quantities will be denoted by a ̂ and matrices and vectors augmented by the smoothing constraints denoted by a
We are interested in computing the expected mean square error (MSE) between the warp model predictions {circumflex over ({right arrow over (d)})} and the ground truth warp {right arrow over (d)}t as a measure of accuracy of the model output. In practice, the ground truth warp is not available but it will not be required if the model predictions are unbiased as shown below
where Σ{circumflex over (d)} denotes the covariance matrix of the model predictions.
Assuming the warp formulated in Sec. 1 models physical reality closely, the model predictions based on image correlation data will be unbiased making Eq. (49) valid. In practice, the bias term will be small and the covariance of the model output will accurately predict the MSE.
We will derive the expression for Σ{circumflex over (d)} for the most general case including the smoothing model and robust fitting. Reducing to the special cases of no smoothing model with and without robust fitting is then trivial. Let W denote the weighting matrix for the data points that is obtained by multiplying the specified weights (if any), which are ideally set to the inverse covariance matrix of the input data for optimality, with the weights obtained during robust fitting (if enabled). If the input data has no specified weights and robust fitting is not performed, this will be the identity matrix. As before,
{circumflex over ({right arrow over (d)})}=A{circumflex over ({right arrow over (p)})}=A(Āt
where the filtering matrix
F=A(Āt
maps the input warp data to the output model prediction. Using Eq. (50), the model prediction covariance can be computed as
where E
However, in practice, the input data covariance estimated from image correlation process may be inaccurate for some number of points. The robust fitting procedure of Sec. 1.2.5 is designed precisely to identity such outlier data points. The robust fitting weights can be regarded as corrections to the weights derived from the supplied input data covariance matrix. In essence, the overall weight matrix
{circumflex over (Σ)}
where σd2 is an unknown scale factor that needs to be estimated. Substituting Eqs. (53) and (51) in (52), we obtain
1.4.1 Estimation of σd2
The residual of the augmented data is given as
{right arrow over (
where
denotes the augmented filtering matrix on the same lines as Eq. (51). Given the linear relationship of the residual to the data and assuming Eq. (53) holds, the residual covariance can be simplified as
where the third line uses the identity
Taking the trace of both sides and approximating the expectation with a single instance of the data (replacing the expectation with a single instance is a very crude approximation, but we make up for that by the trace operation that averages all the data points), we obtain
where na is the number of smoothing constrains that augment the data. This can be looked at as the ML estimate of σd2 with residuals being modeled as zero-mean Gaussian distributed with covariance σd2(I−
Note that Eqs. (54) and (60) taken together make the estimated covariance {circumflex over (Σ)}{circumflex over (d)} of the output prediction invariant to the scale of weights specified for the input data as well as the weights estimated during robust fitting. This a desirable property as there may be errors in the estimation of the scale of the input data covariance due to modeling errors.
1.4.2 Unbiased Estimate of σd2
The noise estimate given by Eq. (60) can potentially be biased lower when robust fitting is performed. Large outliers are suppressed by dialing down the robust weights but in the process other sample points that fall in the true distribution are also de-weighted significantly if they are far away from the mean of the distribution. The exact expression for the bias is difficult to compute analytically when robust fitting is performed without making simplifying assumptions that are typically not valid in practice. Instead, we will use our intuition to come up with a correction factor that accounts for this bias and verify the resulting expression via Monte Carlo simulations.
When computing statistics from N independent samples, we know that the variance of the estimated statistic goes down as 1/N, i.e., each sample has an effective contribution of 1. In robust fitting, we have a weight assigned to each sample i at iteration l, wi(l), where 0≦wi(l)≦1. We can look at this weight as the effective contribution of sample i to reducing the variance of the estimated quantity. As the sample moves further away from the mean of the distribution, it contributes less and less to the result increasing the variance of the final estimate. The ratio of effective number of data samples and the actual number of data samples can then serve as a bias correction factor for our estimated noise. Towards this end, we define
where wi(*) denotes the robust weight assigned to sample i at convergence.
Also, note that an estimate of the input data noise similar to that given by Eq. (60) was obtained as part of robust fitting. See Sec. 1.2.6 and the robust estimate of noise given by Eq. (28). We can utilize this estimate along with the heuristic correction factor K to obtain an unbiased estimate
where {circumflex over (σ)}(*) is the estimated noise in robust fitting at convergence. Alternatively, we can obtain an unbiased estimate from Eq. (60) and our heuristic correction factor K as follows (Note we use K2 rather than K to normalize here since the residuals are multiplied by the robust weights in the numerator)
where we have accounted for the number of degrees of freedom in the model (np) and the total number of constraints (m data points and na smoothing constraints). Typically, the number of smoothing constraints is equal to the number of parameters so the normalization is close to m as in Eq. (60). In practice, the two estimates given by Eqs. (62) and (63) are very close to each other. In case no robust fitting is performed, the unbiased noise estimate is obtained by Eq. (63) with K=1.
The internal data flow within the spline warp model 16 is shown in
{circumflex over ({right arrow over (h)})}=(Σ{circumflex over (d)}−1+Σĝ−1)−1(Σ{circumflex over (d)}−1{circumflex over ({right arrow over (d)})}+Σĝ−1{circumflex over ({right arrow over (g)})}) (64)
where {circumflex over ({right arrow over (d)})} is the de-noised warp estimate from image data obtained from eq. (50) and E{circumflex over (d)} is the associated uncertainty of this data obtained from eq. (54).
Those skilled in the art will readily appreciate that a system for registering images can include a module configured to implement machine readable instructions to perform one or more of the method embodiments described above.
As will be appreciated by those skilled in the art, aspects of the present embodiments may be embodied as a system, method or computer program product. Accordingly, aspects of the present embodiments may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, aspects of the present disclosure may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave.
Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present disclosure may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present disclosure are described above with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the embodiments. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in a flowchart and/or block diagram block or blocks
The methods and systems of the present disclosure, as described above and shown in the drawings, provide for imagery with superior properties including improved multi-band/multi-spectral image registration. While the apparatus and methods of the subject disclosure have been shown and described with reference to preferred embodiments, those skilled in the art will readily appreciate that changes and/or modifications may be made thereto without departing from the scope of the subject disclosure.
This invention was made with government support under a Contract awarded by an agency. The government has certain rights in the invention.