Converting between aspect ratios is a common problem in the field of image and video processing. For example, a display that displays images according to a 16:9 aspect ratio may receive images natively captured according to a 4:3 aspect ratio and perform an aspect ratio conversion to fit the image to the display. Conventional conversion techniques such as cropping, linearly scaling, and padding each result in a perceivable reduction in the quality of the image or video. For example, cropping removes content from the image and reduces the field of view of the image. Linear scaling maintains the full field of view but introduces perceivable distortion into the image. For example, if an image is vertically compressed and/or horizontally stretched to convert from a 4:3 to a 16:9 aspect ratio, features in scene will appear “short and fat” relative to the original image. Padding maintains the full field of view without distortion, but results in unused display space around the sides and/or top of the image, thus rendering an image that appears too small relative to the display.
An input image having a source aspect ratio may be obtained. The input image may include pixels located at input positions. An output image may be generated by applying a transformation to the input image. The output image may have a target aspect ratio different than the source aspect ratio. The output image may include the pixels located at output positions. The transformation may include a linear scaling to uniformly stretch or compress the input image and a non-linear warping to non-uniformly warp the input image. The linear scaling and the non-linear warping may change the pixels from being located at the input positions in the input image to output positions in the output image. The nonlinear warping may include: a horizontal warping that changes pixel positions as a function of horizontal coordinates of the pixels, an amount of horizontal change in pixel positions characterized by a horizontal distortion offset that an individual pixel moves away from a first reference edge; and a vertical warping that changes the pixel positions as a function of vertical coordinates of the pixels, an amount of vertical change in pixel positions characterized by a vertical distortion offset that the individual pixel moves away from a second reference edge different from the first reference edge.
In some embodiments, the first reference edge may include a right edge or a left edge. and the second reference edge may include a top edge or a bottom edge.
In some embodiments, the linear scaling may change the source aspect ratio to the target aspect ratio.
In some embodiments, the nonlinear warping may not offset pixels along edges to prevent padding in the output image.
In some embodiments, the vertical warping may change the pixel positions further as a function of the horizontal coordinates of the pixels.
In some embodiments, magnitudes of distortion performed by the horizontal warping may be horizontally symmetrical.
In some embodiments, degradation in image quality caused by the horizontal warping may be compensated for by the vertical warping.
In some embodiments, the horizontal warping may be tuned in combination with the vertical warping to preserve width of objects throughout a horizontal plane.
The Figures (FIGS.) and the following description relate to preferred embodiments by way of illustration only. It should be noted that from the following discussion, alternative embodiments of the structures and methods disclosed herein will be readily recognized as viable alternatives that may be employed without departing from the principles of what is claimed.
Reference will now be made in detail to several embodiments, examples of which are illustrated in the accompanying figures. It is noted that wherever practicable similar or like reference numbers may be used in the figures and may indicate similar or like functionality. The figures depict embodiments of the disclosed system (or method) for purposes of illustration only. One skilled in the art will readily recognize from the following description that alternative embodiments of the structures and methods illustrated herein may be employed without departing from the principles described herein.
Overview
A camera system comprises an image sensor, a processor, and a non-transitory computer-readable storage medium that stores instructions executable by the processor. The image sensor captures an input image having a source aspect ratio. The processor applies a transformation to the input image to scale and warp the image to generate an output image having a target aspect ratio different than the source aspect ratio. The output image has the same field of view as the input image, maintains image resolution, and limits distortion to levels that do not substantially affect the viewing experience. In one embodiment, the output image is non-linearly warped relative to the input image such that a distortion in the output image relative to the input image is greater in a corner region of the output image than a center region of the output image. The processor outputs the output image having the target aspect ratio.
In one embodiment, the aspect ratio conversion is performed directly on the camera itself rather than in an external post-processing device, such as the display device. This enables the camera to output images directly to a display in the desired target aspect ratio without requiring conversion by the display device. For example, a camera that natively captures images according to a 4:3 aspect ratio can perform conversion and output the images according to a 16:9 aspect ratio that may be displayed directly on a 16:9 display device. Furthermore, in one embodiment, the conversion may occur in substantially real-time such that images captured in the source aspect ratio can be outputted in the target aspect ratio with substantially no delay.
Beneficially, since the aspect ratio conversion preserves the entire field of view of the image, the converted image can be reverted back to its original aspect ratio without any loss of field of view or resolution. Furthermore, since the aspect ratio discrepancy is handled by the camera system, the end user needs not to make any additional adjustments apart from selecting the desired output video format on the camera. The embodiments described herein may apply to both individual images and video (which comprises a sequence of images (or “frames”).
Example Camera System
Image frames captured by the image sensor 102 may be temporarily or permanently stored in the video storage 106 which may comprise, for example, a hard drive or a solid-state memory device (e.g., a memory card or universal serial bus (USB) memory device). The processing unit 108 processes images to convert between aspect ratios as will be described in further detail below. In one embodiment, the processing unit 108 comprises a processor 112 and a memory 114. The memory 114 comprises a non-transitory computer-readable storage medium that stores computer-executable program instructions for aspect ratio conversion, among other functions. To perform the aspect ratio conversion described herein, the processor 112 loads program instructions from the memory 114 and executes the instructions. Alternatively, the processing unit 108 could implement the aspect ratio conversion in hardware, firmware, or a combination of hardware, firmware, and/or software.
In one embodiment, the processing unit 108 converts between a source aspect ratio (i.e., the aspect ratio of the original images captured by the image sensor 104) and a target aspect ratio (i.e., the aspect ratio of the image for storing or outputting by the camera system 102). In one embodiment, the source aspect ratio makes full use of the available field of view of the image sensor 104 (remaining sensitive to mapping distortion effects). For example, in a camera system 102 having a 4:3 image sensor, the image sensor 104 captures the native content according to a 4:3 aspect ratio, although other source aspect ratios are also possible. The processing unit 108 then uses resolution compression and/or stretching in the appropriate axes to convert the captured images in the source aspect ratio to the target aspect ratio. In one embodiment, the conversion is achieved using a resolution remapping that applies a non-linear function across the image so as to minimize or reduce undesirable key feature aspect ratio distortions. Furthermore, in one embodiment, the aspect ratio conversion does not result in any loss of field of view.
In one embodiment, the aspect ratio conversion is performed by a warp module of the processing unit 108. In addition to performing the aspect ratio conversion, the warp module may perform other functions such as, for example, reducing optical lens distortions such as typical barrel and pincushion distortions.
Aspect Ratio Conversion
Examples of techniques for aspect ratio conversion are discussed in further detail below. For the sake of clarity, the following description discusses examples involving conversions between a source aspect ratio of 4:3 and a target aspect ratio of 16:9. However, the described embodiments similarly apply to any source or target aspect ratios.
As can also be observed from
The distribution of distortion levels in different portions of the image may furthermore be tuned in one embodiment to control the size of objects as they pan from horizontally within a scene of video. Fully correcting the geometrical distortion in the center of the image would result in objects looking small in the center and very large on the sides. Thus, in the case of a video, an object may noticeably grow in size as it moves from the center to the edges of the display. In one embodiment, the warping function in step 206 is tuned to reduce this effect.
In an alternative embodiment, the scaling and warping functions applied in steps 204, 206 could be performed in reverse order, such that the warping function in step 206 is applied first followed by scaling in step 204. In another embodiment, the scaling and warping are combined into a single function such that only a single transformation is applied to the image that achieves both the scaling and warping. For example, in
As will be apparent to those skilled in the art, an equitable horizontal remapping can be performed in manners similar to those described herein for vertical remapping if it is desired to decrease image width without decreasing horizontal image field of view and without creating undesirable key feature distortions. For example, images having a source aspect ratio of 2.39:1 may be converted to a 16:9 aspect ratio in this similar manner.
The scaling step (e.g., step 204 of
Examples of Warping Functions
In one embodiment, the warping function involves both a horizontal and vertical warping. For convenience of description, the horizontal and vertical warping is described as two steps, e.g., first horizontal then vertical. However, both horizontal and vertical warping can be executed in one step, for example, by applying a single transformation to the image. Furthermore, due to the symmetrical nature of the distortion, vertical and horizontal distortion profiles can be swapped.
An example of a horizontal warping function is illustrated in
In one embodiment, the amount of horizontal correction applied can be manually tuned to reduce perceivable distortion in the output image. For example, fully correcting the geometrical distortion in the center may cause the objects in the center to be much smaller than on the sides. Thus, in one embodiment, the amount of horizontal correction can be tuned in combination with the vertical correction in order to preserve the width of objects throughout the horizontal plane.
In one embodiment, a similarly shaped function is used for vertical warping. In another embodiment, the vertical warping function is modified so that the amount of compensation in the vertical direction also depends on horizontal position.
As mentioned above, a goal of the vertical distortion is to further correct the geometry that was not already corrected by horizontal distortion. The image center could be fully corrected using the horizontal distortion only (with no vertical warping). However, spreading the correction along both horizontal and vertical axis effectively improves the geometry of not only the center, but also the top, bottom, left and right image sides. The most distorted regions in this embodiment are the four image corners, but this distortion does not substantially reduce perceived image quality. Having residual distortion in the corners while correcting the rest in the image results in a much more natural-looking effect since key scene features are usually not framed in the corners. Examples of this effect can be visible, however, in
In one embodiment, tunable parameters can be controlled to adjust the vertical distortion along both horizontal and vertical directions, resulting in the 3D-wave in
In the description above, the horizontal and vertical distortions have been decoupled for the sake of clarity. However, both distortions could be implemented in a single step. Similarly, in the description above, the aspect ratio conversion (4:3 to 16:9 in this example) has been decoupled from warp distortion, but these could also be combined into a single step.
Example equations are provided below for implementing an example warping function applied in step 206 of
As explained above, the horizontal warp distortion in one embodiment is a function of the horizontal position only. It can therefore be represented in terms of a horizontal coordinate h in an equation such as the example equation below, or an equation substantially similar to the equation below:
Δh/H=0.1107h6+0.534h5−1.7813h4+1.3167h3−0.0722h2−0.1073h
The vertical warp distortion, in one embodiment, is a function of both the horizontal and vertical positions. Therefore, the vertical warp distortion can be represented as a family of equations ΔV/Vn, where “n” is the horizontal coordinate expressed as a percent of the total horizontal image size. Intermediate horizontal coordinates can be interpolated from the example equations given below, or equations substantially similar to these:
Δv/V0=−0.0749v6−0.3167v5+1.0939v4−0.8113v3+0.0408v2+0.0678v
Δv/V10=−0.0658v6−0.2785v5+0.9617v4−0.7132v3+0.0359v2+0.0596v
Δv/V20=−0.0568v6−0.2402v5+0.8294v4−0.6152v3+0.0309v2+0.0514v
Δv/V30=−0.0444v6−0.188v5+0.6491v4−0.4814v3+0.0242v2+0.0403v
Δv/V40=−0.0337v6−0.1427v5+0.4928v4−0.3655v3+0.0184v2+0.0306v
Δv/V50=−0.0296v6−0.1253v5+0.4327v4−0.3209v3+0.0161v2+0.0268v
Δv/V60=−0.0337v6−0.1427v5+0.4928v4−0.3655v3+0.0184v2+0.0306v
Δv/V70=−0.0444v6−0.188v5+0.6491v4−0.4814v3+0.0242v2+0.0403v
Δv/V80=−0.0568v6−0.2402v5+0.8294v4−0.6152v3+0.0309v2+0.0514v
Δv/V90=−0.0658v6−0.2785v5+0.9617v4−0.7132v3+0.0359v2+0.0596v
Δv/V100=−0.0749v6−0.3167v5+1.0939v4−0.8113v3+0.0408v2+0.0678v
The warp distortion described above may be used with cameras producing either rectilinear images (without distortion) or images affected by optical lens distortion characterized by the following equation:
(FOV)=(21.904)*(IH)−(0.6852)*(IH){circumflex over ( )}2.
where FOV is the field of view and IH is image height. As will be apparent to those of ordinary skill in the art, the equations above may vary when used with lenses having different distortion characteristics.
As described above, the above equations can be combined with a scaling function to generate a transformation that performs both scaling and warping.
In alternative embodiments, different equations may be used to achieve similar distortion characteristics. As mentioned above, the symmetric nature of the distortion and the fact that it can be expressed as a percent of image coordinates allows swapping horizontal and vertical distortions. Thus, in an alternative embodiment, the equations above for the horizontal axis can instead by applied in the vertical direction and vice versa.
Furthermore, in other alternative embodiments, the equations may change dynamically in different frames of a video. For example, warping may be applied in a manner that reduces distortion applied to a particular object in motion across different frames of a video since the viewer is likely to focus attention on the object in motion.
Although the example embodiments described herein relate to conversion between a 4:3 aspect ratio and a 16:9 aspect ratio, other aspect ratios may be used for the target and source aspect ratios. For example, in alternative embodiments the source aspect ratio can comprise a 4:3 aspect ratio, a 16:9 aspect ratio, a 1.85:1 aspect ratio, a 2.39:1 aspect ratio, a 3:2 aspect ratio, a 5:3 aspect ratio, a 5:4 aspect ratio, a 1:1 aspect ratio or any other aspect ratio. Similarly, in alternative embodiments, the target aspect ratio can comprise a 4:3 aspect ratio, a 16:9 aspect ratio, a 1.85:1 aspect ratio, a 2.39:1 aspect ratio, a 3:2 aspect ratio, a 5:3 aspect ratio, a 5:4 aspect ratio, a 1:1 aspect ratio or any other aspect ratio.
Additional Configuration Considerations
Throughout this specification, some embodiments have used the expression “coupled” along with its derivatives. The term “coupled” as used herein is not necessarily limited to two or more elements being in direct physical or electrical contact. Rather, the term “coupled” may also encompass two or more elements are not in direct contact with each other, but yet still co-operate or interact with each other, or are structured to provide a thermal conduction path between the elements.
Likewise, as used herein, the terms “comprises,” “comprising,” “includes,” “including,” “has,” “having” or any other variation thereof, are intended to cover a non-exclusive inclusion. For example, a process, method, article, or apparatus that comprises a list of elements is not necessarily limited to only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus.
In addition, use of the “a” or “an” are employed to describe elements and components of the embodiments herein. This is done merely for convenience and to give a general sense of the invention. This description should be read to include one or at least one and the singular also includes the plural unless it is obvious that it is meant otherwise.
Finally, as used herein any reference to “one embodiment” or “an embodiment” means that a particular element, feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.
Upon reading this disclosure, those of skill in the art will appreciate still additional alternative structural and functional designs for a camera expansion module as disclosed from the principles herein. Thus, while particular embodiments and applications have been illustrated and described, it is to be understood that the disclosed embodiments are not limited to the precise construction and components disclosed herein. Various modifications, changes and variations, which will be apparent to those skilled in the art, may be made in the arrangement, operation and details of the method and apparatus disclosed herein without departing from the spirit and scope defined in the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
5657082 | Harada | Aug 1997 | A |
5790696 | Takahashi | Aug 1998 | A |
6757446 | Li | Jun 2004 | B1 |
6900821 | Goertzen | May 2005 | B2 |
6915026 | Sasai | Jul 2005 | B2 |
7079157 | Deering | Jul 2006 | B2 |
7483080 | Arora | Jan 2009 | B2 |
7496243 | Oosawa | Feb 2009 | B2 |
8045788 | Watkins | Oct 2011 | B2 |
8139884 | Chien | Mar 2012 | B2 |
8145013 | Sahu | Mar 2012 | B1 |
8218895 | Gleicher | Jul 2012 | B1 |
8340453 | Chen | Dec 2012 | B1 |
8493459 | Albu | Jul 2013 | B2 |
8525871 | Agarwala | Sep 2013 | B2 |
8723959 | Corcoran | May 2014 | B2 |
8786788 | Jaynes | Jul 2014 | B2 |
8913141 | Campbell | Dec 2014 | B2 |
8917329 | Woodman | Dec 2014 | B1 |
9196228 | Kim | Nov 2015 | B2 |
9253474 | Rui | Feb 2016 | B2 |
9294671 | Woodman | Mar 2016 | B2 |
9674429 | Woodman | Jun 2017 | B2 |
9787960 | Sumiyoshi | Oct 2017 | B2 |
10015413 | Woodman | Jul 2018 | B1 |
10368013 | Woodman | Jul 2019 | B2 |
10819918 | Woodman | Oct 2020 | B2 |
11190709 | Woodman | Nov 2021 | B2 |
20040017492 | Stavely | Jan 2004 | A1 |
20050093893 | Senior | May 2005 | A1 |
20080260290 | Velthoven | Oct 2008 | A1 |
20090202177 | Jeffrey | Aug 2009 | A1 |
20100149216 | Dutta | Jun 2010 | A1 |
20110298982 | Kobayashi | Dec 2011 | A1 |
20130141593 | Bassi | Jun 2013 | A1 |
20130312042 | Shaw | Nov 2013 | A1 |
20140032406 | Roach | Jan 2014 | A1 |
20150077586 | Woodman | Mar 2015 | A1 |
20160173767 | Woodman | Jun 2016 | A1 |
20180309938 | Woodman | Oct 2018 | A1 |
20190327426 | Woodman | Oct 2019 | A1 |
20210037194 | Woodman | Feb 2021 | A1 |
Number | Date | Country |
---|---|---|
2334058 | Sep 2016 | EP |
2010073192 | Jul 2010 | WO |
Entry |
---|
PCT International Search Report and Written Opinion for PCT/US14/51750, dated Sep. 9, 2014, 9 pages. |
United States Office Action for U.S. Appl. No. 14/180,887, dated May 28, 2014, 10 pages. |
Office Action for U.S. Appl. No. 14/536,315 dated Jun. 19, 2015, 5 pages. |
Wang, Yu-Shuen, et al., “Optimized Scale-and-Stretch for Image Resizing”, ACM Transactions on Graphics (TOG), ACM, vol. 27, No. 5, Article 118, Dec. 1, 2008, XP002609797, 8 pages. |
Hwang, Daw-Sen, et al., “Content-Aware Image Resizing Using Perceptual Seam Carving with Human Attention Model”, International Conference on Multimedia and Expo, 2008 IEEE, Piscataway, NJ, Jun. 23, 2008, XP032965469, pp. 1029-1032. |
Avidan, S., et al., “Seam Carving for Content-Aware Image Resizing”, ACM Transactions on Graphics (TOG), ACM, vol. 26, No. 3, Article 10, Jul. 1, 2007, XP007904203, 10 pages. |
Number | Date | Country | |
---|---|---|---|
20220086369 A1 | Mar 2022 | US |
Number | Date | Country | |
---|---|---|---|
61869029 | Aug 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17075923 | Oct 2020 | US |
Child | 17536699 | US | |
Parent | 16456613 | Jun 2019 | US |
Child | 17075923 | US | |
Parent | 16023675 | Jun 2018 | US |
Child | 16456613 | US | |
Parent | 15492738 | Apr 2017 | US |
Child | 16023675 | US | |
Parent | 15011253 | Jan 2016 | US |
Child | 15492738 | US | |
Parent | 14536315 | Nov 2014 | US |
Child | 15011253 | US | |
Parent | 14180887 | Feb 2014 | US |
Child | 14536315 | US |