Computing devices (e.g., computers, tablets, smart phones, digital cameras, wearable devices, etc.) provide numerous ways for people to capture, create, share, view, and otherwise interact with numerous types of digital content. As such, users are increasingly using computing devices to capture different types of digital images or photographs (or simply “digital photos”). For example, many computing devices enable users to capture and store panoramic digital images (or simply “panoramic images”).
In many cases, computing devices capture a typical panoramic image by taking multiple images and stitching those images together in an elongated panoramic image. For example, many conventional systems for generating panoramic images involve a user holding and moving a camera, or other image capturing device (e.g., a mobile device), along a fixed line over a duration of time. Where the user fails to stay exactly along the fixed line or moves the camera at intermittent speeds resulting in bad alignment, a resultant panoramic image often includes a non-uniform shape that, results in an elongated image having various irregularities along the boundary of the resultant panoramic image. In addition to the bad alignment, another reason for shape irregularity is that panoramic images are often projected onto spherical or cylindrical surfaces that cause nonlinear transform of the boundaries. Therefore, such projected panoramic image often have an irregular shape.
Many conventional systems attempt to correct an irregular shape of a panoramic image by cropping or adding content to a panoramic image to generate an image that conforms to a predefined shape. For example, some conventional systems simply crop or add content to a panoramic image to cause the irregular shape of the panoramic image to conform to a rectangular shape. Simply cropping a panoramic image, however, often removes important features from the panoramic image. Additionally, adding content often causes portions of the panoramic image to include content that fails to blend with the rest of the image or otherwise detracts from the modified image.
As an alternative to cropping or adding content, many conventional systems cause a panoramic image to conform to a shape by warping portions of the panoramic image to conform to the predetermined shape. Conventional systems for warping a panoramic image, however, often cause noticeable distortion to various portions of the image. As a result, content within the panoramic image often gets stretched or distorted and disrupts the content of the panoramic image.
To overcome disruption caused by warping images, some conventional systems utilize content-aware warping techniques that analyze content within a panoramic image to avoid causing noticeable distortion when warping the panoramic image. For example, many conventional systems analyze pixels of a panoramic image to identify buildings, people, faces, objects, or other visual features within the content of a panoramic image and avoid stretching or modifying those regions of the panoramic image in such a way that disrupts those identified features of the image. Utilizing content-aware warping techniques, however, involves analyzing content of an image, and often becomes computationally prohibitive depending on the complexity of the individual images being stitched together. As such, many computing devices experience difficulty or take a long time to implement content-aware warping techniques. Furthermore, where an image includes dense or clustered features within the captured image, many content-aware warping techniques fail to warp the image without causing noticeable distortion throughout the panoramic image.
These and other problems exist with regard to modifying a panoramic image.
Embodiments of the present disclosure provide benefits and/or solve one or more of the foregoing and other problems in the art with systems and methods for warping panoramic images. In particular, the disclosed systems and methods generate an enhanced panoramic image without regard to image content by warping a panoramic digital image having skewed boundaries to fit a predetermined shape.
For example, the systems and methods disclosed herein receive an input panoramic digital image (or simply “panoramic image”) that has skewed boundaries. The systems and methods further generate a boundary of points around the skewed edges of the panoramic image and generate a mesh grid having interior points throughout the panoramic image in accordance with a position of the points around the edges of the panoramic image. In particular, the systems and methods described herein generate the mesh grid by interpolating interior points throughout an interior of the mesh grid based on a relative position of the pounds around the boundary of the mesh grid and without regard to the content of the panoramic image.
Further, upon generating the mesh grid, the systems and methods described herein generate an enhanced panoramic image by warping the panoramic image to fit the predetermined shape. In particular, the systems and methods described herein warp the generated mesh grid and underlying pixels of the panoramic image to fit the predetermined shape. Further, the systems and methods described herein reduce over-warping localized portions of the panoramic image by limiting how much individual cells of the mesh grid are warped. In particular, the systems and methods distribute warping of the panoramic image evenly across the cells of the mesh grid to avoid over-warping localized regions of the panoramic image.
Additional features and advantages will be set forth in the description which follows, and in part will be obvious from the description, or may be learned by the practice of such exemplary embodiments.
Various embodiments will be described and explained with additional specificity and detail through the use of the accompanying drawings in which:
One or more embodiments of the present disclosure include an image warping system that warps a panoramic digital image (or simply “panoramic image”) to fit a predetermined shape. The image warping system generates an enhanced panoramic image with a uniform shape from a panoramic image with a skewed or otherwise irregular shape. More particularly, the image warping system generates the enhanced panoramic image in a content-unaware manner without skewing portions of the panoramic image in a way that disrupts content within the panoramic image. Content-unaware, as used herein, refers to features and functionality of the present disclosure that are independent of content displayed by a panoramic image. For example, warping a panoramic image in a content-unaware manner involves warping a panoramic image without consideration of underlying pixels or visual features (e.g., buildings, people, faces, objects) of the panoramic image. As another example, identifying boundary points and/or interior points of the panoramic image in a content-unaware manner involves identifying points around and throughout the panoramic image without consideration of underlying pixels of visual features of the panoramic image.
As will be explained in further detail below, the image warping system causes the panoramic image to conform to the predetermined shape by generating a mesh grid having cells evenly distributed throughout the panoramic image with the skewed or otherwise irregular shape. The image warping system subsequently warps the mesh grid and underlying panoramic image to the predetermined shape.
More particularly, the image warping system generates a mesh grid including cells that are evenly distributed across the panoramic image with the skewed or otherwise irregular shape. Thus, the mesh grid also includes a skewed or otherwise irregular shape. The image warping system warps the mesh grid and the underlying panoramic image to fit a predetermined shape (e.g., a rectangle). In warping the mesh grid and underlying image, the image warping system reduces disruption of the content within the panoramic image by limiting how much individual cells of the mesh grid are warped. In particular, the image warping system warps the mesh grid and underlying panoramic image to fit the predetermined shape while distributing distortion of the panoramic image across all cells of the mesh grid. In this way, the image warping system prevents overly distorting localized regions of the panoramic image.
As mentioned above, the image warping system generates a content-unaware mesh grid for the panoramic image. In one or more embodiments, prior to initializing the mesh grid, the image warping system preprocesses the panoramic image by cropping, scaling, or otherwise modifying the panoramic image to serve as a template for generating the mesh grid. For example, in one or more embodiments, the image warping system crops an input image to a bounding box of solid pixels and/or scales the image down to a smaller resolution. Further, where corners of the panoramic image are not already known, the image warping system can identify corners of the panoramic image to use as corner points of the content-unaware mesh grid.
In one or more embodiments, the image warping system initializes the mesh grid by sampling boundary points along the outside edges of the panoramic image having skewed boundaries. For example, where corner points are not previously known, the image warping system identifies corner points of the panoramic image and generates boundary points that are evenly distributed between the corner points of the panoramic image. The image warping system utilizes the boundary points to further generate interior vertex points of the mesh grid. In particular, the image warping system sets each of the boundary points as control points and interpolates coordinates for interior vertex points of the mesh grid based on the boundary points. For example, based on the number and position of the boundary points, the image warping system determines a number of interior vertex points that define a number of rows and columns.
Once the mesh grid is generated, the image warping system applies the mesh grid to the panoramic image and warps the mesh grid and underlying panoramic image to a new boundary having a predetermined shape (e.g., a rectangle). For example, as will be described in greater detail below, the image warping system warps the mesh grid to fit a bounding box having the predetermined shape. In addition, the image warping system utilizes a global warping process that distributes distortion of the mesh grid across all of the cells of the mesh grid. For example, the image warping system warps the mesh grid while encouraging as similar as possible a transform to individual mesh cells across the entire mesh gird. In other words, the image warping system stretches the mesh grid to fit the bounding box (or other predetermined shape) by stretching the boundaries of the mesh grid to the bounding box and distributing the distortion of the cells throughout the mesh grid. The distribution of the distortion of the cells advantageously minimizes deviations from a similarity transform applied to the cells that make up the mesh grid. In this way, the image warping system minimizes localized warping of the panoramic image that would otherwise disrupt the content of the panoramic image.
As mentioned above, one or more embodiments of the image warping system warp a panoramic image having a skewed boundary using a content-unaware process. That is, in contrast to conventional systems for warping an image that perform a computationally prohibitive analysis of the content of individual images to generate a panoramic image, the disclosed image warping system advantageously generates a content-unaware mesh grid that bypasses the need to analyze content of the panoramic image. In particular, the image warping system generates the mesh grid without consideration of the content shown in the panoramic image and warps the cells of the mesh grid (as well as corresponding portions of the panoramic image underlying the mesh grid). Thus, in contrast to context-aware methods, the image warping system implements a computationally inexpensive warping of a panoramic image. Thus, the image warping system requires less data than conventional systems to warp a panoramic image. Despite the use of less data, the image warping system still achieves the same or better output image quality that state of the art content-aware systems.
Additionally, one or more embodiments of the image warping system avoid issues caused by content-aware warping techniques in cases where a panoramic image has uneven distribution of content. In particular, rather than carving out portions of the panoramic image that are not to be altered in any way, thus causing over-distortion of other portions of the panoramic image, the image warping system avoids overly warping localized portions of the panoramic image by generating a content-unaware mesh grid having evenly distributed cells across the panoramic image. The image warping system the warps each of the cells evenly to avoid overly disrupting localized regions of the panoramic image.
Further, the image warping system avoids computationally expensive analysis and seam-carving of the panoramic image by generating the content-unaware mesh grid. In this way, the image warping system improves function of a computing device by warping a panoramic image while requiring minimal computing processing time and power. Indeed, the image warping system provides an elegant solution to a complex problem that imposes minimal processing power to complete a warping by avoiding the need to analyze content of the panoramic image.
Additional detail will now be provided regarding the image warping system in relation to illustrative figures portraying exemplary embodiments.
In accordance with one or more embodiments,
As shown in
For example, as shown in
As will be described in further detail below, the image warping system uses the input image 102 to construct a mesh grid. When the input image 102 includes an RGBA image, the image warping system can ignore the red green blue (RGB) channels of the input image 102 when generating the mesh grid. Thus, one or more embodiments involve constructing the mesh grid without utilizing data from the RGB channels of the input image 102. As such, in one or more embodiments, the image warping system exclusively utilizes the information contained in the A-channel (Alpha channel) when determining modifications to make to the input image 102.
Additionally, in one or more embodiments, the image warping system down-samples or otherwise generates a reduced resolution version of the input image 102. For example, in preparation for generating the mesh grid, the image warping system crops or resizes the input image 102 to a bounding box of solid pixels and scales down the resolution of the input image 102 to lower resolution than an original version of the input image 102 (e.g., as captured). In this way, rather than modifying a full-resolution version of the input image 102, the image warping system modifies a down-sampled version of the input image 102 using a less computationally expensive process than modifying a full-resolution version of the input image 102.
As mentioned above, the image warping system can generate a mesh grid that overlays the input image 102. As used herein, a “mesh grid” refers to a grid of cells defined by an outer boundary and lines passing between edges of the boundary and through interior vertex points distributed throughout an interior portion of the boundary. The mesh grid can include a height and width defined by a number of cells along each edge of the boundary. In one or more embodiments, the image warping system generates a mesh grid by sampling points between corners points 204a-d of the input image 102. As used herein, “corner points” refer to points along a boundary of a panoramic digital image closes to a respective corner of a bounding box that encloses the panoramic digital image. In one or more embodiments, a panoramic digital image includes four corner points corresponding to respective corners of the bounding box. As an example, each corner point refers to a point on the panoramic digital image having the lowest Euclidean distance from a respective corner of the bounding box.
For example, as shown in
In one or more embodiments, the image warping system identifies the corner points 204a-d by generating a bounding box 202 and identifying corner points 204a-d of the input image 102 utilizing the bounding box 202. As shown in
Upon generating the bounding box 202, the image warping system identifies the corner points 204a-d of the input image 102 based on corresponding corners of the bounding box 202. In one or more embodiments, the image warping determines the corner points 204a-d of the input image 102 by determining the closest point on the input image 102 to each respective corner of the bounding box 202. For example, as illustrated in
Upon identifying corner points 204a-d of the input image 102, the image warping system further generates boundary points 302 around the edges of the input image 102. As used herein, “boundary points” refer to distributed points around a boundary of a panoramic digital image. In one or more embodiments, boundary points refer to a uniform distribution of points around a perimeter of the panoramic digital image. Boundary points can include horizontal points along a top or bottom edge of the panoramic digital image as well as vertical points along side edges of the panoramic digital image.
For example, as shown in
In one or more embodiments, the image warping system determines a number of boundary points 302 based on an aspect ratio of the bounding box 202 around the input image 102. In particular, in one or more embodiments, the image warping system determines a number of horizontal and vertical boundary points 302 based on a width to height ratio of the input image 102 (or bounding box 202). For example, as shown in
To illustrate, as shown in
Upon generating the boundary points 302, the image warping system continues generating the mesh grid by utilizing the boundary points 302 as control points for determining locations of vertex points to make up the interior of the mesh grid. As used herein “vertex points” refer to points distributed throughout an interior portion of a boundary of a panoramic digital image. As described in further detail herein, the interior vertex points may include points that are uniformly distributed throughout a panoramic digital input image having skewed boundaries. Additionally, as described in greater detail below, the interior vertex points may define intersections of lines that form a mesh grid.
For example, as shown in
As shown by
After generating the mesh array 402 including boundary points 302 and interior vertex points 404, the image warping system generates a mesh grid 502 including grid cells 504 evenly distributed across the underlying input panorama image 102. In particular, as shown in
In one or more embodiments, the image warping system forms the mesh grid 502 by connecting adjacent boundary points 302 and interior vertex points 404. Alternatively, in one or more embodiments, the image warping system smooths the lines connecting the boundary points 302 and/or interior vertex points 404 to avoid noisy or fractal edges or lines of the mesh grid 502. It is appreciated that the lines of the mesh grid 502 around the edges of the input image 102 need not touch the boundary of the image 102.
As shown by
As mentioned above, in one or more embodiments, the image warping system smooths the edges and/or crops the input panorama image 102 prior to generating the mesh grid 502. Notwithstanding any smoothing or cropping, the input panorama image 102 retains an irregular shape to which the image warping system fits a mesh grid 502.
In addition to the foregoing, the creation of the mesh grid 502 and its application to the input panorama image 102 is independent of the content of the input panorama image 102. For example, in one or more embodiments, the only input required for creating the mesh grid 502 is the shape of the outer boundary of the input panorama image 102. In the case of an RGBA image, the image warping system considers only the A-channel (Alpha channel) of the input panorama image 102 when generating the mesh grid 502.
Once the mesh grid 502 is generated and applied to the input image 102, the image warping system warps the mesh grid 502 and underlying input image 102 to a predetermined shape. For example, as shown in
As mentioned above, the image warping system generates the enhanced panoramic image 602 by warping the mesh grid 502 and underlying input image 102 evenly across the grid cells 504 of the mesh grid 502. For example, as shown in
In warping the mesh grid 502 and underlying input image 102, the image warping system minimizes deviation of the grid cells 504 of the mesh grid. In particular, the image warping system minimizes distortion throughout the enhanced panoramic image 602 by minimizing deviation of grid cells 504 from a similarity transform applied to the plurality of grid cells 504 that make up the mesh grid 502. For example, in one or more embodiments, the image warping system applies an energy function (e.g., energy heuristic) that preserves shapes and straight lines of the mesh grid 502. More particularly, the image warping system may optimize one or more global energy functions that describe the positioning of the mesh grid 502. In one or more embodiments, the global energy functions may include a function that causes the mesh grid 502 to fill the target shape, a function that preserves straight lines, and a function that preserves high-level properties such as shapes. The image warping system can optimize the functions by finding a lowest global energy for the combination of the one or more global energy functions. Example, global energy functions are discussed in greater detail below.
Moreover, while the above description relates specifically to warping an input image 102 to fit the rectangular boundary 604, it is appreciated that one or more embodiments of the image warping system utilize a total energy function and system of equations to warp an input panoramic image having skewed boundaries to other shapes or dimensions. For example, in one or more embodiments, the image warping system warps an input panoramic image to a circular shape, oval shape (or other predetermined shape) by imposing a hard boundary constraint reflective of a circle, oval or other predetermined shape and similarly minimizing a total energy function including a shape preservation constraint that minimizing warping of interior cells of a mesh grid generated for the input panoramic image. Thus, using similar principles and features as described above in connection with warping the mesh grid 502 and underlying input image 102 to fit the rectangular boundary 604 can apply to warping an input panoramic image to a variety of shapes or dimensions.
Further, upon minimizing the energy function to determine how to warp the input image 102, the image warping system can triangulate the warped mesh grid to fit the warped input image 102 to the rectangular boundary 604. In one or more embodiments, the image warping system warps the input image 102 to fit the rectangular boundary 604 using barycentric coordinates inside each triangle. Additionally, the image warping system warps all of the RGBA channels together. For example, in generating and warping the mesh grid, the image warping system considers only the A-channel (Alpha channel) of the input image 102 and warps the mesh grid and A-channel of the input image 102 prior to applying the RGB channel information to the warped dimensions of the input image 102. Thus, in one or more embodiments, the image warping system analyzes the A-channel exclusively in generating the mesh grid and warping the input image 102 to fit the rectangular boundary 604 and adds the RGB channel data to the warped image in accordance with the A-channel data.
Turning now to
As illustrated in
In one or more embodiments, the image manager 704 analyzes the panoramic image to determine features and properties of the panoramic image prior to generating a mesh grid and/or warping the panoramic image. For example, in one or more embodiments, the image manager 704 crops and/or scales down the panoramic image to a lower resolution. In one or more instances, the image manager 704 crops portions of the panoramic image and scales the panoramic image to 1500 pixels (or other resolution of pixels based on a length dimension of the panoramic image). In one or more embodiments, the image manager 704 scales the panoramic image to a number of pixels based on an aspect ratio of the panoramic image.
Additionally, in one or more embodiments, the image manager 704 determines corner points 204a-d of the panoramic image. For example, in one or more embodiments, the image manager 704 receives corner data (e.g., metadata) including corner points 204a-d when receiving the panoramic image. Alternatively, in one or more embodiments, the image manager 704 determines the corner points 204a-d by generating a bounding box 202 and identifying the closest point of the panoramic image to each of the corners of the bounding box 202. In one or more embodiments, the bounding box 202 has similar dimensions as the predetermined shape of a final output image (e.g., the enhanced panoramic image 602).
One example algorithm for determining the location of the corners 204a-d with respect to the corners of the bounding box 202 is:
d(A,B)=|xA−xB|+|yA−yB|
where d(A, B) represents a total displacement between a corner of the input image 102 and a corresponding corner of the bounding box 202 while xA−xB and yA−yB represent the horizontal and vertical displacement between the corner of the input image 102 and the corresponding corner of the bounding box 202, respectively (see
As further shown in
Upon generating the boundary points, the mesh initiator 706 further generates the mesh array 402 by generating a plurality of interior vector points 404. In particular, the mesh initiator 706 generates interior vertex points 404 distributed across an interior portion of the panoramic image by interpolating coordinates of each of the interior vertex points 404 form the boundary points 302. In one or more embodiments, the mesh initiator 706 distributes the interior vertex points 404 evenly across the panoramic image by interpolating a location of each respective interior vertex point 404 based on a positional difference between a given interior vertex point 404 and each of the boundary points 302 around the panoramic image.
In one or more embodiments, the image warping system interpolates the interior vertex points 404 utilizing a thin plate splines calculation technique. For example, the image warping system determines a displacement at different points of the mesh array 402 to determine a placement of each of the interior vertex points 404 with respect to the boundary points 302 of the mesh array 402. In particular, in one or more embodiments, the image warping system interpolates each of the interior vertex points 404 using the following interpolation equation:
where α1, α2, α3, and ω1 represent coefficients to be determined. U(r)=r2 log(r) refers to a radial basis function of a Euclidean point distance (r). Pi refers to the i-th control point (e.g., i-th boundary point 302). Thus, |Pi−(x,y)| refers to a distance (e.g., The Euclidean point distance (r)) between a control point (P) and a position (x,y).
In one or more embodiments, the image warping system solves the coefficients using the following linear system:
where P represents the control point positions represented by the following equation:
K represents an evaluation of the function U(r) between control points, and is represented using the following equation:
and W and Y are represented using the following equations:
W=[ω1 . . . ωn]′
Y=[v1 . . . vn 0 0 0]′,
where W refers to weighted coefficient values (ω) for each control point (e.g., boundary point 302) and Y refers to the height of control points for the mesh array 402, padded with zeros. It is appreciated that the image warping system can use a similar system of equations with respect to the horizontal position of the control points of the mesh array 402 to calculate the coefficients of the linear system.
As used herein, an “x-y position” of the mesh array 402 refers to a position within the array with respect to boundary points 302 around the perimeter of the mesh array 402. For example, a point on the mesh array 402 at the most bottom-left position of the mesh array 402 would have an x-y position of (0,0). An adjacent point to the right of the (0,0) position would refer to an x-y position of (1,0). Further, an interior vertex point three spots to the right of the left-most boundary points 302 and three spots above the bottom-most boundary points 302 would refer to an interior vertex point having an x-y position of (3,3). Thus, the x-y position refers to a position within the mesh array 402.
Further, as used herein, an “x-y coordinate,” “x-y displacement,” “x-displacement,” “y-displacement” or simply “displacement” refers to a physical position on an x-y plane (or other two-dimensional plane). For example, an x-y coordinate or displacement value provides a physical position with regard to a fixed plane or predetermined shape. Thus, the x-y coordinate or displacement of a boundary point 302 or interior vertex point 404 may refer to a position of the boundary point 302 or interior vertex point 404 with respect to the bounding box 202 or desired shape of the enhanced panoramic image.
Thus, as described above with regard to the interpolation equation and system of equations, the image warping system calculates coefficients based on a distribution of the boundary points 302 around the input image 102 (e.g., with respect to the desired dimensions of a rectangular image). As demonstrated in the equations above, in calculating the coefficients, the image warping system calculates weighting coefficients (ω1-n) for each boundary point 302 on the mesh array 402 corresponding to horizontal and vertical positions of boundary points 302 on the mesh array 402.
Upon calculating the coefficients α1, α2, α3, and ωi, the image warping system plugs the coefficients α1, α2, α3, and ωi into the above-described interpolation equation and solves a horizontal and vertical positional displacement for each of the interior vertex points 404. As shown by the interpolation equation and the system of equations above, the image warping system utilizes the weighting coefficients to weigh different control values (e.g., boundary points 302) differently based on the x-y position of a given interior vertex point 404 with respect to the boundary points 302. For example, the image warping system utilizes the weighting coefficients to weigh boundary points 302 nearby a given interior vertex point 404 more heavily than boundary points 302 that are further away from the given interior vertex point 404. To illustrate, the image warping system weighs the first boundary point 204a and other nearby border points 302 more heavily to determine a x-y displacement of interior vertex points 404 toward the top-left corner of the mesh array 402 than the fourth corner point 204d and other border points 302 nearby the fourth corner point 204d.
Nevertheless, while the image warping system weighs different boundary points 302 more heavily for different interior vertex points 404, in one or more embodiments, the image warping system considers a combination of all of the boundary points to determine x-y coordinates of each of the interior vertex points 404 within the mesh array 402. For example, as shown in the interpolation equation above, the image warping system calculates a sum of distances between boundary points 302 and an interior vertex point corresponding to an x-y position to determine a displacement for the interior vertex point. Thus, while the image warping system considers nearby boundary points 302 more heavily than more distant boundary points 302 in calculating the sum of distances, the image warping system nonetheless considers all of the boundary points 302 in determining a displacement (e.g., x-y coordinate) of each of the interior vertex points 404.
Once the mesh initiator 706 generates the mesh array 402 including the boundary points 302 and interior vertex points 404, the mesh initiator 706 further generates a mesh grid 502 including grid cells 504 defined by lines running through the points of the mesh array 402. For example, the mesh initiator 706 generates the mesh grid 502 by drawing lines connecting adjacent boundary points 302 and interior vertex points 404. In one or more embodiments, the mesh initiator 706 smooths the lines and edges of the mesh grid 502. Alternatively, in one or more embodiments, the mesh initiator 706 simply forms the mesh grid 502 by drawing a straight line between adjacent points of the mesh array 402.
As further shown in
In particular, image warping system distributes distortion throughout the mesh grid 502 by minimizing the energy function. For example, in one or more embodiments, the image warping system applies the following total energy function:
E(V)=ES(V)+λEB(V)
where E(V) represents the total energy representative of a vector of all the mesh vertices (V). In one or more embodiments, the values of the mesh vertices (V) are represented by the following equation:
V=[x11,x12, . . . ,x1n
where xn
As shown in the above total energy function, the total energy of the mesh vertices (V) includes a shape preservation constraint (ES(V)) and a boundary constraint (EB(V)). In one or more embodiments, the shape preservation constraint (ES(V)) is represented using the following equation:
where n represents a number of grid cells 504 of the mesh grid 502, Aq represents coordinate values of input cells and Vq represents coordinate values of output cells. In particular, Aq is represented by the following:
where ({circumflex over (x)}0, ŷ0), . . . , ({circumflex over (x)}3, ŷ3) represent coordinates of input cells. Further, Vq is represented by the following equation:
where (x0, y0), . . . , (x3, y3) represent coordinates of output cells.
Additionally, in one or more embodiments, the boundary constraint (EB(V)) is represented using the following equation:
where L, R, T, and B denote the left, right, top, and bottom boundary edges of the rectangular boundary 604, w represents a width of the rectangular boundary 604 and h represents a height of the rectangular boundary 604. In one or more embodiments, the panoramic warping system utilizes features and functionality by the mesh-based global warping technique described in “Rectangular Panoramic Images via Warping” by Kaiming He, Huiwen Chang, and Jian Sun, which is incorporated by reference herein in its entirety.
As further shown in
Each of the components 704-710 of the image warping system 702 and corresponding elements may be in communication with one another using any suitable communication technologies. It will be recognized that although components 704-710 and their corresponding elements are shown to be separate in
The components 704-710 and their corresponding elements can comprise software, hardware, or both. For example, the components 704-710 and their corresponding elements can comprise one or more instructions stored on a computer-readable storage medium and executable by processors of one or more computing devices. When executed by the one or more processors, the computer-executable instructions of the image warping system 702 can cause a client device and/or a server device to perform the methods described herein. Alternatively, the components 704-710 and their corresponding elements can comprise hardware, such as a special purpose processing device to perform a certain function or group of functions. Additionally, the components 704-710 and their corresponding elements can comprise a combination of computer-executable instructions and hardware.
Furthermore, one or more of the components 704-710 of the image warping system 702 may, for example, be implemented as one or more stand-alone applications, as one or more modules of an application, as one or more plug-ins, as one or more library functions or functions that may be called by other applications, and/or as a cloud-computing model. Thus, one or more of the components 704-710 of the three-dimensional preview generation system 400 may be implemented as a stand-alone application, such as a desktop or mobile application. Furthermore, one or more of the components 704-710 of the image warping system 702 may be implemented as one or more web-based applications hosted on a remote server. Alternatively or additionally, one or more components 704-710 of the image warping system 702 may be implemented in a suit of mobile device applications or “apps.” To illustrate, one or more of the components of the image warping system 702 may be implemented in a digital image editing application, including but not limited to ADOBE® PHOTOSHOP® or ADOBE® REVEL®. “ADOBE®,” “ADOBE® PHOTOSHOP®,” and “ADOBE® REVEL®” are either registered trademarks or trademarks of Adobe Systems Incorporated in the United States and/or other countries.
As further shown in
In one or more embodiments, generating the mesh grid involves identifying corner points 204a-d of the panoramic digital image with skewed boundaries. In one or more embodiments, the corner points 204a-d or received or otherwise known when the panoramic digital image is received. Alternatively, in one or more embodiments, identifying the corner points 204a-d of the panoramic digital image involves generating a bounding box 202 around the panoramic digital image with skewed boundaries. In one or more embodiments, generating the bounding box 202 involves generating a frame of the panoramic digital image with skewed boundaries, the frame having a shape corresponding to the predetermined shape of the enhanced panoramic image 602.
Further, in one or more embodiments, identifying the corner points 204a-d of the panoramic digital image involves identifying the corner points 204a-d by determining a closest point of the panoramic digital image with skewed boundaries to each corner of the bounding box 202. For example, in one or more embodiments, identifying the corner points 204a-d involves pushing out a forty-five degree line 206 from a corner of the bounding box 202 to a nearest point on the panoramic digital image.
As mentioned above, in one or more embodiments, generating the mesh grid 502 involves sampling boundary points 302 along outside edges of the panoramic digital image. In one or more embodiments, sampling boundary points 302 involves uniformly distributing a plurality of boundary points 302 between the identified corner points 204a-d of the panoramic digital image with skewed boundaries. Further, in one or more embodiments, sampling the boundary points 302 involves generating a number of horizontal boundary points 302 and a number of vertical boundary points 302 based on an aspect ratio of the predetermined shape of the enhanced panoramic image 602.
As further mentioned above, in one or more embodiments, generating the mesh grid 502 involves generating a plurality of interior vertex points 404. In one or more embodiments, generating the plurality of interior vertex points 404 involves interpolating a horizontal and vertical displacement for each of the plurality of vertex points 404 based on horizontal and vertical positions of all of the boundary points 302 within the mesh grid 502 or within the mesh array 402. For example, where the method 800 involves generating a number of horizontal and vertical boundary points 302, generating the plurality of interior vertex points 404 can include evenly distributing a number of interior vertex points 404 corresponding to the number of horizontal boundary points 302 and the number of vertical boundary points 302 to fill out the an interior portion of the mesh grid 502 (or mesh array 402).
In one or more embodiments, generating the plurality of interior vertex points includes interpolating an x-y coordinate from the boundary points by minimizing, for each of the plurality of interior vertex points 404 (e.g., each position of the plurality of interior vertex points 404 within the mesh array 402), a sum of distances from a given interior vertex point 404 to each of the boundary points 302. In one or more embodiments, minimizing the sum of distances from each of the boundary points 302 involves minimizing a sum of weighted distances from each of the boundary points 302. Further, in one or more embodiments, boundary points 302 closer to a given interior vertex point 404 are weighted more heavily than boundary points 302 further from the given interior vertex point 404.
Thus, as described herein, the method 800 can include generating a mesh array 402 including boundary points 302 and interior vertex points 404. Upon generating the mesh array 402, one or more embodiments of the method 800 further includes generating the mesh grid 502 including a grid of lines passing between the boundary points 302 and the interior vertex points 404 to form the plurality of cells 504 of the mesh grid 502.
As further shown in
In one or more embodiments, warping the mesh grid 502 and underlying pixels of the panoramic digital image 102 includes warping outer lines of the mesh grid 502 to a hard boundary constraint corresponding to the predefined shape 604. Additionally, one or more embodiments of warping the mesh grid 502 involves minimizing deviation of cells 504 of the mesh grid 502 from a similarity transform applied to the plurality of grid cells 504 by warping each cell.
Additionally, it is appreciated that the predefined shape 604 can include one of several elongated shapes. For example, in one or more embodiments, the predefined shape 604 includes a rectangular shape. Alternatively, in one or more embodiments, the predefined shape refers to an oval, spheroid (e.g., prolate ellipsoid), parallelogram, or other elongated shape.
As further shown in
As further shown in
Additionally, as shown in
As further shown in
As further shown in
Embodiments of the present disclosure may comprise or utilize a special purpose or general-purpose computer including computer hardware, such as, for example, one or more processors and system memory, as discussed in greater detail below. Embodiments within the scope of the present disclosure also include physical and other computer-readable media for carrying or storing computer-executable instructions and/or data structures. In particular, one or more of the processes described herein may be implemented at least in part as instructions embodied in a non-transitory computer-readable medium and executable by one or more computing devices (e.g., any of the media content access devices described herein). In general, a processor (e.g., a microprocessor) receives instructions, from a non-transitory computer-readable medium, (e.g., a memory, etc.), and executes those instructions, thereby performing one or more processes, including one or more of the processes described herein.
Computer-readable media can be any available media that can be accessed by a general purpose or special purpose computer system. Computer-readable media that store computer-executable instructions are non-transitory computer-readable storage media (devices). Computer-readable media that carry computer-executable instructions are transmission media. Thus, by way of example, and not limitation, embodiments of the disclosure can comprise at least two distinctly different kinds of computer-readable media: non-transitory computer-readable storage media (devices) and transmission media.
Non-transitory computer-readable storage media (devices) includes RAM, ROM, EEPROM, CD-ROM, solid state drives (“SSDs”) (e.g., based on RAM), Flash memory, phase-change memory (“PCM”), other types of memory, other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store desired program code means in the form of computer-executable instructions or data structures and which can be accessed by a general purpose or special purpose computer.
A “network” is defined as one or more data links that enable the transport of electronic data between computer systems and/or modules and/or other electronic devices. When information is transferred or provided over a network or another communications connection (either hardwired, wireless, or a combination of hardwired or wireless) to a computer, the computer properly views the connection as a transmission medium. Transmissions media can include a network and/or data links which can be used to carry desired program code means in the form of computer-executable instructions or data structures and which can be accessed by a general purpose or special purpose computer. Combinations of the above should also be included within the scope of computer-readable media.
Further, upon reaching various computer system components, program code means in the form of computer-executable instructions or data structures can be transferred automatically from transmission media to non-transitory computer-readable storage media (devices) (or vice versa). For example, computer-executable instructions or data structures received over a network or data link can be buffered in RAM within a network interface module (e.g., a “NIC”), and then eventually transferred to computer system RAM and/or to less volatile computer storage media (devices) at a computer system. Thus, it should be understood that non-transitory computer-readable storage media (devices) can be included in computer system components that also (or even primarily) utilize transmission media.
Computer-executable instructions comprise, for example, instructions and data which, when executed at a processor, cause a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. In one or more embodiments, computer-executable instructions are executed on a general purpose computer to turn the general purpose computer into a special purpose computer implementing elements of the disclosure. The computer executable instructions may be, for example, binaries, intermediate format instructions such as assembly language, or even source code. Although the subject matter has been described in language specific to structural marketing features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the described marketing features or acts described above. Rather, the described marketing features and acts are disclosed as example forms of implementing the claims.
Those skilled in the art will appreciate that the disclosure may be practiced in network computing environments with many types of computer system configurations, including, personal computers, desktop computers, laptop computers, message processors, hand-held devices, multi-processor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, mobile telephones, PDAs, tablets, pagers, routers, switches, and the like. The disclosure may also be practiced in distributed system environments where local and remote computer systems, which are linked (either by hardwired data links, wireless data links, or by a combination of hardwired and wireless data links) through a network, both perform tasks. In a distributed system environment, program modules may be located in both local and remote memory storage devices.
Embodiments of the present disclosure can also be implemented in cloud computing environments. In this description, “cloud computing” is defined as an un-subscription model for enabling on-demand network access to a shared pool of configurable computing resources. For example, cloud computing can be employed in the marketplace to offer ubiquitous and convenient on-demand access to the shared pool of configurable computing resources. The shared pool of configurable computing resources can be rapidly provisioned via virtualization and released with low management effort or service provider interaction, and then scaled accordingly.
A cloud-computing un-subscription model can be composed of various characteristics such as, for example, on-demand self-service, broad network access, resource pooling, rapid elasticity, measured service, and so forth. A cloud-computing un-subscription model can also expose various service un-subscription models, such as, for example, Software as a Service (“SaaS”), a web service, Platform as a Service (“PaaS”), and Infrastructure as a Service (“IaaS”). A cloud-computing un-subscription model can also be deployed using different deployment un-subscription models such as private cloud, community cloud, public cloud, hybrid cloud, and so forth. In this description and in the claims, a “cloud-computing environment” is an environment in which cloud computing is employed.
In one or more embodiments, the processor 1002 includes hardware for executing instructions, such as those making up a computer program. As an example and not by way of limitation, to execute instructions for digitizing real-world objects, the processor 1002 may retrieve (or fetch) the instructions from an internal register, an internal cache, the memory 1004, or the storage device 1006 and decode and execute them. The memory 1004 may be a volatile or non-volatile memory used for storing data, metadata, and programs for execution by the processor(s). The storage device 1006 includes storage, such as a hard disk, flash disk drive, or other digital storage device, for storing data or instructions related to object digitizing processes (e.g., digital scans, digital models).
The I/O interface 1008 allows a user to provide input to, receive output from, and otherwise transfer data to and receive data from computing device 1000. The I/O interface 1008 may include a mouse, a keypad or a keyboard, a touch screen, a camera, an optical scanner, network interface, modem, other known I/O devices or a combination of such I/O interfaces. The I/O interface 1008 may include one or more devices for presenting output to a user, including, but not limited to, a graphics engine, a display (e.g., a display screen), one or more output drivers (e.g., display drivers), one or more audio speakers, and one or more audio drivers. In certain embodiments, the I/O interface 1008 is configured to provide graphical data to a display for presentation to a user. The graphical data may be representative of one or more graphical user interfaces and/or any other graphical content as may serve a particular implementation.
The communication interface 1010 can include hardware, software, or both. In any event, the communication interface 1010 can provide one or more interfaces for communication (such as, for example, packet-based communication) between the computing device 1000 and one or more other computing devices or networks. As an example and not by way of limitation, the communication interface 1010 may include a network interface controller (NIC) or network adapter for communicating with an Ethernet or other wire-based network or a wireless NIC (WNIC) or wireless adapter for communicating with a wireless network, such as a WI-FI.
Additionally, the communication interface 1010 may facilitate communications with various types of wired or wireless networks. The communication interface 1010 may also facilitate communications using various communication protocols. The communication infrastructure 1012 may also include hardware, software, or both that couples components of the computing device 1000 to each other. For example, the communication interface 1010 may use one or more networks and/or protocols to enable a plurality of computing devices connected by a particular infrastructure to communicate with each other to perform one or more aspects of the digitizing processes described herein. To illustrate, the image compression process can allow a plurality of devices (e.g., server devices for performing image processing tasks of a large number of images) to exchange information using various communication networks and protocols for exchanging information about a selected workflow and image data for a plurality of images.
In the foregoing specification, the present disclosure has been described with reference to specific exemplary embodiments thereof. Various embodiments and aspects of the present disclosure(s) are described with reference to details discussed herein, and the accompanying drawings illustrate the various embodiments. The description above and drawings are illustrative of the disclosure and are not to be construed as limiting the disclosure. Numerous specific details are described to provide a thorough understanding of various embodiments of the present disclosure.
The present disclosure may be embodied in other specific forms without departing from its spirit or essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. For example, the methods described herein may be performed with less or more steps/acts or the steps/acts may be performed in differing orders. Additionally, the steps/acts described herein may be repeated or performed in parallel with one another or in parallel with different instances of the same or similar steps/acts. The scope of the present application is, therefore, indicated by the appended claims rather than by the foregoing description. All changes that come within the meaning and range of equivalency of the claims are to be embraced within their scope.
Entry |
---|
Lombaert, Herve “Manual Registration with Thin Plates;” École Polytechnique de Montréal; Jun. 2006. |
Bookstein, Fred L. “Principal Warps: Thin-Plate Splines and the Decomposition of Deformations;” IEEE Transactions on Pattern Analysis and Machine Intelligence; Jun. 1989. |
He, Kaiming; Chang, Huiwen; Sun, Jian; “Rectangling Panoramic Images via Warping”; SIGGRAPH 2013; Jul. 2013. |
Avidan, Shai; Shamir, Ariel; “Seam Carving for Content-Aware Image Resizing;” SIGGRAPH 2007; Jul. 2007. |
Number | Date | Country | |
---|---|---|---|
20180082401 A1 | Mar 2018 | US |