Motion blur often limits the quality of photographs and can be caused by either the shaking of the camera or the movement of photographed objects (e.g., subject, passerby, props, etc.) in the scene. Modern cameras address the former case with image stabilization, where motion sensors control mechanical actuators that shift the sensor or camera lens element in real time during the exposure to compensate for the motion (shaking) of the camera, e.g. Canon. 2003. EF Lens Work III, The Eyes of EOS. Canon Inc. Lens Product Group. The use of image stabilization enables sharp hand-held photographs of still subjects at much longer shutter speed, thereby reducing image noise. Unfortunately, image stabilization only addresses camera motion and cannot help with moving objects in the subject scene or field of view.
One option is to remove the blur after the shot was taken using deconvolution. However, this raises several challenges. First, the typical motion-blur kernel is a line segment in the direction of motion, which corresponds to a box filter. This kernel severely attenuates high spatial frequencies and deconvolution quickly becomes ill-conditioned. Second, the length and direction of the blur kernel both depend on the motion and are therefore unknown and must be estimated. Finally, motion blur usually varies over the image since different objects or regions can have different motion, and segmentation must be used to separate image regions with different motion. These two later challenges lead most existing motion deblurring strategies to rely on multiple input images (see Bascle, B., Blake, A., and Zisserman, A., “Motion de-blurring and superresolution from an image sequence,” ECCV, 1996; Rav-Acha and Peleg, S., “Two motion-blurred images are better than one,” Pattern Recognition Letters, 2005; Zheng, M. S. J., “A slit scanning depth of route panorama from stationary blur,” Proc. IEEE Conf. Comput. Vision Pattern Recog., 2005; Bar, L., Berkels, B., Sapiro, G., and Rumpf, M., “A variational framework for simultaneous motion estimation and restoration of motion-blurred video,” ICCV, 2007; Ben-Ezra, M., and Nayar, S. K., “Motion-based motion deblurring,” PAMI, 2004; Yuan, L., Sun, J., Quan, L., and Shum, H., “Image deblurring with blurred/noisy image pairs,” SIGGRAPH, 2007.)
More recent methods attempt to remove blur from a single input image using natural image statistics (see Fergus, R., Singh, B., Hertzmann, A., Roweis, S., and Freeman, W., “Removing camera shake from a single photograph,” SIGGRAPH, 2006; Levin, A., “Blind motion deblurring using image statistics,” Advances in Neural Information Processing Systems (NIPS), 2006). While these techniques demonstrated impressive abilities, their performance is still far from perfect. Raskar et al. proposed a hardware approach that addresses the first challenge (Raskar, R., Agrawal, A., and Tubmlin, J., “Coded exposure photography: Motion deblurring using fluttered shutter,” ACM Transactions on Graphics, SIGGRAPH 2006 Conference Proceedings, Boston, Mass. vol. 25, pgs. 795-804). A fluttered shutter modifies the line segment kernel to achieve a more broad-band frequency response, which allows for dramatically improved deconvolution results. While the Raskar approach blocks half of the light, the improved kernel is well worth the tradeoff. However, this approach still requires the precise knowledge of motion segmentation boundaries and object velocities, an unsolved problem.
The present invention addresses the foregoing problems in the art. In the present invention, applicants show that if the motion is restricted to a 1D set of velocities, such as horizontal motion (as is the case with many real world objects like cars or walking people), one can address all three challenges of the prior art mentioned above. Using camera hardware similar to that used for image stabilization, applicants and the present invention make the point-spread function (PSF) invariant to motion and easy to invert. For this, applicants/the invention system introduce a specific camera movement during exposure. This movement is designed so that the compound motion of the camera and any object velocity (within a speed range and along the selected orientation) and at any depth in the camera filed of view results in the same easy-to-invert PSF. Since the entire scene is blurred with an identical PSF (up to tail truncation), including static objects and moving objects, the blur can be removed via deconvolution, without segmenting moving objects and without estimating their velocity. In practice, applicants find that motions even somewhat away from the selected 1D orientation are deblurred as well.
In a preferred embodiment, a method and apparatus deblurs images of a moving object. During imaging of the moving object, the invention system blurs an entire scene of the moving object. This blurring is in a manner which is invariant to velocity of the moving object. Next the invention system deconvolutes the blurred entire scene and generates a reconstructed image. The reconstructed image displays the moving object in a deblurred state.
The invention step of blurring the entire scene is preferably implemented by moving any one or combination of the camera, a lens element of the camera and camera sensor. This moving of the camera or part of the camera system includes linear movement in a range of direction and speed sufficient to include direction and speed of the moving object. Examples of linear movement here are a sinusoidal pattern, a parabolic pattern or any other simple harmonic motion and the like.
In one embodiments, the linear movement follows a parabolic path by moving laterally initially at a maximum speed of the range and slowing to a stop and then moving in an opposite direction laterally, increasing in speed to a maximum speed of the range in the opposite direction and stopping.
The present invention may be applied to a variety of moving objects and environments. For non-limiting examples, the moving object may be (a) a moving vehicle on a roadway or other terrain, (b) a body part of a patient (human or animal), (c) in aerial photography, or other moving objects in a subject scene.
The foregoing will be apparent from the following more particular description of example embodiments of the invention, as illustrated in the accompanying drawings in which like reference characters refer to the same parts throughout the different views. The drawings are not necessarily to scale, emphasis instead being placed upon illustrating embodiments of the present invention.
a is a block diagram of an embodiment of the present invention.
b is a flow diagram of an embodiment of the present invention.
a-2d are schematic graphs illustrating xt-slice and integration curves resulting from different camera motions.
e-2h are graphs illustrating corresponding integration curves sheared to account for object slope for
i-2l are graphs of projected point spread functions corresponding to different object velocities of
a-3d is a set of simulated photographs of five dots moving over a range of speeds and directions.
a-4d are illustrations of integration curve traces in space time and corresponding log spectrums of a static camera, a parabolic motion camera of the present invention, a flutter shutter camera and the upper bound.
a-5c are synthetic visualizations (imagery) of point spread function information loss between a blurred input and deblurring solution result.
a-7c are photographic illustrations of deblurring results of the present invention.
a-8e are comparisons of deblurring photographic images using the present invention and using static camera deblurring of the art.
a-9b are scene views illustrating the present invention PSF clipping and a working velocities range.
A description of example embodiments of the invention follows.
Applicants' approach is inspired by wavefront coding (Cathey, W., and Dowski, R., “A new paradigm for imaging systems,” Applied Optics, No. 41, pgs. 1859-1866, (1995)), where depth of field is improved by modifying a lens to make the defocus blur invariant to depth and easy to invert. While the cited work deals with wave optics and depth of field, applicants and the present invention consider geometric ray optics and remove 1D motion blur.
By analyzing motion blur as integration in a space time volume over curves resulting from camera and object motion, applicants prove that one integration curve that results in a motion-invariant PSF (point-spread function) is a parabola. This corresponds to constant 1D acceleration of the camera, first going fast in one direction, progressively slowing down to a stop and then picking up speed in the other (opposite) direction. As a result for any object velocity within a range, there is always one moment during exposure where the camera is perfectly tracking (in speed and direction) the object. While the camera motion is along a straight or lateral line, applicants call it “parabolic motion” because of the parabolic relationship between position and time.
In addition to its invariance to object speed, the present invention PSF preserves more high frequencies for moving objects than a normal exposure. This however comes at the cost of slightly degraded performance for static objects. In fact, applicants show that even if object motions could be estimated perfectly, the type of PSFs resulting from the parabolic camera motion is near-optimal for a stable deconvolution over a range of possible object speeds. This optimality is in the sense of minimizing the degradation of the reconstructed image for a range of potential object velocities. In a nutshell, applicants show that there is a fixed bandwidth budget for imaging objects at different velocities. For example, a static camera spends most of this budget to achieve high-quality images of static objects, at the cost of severe blur for moving objects. Applicants' (the present invention's) design distributes this budget more uniformly, improving the reconstruction of all motion velocities, at the price of a slightly worse reconstruction of the static parts.
There are three basic options for implementing this camera movement: a translation of the full camera, a rotation of the camera, or a translation of the sensor or lens element. For a commercial product, the latter may be the best solution, and could be achieved with the existing hardware used for stabilization. However, if the focal length is not too wide-angle, a camera rotation is a good approximation to sensor translation and is easier to implement as a prototype. Applicants demonstrate a prototype using camera rotation and show 1D speed-invariant deconvolution results for a range of 1D and even for some 2D motions.
In order to derive a motion-invariant photography scheme, the present invention characterizes motion blur as an integration in space-time. Applicants show that the effect of object motion can be characterized by a shear. Applicants also show that a camera parabolic movement is invariant to shear in space-time and permits the removal of motion blur.
Space-time analysis of motion blur: The set of 2D images falling on a detector over time forms a 3D space-time volume of image intensities. Consider a 2D xt-slice through that 3D space-time volume. Each row in this slice represents a horizontal 1D image, as captured by a static pinhole camera with an infinitesimal exposure time.
For sufficiently small exposure, a first order approximation to the object motion is sufficient, and the motion path is assumed to be linear. In this case, scene points trace straight lines in the xt-slice and the slopes of these lines are a function of the object velocity and depth.
Formally, the space-time function of an object moving at constant velocity s is related to that of a static object by a shear, since kinematics gives:
x(t)=x(0)+st (1)
Camera motion and integration: If the sensor is translating, the image recorded at time instance t is a shifted version of row t in the xt-plane (the xt-plane represents the scene relative to a static camera). Thus, when the scene is captured by a translating sensor over a finite exposure time, the recorded intensities (the blurred image) are the average of all shifted images seen during the exposure length, at all infitisimal time instances. That is, the sensor elements integrate light over curves in the xt-plane. The simplest case is a static camera, which integrate light over straight vertical lines 13 (
Since the applicants only translate the sensor, the integration curves that applicants consider are spatially shift invariant. Applicants denote by L(x,t) the intensity of light rays in the xt-slice, I(x) the intensity of the captured image, f(t) the integration curve, and [−T,T] an integration interval of length 2T. The captured image can be modeled as:
The Point Spread Function: Denote by I0(x) an ideal instantaneous pinhole image I0(x)=L(x, 0). The movement of the camera creates motion blur. For a static object, applicants can model it as a convolution of I0 with a Point Spread Function (PSF) φ0:I=φ0{circle around (×)}I0. In this case, φ0 is simply the projection off along the time direction onto the spatial line:
φ0(x)=∫t δf(t)=xdt (3)
where δ is a Dirac.
Now consider objects moving at speed s and seek to derive an equivalent Point Spread Function φs. We can reduce this to the static case by applying a change of frame that “stabilizes” this motion, that is, that makes the space-time volume of this object vertical. We apply the inverse of the shear in Eq. 1, which is the shear in the opposite direction, and the sheared curve can be expressed as:
fs(t)=f(t)−st (4)
Sheared curves are illustrated in
i-2l present the PSF 26, 27, 28, 29 of the three different objects 15, 17, 19, for each of the curves 13, 21, 23, 25, in
The analytic way to derive this projection is to note that the vertical projection is the “amount of time” the curve f spent at the spatial point x—the slope of the inverse curve. That is, if gs=fs−1 is the inverse curve, the PSF (the vertical projection) satisfies: φs(x)=gs′(x).
Shear invariant curves: Applicants and the present invention derive a camera motion rule that leads to a velocity invariant PSF. One can achieve such effect if one devotes a portion of the exposure time tracing each possible velocity, and one spends an equal amount of time tracing each velocity, so that all velocities are covered equally. The derivative of an integration curve representing such motion should be linear and therefore, a candidate curve is a parabola.
Applicants have shown that PSFs corresponding to different velocities are obtained from sheared version of the sensor integration curve. Consider a parabola curve 23 of the form: f(t)=a0t2 (
Thus, the projections φs are also identical up to a spatial shift. The important practical application of this property is that if the camera is moved during integration along a parabola curve, one can deconvolve all captured images I with the same PSF, without segmenting the moving objects in the image, and without estimating their velocity or depth. The small spatial shift of the PSF leads to a small spatial shift of the deconvolved image, but such a shift is uncritical as it does not translate to visual artifacts. This simply means that the position of moving objects corresponds to different time instants within the exposure. The time shift for a given velocity corresponds to the time where the sensor is perfectly tracking this velocity.
It is noted that the above invariance involves two approximations. The first approximation has to do with the fact that the invariant convolution model is wrong at the motion layer boundaries. However, this has not been a major practical issue in applicants' experiments and is visible only when both foreground and background have high-contrast textures. The second approximation results from the fact that a parabola is perfectly shear invariant only if an infinite integration time is used. For any finite time interval, the accurate projection is equal to:
Thus, for a finite integration interval, the tails of the PSF do depend on the slope s. This change in the tail clipping can also be observed in the projected PSFs 28 in
thus reducing a0 also reduces the range of s values for which the tail clipping is actually negligible.
Simulation: To simulate the blur from a camera moving in a parabolic displacement in space-time (constant 1D acceleration), applicants projected synthetic scenes and summed displaced images over the camera integration time.
Applicants derive optimality criteria as follows.
We have seen that the parabola is a shear invariant curve, and that parabolic displacement is one camera movement that yields a PSF invariant to motion. Here applicants show that, in the case of 1D motions, this curve approaches optimality even if we drop the motion-invariant requirement. That is, suppose that we could perfectly segment the image into different motions, and accurately know the PSF of each segment. For good image restoration, we want the PSFs corresponding to different velocities or slopes to be as easy to invert as possible. In the Fourier domain, this means that low Fourier coefficients must be avoided. We show that, for a given range of velocities, the ability to maximize the Fourier spectrum is bounded and that our parabolic integration approaches the optimal spectrum bound.
At a high level, our proof is a bandwidth budget argument. We show that, for a given spatial frequency wx, we have a fixed budget which must be shared by all motion slopes. A static camera spends most of this budget on static objects and therefore does poorly for other object speeds. In contrast, our approach attempts to distribute this budget uniformly across the range of velocities and makes sure that no coefficient is low.
Space time integration in the frequency domain: We consider the Fourier domain ωx, ωt of a scanline of space time. Fourier transforms will be denoted with a hat and Fourier pairs will be denoted k{circumflex over (k)}.
First consider the space-time function of a static object. It is constant over time, which means that its Fourier transform is non-zero only on the pure spatial frequency line ωt=0. This line is the 1D Fourier transform of the ideal instantaneous image I0.
We have seen that image-space object velocity corresponds to the slope of a shear in space time. In the frequency domain, a given slope corresponds to a line orthogonal to the primal slope. Or equivalently, the shear in the primal corresponds to a shear in the opposite direction in the Fourier domain. The frequency content of an object at velocity s is on the line of slope s going through the origin. A range of velocities −S≦s≦S corresponds to a double-wedged in the Fourier domain. This is similar to the link between depth and light field spectra (Chai, J., Tong, X., Chan, S., and Shum, H., “Plenoptic sampling,” SIGGRAPH, 2000; Isaksen, A., McMillan, L., and Gortler, S. J., “Dynamically reparameterized light fields,” SIGGRAPH, 2000). This double-wedged is the frequency content that we strive to record. Areas of the Fourier domain outside it correspond to faster motion, and can be sacrificed.
Consider a given light integration curve f and its 2D trace k(x,t) in space time, where k(x,t) is non zero only at x=f(t) (
For example, a static camera has a kernel k that is a box in time, times a Dirac in space. Its Fourier transform is a sinc in time, times a constant in space (
In summary, we have reduced the problem to designing an integration curve whose spectrum {circumflex over (k)} has the highest possible Fourier coefficients in the double-wedge defined by a desired velocity range.
Slicing: We now show that for each vertical slice of the Fourier doubled wedge, we have a fixed bandwidth budget because of conservation of energy in the spatial domain. That is, the sum of the squared Fourier coefficients for a given spatial frequency ωx is bounded from above.
When studying slices in the Fourier domain, we can use the slicing theorem. First consider the vertical Fourier slice {circumflex over (k)}0 going through (0,0). In the primal space time, this Fourier slice corresponds to the projection along the horizontal x direction.
{circumflex over (k)}
0(ωt)kp(t)=∫xk(x,t)dx
And using the shifting property, we obtain an arbitrary slice for a given ωx using
{circumflex over (k)}ωx(ωt)∫xk(x,t)e−2πiω
which only introduces phases shifts in the integral.
Conservation of energy: We have related slices in the Fourier domain to space-only integrals of our camera's light integration curve in space-time. In particular, the central slice is the Fourier transform of kp(t), the total amount of light recorded by the sensor at a given moment during the exposure. Conservation of energy imposes
k
p(t)≦1 (8)
Since k is non-zero only during the 2T exposure time, we get a bound on the square integral
∫tkp(t)2dt≦2T (9)
This bound is not affected by the phase shift used to extract slices at different ωx.
Furthermore, by Parseval's theorem, the square integral is the same in the dual and the primal domains. This means that for each slice at a spatial frequency ωx,
The squared integral for a slice is bounded by a fixed budget of 2T. In order to maximize the minimal frequency response, one should use a constant magnitude. Given the wedged shape of our velocity range in the Fourier domain, we get
where S is the absolute maximal slope (speed). This upper bound is visualized in
When one wants to cover a broader range of velocities, the budget must be split between a larger area of the Fourier domain and overall signal-noise ratio is reduced according to a square root law.
Discussion of Different Cameras
Applicants have shown that in a traditional static camera, the light integration curve in space-time k(x,t) is a vertical box function. Performances are perfect for the ωt=0 line corresponding to static objects, but degrade according to a sinc for lines of increasing slope, corresponding to higher velocities.
The flutter-shutter approach adds a broad-band amplitude pattern to a static camera. The integration kernel k is a vertical 1D function over [−T,T] and the amount of recorded light is halved. Because of the loss of light, the vertical budget is reduced from 2T to T for each ωx. Furthermore, since k is vertical, its Fourier transform is constant along ωx. This means that the optimal flutter code must have constant spectrum magnitude over the full domain of interest (
Since {circumflex over (k)} is constant along ωx, this bound applies to all ωx. As a result, for all band frequencies |ωx|<Ωmax, {circumflex over (k)} spends energy outside the slope wedge and thus does not make a full usage of the vertical {circumflex over (k)}ωx, budget.
The parabolic integration curve attempts to distribute the bandwidth budget equally for each ωx slice (
On the other hand, achieving a good PSF for all −S≦s≦S implies that
(otherwise, from Eq 6 the PSF won't include an infinite spike). Using Eq 13, applicants can conclude that if the exposure was infinitely long
and the infinite parabola has the same falloff as the upper bound. Of course, the upper bound is valid for a finite exposure, and we can relate the infinite parabola to our finite kernel by a multiplication by a box in the spatial domain, which is a convolution by a sinc in the Fourier domain. Thus, the parabola curve of finite exposures approaches the upper bound, in the limit of long exposure times. The intuitive reason why the parabolic camera can better adapt to the wedged shape of the Fourier region of interest is that its kernel is not purely vertical, that is, the sensor is moving. A parabola in 2D contains edge pieces of different slopes, which corresponds to Fourier components of orthogonal orientation.
In summary, in the special case of 1D motions, if one seeks the ability to reconstruct a given range of image-space velocities, with minimal degradation to the reconstructed image for any velocity, the parabolic light integration curve is near optimal. On the other hand, a fluttered shutter can handle all motion directions, albeit at the cost of motion identification and image segmentation.
Simulation: To visualize these tradeoffs, in
A static camera, the flutter shutter camera, and a parabolic motion camera (the present invention) each offer different performance tradeoffs. A static camera is optimal for photographing static objects, but suffers significantly in its ability to reconstruct spatial details of moving objects. A flutter shutter camera is also excellent for photographing static objects (although records a factor of two less light than a full exposure). It provides good spatial frequency bandwidth for recording moving objects and can handle 2D motion. However, to reconstruct, one needs to identify the image velocities and segment regions of uniform motion. Motion-invariant photography of the present invention (e.g., parabolic motion camera) requires no speed estimation or object segmentation and provides nearly optimal reconstruction for the worst-case speed within a given range. However, relative to the static camera and the flutter shutter camera, it gives degraded reconstruction of static objects. While the invention method is primarily designed for 1D motions, we found it gave reasonable reconstructions of some 2D motions as well.
Embodiments of the present invention 11 are thus as illustrated in
In particular, the automated control assembly 101 operates the camera 100 to produce a subject image having both moving objects 10 and static objects 20. First as shown at step 201 in
The deconvolution processor 105 may be within the camera 100 processing during image exposure (near real time) or external to the camera 100 processing subsequence to image exposure. Deconvolution processor (or similar engine) 105 employs deconvolution algorithms and techniques known in the art. Example deconvolution techniques are as given in Levin, A., Fergus, R., Durand, F., and Freeman, W., “Image and depth from a conventional camera with a coded aperture,” SIGGRAPH, 2007; and Lucy, L., “Bayesian-based iterative method of image restoration,” Journal of Ast., 1974, both herein incorporated by reference.
The reconstructed image 112 showing moving objects 10 and static objects 20 in an unblurred state is produced (generated as output).
Experiments
While camera stabilization hardware should be capable of moving a detector with the desired constant acceleration (parabolic displacement) inside a hand-held camera, applicants chose to use larger scale structures for an initial prototype, and approximate sensor translation using a rotation of the entire camera. The hardware shown in
x(θ)=cos(θ)(c−bθ2)
y(θ)=sin(θ)(c−bθ2) (14)
In applicants' experiments, c=8 cm, b=0.33 cm. The cam 67 rotates at a constant velocity, pushing the lever arm 65 to rotate the camera 61 with approximately constant angular acceleration, yielding horizontal motion with the desired parabolic integration path in space-time. For a fixed cam size, one can increase the magnitude of the parabola by moving the cam 67 closer to the camera 61. Applicants place a static camera next to the rotating camera 61 to obtain a reference image for each moving-camera image. A microcontroller synchronizes the cam 67 rotation and the camera shutters. In order to reduce mechanical noise, the exposure length of the system was set to 1 second. This relatively long exposure time limits the linear motion approximation for some real-world motions. To calibrate the exact PSF produced by the rotating camera 61, applicants captured a blurred image I of a calibration pattern. Applicants also captured a static image I0 of the same pattern and solved for the PSF φ minimizing the squared convolution error: φ=argmin ∥I0−φ*I∥2.
Results
The deconvolution results presented herein were achieved with the sparse deconvolution algorithm of Levin, A., Fergus, R., Durand, F., and Freeman, W., “Image and depth from a conventional camera with a coded aperture,” SIGGRAPH, 2007 (incorporated herein by reference). Comparable, but slightly worse, results can be obtained using the Richardson-Lucy deconvolution algorithm (see Lucy, L., 1974, cited above).
a-c present deblurring results on images captured by the invention camera 100, 61. For each example,
Applicants are encouraged by the deconvolution results on some images even with substantial non-horizontal motions. One possible explanation for the results is the aperture effect, the ambiguity of the 2D motion of locally 1-dimensional image structures, such as edges and contours. The velocity component normal to the edge or contour is determined from the image data, but the parallel component is ambiguous. Local image motion that could be explained by horizontal motions within the range of the camera motions should deconvolve correctly, even though the object motions were not horizontal.
Note that the static object resolution in applicants results decreases with respect to the static camera input, as applicant uniformly distribute the bandwidth budget over velocities range.
Motion deblurring from a stationary camera is very challenging due to the need to segment the image by motion and estimate accurate PSFs within each segment.
The present invention results obtained spatially uniform deconvolution of images (
In
Accordingly, the present invention suggests a solution that handles motion blur along a 1D direction. In the invention system 11, the camera 100 (
The teachings of all patents, published applications and references cited herein are incorporated by reference in their entirety.
While this invention has been particularly shown and described with references to example embodiments thereof, it will be understood by those skilled in the art that various changes in form and details may be made therein without departing from the scope of the invention encompassed by the appended claims.
For example, the above description mentions parabolic or other motion of the camera. This motion may be manually produced by the user (photographer) in some embodiments and mechanically automated, such as by a controller assembly 101, in other embodiments.
Further, the controller 101 and deconvolution processor 105 may be executed by one CPU (digital processing unit) or chip in camera 100 or may be separate computers/digital processing systems, either stand alone or networked. Common computer network communications, configurations, protocols, busses, interfaces, couplings (wireless, etc.) and the like are used. The network may be a wide area network, a local area network, a global computer network (e.g., Internet) and the like.
Fields of application may then include:
(a) medical imaging at hospitals, clinics, care profession's office (e.g., dentist, pediatrician, etc.), mobile unit, etc;
(b) arial imaging of vehicles or vessels in various terrain maneuvers;
(c) monitoring systems at airports, secured areas, security locations, or public/pedestrian throughways; and
(d) toll booth imagery of traveling vehicle license plates or similar check points where a moving subject is photographed for identity verification or similar purposes.
Other applications and uses are within the purview of one skilled in the art given this disclosure.
The invention was supported, in whole or in part, by the following grants: HM 1582-05-C-0011 from the National Geospatial Intelligence Agency,IIS-0413232 from the National Science Foundation, andCAREER 0447561 from the National Science Foundation. The government has certain rights in the invention.