This Non-provisional application claims priority under 35 U.S.C. §119(a) on Patent Application No. 2006-303264 filed in Japan on Nov. 8, 2006, the entire contents of which are hereby incorporated by reference.
1. Field of the Invention
The present invention relates to a motion vector detecting method, a motion vector detecting device, and an imaging system for use in motion compensation predictive encoding in moving image compression encoding.
2. Description of the Related Art
In recent years, there has been a rapid progress in practical moving image compression encoding techniques, such as MPEG (Moving Picture Experts Group) having highly efficient encoding ability and the like, which have come into widespread use in camcorders, mobile telephones, and the like. In moving image compression encoding techniques, such as MPEG and the like, motion compensation prediction is used in which only a displacement of a subject and difference data between images are encoded so as to efficiently compress image data. When the motion compensation prediction is performed, it is necessary to detect a motion vector indicating a displacement of a subject.
To detect such a motion vector, a block matching method is widely used. In a motion vector detecting method employing the block matching method, image data of a block composed of a predetermined number of pixels in a current image which are to be encoded (hereinafter referred to as a target image or a target block) is compared with a region which is located in the vicinity of the target block in the same space in an image preceding the current image and is larger than the target block (hereinafter referred to as a reference region) so as to obtain the degree of correlation between the target image and the reference image by calculating a predetermined evaluation function. Thereafter, a location of a reference block (a block which is in the reference region and has the same size as that of the target block) which matches the target block best (correlation is strong) is obtained, a distance and a direction between the location of the reference block and the location of the target block are detected as a motion vector.
As a method for detecting a reference block having strong correlation, for example, there is a well-known method in which correlation coefficients of upper, lower, left, and right locations are obtained with reference to a predetermined search start location (referred to as a reference point) in a reference region, the reference point is shifted to a location where correlation is highest, and the search location is shifted so that a highest level of correlation is obtained while performing correlation calculation with respect to a direction for which a correlation coefficient has not yet been calculated (One-at-a-Time method).
In the block matching method, the motion vector detection requires a large processing amount, so that it takes a long time to complete the process. Therefore, various attempts have been made to speed up the process. For example, a motion vector detecting device has been disclosed in which a plurality of devices for calculating the evaluation function (e.g., difference accumulating devices) are prepared so as to perform parallel processing, thereby speeding up the process (see, for example, Japanese Unexamined Patent Application Publication No. 2006-13873).
Generally, in many data processing devices, when data is transferred and is read from and written to a storage device, a technique of increasing the processing speed by packing a P (P is any natural number) pieces of data is employed. Therefore, also in the above-described motion vector detecting device, it is contemplated that the target image and the reference image are packed so as to increase the processing speed.
However, a boundary between reference blocks does not necessarily coincide with a boundary between pieces of packed data. Therefore, when a plurality of reference blocks are read from a storage device which stores data of a reference region while shifting the locations thereof, the same data may be redundantly read out, likely leading to a significant deterioration in read efficiency.
The present invention has been achieved in view of the above-described problems. An object of the present invention is to provide a technique of detecting a motion vector without redundantly reading data of a reference region when the data of the reference region is packed and stored in a memory device.
To achieve the object, according to an embodiment of the present invention, a method is provided for detecting a motion vector in units of a block using a rectangular target image packed in units of a first pixel number and stored in a target image storing section and a rectangular reference image packed in units of a second pixel number and stored in a reference image storing section when moving image compression encoding is performed. The method comprises a target image reading step of reading the target image from the target image storing section, a reference image reading step of reading image data having the same size as that of the target image and, in addition, at least one or more reference image packing units of extra image data from the reference image storing section, and a correlation degree calculating step of calculating a degree of correlation between the target image and each of a plurality of reference blocks, wherein each reference block is a block of image data having the same size of that of the target image within the image data read out in the reference image reading step, and the reference blocks have locations different from each other.
Hereinafter, embodiments of the present invention will be described with reference to the accompanying drawings. Like parts are indicated by like reference numerals throughout the specification and will not be repeatedly described.
(Configuration of Motion Vector Detecting Device 100)
As shown in
(Function of Each Component)
The motion vector detection control section 101 controls operations of the target image storing section 102, the reference image storing section 103, the target image reading section 104, reference image reading section 105, the target image temporarily accumulating section 106, the reference image temporarily accumulating section 107, and the SAD calculating section 108 as follows.
The target image storing section 102 stores image data to be encoded (referred to as a target image or a target block) as it is packed in units of a predetermined number of pixels (referred to as a first pixel number).
The reference image storing section 103 stores the whole or a part of image data (referred to as a reference image) of a region (referred to as a reference region) in an image preceding in time a current image, as it is packed in units of a predetermined number of pixels (referred to as a second pixel number), where the region is located in the vicinity of the same space location as that of a target block and is larger than the target block. A reference image is used so as to perform a search with respect to a motion vector of a target image and encoding (specifically, a difference between the target image and the reference image is encoded). The first pixel number and the second pixel number are both referred to as a packing data number.
Note that it is assumed in this embodiment that a target image has a size (search size) of 16 pixels×16 pixels as shown in
The number of pieces of packed data which are required when a search is performed with respect to a motion vector point (0, 0) can be seen from
However, when the location of a reference image is shifted from this, a larger amount of image data needs to be read. For example, the number of pieces of packed data which are required when a search is performed with respect to a motion vector point (1, 0) is 5 pieces of packed data (horizontal direction)×16 lines (vertical direction) as shown in
The target image reading section 104 reads out a target image stored in the target image storing section 102, which is required for SAD calculation, in units of the first pixel number (in this example, P pixels) in accordance with a control of the motion vector detection control section 101.
The reference image reading section 105 reads a reference image stored in the reference image storing section 103, which is required for SAD calculation, in units of the second pixel number (in this example, P pixels) and in an amount corresponding to the reference read size in accordance with a control of the motion vector detection control section 101.
The target image temporarily accumulating section 106 temporarily accumulates a target image read out by the target image reading section 104. More specifically, the target image temporarily accumulating section 106 has a buffer area having a capacity corresponding to a piece of packed data of a target image (i.e., P pixels of data) and performs an FIFO (First In First Out) operation. Note that the output of the target image temporarily accumulating section 106 is supplied to the SAD calculating sections 108-1 to 108-n in accordance with a control of the motion vector detection control section 101.
The reference image temporarily accumulating section 107 temporarily accumulates a reference image read out by the reference image reading section 105. More specifically, the reference image temporarily accumulating section 107 has a buffer area having a capacity corresponding to two pieces of packed data of a reference image (i.e., 2P pixels of data) and performs an FIFO operation.
The SAD calculating sections 108-1 to 108-n (in this embodiment, it is assumed that n=5) calculate an SAD value defined as described below, using a target image supplied from the target image temporarily accumulating section 106 and a reference image supplied from the reference image temporarily accumulating section 107.
The SAD value is defined by:
SAD=Σ|Ref(Mx+x,My+y)−Org(x,y)|
where Ref(Mx+x, My+y) indicates a pixel value at a pixel location (Mx+x, My+y) in a reference block located at a location (Mx, My) relative to a target block, and Org(x, y) indicates a pixel value at a pixel location (x, y) in the target block.
Also, the output of the reference image temporarily accumulating section 107 is supplied to the SAD calculating sections 108-1 to 108-n in accordance with a control of the motion vector detection control section 101. Specifically, two pieces of packed data (i.e., 8 pixels of data) accumulated in the reference image temporarily accumulating section 107 are decomposed into pixel units of data by the motion vector detection control section 101, which are in turn transferred to the SAD calculating sections 108-1 to 108-n. Specifically, assuming that 8 pixels of data accumulated in the reference image temporarily accumulating section 107 are represented by d1 to d8, 4 pixels of data d1 to d4 are transferred to the SAD calculating section 108-1, 4 pixels of data d2 to d5 are transferred to the SAD calculating section 108-2, 4 pixels of data d3 to d6 are transferred to the SAD calculating section 108-3, 4 pixels of data d4 to d7 are transferred to the SAD calculating section 108-4, and 4 pixels of data d5 to d8 are transferred to the SAD calculating section 108-5 (see
Thereby, SAD values can be simultaneously obtained for 5 points which are shifted pixel by pixel in the horizontal direction. Specifically, an SAD calculating section which calculates the SAD value of a search point (0, 0) is the SAD calculating section 108-1. An SAD calculating section which calculates the SAD value of a search point (1, 0) is the SAD calculating section 108-2. An SAD calculating section which calculates the SAD value of a search point (4, 0) is the SAD calculating section 108-5. This is generalized as follow: search points whose SAD values can be simultaneously calculated are a point (4×P, Q), a point (4×P+1, Q), a point (4×P+2, Q), a point (4×P+3, Q), and a point (4×P+4, Q) (note that P and Q are integers).
The search result storing section 109 temporarily accumulates an SAD value which can be used in a motion vector search with respect to an image other than a target image.
The searched point storing section 110 stores a flag for determining, for example, whether or not a search has been performed (an SAD value has been obtained) with respect to each point in a reference image. In this embodiment, the flag is of two bits. Note that it is assumed that, if the value of the flag is “10b” (b indicates that the number is a binary number), the flag indicates that, although a search has already been completed, an SAD value is not stored in the search result storing section 109; if the value of the flag is “01b”, the flag indicates that a search has been completed and an SAD value is stored in the search result storing section 109; if the value of the flag is “00b”, the flag indicates that a search has not been performed.
(Operation of Motion Vector Detecting Device 100)
An operation of the motion vector detecting device 100 will be described, assuming a case where a minimum SAD value is searched for from a reference point (0, 0).
As a process during the start of the flow (initialization), the search result storing section 109 is cleared (time t0 in
As a first process, a search is performed with respect to the reference point (0, 0) (S100). For the search, the flow goes to the process of SUB101. In this process, initially, the motion vector detection control section 101 determines whether or not a search has been performed with respect to the reference point (0, 0), with reference to the status of a corresponding flag in the searched point storing section 110 (SUB101).
In this example, since the value of the flag is “00b” (see
Initially, the motion vector detection control section 101 controls the reference image reading section 105 to read out a reference image. To perform a search with respect to a motion vector point (0, 0), packing data P2-2b to P17-5 (a total of 64 pieces of packed data) are required. In accordance with the reference read size, P2-2b to P17-6 (a total of 80 pieces of packed data) are read out. By this reading, a search can be performed with respect to a point (1, 0), a point (2,0), a point (3,0), and a point (4,0) as well as the reference point (0, 0). For reference,
Thus, when data is supplied to the SAD calculating section 108, the SAD calculating section 108 calculates an SAD value (performs a search). When the search is completed, the SAD value (e.g., “20”) of the reference point (0, 0) is returned to the motion vector detection control section 101.
The motion vector detection control section 101 rewrites a flag in the searched point storing section 110 corresponding to the reference point (0, 0). Specifically, as shown in
A search can be performed with respect to the search points (1, 0) to (4, 0) at the same time when a search is performed with respect to the reference point (0, 0). The calculated SAD values of the search points (1, 0) to (4, 0) with respect to which a search has been performed at the same time are stored into the search result storing section 109 (see t1 in
In the next process, a search is performed with respect to a point to the right of the reference point (S101). Since the reference point is now the point (0, 0), an SAD value of the search point (1, 0) is to be calculated. To calculate it, the motion vector detection control section 101 determines whether or not a search has been performed with respect to the search point (1, 0), with reference to the status of the flag in the searched point storing section 110 (SUB101).
For example, as shown in
Therefore, for this point, it is not necessary to newly read out a target image and a reference image and perform SAD calculation. A search can be performed only by reading out an SAD value (e.g., “19”) corresponding to the search point (1, 0) stored in the search result storing section 109 (SUB104).
Note that, since information about the search point (1, 0) is not subsequently required, the information is deleted from the search result storing section 109 so as to free memory.
Also in this step, for a point with respect to which a search has been performed, a corresponding flag in the searched point storing section 110 is rewritten (see
When S10 is completed, the flow goes to the next step (S102). In S102, a search is performed with respect to a point to the left of the reference point. Since the reference point is now (0, 0), an SAD value of a search point (−0, 0) is to be calculated. To calculate it, the motion vector detection control section 101 determines whether or not a search has been performed with respect to the search point (−0, 0), with reference to the status of a corresponding flag in the searched point storing section 110 (SUB101).
For example, as shown in
A search can be performed with respect to search points (−4, 0) to (0, 0) at the same time when a search is performed with respect to the search point (−0, 0). Among them, the calculated SAD values of the search points (−4, 0) to (−2, 0) are stored into the search result storing section 109 (see t3 in
When a search has been completed with respect to the points to the left and right of the reference point, the SAD values are compared (S103). Since the SAD value of “19” of the right search point is smaller than the SAD value of “20” of the reference point (0, 0), the reference point is shifted to the right search point (1, 0), and the flow goes to S101 again.
In the next process, a point to the right of the reference point (1, 0) is searched for (S101). Since the reference point is now (1, 0), an SAD value of the search point (2, 0) is to be calculated. To calculate it, the motion vector detection control section 101 determines whether or not a search has been performed with respect to the search point (2, 0), with reference to the value of a corresponding flag in the searched point storing section 110 (SUB101).
For example, as shown in
The next search is to be performed with respect to a point to the left of the search point (2, 0). However, a flag corresponding to this point in the searched point storing section 110 is “10b”, i.e., a search has already been completed (referred to as an invalid point), so that a search is not performed with respect to this point.
In comparison of SAD values in S103, since the SAD value of “18” of the right point is smaller than the SAD value of “19” of the reference point, the reference point is shifted to the right point (2, 0) and step S101 is executed again.
Thereafter, a search is similarly performed. Note that, when a search needs to be performed with respect to a point whose flag in the searched point storing section 110 has a value of “00b”, a search can be performed simultaneously with respect to five points enclosed by a thick quadrangular frame in
As described above, in this embodiment, it is not necessary to redundantly read out data from the reference image storing section 103, so that the read efficiency is not deteriorated.
For example, if an SAD value is obtained for each point using the One-at-a-Time method, reading of a target image and a reference image and an SAD calculation need to be performed as many as 15 times until a search is completed with respect to the above-described reference regions having the SAD values, as shown in
In other words, even when an attempt is made to read out only a search size of reference image which is packed in units of P pixels, it is highly likely to read unnecessary image data at the same time. Assuming the example of this embodiment, it is necessary to temporarily read out 20 pixels (horizontal direction)×16 pixels (vertical direction) so as to eventually read out 16 pixels (horizontal direction)×16 pixels (vertical direction). In this case, 4 pixels (horizontal direction)×16 pixels (vertical direction) located at left and right portions are unnecessary data (data which is not used in the process). The unnecessary data is conventionally not used and is discarded. In this embodiment, the unnecessary data is utilized to a maximum extent so as to perform a search with respect to all possible points (SAD values are calculated). Therefore, it is possible to remove the step of reading out data at the same location again and newly perform SAD calculation. In other words, it is possible to perform and complete a search quickly.
Note that, when a search is performed simultaneously with respect to five points as described in this embodiment, the following two reading orders allow a search with respect to the motion vector point (0, 0), for example.
A first reading order is packing pixel data “P2-1b→P2-2b→P2-3b→P3-1b→ . . . →P17-3b” required for a search with respect to the search points (−4, 0), (−3, 0), (−2, 0) and (−1, 0). A second reading order is packing pixel data “P2-2b→P2-3b→P2-4b→P3-2b→ . . . →P17-4b” required for a search with respect to the search points (0, 0), (1, 0), (2, 0), (3, 0) and (4, 0). Hereinafter, a point which has two image data reading orders when a motion vector search is performed is referred to as a “redundant search point”.
The motion vector detecting device 100 may be modified so that a search is performed with respect to the search point (0, 0) only when any one of the two reading orders is performed. For example, during reading with the first reading order, a search may not be performed with respect to the search point (0, 0), and a search may be performed with respect to only the four search points (−4, 0), (−3, 0), (−2, 0) and (−1, 0), and during reading with the second reading order, a search may be performed with respect to the search point (0, 0). In other words, when there are two reading orders for a search with respect to a motion vector point (in
Thereby, a search is performed simultaneously with respect to four points instead of five points (see
Also, by enlarging the size of reference image data to be read out in the horizontal or vertical direction, the number of points with respect to which a search can be performed simultaneously can be increased, thereby making it possible to further increase the speed of a search.
For example, as compared to the reference image “P2-2b→P2-3b→P2-4b→P3-2b→ . . . →P17-4b” required for a search with respect to the search points (0, 0), (1, 0), (2, 0), (3, 0) and (4, 0), the read size is enlarged by one packing pixel in the horizontal direction, resulting in a reference image “P2-2b→P2-3b→P2-4b→P2-5b→P3-2b→ . . . →17-4b→P17-5b”. Thereby, a search can be performed simultaneously with respect to a total of nine points (search points (5, 0), (6, 0), (7, 0) and (8, 0) as well as the above-described search points).
On the other hand, in the case of a reference image “P2-2b→P2-3b→P2-4b→P3-2b→ . . . →P17-4b→P18-2b→P18-3b→P18-4b” which is obtained by enlarging a read size by one packing pixel in the vertical direction, a search can be performed simultaneously with respect to a total of ten points (search points (0, 1), (1,1), (2,1), (3,1) and (4,1) as well as the above-described search points). Also, by enlarging a read size both in the horizontal and vertical directions, the number of points with respect to which a search can be performed simultaneously can be increased, resulting in an increase in the processing speed.
Also, even when the read size is enlarged as described above, a redundant search point is present. For example, when the read size is enlarged in the horizontal direction, the search points (0, 0) and (8, 0) are redundant search points. When the read size is enlarged in the vertical direction, the search points (0, 0), (0, 1), (4, 0) and (4, 1) are redundant search points. For example, in the former case, a search may be performed simultaneously with respect to a total of eight points excluding the search point (8, 0), and in the latter case, a search may be performed simultaneously with respect to a total of eight points excluding the search points (4, 0) and (4, 1). Thereby, the occurrence of a redundant search point can be prevented, and the number of SAD calculation sections can be most reduced. In this case, the number of points with respect to which a search is performed simultaneously is a multiple of the packing data number P.
The search size may not be fixed in a process. For example, a search may be performed with respect to not only 16×16 pixels, but also 8×16 pixels, 16×8 pixels, and 8×8 pixels, and further 4×4 pixels (referred to as multi-search size search). In this case, a plurality of search sizes are used for a search, and an optimum result is selected.
If a search (SAD value calculation) is performed in units of a block of 4×4 pixels (sub-block), the result can be used to produce a result of a search (SAD value calculation) with another search size. Therefore, to achieve each search shown in this embodiment, the search is performed in units of 4×4 pixels (the minimum search size). In this case, 16 SAD calculating sections 108 are required so as to calculate an SAD value for 16×16 pixels in parallel.
Every time a search is completed with respect to each point, an SAD value for the 16×16-pixel size is calculated, and is transferred to the motion vector detection control section 101 or the search result storing section 109, thereby making it possible to achieve the same search process as that which has been shown in this embodiment.
Also, SAD values for other sizes, such as 4×4 pixels, 8×8 pixels, 16×8 pixels, 8×16 pixels and the like, are calculated and stored into the search result storing section 109. Each search is performed in units of 16×16 pixels. After all searches are completed, search points can be determined by considering which search size is most effective based on an SAD value for 16×16 pixels and SAD values for other sizes stored in the search result storing section 109.
Also, one-pixel thinning may be performed in the vertical direction, and the pixel may be used to perform an interlaced search (SAD value calculation). Thereby, an SAD value which would be obtained by a non-thinning search (referred to as a progressive search) can be produced. This is a considerably effective technique when interlaced encoding is performed.
Also, in this embodiment, since the SAD values of points with respect to which a search can be performed simultaneously are stored into the search result storing section 109 in the course of a search, the search result storing section 109 needs to have a considerably large capacity.
Such a capacity, which is previously secured, can be reduced by using a predetermined technique to reduce the amount of data stored in the search result storing section 109 when an amount of data exceeding a predetermined threshold is stored.
For example, as a first method, all search result data is erased from the search result storing section 109. At the same time, for a motion vector point corresponding to the erased data, a corresponding flag in the searched point storing section 110 is set to be “00b” indicating that a search has not been performed. If the result is required for a subsequent search, a search is performed again. Thereby, the upper limit of the capacity of the search result storing section 109 can be compensated for.
As another method, when a value which is larger than the SAD value of a search point when the storage means capacity exceeds the threshold is stored in the search result storing section 109, the search result data is erased. At the same time, for a motion vector point corresponding to the erased data, a corresponding flag in the searched point storing section 110 is set to be “10b” indicating that a search has been performed. Thereby, only search result data which is not required for a subsequent search can be erased.
Also, the latter method may be first executed, and when the amount of data exceeds the threshold after the execution, the former method may be executed. By combining both the methods in this manner, a more effective method is achieved.
Also, even when the target image storing section 102 or the reference image storing section 103 is divided into a plurality of storage means, a similar effect can be obtained. Specifically, when an image is stored in the target image storing section 102 where P=4 as in this embodiment (see
Thus, if the target image storing section 102 or the reference image storing section 103 is divided into a plurality of storage means, then when each storage means is operated while being supplied with clock, clock supply can be suspended for a storage means which is not being used, thereby making it possible to effectively reduce power consumption.
Note that, also in Embodiment 2, it is assumed that the search size is 16 pixels×16 pixels, the packing data number P is 4, and the number of SAD calculating sections n is 5.
It has been assumed in Embodiment 1 that only the SAD value of a reference point is transferred to the motion vector detection control section 101, while the SAD values of the other points with respect to which a search can be performed simultaneously are stored into the search result storing section 109. In this embodiment, however, the SAD values of all points (five points) with respect to which a search can be performed are transferred to the motion vector detection control section 201.
The motion vector detection control section 201 controls SAD value calculation as described below. In this embodiment, among the SAD values of all points (five points) with respect to which a search can be performed, a point having a minimum SAD value is selected and processed.
Specifically, processes will be described with reference to
Initially, an SAD value is calculated for a reference point (0, 0) (see S200 in
In the example of
Note that, in SUB203, flags corresponding to all the five points in the searched point storing section 110 are rewritten to “10b”.
In S201 of
In S202, a search is to be performed with respect to a point (3, 0) to the left of the reference point (4, 0). However, since a search has been performed with respect to the point (3, 0) (since a corresponding flag in the searched point storing section 110 is “10b”), a search is not performed again.
Next, in S203, the SAD values are compared. As a result of the search with respect to the left and right points, an SAD value which is smaller than the SAD value of 15 of the reference point (4, 0) has not been detected in the example of
In S205, a search is performed with respect to a point (4, 1) below the reference point (4, 0) and points (5, 1) to (8, 1) with respect to which a search can be performed at the same time so as to obtain a point having a minimum SAD value. In this example, the SAD value of 14 of the point (4, 1) is assumed to be the result of the downward point search.
In S206, a search is performed with respect to a point (4, −1) above the reference point (4, 0) and points (5, −1) to (8, −1) with respect to which a search can be performed at the same time so as to obtain a point having a minimum SAD value. In this example, the SAD value of 16 of the point (5, −1) is assumed to be the result of the upward point search.
In S207, the SAD values are compared. As a result of the upward and downward point searches, the SAD value of 14 of the lower point (4, 1) is smaller than the SAD value of 15 of the reference point (4, 0). Therefore, the reference point is shifted to (4, 1), and the flow returns to the process of S201 again.
In S201, a search is to be performed with respect to the point (5, 1) to the right of the reference point (4, 1). However, since a search has already been performed with respect to the point (5, 1), a search is not performed again.
In S202, a search is to be performed with respect to points to the left of the reference point (4, 1). A search is performed simultaneously with respect to the points (0, 1) to (4, 1). In this example, as a result of the search, the SAD value of 8 of the point (1, 1) is minimum and this is set to be the result of the leftward point search.
Next, in S203, the SAD values are compared. In this example, the SAD value of 8 of the lower point (1, 1) is smaller than the SAD value of 14 of the reference point (4, 1), so that the reference point is shifted to the point (1, 1). By performing similar processes, a search is performed with respect to points above and below and to the left and right of this reference point. In this example, since the SAD values are not smaller than 8, a reference block corresponding to the reference point (1, 1) is the result of the motion vector detection.
As described above, in this embodiment, every time a search is performed with respect to a plurality of points, a point having a minimum SAD value is selected from those points and the next search is performed. Therefore, the search result storing section 109, which is required in Embodiment 1, is not required. Therefore, a more compact motion vector detecting device can be achieved.
Note that, also in this embodiment, the method for preventing redundant search points as described in Embodiment 1 (“the packing data number P=the number of points with respect to which a search is performed simultaneously”) is effective. Also, in this embodiment, by eliminating redundant search points, the number of flags stored in the searched point storing section can be reduced. For example, if a search has been performed with respect to the search point (0, 0), a search has also been performed with respect to the search points (1, 0) to (3, 0). In other words, a flag can be shared by these four points.
In this embodiment, each point has two search statuses, i.e., “not yet searched” or “already searched”. Therefore, the flag is not necessarily of two bits as in Embodiment 1.
Also, the method of Embodiment 1 for reading out a reference image which is enlarged in the horizontal or vertical direction so as to increase the number of points with respect to which a search is performed simultaneously, is significantly effective for this embodiment.
Note that, when a reference point is shifted, the process speed can be increased by previously confirming the value of a corresponding flag in the searched point storing section 110.
The motion search method of this embodiment comprises a step of receiving a search result and determining the next search point (referred to as a next search point determining step) and a step of actually executing a search to obtain a search result (referred to as an SAD value calculating step). By repeatedly performing the method, a motion vector can be detected.
It is now assumed that, in the SAD value calculating step, for example, a search is performed with respect to four points located as shown in
A search is to be performed with respect to a point “2-05” to the right of the reference point “2-04”. However, since a search has already been performed with respect to this point, a search is to be performed with respect to a point “2-03” to the left of the reference point “2-04”. If a search has been completed with respect to the “2-03” point (the searched point storing section 110 determines whether or not the search has been completed), a search is to be performed with respect to a point “3-04” below the point reference point “2-04”. If a search has been completed with respect to the point “3-04”, a search is to be performed with respect to a point “1-04” above the reference point “2-04”. If a search has been completed with respect to all surrounding search points, “2-04” is set as a motion vector and the search process is ended.
It is also assumed that a search is performed with respect to the four points located as shown in
A search is to be performed with respect to a point “2-06” to the right of the reference point “2-05”. However, since a search has already been performed with respect to this point, a search is to be performed with respect to the point “2-04” to the left of the reference point “2-05”. Since a search has been completed with respect to this point, a search is to be performed with respect to a point “3-05” below the reference point “2-05”. If a search has already been completed with respect to the point “3-05”, a search is to be performed with respect to a point “1-05” above the reference point “2-05”. If a search has been completed with respect to all surrounding points, the reference point “2-05” is set as a motion vector and the search process is ended. It is also assumed that a search is performed with respect to the four points located as shown in
As described above, when a search is performed with respect to four points, the next point search location for each point is previously determined based on the value of a corresponding flag in the searched point storing section 110. Thereby, immediately after a search is completed, the next search can be performed with respect to a determined point, leading to an increase in the processing speed.
Embodiment 3 is an exemplary device for performing SAD value calculation using sub-sampled image data instead of all image data having a search size in order to calculate an SAD value with higher speed.
The motion vector detecting device of Embodiment 3 has the same components as those of Embodiment 1 (
In the target image storing section 102 and reference image storing section 103, as shown in
Only an image to be used as a target image may be read out with the following order: T1-1c→T1-3c→T2-2c→T2-4c→T3-1c→T3-3c→ . . . →T16-2c→T16-4c (see
Only an image to be used as a reference image may be read out with two reading orders. The orders depend on the value of the x coordinate of a motion vector. When the x coordinate of the motion vector is even, the image is read out with the following order: P2-2c→P2-4c→P2-6c→P3-3c→P3-5c→P3-7c→ . . . →P17-3c→P17-5c→P17-7c (see
When the image data of
When the image data of
As described above, although this embodiment is different from Embodiments 1 and 2 in the locations of points with respect to which a search is performed simultaneously, sub-sampled pixels can be used to perform a motion vector search (SAD value calculation) with high speed by performing a process similar to that of Embodiment 1 or 2.
Note that the method of reducing the number of redundant search points and the method of increasing the number of points with respect to which a search is performed simultaneously by enlarging a reference image in the horizontal or vertical direction, which are described in Embodiments 1 and 2, are also considerably effective for this embodiment.
The optical system 401 brings incident image light into focus on the sensor 402.
The sensor 402 is driven by the timing control circuit 408, accumulates image light focused by the optical system 401, and converts the image light into an electrical signal (photoelectric conversion).
The AD converter 403 converts the electrical signal output from the sensor 402 into a digital signal, and outputs the digital signal to the image processing circuit 404.
The image processing circuit 404 performs image processing, such as a Y/C process, an edge process, enlargement and reduction of an image, an image compression/decompression process, and the like. The image-processed signal is output to the recording transfer circuit 406. The image processing circuit 404 comprises a signal processing device 405 for image compression. The signal processing device 405 is any of the motion vector detecting devices of Embodiments 1 to 3.
The recording transfer circuit 406 records or transfers an output of the image processing circuit 404 to a medium.
The reproduction circuit 407 reproduces a signal recorded or transferred by the recording transfer circuit 406.
The timing control circuit 408 controls timing of operations of the optical system 401, the sensor 402, the AD converter 403 and the image processing circuit 404.
The system control circuit 409 controls an operation of the whole system.
Note that the image processing by the signal processing device 405 of this embodiment is applicable not only to a signal based on image light focused on the sensor 402 via the optical system 401, but also to, for example, when an image signal input as an electrical signal from an external device is processed.
The packing unit of target images is not necessarily the same as the packing unit of reference images. For example, the present invention is also applicable when target images are packed in units of eight pixels while reference images are packed in units of four pixels, i.e., target images and reference images are packed in different units.
As described above, the motion vector detecting method of the present invention can detect a motion vector without redundantly reading out data of a reference region when the data of the reference region is packed and stored in a memory device. Therefore, the motion vector detecting method of the present invention is useful as a motion vector detecting device, an imaging system or the like for use in motion compensation predictive encoding in moving image compression encoding.
Number | Date | Country | Kind |
---|---|---|---|
2006-303264 | Nov 2006 | JP | national |