The present invention contains subject matter related to Japanese Patent Application JP 2006-315164 filed in the Japanese Patent Office on Nov. 22, 2006, the entire contents of which being incorporated herein by reference.
1. Field of the Invention
The present invention relates to an image processing apparatus and an image processing method for processing an image captured using a wide-angle lens.
2. Description of the Related Art
In the past, there has been proposed a technique in which a necessary area in an image captured, for example, using a fisheye lens is designated by a user, distortion aberration of fisheye image data of the designated area is corrected, and the corrected image is displayed on a monitor. The captured image is not only a still image but also a moving image (for example, see Patent Document 1).
In this Patent Document 1, fisheye image data (24) is displayed on part of a monitor (28), and a display area (25) is designated by designating part of the displayed data with a control stick (27). A plane reproduced image (29) obtained by correcting distortion aberration of the designated fisheye image data (24) is displayed on the monitor (28). When the fisheye image data (24) is tried to be added to part of the plane reproduced image (29) as just described, it is necessary to read pixel data of the plane reproduced image (29) and reconstruct the image.
Patent Document 1: Japanese Patent Application Laid-Open No. 2000-324386 (paragraph [0010], FIG. 1, FIG. 2)
When a high-pixel sensor is used as an image-capturing sensor when data such as fisheye image data is added to part of an entire screen as described above, it takes time to read the above pixel data.
In view of the above circumstances, it is desirable to provide a technique capable of efficiently performing processing when a wide-field image captured using a wide-angle lens is added to part of an entire screen.
According to an embodiment of the present invention, there is provided an image processing apparatus. The image processing apparatus includes a thinning-out section generating thinned-out line data of thinned-out data constituted by a plurality of the thinned-out line data, the thinned-out data being obtained by thinning out wide-field image data with distortion captured using a wide-angle lens, and sequentially outputting the thinned-out line data at every predetermined timing, a switching section performing switching from an output of the wide-field image data to an output of the thinned-out line data in response to the predetermined timing, and a buffer temporarily storing the wide-field image data and the thinned-out data constituted by the plurality of thinned-out line data outputted after the switching.
In the embodiment of the present invention, the thinned-out line data generated by the thinning-out section is outputted to the buffer after the switching from the wide-field image data to the thinned-out lined data. Thus, the thinned-out data corresponding to the wide-field image data is efficiently generated.
According to the embodiment of the present invention, the thinning-out section includes a first addition section adding pixel data of respective pixels constituting the wide-field image data in units of a predetermined number of pixels in a line direction and outputting added pixel data obtained by the addition, and a second addition section adding line data constituted by a predetermined number of the added pixel data sequentially outputted in units of a predetermined number of lines in a column direction and outputting the thinned-out line data obtained by the addition. In the embodiment of the present invention, the separation between the line direction and the column direction enables efficient thinning-out processing.
According to the embodiment of the present invention, the image processing apparatus further includes a conversion section converting RGB data of the wide-field image into luminance/color difference data containing luminance data and color difference data, and the thinning-out section generates the thinned-out line data of the luminance/color difference data obtained by the conversion by the conversion section. In the embodiment of the present invention, after the conversion into the luminance/color difference data having a smaller data amount than the RGB data, the thinned-out data is generated, which makes it possible to reduce the calculation amount and realize efficient processing.
According to the embodiment of the present invention, the thinning-out section generates the thinned-out line data in the same format as that of the luminance/color difference data obtained by the conversion by the conversion section. Consequently, the luminance/color difference data subjected to the thinning-out processing can be faithfully reproduced in the thinned-out line data.
According to the embodiment of the present invention, the image processing apparatus further includes a correction section correcting the distortion of an image of a selected area selected out of the wide-field image, and a synthesis section synthesizing a distortion-corrected image obtained by the correction section and the thinned-out data including a highlighted area obtained by highlighting the selected area as image data of one screen. In the embodiment of the present invention, the highlighted area is included in the thinned-out data, so that a user can recognize which portion of a wide-field entire image (image of thinned-out data) is highlighted. Additionally, the image obtained by correcting distortion of the selected area image and the thinned-out image are synthesized, so that the user can see the distortion-corrected image while seeing the thinned-out image.
An image processing method according to an embodiment of the present invention includes generating thinned-out line data of thinned-out data constituted by a plurality of the thinned-out line data, the thinned-out data being obtained by thinning out wide-field image data with distortion captured using a wide-angle lens, sequentially outputting the thinned-out line data at every predetermined timing, performing switching from an output of the wide-field image data to an output of the thinned-out line data in response to the predetermined timing, and temporarily storing the wide-field image data and the thinned-out data constituted by the plurality of thinned-out line data outputted after the switching.
As described above, according to the embodiment of the present invention, in the processing in which the thinned-out data is added to part of the wide-field image, efficient processing can be performed.
An embodiment of the present invention will be described below with referenced to the drawings.
The image sensor 2 is a sensor which converts light taken in through the wide-angle lens 1 into an electrical signal. For example, a CMOS (Complementary Metal-Oxide Semiconductor) sensor, a CCD (Charge Coupled Device), or the like is used. As the wide-angle lens 1, a lens having a wide viewing angle or a wide field angle is used, and, for example, a lens having a field angle of 45 degrees or more is used, but the wide-angle lens 1 is not limited to this. As an example of the wide-angle lens 1, a fisheye lens, a PAL (Panoramic Annular Lens) (annular lens) which can obtain an annular image, or the like is cited. Alternatively, by using two fisheye lenses having a field angle of about 180°, an image can be captured with an all-round (spherical space (360°)) field of view.
The color processing circuit 3 includes a YCrCb conversion circuit (not shown) which coverts RGB data outputted from the image sensor 2 into YCrCb data (YUV data) containing luminance data and color difference data. The color processing circuit 3 additionally includes, although not shown, an AE (Automatic Exposure) operation circuit which controls light intensity, an AWB (Automatic White Balance) operation circuit which controls white balance, and a gain adjustment circuit which performs gain adjustment on each RGrGbB pixel filter by a nonlinear table.
As described in
The distortion correction processing circuit 4 mainly performs distortion correction processing on an image with distortion processed by the color processing circuit 3. Further, the distortion correction processing circuit 4 performs coordinate interpolation processing of the pixel data (above YCrCb data) containing the luminance data and the color difference data in the distortion correction processing as will be described later. The memory 6 functions as a buffer in the processing of the distortion correction processing circuit 4. In particular, the memory 6 has a function of storing pixel data (RGB data or YCrCb data) of a selected area image described later. A DMA (Direct Memory Access) circuit not shown may be connected to the memory 6. In this case, data is inputted to and outputted from the memory 6 independently of the control of the controller 5.
The controller 5 performs overall control on the entire image processing apparatus 10 and is constituted, for example, by a CPU (Central Processing Unit).
The image compression circuit 7 compresses the image processed by the distortion correction processing circuit 4 in a predetermined format. As the compression format, for example, JPEG (Joint Photographic Expert Group) is used. However, any other publicly known format may be used appropriately.
The display interface 8 is an interface which outputs the image processed by the distortion correction processing circuit 4 to the display unit 12. The display interface 8 generates output data, for example, in an NTSC (National Television System Committee) format, a PAL (Phase Alternating Line) format, or the like.
The USB interface 9 controls an output of the image processed by the image compression circuit 7 to the external device 13 such as an external computer. Incidentally, the above display interface 8 also may output the image compressed by the image compression circuit 7.
The input device interface 11, for example, receives a signal of an operation input by a user. As the input device 14, for example, a mouse, a keyboard, a switch device, a touch sensor, a controller of a game device, a stick-shaped operation device graspable by the user, or some other device is cited.
Incidentally, the “image” in this embodiment includes a still image, but in actuality, it is processed as a moving image in many cases.
The color processing circuit 3, the distortion correction processing circuit 4, the thinning-out processing circuit 15, the controller 5, and so on can each realize processing, for example, by at least either of an FPGA (Field Programmable Gate Array) or a DSP (Digital Signal Processor).
Hereinafter, the image in
The selected area in the entire image 25 is not limited to taking the form of being selected by the user. For example, a form in which a preset area in the entire image 25 is selected is conceivable. Information indicating this area (positional information, etc.) in this case is only necessary to be previously stored in a ROM, an external storage, or the like not shown. A form in which in a case where some specific area in the entire image 25 is automatically recognized in addition to the above case where the selected area is preset, the automatically recognized “specific area” is processed as the “selected area” is also conceivable. Alternatively, a form in which an image area of a portion detected in the entire image 25 by each of various sensors not shown is processed as the “selected area” is also conceivable. In this case, examples of the sensors include a light sensor, a temperature sensor, a pressure sensor, a sound sensor, a humidity sensor, a vibration sensor, a gas sensor, and other various sensors.
The controller 5 can perform switching between outputs of the entire image 25, the distortion-corrected image 35, and the synthetic image 36 shown in
Incidentally, the mode in which the entire image 25 in
Next, forms of the installation state of a camera equipped with the wide-angle lens 1 will be described.
When the viewpoint is at a center O of a sphere 31 with reference to
In addition to these, obliquely upper half and obliquely lower half fields of view are also conceivable. As just described, various hemispherical fields of view can be obtained by variously setting the orientation or inclination of the fisheye lens when the fisheye lens is installed.
Incidentally, in
Next, the operation of the image processing apparatus 10 thus constituted will be described.
The controller 5 converts the light taken in through the fisheye lens 1 into the electrical signal by the image sensor 2 (step 501). The controller 5 performs the color processing by the color processing circuit 3 (step 502). In the color processing, particularly the RGB data is converted into the YCrCb data. In this conversion processing, a 4:4:4 format has only to be adopted. Alternatively, thinning-out in a 4:2:2 format, a 4:1:1 format, or a 4:2:0 format may also be performed. The YCrCb data is stored in the memory 6 (step 503).
Incidentally, conversion equations from RGB to YCrCb are expressed by the following equations (1) to (3). However, in these equations, numerical values of each term may slightly vary.
Y=0.299R+0.587G+0.114B (1)
Cr=0.500R−0.419G−0.081B (2)
Cb=−0.169R−0.331G+0.500B (3)
The controller 5 performs the distortion correction processing on the selected area image in the entire image 25 in response to the input information from the input device interface 11 and generates the distortion-corrected image 35 by the distortion correction processing circuit 4 and stores it (step 504). Typically, the distortion correction processing circuit 4 finds an address of the memory 6 corresponding to coordinates of a pixel of a display plane displayed by the display unit 12 by coordinate calculation processing as will be described later. Namely, coordinate conversion processing is performed. The address of the memory 6 corresponds to correction coordinates of the selected area image. The correction coordinates, that is, memory address, found by the calculation includes a decimal point in many cases. Accordingly, the distortion correction processing circuit 4 generates the distortion-corrected image 35 by generating the pixel data by the coordinate interpolation processing.
Meanwhile, the thinning-out processing circuit 15 generates the thinned-out image 45 from the YCrCb data (data on the wide-field image 25) stored in the memory 6 in step 503 and stores this thinned-out image 45 with the wide-field image 25 in a frame buffer 27 (see
The controller 5 outputs the generated entire image 25 (distortion-corrected image 35, or synthetic image 36) shown in
Incidentally, the order of step 504 and step 505 does not matter, or these steps may be performed simultaneously.
Next, the above step 504 will be described in detail. First, the distortion correction by the distortion correction processing circuit 4 will be described.
In
Here,
Next, the coordinate conversion processing for the distortion correction will be described.
First, the incident angle (elevation angle) 0 of P (u, v, w) is found with reference to
OP=(u2+v2+w2)1/2 (4)
θ is expressed by the following equation.
θ=arccos(w/OP) (5)
The image height h (see
When the image height h is found, a point P′ (u, v, 0) which is vertically below the point P is scaled up or down to the point Q (x, y) (see
OP′=OPsin θ (6)
x=uh/OP′ (7)
y=vh/OP′ (8)
When the coordinates (correction coordinates) of the point Q are calculated as described above, the coordinates of the point Q shown in
Here, as described above, the coordinates of the point Q found by the operation (memory address found by the operation) for the distortion correction are not in a one-to-one correspondence with each pixel constituting the distortion-corrected image 35 of the display plane 32 in many cases. Accordingly, the distortion correction processing circuit 4 performs interpolation using the coordinates found by the operation. As shown in
Then, by performing the above coordinate interpolation processing on the point Q based on the pixel data on these four points (luminance data (Y data) and color difference data (CrCb data) on the respective four points), pixel data after the coordinate conversion of the point Q is acquired. There are various methods for the interpolation processing. For example, there are methods of calculating a mean value and calculating a median value from the pixel data of the four points. When the pixel data of the four points are YCrCb data and their format is 4:2:0, regarding the point Q, it is only necessary to linearly interpolate the luminance data (Y) and use color difference data of these four points themselves as the color difference data (Cr, Cb).
The thinning-out processing circuit 15 includes a line FIFO (First In First Out) 21, a thinning-out circuit 22, a data selector 23, a line buffer 24, a DMA circuit 26, and a frame buffer 27.
The line FIFO 21 sequentially inputs pixel data of the wide-field image 25 as an actual image (hereinafter referred to as wide-field image data) line by line. The line means each line in the lateral direction of the image, and line data means data of each line constituting the image data.
The data selector 23 performs switching from an output of the wide-field image data to an output of thinned-out line data generated by the thinning-out circuit 22 in response to a predetermined timing. The data selector 23 performs switching from the wide-field image data to the thinned-out line data generated by the thinning circuit 22 and outputs this thinned-out line data to the buffer. Thus, the thinned-out data corresponding to the wide-field image data is efficiently generated.
The line buffer 24 inputs the wide-field image data and the thinned-out line data selected and outputted by the data selector 23 and sequentially outputs them line by line to the DMA circuit 26. The line buffer 24 is, for example, a buffer having a FIFO function.
The DMA circuit 26 transfers the wide-field image data and the thinned-out line data to the frame buffer 27 according to address control by the timing of a line count-up signal Cu2 outputted from the thinning-out circuit 22. Consequently, the wide-field image data and data of the thinned-out image 45 (hereinafter referred to as thinned-out data) for display are temporarily stored in the frame buffer 27. For example, a DRAM is used as the frame buffer 27 or like, but the frame buffer 27 or the like is not limited to this.
Next, the operation of the thinning-out processing circuit 15 in step 505 will be described.
With reference to
The data selector 23 performs switching from the output of the wide-field image data from the line FIFO 21 to the output of the thinned-out line data generated by the thinning-out circuit 22 at a timing when the count value of the line count-up signal Cu2 (line count-up signal for thinned-out line data described later) outputted from the thinning-out circuit 22 becomes a predetermined count value.
Here, the operation of generating the thinned-out line data by the thinning-out circuit 22 will be described with reference to
In the first counter 38, the predetermined target value is set in the fifth register 55. This target value is the thinning-out value, that is, a value representing a thinning-out ratio. The target value is a thinning-out value indicating a thinning-out ratio in the line direction in the pixel data adding circuit 37, and, for example, in the case of thinning-out to ⅛ in the line direction, the target value is set to “8”. In response to the line synchronizing signal Sy1 sent from the controller 5 or the like, the reset signal receiving unit 75 receives it as the reset signal. When the reset signal is received, the selector 73 selects “0”, and “0” is set in the sixth register 56. The first adder 63 adds “0” and “−1”, and outputs “−1” to the selector 73 and the second adder 64. The selector 73 sets this “−1” in the sixth register 56. The second adder 64 outputs “7” by adding the target value “8” and “−1”. Such an operation is repeated (step 1601), and a countdown from “8” to “0” is performed by the second adder 64. The count-up signal Cu1 is outputted at a timing when the second adder 64 outputs “0”. Thus, when the target value is “8”, the first counter 38 outputs one count-up signal Cu1 with respect to eight pixel clocks (step 1602). This count-up signal Cu1 is inputted to the pixel data adding circuit 37.
In the pixel data adding circuit 37, the count-up signal Cu1 from the first counter 38 is inputted as the reset signal to the selector 71. The selector 71 selects “0” in response to the reset signal, and “0” is set in the second register 52. Out of pixel data constituting the wide-field data stored in the memory 6, first, for example, the first pixel data of the uppermost line is stored in the first register 51. The adder 61 adds “0” and this first pixel data, and this first pixel data is selected by the selector 71 and stored in the second register 52. Then, the second pixel data is stored in the first register 51. The adder 61 adds the first pixel data stored in the second register 52 and the second pixel data stored in the first register 51. Such an operation is repeated, and pixel data are added in units of a predetermined number of pixels by the adder 61. Typically as shown in
Incidentally, typically the pixel data stored in the memory 6 are burst read every eight lines. Consequently, the number of accesses to the memory 6 is reduced. one pixel data is, for example, eight to ten bits, and the addition of eight pixel data leads to an increase of only three bits.
The pixel data adding circuit 37 repeats the above operation, and as shown in
Alternatively, it is also suitable to provide a plurality (one-eighth the number of pixels corresponding to one line) of such pixel data adding circuits 37 and perform parallel processing. The numbers of line data adding circuits 47, counters 38, and so on provided in this case have only to correspond to the number of pixel data adding circuits 37.
The line data adding circuit 47 operates in the same manner as the pixel data adding circuit 37. The line data adding circuit 47 takes in the above line data L and adds the line data L in the column direction in response to each line synchronizing signal Sy1 using the temporary buffer 40 (step 1604).
The second counter 48 operates in the same manner as the first counter 38. In the second counter 48, a predetermined thinning-out value (for example, “8”) is set in the seventh register 57. The second counter 48 outputs one count-up signal Cu2 for every eight line synchronizing signals Sy1 with the synthetic line synchronizing signal Sy2 as the reset signal (step 1605). As shown in
In the line data adding circuit 47, the selector 72 selects 0 every time the synthetic line synchronizing signal Sy2 is inputted. Meanwhile, the first pointer 39 increments the point value by “1” in response to each line synchronizing signal Sy1. In response to each synthetic line synchronizing signal Sy2, the selector 72 selects 0 and outputs a point value “8” to the temporary buffer 40 to update the address. Thus, as shown in
The second pointer 49 takes in the predetermined read clock φ′, and at this timing, reads the thinned-out line data L8 of one line from the temporary buffer 40. Then, the thinning-out circuit 22 outputs the read thinned-out line data L8 to the line buffer 24 in response to the line count-up signal (at a timing of the synthetic line synchronizing signal Sy2).
When the thinned-out line data L8 of one line from the line buffer 24 is outputted, the data selector 23 performs the switching to the output of the wide-field image data from the line FIFO 21 as described above, and outputs this wide-field image data to the frame buffer 27 via the line buffer 24 and the DMA circuit 26.
Here, the relationship among the rates of the pixel clock φ, a read clock of the frame buffer 27, and a clock of the line buffer 24 is as follows.
“pixel clock φ<<read clock of frame buffer 27<<clock of line buffer 24”
In other words, the line buffer 24 is almost always in an empty state. Hence, as shown in
Incidentally, typically the wide-field image data and the thinned-out data stored in the frame buffer 27 are stored as synchronized data. This is because line-by-line synchronization is possible due to the above difference among the respective clocks. However, it is also no problem to make the rates of the wide-field image data and the thinned-out data different.
As described above, the thinning-out circuit 22 according to this embodiment generates the thinned-out line data separately in the line direction and the column direction by the pixel data adding circuit 37 and the line data adding circuit 47, which enables efficient thinning-out processing.
Further, in this embodiment, after the conversion into the YCrCb data having a smaller data amount than the RGB data, the thinned-out data is generated. This makes it possible to reduce the calculation amount and realize efficient processing.
In this case, in the thinning-out circuit 22, as shown in
Embodiments according to the present invention are not limited to the embodiment described above, and other various embodiments can be conceived.
For example, in the above embodiment, the RBG data is converted into the YCrCb data, and the thinned-out data is generated regarding the pixel data after the conversion. However, the thinned-out data may be generated regarding RGB pixel data.
In the above embodiment, the thinning-out ratio is set to ⅛, but this setting can be appropriately changed. Note, however, that a power of two facilitates control.
Number | Date | Country | Kind |
---|---|---|---|
2006-315164 | Nov 2006 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5986699 | Nishihara | Nov 1999 | A |
6710801 | Kubo | Mar 2004 | B1 |
6891569 | Matsuoka et al. | May 2005 | B1 |
7202888 | Tecu et al. | Apr 2007 | B2 |
7570280 | Ozaki | Aug 2009 | B2 |
7714936 | Martin et al. | May 2010 | B1 |
7813585 | Higurashi et al. | Oct 2010 | B2 |
7848575 | Watanabe et al. | Dec 2010 | B2 |
20010030707 | Fujii | Oct 2001 | A1 |
20020064341 | Fauver et al. | May 2002 | A1 |
20040027346 | Naske | Feb 2004 | A1 |
20040091083 | Jurgen | May 2004 | A1 |
20050058360 | Berkey et al. | Mar 2005 | A1 |
20050174590 | Kubo | Aug 2005 | A1 |
20060109343 | Watanabe et al. | May 2006 | A1 |
20060187305 | Trivedi et al. | Aug 2006 | A1 |
20060239534 | Sumida et al. | Oct 2006 | A1 |
20060268129 | Deng | Nov 2006 | A1 |
20060268300 | Suzuki | Nov 2006 | A1 |
20070047805 | Ohtsu | Mar 2007 | A1 |
Number | Date | Country |
---|---|---|
2000-324386 | Nov 2000 | JP |
2002-354299 | Dec 2002 | JP |
2002-358537 | Dec 2002 | JP |
2005-286954 | Oct 2005 | JP |
2006216871 | Aug 2006 | JP |
2006-287597 | Oct 2006 | JP |
Number | Date | Country | |
---|---|---|---|
20080118180 A1 | May 2008 | US |