This application is related to and claims priority to Japanese patent application no. 2007-75496 filed on Mar. 22, 2007 in the Japan Patent Office, and incorporated by reference herein.
1. Field
The embodiments discussed herein are directed to an image recognition device which processes an image using computing hardware and/or software, and more specifically an image recognition device which rotates an input image at real time, including methods and computer readable media thereof.
2. Description of the Related Art
Most of image processes used for image recognition are currently executed by software, but some of functions are being implemented in computing hardware. This is because high-speed image process by parallel processing which is an advantage of hardware is required.
For example, Japanese Patent Application Laid-Open Nos. 11-252353, 6-333032, 2006-13803 and 10-222655 disclose a device in which some or all of functions are implemented in hardware and an image process such as rotation is executed on original images.
Details of the processing flow is as follows.
(100) Data about the original image 2 for one frame is stored in a memory.
(102) A rotting angle of the rotation image 1 to be output is determined before the process starts.
(103) The coordinates of pixels to be referred to are calculated as to which pixel of the original image 2 correspond to each pixel of the output rotation image 1.
The coordinates of the original image 2 to be referred to are obtained by the following calculating formula.
x=X cos θ+Y sin θ
y=−X sin θ+Y cos θ
θ: rotating angle, (x,y): the coordinate of the original image 2, (X,Y): the coordinate of the output image 1
(104) The pixel data of the coordinates to be referred to from the original image 2 are read from the memory. When pixels on which the calculated coordinates correspond to an intermediate value are not present, values of the pixels should be created by interpolation. For this reason, values of peripheral pixels are read.
(105) The data about the output rotation image 1 is output. A portion which requires interpolation is subject to the interpolation so as to be output.
(106) The processes (103) to (105) are successively executed on all the pixels of the output rotation image 1 so that data is created.
In
A time chart of the processes (100) to (106) is shown in
After the input of the original image 2 into the memory is completed, the processes (103) to (105) are executed successively on all the pixels of the output rotation image 1 (106).
When these image processes are executed by software, since the calculation is carried out on all the pixels of the output rotation image 1, a calculating amount is large, and an immense amount of time is required in a software process.
Therefore, when the processes are performed in hardware in order to increase the speed of the processes, it is necessary to once store the original image 2 for one frame, and thus a large memory is required. Further, since complicated calculating processes such as trigonometrical function and division process are included, a circuit size for the calculating process becomes huge.
It is an aspect of the embodiments discussed herein to provide an image recognition device for generating an output rotation image from input original image data, including a memory section being capable of storing data of lines including pixels of the original image data to be processed and lines including pixels to be used for an interpolating process therein, an angle-to-sine/cosine converting section obtaining an X component and a Y component where a pixel interval of the original image data is an oblique side based on a rotating angle, a coordinate searching section calculating reference coordinates of the output rotation image for the original image using the X component and the Y component in order of inputting the original image data, an interpolating section executing an interpolating process when the reference coordinates are not present, and a rearranging section rearranging converted data acquired in the interpolating process so as to output data of the output rotation image.
These together with other aspects and advantages which will be subsequently apparent, reside in the details of construction and operation as more fully hereinafter described and claimed, reference being had to the accompanying drawings forming a part hereof, wherein like numerals refer to like parts throughout.
An outline of an image rotating process in an image recognition device according to an embodiment is described. In the image recognition device according to the embodiment, as shown in
As shown in
Since it is not necessary to once store an original image for one frame in a memory unlike a conventional technique, the capacity of the memory for storing an original image can be reduced by this process.
When a portion to be interpolated at the time of creating the output rotation image 12 is thickened, the rotating process and an image enlarging process can be simultaneously executed. A size of the range 13 to be processed is determined in advance.
In the image recognition device of the embodiment, a tilt of the rotation to be used for the image process is specified by using not an angle but an X-axial component (cosine) and a Y-axial component (sine) where a pixel interval of the output rotation image is an oblique (inclined) line, for example, an oblique side of a triangle as shown in
The angle is converted into sine and cosine by using, for example, a conversion table. As a result, a size of a computing unit to be used for calculation can be reduced. The values of sine and cosine are expressed by a binary fixed decimal point, and n-digit decimal parts are prepared. The calculation is made with the pixel interval of the original image being 1. A coordinate of the original image to be referred to is also expressed by a binary fixed decimal point having n-digit decimal part. As a result, the interval of one pixel can be expressed by ½n interval.
A constitution of the image recognition device in the embodiment is described below.
The original image data 21 is composed of a timing pulse showing a head of a frame and image data. The parameter data 22 is data showing the rotating angle, a center position and an enlargement factor.
The memory section 23 is an image buffer memory having a capacity for enabling an original image for two lines to be saved. The angle-to-sine/cosine converting section 24 converts the rotating angle given as the parameter data 22 into data of an X-axial component (cosine) and a Y-axial component (sine) using a conversion table provided to the angle-to-sin/cosine converting section 24. The coordinate searching section 25 calculates a reference coordinate of the output rotation image for the original image using the X-axial component and the Y-axial component. The memory read address control section 26 generates addresses of four pixels around a coordinate to be referred to be used for the interpolating process in the memory section 23. The interpolating section 27 generates data of the coordinate to be referred to according to the interpolating process. The rearranging section 28 rearranges converted data obtained at the interpolating process at the time of outputting them.
The image recognition device 20 processes the original image data 21 on a processing area by processing area per frame.
(1) A timing pulse showing a head of a frame is received from the input original image data 21.
(2) Upon reception of the timing pulse of the original image in (1), the conversion table is referred to in the angle-to-sine/cosine converting section 24. As a result, the rotating angle and the enlargement factor in the parameter data 22 are converted into the X-axial component (cosine) and the Y-axial component (sine) of the pixel interval in the output rotation image, and the processing effective range is calculated so that an effective range flag is set.
(3) A coordinate to be referred to is calculated in the coordinate searching section 25.
(4) The memory read address control section 26 generates read addresses of four pixels around the coordinate to be referred to.
(5) Data values of the four pixels obtained at (3) are read from the memory section 23.
(6) The interpolating section 27 calculates a value of one pixel from the four pixels using the bilinear method.
(7) The processes (3) to (6) are executed by a pipeline process according to the input of the image data of the original image. This process is executed on all the effective range of the image.
(8) When the data creation for one frame is ended, the rearranging section 8 executes a rearranging process, and outputs a rotated image.
The above process is expressed by a flow chart in
Upon reception of the timing pulse of the image at S1, the angle-to-sine/cosine converting section 24 converts the rotating angle in the parameter data 22 into the X-axial component (cosine) and the Y-axial component (sine) of the pixel interval of the output rotation image using the conversion table at S2. The angle-to-sine/cosine converting section 24 calculates the effective range.
The coordinate to be referred to is calculated at S3 (S301). Read addresses of four pixels around the coordinate to be referred to in the memory section 23 are generated at S3 (S302). The data values of the four pixels are read at S3 (S303). Four processes in the interpolating process (S304) according to the bilinear method are executed in a pipeline manner according to the input of the image at S3. When the creation of data for one frame is ended, the data are rearranged so as to be output at S4.
The angle-to-sine/cosine converting section 24 does not carry out sin and cos calculations but converts the rotating angle and the enlargement factor into the X-axial component and the Y-axial component using the conversion tables. As a result, the circuit size can be reduced, and the converting speed can be increased.
The coordinate searching section 25 specifies the tilt of the rotation by using not an angle but the X-axial component (cosine) and the Y-axial component (sine) where the pixel interval of the output rotation image is an oblique side.
As to the X-axial component and the Y-axial component, the pixel interval of the original image (X-axial direction and Y-axial direction) is 1. The X-axial component and the Y-axial component are expressed by binary fixed decimal point, and n-digit decimal part is prepared. In this expressing method, the rotation through ±90° is supported, and the X-axial component does not have symbol information. In the case of the regular rotation (0 to 90°) shown in
The method for calculating the X-axial component (cosine) and the Y-axial component (sine) of the output rotation image is as described below.
X-axial component=pixel interval (in the case 1 of the enlargement factor 100%)×cos θ
Y-axial component=pixel interval (in the case 1 of the enlargement factor 100%)×sin θ
When the pixel interval of the output rotation image is reduced to half of the pixel interval of the original image, the pixel generated from the same area of the original image is doubled, and the output rotation image is enlarged two times. When
The X component and the Y component which are the same as the rotation are used for specifying the enlargement. When the pixel interval is 1, the size of the output rotation image is 100% with respect to the original image. Since the size of the output rotation image is determined in inverse proportion to a length of the pixel interval, the calculating formula for the X-axial component and the Y-axial component of the output rotation image described in
X-axial component=100/enlargement factor (%)×cos θ
Y-axial component=100/enlargement factor (%)×sin θ
In the above calculation and the calculation in
In
Q=P0W0+P1W1+P2W2+P3W3.
Here, Pi (i=0 to 3) represents the value of the pixel Pi, and Wi (i=0 to 3) represents the weighting factor of the pixel Pi.
A horizontal distance X1 between the target pixel Q and the pixel P0 becomes “a,” and a vertical distance Y1 between the pixel Q and the pixel P0 becomes “b” in
In this example, the weighting factor Wi (i=0 to 3) is determined by using the above distances, and the respective weighting factors are obtained by formulas: W0=(1−a)×(1−b), W1=a×(1−b), W2=(1−a)×b, and W3=a×b. Here, “a” represents the decimal part of the X axis of the output rotation coordinate Q, and “b” represents the decimal part of the Y axis of the output rotation coordinate Q.
When the process in
Data for one line of the original image data is input into the memory section 23 at S12. A determination is made at S13 whether the data for one line input at S2 is within the effective range. As a result of the determination, when the data is not within the effective range (NO at S13), the process returns to S12 and data for next one line is input into the memory section 23.
When the data for one line input into the memory section 23 is within the effective range at S13 (YES at S13), a coordinate of a pixel where the process in the processing area is started and a coordinate of a pixel where the process is ended are calculated at S14. Details of this process are mentioned later.
The coordinate of the pixel where the process is started obtained at S14 is output as the coordinate of the pixel to be processed from the coordinate searching section 25 at S15.
A determination is made at S16 whether the coordinate of the pixel to be processed is the coordinate of the pixel where the process is ended obtained at S14. When the coordinate is not the end coordinate (NO at S6), a coordinate of a pixel next to the pixel to be processed is output at S17, and the process returns to S16.
When the end coordinate is output and the coordinate to be processed is the end coordinate at S16 (YES at S16), a determination is made at S18 whether next input one line is within the effective range. When the one line is within the effective range (YES at S18), the one line is input into the memory section 23 at S19 and the process moves to a next processing area (area shift). When the next input one line is not within the effective range at S18, the process on all the lines within the effective range is completed, and thus this process is ended.
The effective range 43 refers to a range between the top corner (the value Y is the smallest) and the bottom corner (the value Y is the largest) of the four corners 42. The lines of the original image 41 within the effective range 43 are subject of the coordinate calculating process.
The processing area refers to an area where the coordinates of the pixels to be output are searched, namely, a range between two lines. For example, the processing area n refers to a range between line n and line n+1, and the processing area n+1 refers to a range between line n+1 and line n+2. The line shift refers to moving of the process to the next processing area, and for example, the process is moved from the processing area n to the processing area n+1. The processing area is a range stored in the memory section 23 in the original data.
The start coordinate obtained at S14 refers to a coordinate of a pixel of the output rotation image on the leftmost side in the processing area (the value X is the smallest). The end coordinate refers to a coordinate of a pixel of the output rotation image on the rightmost side in the processing area (the value X is the largest). For example, in the processing area n, a pixel 44 is the pixel of the start coordinate, and a pixel 45 is the pixel of the end coordinate.
(200) The coordinates of the four corners of the rectangle and the effective range to be subject to the coordinate calculating process are calculated at the head of the frame.
(202) The sequence waits until original image data corresponding to the effective range is input.
(203) The start coordinate and the end coordinate in the processing area are calculated at the head of the processing area.
(204) Coordinates in the processing area from the start coordinate to the end coordinate are successively output.
(205) The process from (20) to (4) is executed on all the processing areas within the effective range.
This flow is executed every time when a frame of original image data is input. In the process of
Details of the calculation of the start coordinate in the processing area is described below.
When the start coordinate is calculated, any one of the coordinates of the four corners on the output rotation image obtained at the head of the frame is used as a start point, and adjacent pixels are searched one by one. A portion of the area (processing area) in the memory section 23 having data which is searched firstly is a start coordinate. The searching refers to comparing reference coordinates of pixels of the output rotation image along Y-axis one by one and simultaneously moving the same.
In
As shown in
In
The processing area is compared with the Y-axial coordinate of the searching coordinate at S24. When both of them do not match (NO at S24), the X component in
As a result of the comparison of the Y-axial coordinates, when the processing area< the upper left corner of the output rotation image does not hold at S22 (NO at S22), the searching is started on the upper left corner of the output rotation image at S27.
The processing area is compared with the Y-axial coordinate of the searching coordinate at S28. When both of them do not mach (NO at S28), the X component in
If a determination is made at S21 that the image rotating process is the reverse rotation (reverse rotation at S21), in
The processing area is compared with the Y-axial coordinate of the searching coordinate at S33. When both of them do not match (NO at S33), the X component in
As a result of the comparison of the Y-axial coordinates, when the processing area< the lower left corner of the output rotation image does not hold at S31 (NO at S31), the searching is started on the lower left corner of the output rotation image at S36.
The processing area is compared with the Y-axial coordinate of the searching coordinate at S37. When both of them do not match (NO at S37), the X component in
The processing area is compared with the Y-axial coordinate of the searching coordinate at S44. When both of them do not match (NO at S44), the X component in
As a result of the comparison of the Y-axial coordinates, when the processing area< the lower right corner of the output rotation image does not hold at S42 (NO at S42), the searching is started on the lower right corner of the output rotation image at S47.
The processing area is compared with the Y-axial coordinate of the searching coordinate at S48. When both of them do not mach at S48 (NO at S48), the X component in
If, the determination is made at S41 that the image rotating process is the reverse rotation (reverse rotation at S41), in
The processing area is compared with the Y-axial coordinate of the searching coordinate at S53. When both of them do not match (NO at S53), the X component in
As a result of the comparison of the Y-axial coordinates, when the processing area< the upper right corner of the output rotation image does not hold at S51 (NO at S51), the searching is started on the upper right corner of the output rotation image at S56.
The processing area is compared with the Y-axial coordinate of the searching coordinate at S57. When both of them do not match (NO at S57), the X component in
The process sequence numbers (220) to (230) in
When the coordinate moves from the coordinate (223) to the right adjacent one, it is out of the processing area, and thus the coordinate cannot move to right adjacent one. Since the lower movement is enabled on the coordinate (223), the jump flag is turned ON. Since the coordinate cannot move from the coordinate (223) to right adjacent one and the jump flag is ON, the coordinate moves to a lower adjacent coordinate (224), and the jump flag is turned OFF.
Since the searching coordinate cannot move from the coordinate (224) to lower adjacent one, the jump flag is held OFF, but since the coordinate can move to right adjacent one, moves to a right adjacent coordinate (225). Since the coordinate can move from the coordinate (225) to lower adjacent one, the jump flag is turned ON, and since can move also to right adjacent one, moves to a right adjacent coordinate (226).
The searching coordinate cannot move from the coordinate (226) to right adjacent one because it is out of the processing area. Since the jump flag is ON on the coordinate (225), the searching coordinate moves to a coordinate (227) lower adjacent to the coordinate (225), and the jump flag is turned OFF.
Since the searching coordinate cannot move from the coordinate (227) to lower adjacent one, the jump flag is held OFF, and moves to a right adjacent coordinate (228). Since the searching coordinate cannot move from the coordinate (228) to lower adjacent one, the jump flag is turned OFF, but since can move to right adjacent one, moves to a right adjacent coordinate (229).
When the searching coordinate moves from the coordinate (229) to a right adjacent one, it is out of the processing area. For this reason, the searching coordinate cannot move to right adjacent one. Since the searching coordinate can move from the coordinate (229) to lower adjacent one, the jump flag is turned ON. Since the searching coordinate cannot move from the coordinate (229) to right adjacent one and the jump flag is ON, it moves to a lower adjacent coordinate (230), and the jump flag is turned OFF. Since the coordinate (230) is the end coordinate, the coordinate calculating process is ended.
In such a manner, the reference coordinates of the output rotation image for the original image in the processing area per frame of the input image are calculated, interpolated, rearranged and output. This process is executed every time data for one line of the original image is input into the memory section 23. For this reason, the capacity of the memory section 23 can be reduced.
A determination is made at S62 whether the rotating process is the regular rotation or the reverse rotation based on the rotating angle given as the parameter data 22. As a result, when the rotating process is the regular rotation (the value of the rotating angle is positive) (regular rotation at S62), a determination is made at S63 that the searching coordinate is the end coordinate.
As a result of the determination at S63, when the searching coordinate is not the end coordinate (NO at S63), if a coordinate where the jump flag is ON is absent and a lower adjacent coordinate is within the processing area at S64 (YES at S64), the jump flag is turned ON and the coordinate lower adjacent to the searching coordinate is set as a jump coordinate at S65. When a coordinate where the jump flag is ON is not absent and the lower adjacent coordinate is not within the processing area at S64 (NO at S64), the process at S65 is skipped.
A determination is made at S66 whether a coordinate right adjacent to the searching coordinate is within the processing area. When this coordinate is within the processing area (YES at S66), and the searching coordinate is moved to the right adjacent coordinate, and the right adjacent coordinate is output at S67, so that the process returns to S63. When the coordinate right adjacent to the searching coordinate is not within the processing area at S66 (NO at S66), the searching coordinate is moved to the jump coordinate and this coordinate is output and the jump flag is turned OFF at S68. Thereafter, the process returns to S63.
When the searching coordinate is the end coordinate at S63 (YES at S63), this process is ended. As a result of the determination at S62, when the process is the reverse rotation (the value of the rotating angle is negative) (reverse rotation at S62), in
As a result of the determination at S69, when the searching coordinate is not the end coordinate (NO at S69), the process goes to S70. When a coordinate where the jump flag is ON is absent and the right adjacent coordinate is within the processing area at S70 (YES S70), the process goes to S71. The jump flag is turned ON and the coordinate right adjacent to the searching coordinate is set as the jump coordinate at S71. When a coordinate where the jump flag is ON is not absent and a right adjacent coordinate is not within the processing area (NO at S70), S71 is skipped.
A determination is made at S72 whether a coordinate upper adjacent to the searching coordinate is within the processing area. When the coordinate is within the processing area (YES at S72), the searching coordinate is moved to the upper adjacent coordinate and this coordinate is output at S73. Thereafter, the process returns to S69. If the determination is made at S72 that the coordinate right adjacent to the searching coordinate is not within the processing area (NO at S72), the searching coordinate is moved to the jump coordinate and this coordinate is output, and the jump flag is turned OFF at S74. Thereafter, the process returns to S69.
When the searching coordinate is the end coordinate at S69 (YES at S69), this process is ended. In such a manner, the reference coordinates from the start coordinate to the end coordinate of the output rotation image for the original image in the processing area are calculated in the order of inputting the original image data.
The reference coordinates are interpolated so that the converted data are obtained. The converted data acquired in the interpolating process are rearranged so that data of the output rotation image are output.
According to this embodiment, since the pixel data of the output rotation image can be generated in the order of input original image data, all the original image data do not have to be stored, and thus the memory capacity can be reduced.
When the specification of the rotating angle is changed and the conversion tables are used for the coordinate conversion, this is substituted for the calculation such as trigonometrical function and division. Therefore, a circuit required for such a calculation can be reduced.
Further, the enlarging process and the simultaneous rotating process contribute to the reduction in circuits.
The embodiments can be implemented in computing hardware (computing apparatus) and/or software, such as (in an unlimiting example) any computer that can store, retrieve, process and/or output data and/or communicate with other computers. The computer (e.g., the image recognizer device 20, etc.) comprises a controller (CPU) and a display device. The results produced can be displayed on a display of the computing hardware. A program/software implementing the embodiments may be recorded on computer readable media comprising computer-readable recording media. The program/software implementing the embodiments may also be transmitted over a transmission communication media. Examples of the computer-readable recording media include a magnetic recording apparatus, an optical disk, a magneto-optical disk, and/or a semiconductor memory (for example, RAM, ROM, etc.). Examples of the magnetic recording apparatus include a hard disk device (HDD), a flexible disk (FD), and a magnetic tape (MT). Examples of the optical disk include a DVD (Digital Versatile Disc), a DVD-RAM, a CD-ROM (Compact Disc-Read Only Memory), and a CD-R (Recordable)/RW. Examples of transmission communication media include a carrier-wave signal, an optical signal, etc. Further, according to an aspect of the embodiments, any combinations of the described features, functions and/or operations, including benefits thereof, can be provided and/or achieved.
The many features and advantages of the embodiments are apparent from the detailed specification and, thus, it is intended by the appended claims to cover all such features and advantages of the embodiments that fall within the true spirit and scope thereof. Further, since numerous modifications and changes will readily occur to those skilled in the art, it is not desired to limit the inventive embodiments to the exact construction and operation illustrated and described, and accordingly all suitable modifications and equivalents may be resorted to, falling within the scope thereof.
Number | Date | Country | Kind |
---|---|---|---|
2007-075496 | Mar 2007 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5111192 | Kadakia | May 1992 | A |
5793378 | Truong et al. | Aug 1998 | A |
5966138 | Tanaka | Oct 1999 | A |
6097855 | Levien | Aug 2000 | A |
6643415 | Fukai et al. | Nov 2003 | B1 |
7215830 | Knee et al. | May 2007 | B2 |
7345784 | Osawa et al. | Mar 2008 | B2 |
7391930 | Shih et al. | Jun 2008 | B2 |
7411593 | Prakash et al. | Aug 2008 | B2 |
Number | Date | Country |
---|---|---|
06-333032 | Dec 1994 | JP |
10-222655 | Aug 1998 | JP |
11-205576 | Jul 1999 | JP |
11-252353 | Sep 1999 | JP |
2002-288649 | Oct 2002 | JP |
2006-013803 | Jan 2006 | JP |
Number | Date | Country | |
---|---|---|---|
20080232717 A1 | Sep 2008 | US |