US 7324706 B2 Abstract A system and method for representing a two-dimensional spatial transformation that describes the transformation by an inverse mapped grid data set. The grid data for each coordinate is surface fitted on an array of rectangular patches defined in the output space using numerical techniques. Error analysis determines whether a finer mesh resolution is required for surface fitting. The spatial transformation is then defined by the array of rectangular surface patches and the set of surface coefficients such that the spatial transformation can be executed through evaluation of the surface polynomials. The two-dimensional surface polynomial representation allows the transformation to be easily adjusted for scale changes and zooming and panning effects.
Claims(44) 1. An electronic system for implementation of a two dimensional image transformation in a single pass, the transformation transforming an input image having input pixel coordinates, to an output image having output pixel coordinates, said system comprising:
(a) a geometry input interface for obtaining geometric parameters that define the transformation and which include lens parameters describing display optics, projection angles, display panel geometry for flat screen and curved screen, and user specified parameters;
(b) a grid transformation generator, coupled to said geometry input interface, for generating a grid data transformation that maps the output pixel coordinates onto the input pixel coordinates;
(c) a patch geometry generator, coupled to said grid transformation generator, for dividing the output pixel coordinate space into a number of corresponding patches according to an underlying geometry, each patch having an associated grid data set, said patch geometry generator determining the boundaries of the output space patches;
(d) a surface function estimator, coupled to said patch geometry generator, to parameterize the grid data set for each patch as a surface functional represented by surface coefficients; and
(e) an output interface coupled to the surface function estimator to store the surface coefficients.
2. The system of
3. The system of
4. The system of
5. The system of
6. The system of
7. The system of
8. The system of
9. The system of
10. The system of
11. The system of
12. The system of
13. The system of
14. The system of
15. The system of
16. The system of
17. The system of
18. The system of
19. The system of
20. The system of
21. The system of
20.22. The system of
23. A method for representing a two dimensional image transformation to perform in a single pass, said transformation transforming an input image having input pixel coordinates to an output image having output pixel coordinates, said method comprising:
(a) obtaining geometric input parameters that define the transformation and that include lens parameters describing display optics, projection angles, display panel geometry for flat screen and curved screen, and user specific parameters;
(b) generating a grid data transformation based on said geometric input parameters, to map the output pixel coordinates onto the input pixel coordinates;
(c) dividing the output pixel coordinate space into a number of corresponding patches according to an underlying geometry, each patch having an associated grid dataset and determining the boundaries of the output space patches;
(d) parameterizing said grid data transformation, in each of the patches, as a surface functional represented by surface coefficients; and
(e) storing said surface coefficients.
24. The method of
25. The method of
26. The method of
27. The method of
28. The method of
29. The method of
30. The method of
31. The method of
32. The method of
33. The method of
34. The method of
35. The method of
36. The method of
37. The method of
38. The method of
39. The method of
40. The method of
41. The method of
42. The method of
43. The method of
42.44. The method of
Description This invention relates to digital image data transformations, and more particularly to the representation of two-dimensional spatial transformation of digital image data. Most image processing systems can be considered in part as a spatial transformation system. In two-dimensional (2D) image processing, an image is generated by assigning a “color” value to every pixel in the 2D output space according to that pixel's relationship to some input data (possibly 3D). Introducing a coordinate system on the input and output data spaces, this relationship is conveniently expressed as a spatial mapping. The spatial mapping may be implicit in the design of the image processing system (lens arrangement, etc.), or may be explicitly specified to obtain a certain effect. Image warping, a term referring to a mapping between 2D input and output images or spaces, is often applied to correct optical distortions and various artifacts, such as aberrations, that are common in image capture and image display devices. Other uses of image warping include special effects, animation, image stitching and general geometric transformations. In general, image warping need not be a spatial transformation, however, the emphasis here is on spatial mappings. Many electronic image distortion or transformation algorithms are designed with the primary goal to simplify the hardware implementation. This objective often leads to restrictions on the complexity of the spatial transformation or unrealistic descriptions of the transformation. For example, a method often used in image warping is the two-pass method. Specific warping systems based on the two-pass method include the Ampex device detailed in U.S. Pat. No. 4,472,732 to Bennett et al. The method disclosed is well suited for hardware implementations of real-time image processing systems and decomposes a 2D map into a series of 1D maps, which require only 1D filtering or re-sampling. Re-sampling in 1D is much simpler than in 2D and allows high optimization of the hardware using various architectures. However, the two-pass method is prone to the bottleneck effect, i.e. large compression in intermediate image, leading to loss of data. In the extreme case, complete data loss can occur, e.g. where an area is compressed to a line. This effect restricts the type of geometric transformations that can be applied. Other problems with the two-pass method involve generating the intermediate pass data. Various enhancements to the two-pass method have been attempted in order to resolve these issues, as discussed in U.S. Pat. No. 5,175,808 to Sayre and U.S. Pat. No. 5,204,944 to Wolberg et al., these methods are based on a pixel-by-pixel description (i.e. look-up tables). A pixel-by-pixel description requires large storage spaces and more importantly, does not allow simple means for additional data manipulations. Once an image is warped, a second transformation, say a zoom operation, may be needed. In a pixel-by-pixel description, the entire grid has to be re-generated for a zooming warp, which can be inefficient, especially if zooming is a feature that is regularly used. Other algorithms for spatial transformations, not necessarily based on the two-pass method, are limited to certain mapping types, such as rotations, linear scaling, affine, and perspective transforms as described in U.S. Pat. No. 4,835,532 to Fant, U.S. Pat. No. 4,975,976 to Kimata et al., U.S. Pat. No. 5,808,623 to Hamburg, and U.S. Pat. No. 6,097,855 to Levien. Some prior art methods also tend to identify the mathematical coordinate spaces with the physical memory spaces, which means that in a hardware implementation the transformations are restricted by the organization of the memory structure. Furthermore, most warping algorithms do not provide a simple format for applying independent transformations to different parts of an image. Complicated mappings, such as a change in topology (e.g. from circular image to rectangular image), require independent mappings for different regions. These limitations can be eliminated using 2D representations, i.e. single-pass, making use of 2D filtering. Examples of systems based on 2D representations include the video processor and display unit of U.S. Pat. No. 5,384,912 to Orginc et al. and the integrated circuit TMC2302A manufactured by Fairchild Semiconductor. However, these prior art methods are based on a restricted subset of 2D transformations, hence they cannot represent general 2D mappings. In particular, neither of these systems provides the means for applying independent transformations to different parts of a single image. The present invention provides in one aspect, an electronic system for implementation of a two dimensional image transformation in a single pass, the transformation transforming an input image having input pixel coordinates, to an output image having output pixel coordinates, said system comprising: -
- (a) a geometry input interface for obtaining geometric parameters that define the transformation and which include lens parameters describing display optics, projection angles, display panel geometry for flat screen and curved screen, and user specified parameters;
- (b) a grid transformation generator, coupled to said geometry input interface, for generating a grid data transformation that maps the output pixel coordinates onto the input pixel coordinates;
- (c) a patch geometry generator, coupled to said grid transformation generator, for dividing the output pixel coordinate space into a number of corresponding patches according to an underlying geometry, each patch having an associated grid data set, said patch geometry generator determining the boundaries of the output space patches;
- (d) a surface function estimator, coupled to said patch geometry generator, to parameterize the grid data set for each patch as a surface functional represented by surface coefficients; and
- (e) an output interface coupled to the surface function estimator to store the surface coefficients.
In another aspect, the present invention presents a method for representing a two dimensional image transformation to perform in a single pass, said transformation transforming an input image having input pixel coordinates to an output image having output pixel coordinates, said method comprising: -
- (a) obtaining geometric input parameters that define the transformation and that include lens parameters describing display optics, projection angles, display panel geometry for flat screen and curved screen, and user specific parameters;
- (b) generating a grid data transformation based on said geometric input parameters, to map the output pixel coordinates onto the input pixel coordinates;
- (c) dividing the output pixel coordinate space into a number of corresponding patches according to an underlying geometry, each patch having an associated grid dataset and determining the boundaries of the output space patches;
- (d) parameterizing said grid data transformation, in each of the patches, as a surface functional represented by surface coefficients; and storing said surface coefficients.
Further details of different aspects and advantages of the embodiments of the invention will be revealed in the following description along with the accompanying drawings. In the accompanying drawings: Reference is first made to Warp system Geometry input interface Grid transformation generator Referring now to As shown in These equations state that a pixel in the output image, with coordinates (X,Y), is mapped via the spatial transformation F=(F
There are two common conventional approaches to defining a spatial transform. First, explicit functional forms for the mappings (F The grid dataset relation model is considered to be the “ideal” representation of the spatial transformation (In practice, the grid data may contain noise, in which case “ideal” is itself an approximation). This description may be very complicated however, with the dataset (or functions) varying greatly from one region of the image to another. An image transformation system based directly on such a representation is hard to implement in software or hardware. When the grid dataset {(X A simplification often made prior to functional representation is to separate the data for a two-pass processing. As is conventionally known, the main benefit of using a separation is that the corresponding hardware implementation is simplified. Separating the scaling data into vertical and horizontal passes (or datasets), allows for the use of 1D filtering. However, this sacrifices image quality and, in addition, not all mappings can be separated. Given the current advances in memory space and speed, efficient single-pass implementations of 2D filtering can now be implemented. One example of such implementation is the sxT2 chip (manufactured by Silicon Optix Inc. of San Jose, Calif.). Thus the prior art hardware advantages from separation of two-pass processing are replaced by the more important goals of maintaining image quality and transformation flexibility. The method of this invention does not use separation, yet it allows an efficient hardware implementation and retains full flexibility to represent general 2D mappings. As the method is single-pass, the resulting image quality (when using a 2D filter) is superior to that of a two-pass method. In order to fully appreciate the usefulness of the present invention, it is important to understand scan-line processing that is commonly used to evaluate the 2D transformation at the output space in order to simplify the hardware processing. The transformation could be a two-pass as in the prior art, or a single-pass as in the present invention. In scan-line processing, output pixels are generated sequentially along rows (horizontally) and/or columns (vertical). After a row/column is fully generated, processing proceeds to the next row/column. A variation on scan-line processing is to first process a section of each row/column, say section The main limitation of using scan-line processing at the output is that memory access (of pixel data needed in filtering) at the input can be random. Nearby pixels in the output space (which are processed nearly one after the other) may need data in the input space that is spread out over a large region, making input memory access inefficient. This can be a problem in filtering (leading to slower processing and longer time delay) but not so in evaluating the surface polynomials describing the transformation, which is the focus of the present invention. In the present invention, the surface polynomials are defined on the output space and do not need access to input pixel data. For scan-line processing, a spatial transformation needs to be defined for all pixels in the output space. This means going from a dataset description to a functional description that best approximates the ideal mapping for every pixel (recall that for the sampled pixels, the ideal mapping is given by the known grid dataset relation). For regions where a mathematical model is not well defined, a functional description may extrapolate the well-defined data or map such regions to background. This latter behavior is acceptable since ill-defined regions for a mathematical model always correspond to background pixels. Coupled to patch geometry generator Both these problems can be resolved by surface fitting the grid data for both coordinates. Surface fitting, which applies to both single-pass and two-pass methods, is the natural way of describing a 2D spatial transformation. It gives an accurate description that simultaneously incorporates the geometric behavior in both directions. Surface fitting, when achieved by the polynomial method, means to fit the polynomial coefficients that describe the single direction scan-line fitting. Although a surface gives a full 2D description of the mapping, the evaluation of the surface can still proceed in a scan-line order, vertically or horizontally. Thus a surface based description can also be implemented using an efficient scan-line algorithm. Referring now to A more detailed description of the particular implementation of a polynomial based approach will now be discussed. Polynomial functions (terms of the form x
Here, the coordinates on which the surfaces are evaluated span the entire patch, and not merely the sampled pixels in the datasets (the subscript c denotes computed). The orders of the surface are K in the x-direction and L in the y-direction, which can be different. The surface coefficients {S Surface fitting makes the transition from a grid-based representation, i.e. {(u Once the surfaces are obtained, for each output coordinate point in the 2D dataset, error analysis stage The process of optimizing the patch geometry, in implemented examples of the present invention, is done via gradient search and/or random search. The search is made in the vector space of the patch boundary positions. For an M×N array of patches, there are M+1 y boundaries (vertical) and N+1 x boundaries (horizontal), giving a dimensionality of M+N+2 for the vector space. In a gradient search, a starting configuration (vector) of patch boundaries is chosen, denoted The random search randomly selects boundary vectors In another example of the present invention, an efficient and robust approach to error reduction involves combining the gradient and random search. The random search is first used to obtain a vector, Some important points regarding the above surface representation need be emphasized. If necessary, each patch can be treated as an independent output coordinate space, and the dataset for that patch as an independent 2D transformation in itself. In particular, each patch can be independently fitted, which implies that the output images need not be continuous. Examples of discontinuous and continuous surface fits on patches are shown in For the more common situation of maintaining continuity of the image across patch boundaries, basis functions that explicitly allow or impose continuity constraints can be used. The most well known functions for controlling continuity in 2D are the B-spline and Bezier surfaces. Both types of surfaces can be used to obtain a required degree of continuity (in the mathematical sense of C The complete representation of a general 2D spatial transformation is given by the following data, which applies to every patch: - 1) Geometry of the patch (absolute position of patch origin, patch size)
- 2) Surface coefficients describing surface fit to grid data relation
This representation provides a unified format for defining 2D mappings. The representation is geared towards real-time hardware implementations of 2D image transformation systems. In a hardware implementation, the surface polynomials will be evaluated in scan-line order, with the position and derivative information being passed to a processing filter. (The derivative is easily extracted from the position surface.) Since the mappings are given in closed functional form, full geometric data (various order derivatives) is readily available for a filtering stage. As the complexity of the map increases, the number of patches, and hence the amount of data contained in the (1) and (2) representation above increases. The data scales to the complexity of the mapping, without any changes to the overall format. An increase in the number of patches will also serve to reduce fitting error. In principle, the maximum fitting error can be reduced to an arbitrary small level by continuously subdividing the patch array. However in practice, restrictions on how much space (memory) is available to store the data (each patch has associated with it data components (1) and (2)), will limit the number of patches. Balancing memory requirements versus error minimization (tolerance level) will determine the final patch array size. Most 2D transformations of practical interest do not require a high-resolution patch mesh. To quantify these size and error issues, several 2D mappings were studied using the above format. They included (i) common lens distortions, such as the radial pincushion and barrel distortions, (ii) projection maps, such as the vertical/horizontal keystone correction and projecting onto curved surfaces, (iii) rotations combined with linear scaling, (iv) combinations of the above; to more complicated maps such as (v) arc raster maps, (vi) correcting wide-angle/360 degrees/panoramic images (obtained using fisheye lenses or special 360 degrees imaging systems). A polynomial surface of degree 3 (K=L=3) was used, which implies 16 surface coefficients per patch. An error limit of 0.5 pixels was set. For the transforms (ii)-(iv), a maximum of four patches were needed. This amounts to <=128 surface coefficients to define the entire the map. If a surface coefficient is stored as a four-byte float, the data size amounts to <=512 bytes. This is a very reasonable number and it is easily accommodated by on-board/on-chip memories. For transforms (i) and (v), a maximum total (for both coordinates) of 26 patches were needed, giving a data size of <=1.625 Kbytes, again easily handled by current on-board/on-chip memories. For transform (vi), a perspective correction to a wide 90 degrees field of view requires a maximum total of 18 patches, or <=1.125 Kbytes. If the full functionality of the representation is used, then complicated transformations can be applied to images obtained from (vi). For example, images from two 180 degrees fisheyes can be transformed to a stitched 360 panoramic view, plus, say two zoomed up 90 degrees views of specific regions, corrected for perspective. Such a transformation corresponds to approximately six maps (360/90+2), each transforming a specific 90 degrees region, which gives a data size of <=6.75 Kbytes. Such special wide-angle/360 based transformations have gained popularity in the recent years, especially in security applications. Accordingly, it is clear from these results that the method presented above is capable of representing general 2D transformations, with reasonable data sizes (sizes scale linearly with complexity) and sub-pixel accuracy. Further hardware optimization can be achieved by complementing the image transformation data with bounding box data. Bounding box data, generated by the bounding box generator Not all background pixels are identified in this manner, since the non-background pixel boundary is usually not rectangular. However, with a finer division of bounding boxes, possibly more than one box per patch, this boundary can be closely approximated with rectangular bounding boxes, at the expense of more storage (require for the bounding box coordinates). For most transformations, bounding box data is not necessary, and for the extreme transformations one bounding box per patch is sufficient. If bounding box data is not used, a more standard approach can be used to eliminate unnecessary processing. In the standard approach, the surface is evaluated for all output pixels and a check is made to determine whether the resulting coordinates lie within the input space. If a coordinate is within the input space, then processing proceeds as normal, that is, the output pixel color value is determined by a 2D filtering. If the coordinates are outside, then the pixel is simply assigned the background color, and the 2D filter is not executed. Here, although the surface has to be evaluated, gains from the fact that the filter will not process these data can be considerable. In addition, the non-background pixel boundary can be very accurately determined, since this boundary is fully specified by the surface map onto the input space. Image transformation of warp system As shown in The constants {r
Comparing with the standard form:
Therefore, to adjust for a change in input or output resolution, all coefficients are scaled by a factor. This is a relatively simple operation with no re-fitting or interpolation needed. It should be understood, however, that the patch geometry (i.e. patch size and absolute position of patch origin) will also have to be appropriately scaled by warp system Consider a transformation, called the Base Map ( Mathematically, the first step in zooming is a multiplication operation, and the second step is a shift or addition operation. The absolute positions in the base and new output spaces are related by:
_{A }
x _{A} ″=Kx _{A} −K _{A } (12)
or x _{A}=(x _{A} ″+ _{A})/K
x _{A}=(y _{A} ″+ _{A})/K (13)
Before these equations can be substituted into the surface expressions, we need to convert them into relative positions. This is less trivial, because the second step introduces additional complications not previously seen in the simpler resolution change operation. Shifting the origin in the scaled image and extracting a window of size K The top left corner (denoted by an index of 1) and bottom right corner (denoted by an index of 2) of the nth patch in the base map are labeled as follows (these are absolute positions, though the subscript A is omitted to simplify notation):
These points are mapped to the following new corner points in the new spaces:
The new patch dimensions are given by:
_{1})−Maximum(x1_{n}″,0) (new patch width)
H(n)=Minimum(y2_{n} ″, K _{1})−Maximum(y1_{n}″,0) (new patch height) (16)
If either the new width or height for the patch is <=0, then the patch is excluded from the new map. If both the width and height are greater than zero, then the patch is included in the zooming transformation. The included patch's absolute position (i.e. the top left corner) needs to be re-computed, since the patch may be only partially included. The new positions are given by:
_{n}″=Maximum(x1_{n}″,0)
1_{n}″=Maximum(y1_{n}″,0) (17)
Every patch that is retained has its new patch geometry (position and size) given by:
Knowing the new patch geometries, equations (12) and (13) can be converted to the relative origin representation on the new output space (dropping the patch index):
Lastly, these can be substituted into the surface expressions for the base map
Expanding equations (20), and comparing them with the standard form, the new surface coefficients can be extracted in a straightforward manner. These coefficients, combined with the patch geometries, completely define the zooming transformation. Data rearrange stage A similar technique can be used for evaluating the surfaces. A surface can be rewritten as:
The surface is treated as a polynomial in x, with the coefficients of the x-polynomial being polynomials in y. Every polynomial (5 in total) is evaluated using Horner's method. For every horizontal scan-line (row), the y-polynomials need to be evaluated only once (per patch). Expression (22) can also be used for vertical scan-lines. In this case, the y-polynomials should be evaluated and stored for the first vertical scan-line (column) of each patch. These can then be used for the remaining vertical scan-lines in the patch, for they are independent of the x-positions of the scan-lines. This increases processing speed and treats the transformation as 1D position polynomials directly dependent on x, with an implicit dependence on y, as expressed by the position coefficients themselves being polynomials of y. Alternatively the surface can be treated as a polynomial in y, with the coefficients of the y-polynomial being polynomials in x. Depending on the implementation, one or the other approach may be better suited to the specifics of the memory access/storage and arithmetic units. Another standard technique for evaluating polynomial expressions is the use of forward differences. Forward difference evaluations are prone to accumulation errors however. Their main benefit is a reduction in hardware complexity (specifically reducing multipliers and the possibility of using fixed point). If the patch sizes are small in the scan line direction and reasonable bits of numerical precision are available, then the accumulation error may be small. At this point surface data and patch data are all generated. These data are analyzed at steps Once the error analysis step is satisfied, at step At step Warp system Warp system Warp system Warp system Warp system Warp system One particular implementation of warp system In another implementation, warp system The method described above can be expanded to include multiple pass to support layering of image surfaces. The image data may include depth information that is re-sampled as per image luminance and chrominance data. The depth information is used in the layering process to determine visibility or occlusion of each pixel. The surfaces need not be of the same size and can be overlapping or non-overlapping. As will be apparent to those skilled in the art, various modifications and adaptations of the structure described above are possible without departing from the present invention, the scope of which is defined in the appended claims. Patent Citations
Non-Patent Citations
Referenced by
Classifications
Legal Events
Rotate |