The present invention relates to motion estimation generally and, more particularly, to a method and/or apparatus for implementing a cache prefetch during motion estimation.
Motion estimation in video compression exploits temporal redundancy within a video sequence for efficient coding. A block matching technique is widely used in the motion estimation. A purpose of the block matching technique is to find another block from a video object plane that matches a current block in a current video object plane. The matching block can be used to discover temporal redundancy in the video sequence thereby increasing the effectiveness of interframe video coding. Since a full motion estimation search for all possible hypothetical matches within a search range is intensive in terms of processing power, alternative sub-optimal techniques are commonly used. The sub-optimal techniques search a low number of hypotheses while maintaining a minimal amount of quality degradation.
A problem in implementing sub-optimal search patterns is the resulting non-subsequent memory accesses. The non-subsequent memory accesses are caused by having a starting point for each search pattern in a given iteration being determined by the best hypothesis of the previous iteration. Such accesses to memory involve stalls (i.e., dead cycles within a core pipeline) which occur between each iteration. The stalls increase the number of processing cycles used in the motion estimation to perform the block matching. The stalls are conventionally avoided by reading the entire search area into an internal zero wait state memory. However, reading the entire search area is a large internal expense and uses large die size memory.
It would be desirable to implement a cache prefetch during motion estimation.
The present invention concerns an apparatus having a cache and a processor. The cache may be configured to (i) buffer a first subset of reference samples of a reference picture to facilitate a motion estimation of a current block and (ii) prefetch a second subset of the reference samples while a first search pattern is being tested. The first search pattern used in the motion estimation generally defines multiple motion vectors to test. The reference samples of the second subset may be utilized by a second search pattern in the motion estimation of the current block. The prefetch of the second subset may be based on a geometry of the first search pattern and scores of the motion vectors already tested. The processor may be configured to calculate the scores of the motion vectors by a block comparison of the reference samples to the current block according to the first search pattern.
The objects, features and advantages of the present invention include providing a method and/or apparatus for implementing a cache prefetch during motion estimation that may (i) test a low possible number of hypotheses, (ii) be aware of a current search pattern, (iii) be aware of test scores already calculated for the search pattern, (iv) prefetch additional samples to a cache before the additional samples are considered, (v) prefetch the additional samples based on probabilities, (vi) avoid stalls and/or (vii) be implemented in a digital signal processor.
These and other objects, features and advantages of the present invention will be apparent from the following detailed description and the appended claims and drawings in which:
A cache mechanism aware of search pattern memory accesses and of a sum of absolute differences of previously examined hypotheses may be used to predict with certainty, and/or with a probability threshold, the memory accesses that may be used later in a motion estimation process. After the memory accesses are predicted, the corresponding data (e.g., reference samples) may be prefetched to the cache to avoid stalling a core processor.
Referring to
The circuit 104 may be directly coupled to the circuit 102 to exchange data and control information. The circuit 104 may be coupled to the circuit 106 to exchange data. An input signal (e.g., IN) may be received by the circuit 104. A bitstream signal (e.g., BS) may be presented by the circuit 104.
The signal IN may be one or more analog video signals and/or one or more digital video signals. The signal IN generally comprises a sequence of progressive-format frames and/or interlace-format fields. The signal IN may include synchronization signals suitable for synchronizing a display with the video information. The signal IN may be received in analog form as, but is not limited to, an RGB (Red, Green, Blue) signal, an EIA-770 (e.g., YCrCb) signal, an S-video signal and/or a Composite Video Baseband Signal (CUBS). In digital form, the signal IN may be received as, but is not limited to, a High Definition Multimedia Interface (HDMI) signal, a Digital Video Interface (DVI) signal and/or a BT.656 signal. The signal IN may be formatted as a standard definition signal or a high definition signal.
The signal BS may be a compressed video signal, generally referred to as a bitstream. The signal BS may comprise a sequence of progressive-format frames and/or interlace-format fields. The signal BS may be compliant with a VC-1, MPEG and/or H.26x standard. The MPEG/H.26x standards generally include H.261, H.264, H.263, MPEG-1, MPEG-2, MPEG-4 and H.264/AVC. The MPEG standards may be defined by the Moving Pictures Expert Group, International Organization for Standards, Geneva, Switzerland. The H.26x standards may be defined by the International Telecommunication Union-Telecommunication Standardization Sector, Geneva, Switzerland. The VC-1 standard may be defined by the document Society of Motion Picture and Television Engineer (SMPTE) 421M-2006, by the SMPTE, White Plains, N.Y.
The circuit 102 may be implemented as a processor. The circuit 102 may be operational to perform select digital video encoding operations. The encoding may be compatible with the VC-1, MPEG or H.26x standards. The circuit 102 may also be operational to control the circuit 104. In some embodiments, the circuit 102 may implement a SPARC processor. Other types of processors may be implemented to meet the criteria of a particular application. The circuit 102 may be fabricated as an integrated circuit on a single chip (or die).
The circuit 104 may be implemented as a video digital signal processor (e.g., VDSP) circuit. The circuit 104 may be operational to perform additional digital video encoding operations. The circuit 104 may be controlled by the circuit 102. The circuit 104 may be fabricated as an integrated circuit on a single chip (or die). In some embodiments, the circuits 102 and 104 may be fabricated on separate chips.
The circuit 106 may be implemented as a dynamic random access memory (e.g., DRAM). The circuit 106 may be operational to store or buffer large amounts of information consumed and generated by the encoding operations and the filtering operations of the apparatus 100. As such, the circuit 106 may be referred to as a main memory. The circuit 106 may be implemented as a double data rate (e.g., DDR) memory. Other memory technologies may be implemented to meet the criteria of a particular application. The circuit 106 may be fabricated as an integrated circuit on a single chip (or die). In some embodiments, the circuits 102, 104 and 106 may be fabricated on separate chips.
Referring to
The steps 110 and 114 may receive a current block signal (e.g., CB) from the circuit 106. The step 110 may generate a motion vector signal (e.g., M) transferred to the step 112. A prediction block signal (e.g., PB) may be generated by the step 112 and presented to the steps 114 and 128. The step 114 may generate a residual signal (e.g., R) received by the step 116. The step 116 may present information to the step 118. A signal (e.g., X) may be generated by the step 118 and transferred to the steps 120 and 124. The step 120 may present information to the step 122. The step 122 may generate and present the signal BS. The step 124 may transfer information to the step 126. A reconstructed residual signal (e.g., R′) may be generated by the step 126 and transferred to the step 128. The step 128 may generate a reconstructed current block signal (e.g., CB′) received by the circuit 106. The circuit 106 may also generate a reference sample signal (e.g., RS) presented to the steps 110 and 112.
The step 110 may implement a motion estimation step. The step 110 is generally operational to estimate a motion between a current block of a current picture (or field or frame) and a closest matching block in a reference picture (or field or frame). The estimated motion may be expressed as a motion vector (e.g., MV) that points from the current block to the closest matching reference block. The reference picture may be earlier or later in time than the current picture. The reference picture may be spaced one or more temporal inter-picture distances from the current picture. Each pixel of a picture may be considered to have a luminance (sometimes called “luma” for short) value (or sample) and two chrominance (sometimes called “chroma” for short) values (or samples). The motion estimation is generally performed using the luminance samples.
The estimation of the motion may be performed by multiple steps. The steps may include, but are not limited to, the following. An initial subset of the reference samples of a reference picture may be buffered in a cache of the circuit 104 to facilitate the motion estimation of the current block. An initial search pattern used in the motion estimation generally defines multiple motion vectors (or locations) to be tested. Multiple scores of the possible motion vectors may be calculated by a block comparison of the reference samples to the samples of the current block according to the current search pattern. Prefetching of a next subset of the reference samples to the cache may be performed while a current search pattern is being tested. The reference samples of the next subset are generally utilized by a next search pattern in the motion estimation of the current block. The prefetching of the next subset may be based on a geometry of the current search pattern and the scores of the motion vectors already tested. The motion estimation may include calculating interpolated reference samples at sub-pel locations between the integer pel locations. The sub-pel locations may include, but are not limited to, half-pel locations, quarter-pel locations and eighth-pel locations. The motion estimation may refine the search to the sub-pel locations.
The step 112 may implement a motion compensation step. The step 112 is generally operational to calculate a motion compensated (or predicted) block based on the reference samples received in the signal RS and a motion vector received in the signal M. Calculation of the motion compensated block generally involves grouping a block of reference samples around the motion vector where the motion vector has integer-pel (or pixel or sample) dimensions. Where the motion vector has sub-pel dimensions, the motion compensation generally involves calculating interpolated reference samples at sub-pel locations between the integer pel locations. The sub-pel locations may include, but are not limited to, half-pel locations, quarter-pel locations and eighth-pel locations. The motion compensated block may be presented in the signal PB. The calculated (or predicted) motion compensated block may be presented to the steps 114 and 128 in the signal PB.
The step 114 may implement a subtraction step. The step 114 is generally operational to calculate residual blocks by subtracting the motion compensated blocks from the current blocks. The subtractions (or differences) may be calculated on a sample-by-sample basis where each sample in a motion compensated block is subtracted from a respective current sample in a current block to calculate a respective residual sample (or element) in a residual block. The residual blocks may be presented to the step 116 in the signal R.
The step 116 may implement a transform step. The step 116 is generally operational to transform the residual samples in the residual blocks into transform coefficients. The transform coefficients may be presented to the step 118.
The step 118 may implement a quantization step. The step 118 is generally operational to quantize the transform coefficients received from the step 116. The quantized transform coefficients may be presented in the signal X.
The step 120 may implement a reorder step. The step 120 is generally operational to rearrange the order of the quantized transform coefficients and other symbols and syntax elements for efficient encoding into a bitstream.
The step 122 may implement an entropy encoder step. The step 122 is generally operational to entropy encode the string of reordered symbols and syntax elements. The encoded information may be presented in the signal BS.
The step 124 may implement an inverse quantization step. The step 124 is generally operational to inverse quantize the transform coefficients received in the signal X to calculate reconstructed transform coefficients. The step 124 may reverse the quantization performed by the step 118. The reconstructed transform coefficients may be transferred to the step 126.
The step 126 may implement an inverse transform step. The step 126 is generally operational to inverse transform the reconstructed transform coefficients to calculate reconstructed residual samples. The step 126 may reverse the transform performed by the step 116. The reconstructed residual samples may be presented in the signal R′.
The step 128 may implement an adder step. The step 128 may be operational to add the reconstructed residual samples received via the signal R′ to the motion compensated samples received via the signal PB to generate reconstructed current samples. The reconstructed current samples may be presented in the signal CB′ to the circuit 106.
Referring to
The example search pattern illustrated may implement a small diamond search (e.g., SDS) pattern. Each dot A-E generally represents a possible location (or possible motion vector) at the center of a block comparison. The locations A-E are generally illustrated at integer-pel locations. The current block being encoded in the example may be a 2×2 block of current samples. Other block sizes may be implemented to meet the criteria of a particular application.
An initial block comparison may be performed between the four samples of the current block and the four reference samples around the location A (e.g., MV=(0,0)). The block comparison generally calculates a sum of absolute differences (e.g., SAD) between the current block and the reference samples around the current location (or hypothesis). The SAD value may be considered a score of the location. Next, a block comparison may be performed between the four samples of the current block and the four reference samples around the location B (e.g., MV=(−1,0)). Similar block comparisons may subsequently be performed for the locations C, D and E. The individual scores may be compared against each other to find a best score. Because the locations outside the search area 142 are not considered by the search pattern, the corresponding reference samples may not be copied from the memory 106 into the search memory 140 before performing the initial search. In some embodiments, the reference samples may be copied from the circuit 106 in multi-sample blocks generally corresponding to a width of a memory bus and/or a length of a burst transfer. Therefore, some of the locations outside the search area 142 may contain copies of reference samples.
Referring to
Referring to
If the fetching of the additional reference samples (e.g., E1-E4 in
A cache mechanism of the circuit 104 may be aware of the search pattern memory accesses and may be aware of the scores of the previously examined locations. The cache mechanism may predict (with certainty and/or with a probability threshold) the memory accesses that may be utilized by the motion estimation process for additional estimations. After the memory accesses are predicted, the additional reference samples may be prefetched to the search memory 140 to avoid the stalls.
Consider the following example using the small diamond search pattern of
Referring to
Returning to the example case, in some embodiments the circuit 104 may prefetch the reference sample E4/D4 once the location C is determined to have a poorer score than the location B. In addition, the circuit 104 may also prefetch the reference sample B1 (same reference sample as E1) in anticipation of either locations B or E having the best score. In other embodiments, if the location B has the current best score, the circuit 104 may not prefetch the reference sample D4/E4 until after the location D has been tested. If the score of the location D is calculated to be worse than that of the location B, the circuit 104 may prefetch the reference sample B1/E1. If the score of the location D is better than the score of the location B, the circuit 104 may prefetch the reference sample D4/E4.
Referring to
The example search pattern illustrated may implement a large diamond search (e.g., DS) pattern. Each dot A-I generally represents a possible location (or possible motion vector) at the center of a block comparison. The locations A-I are generally illustrated at integer-pel locations. The current block being encoded in the example may be a 2×2 block of current samples. Other block sizes may be implemented to meet the criteria of a particular application.
An initial block comparison may be performed between the four samples of the current block and the four reference samples around the location A (e.g., MVA=(0,0)). The block comparison generally calculates a SAD value between the current block and the reference samples around the current location (or hypothesis). The SAD value may be considered a score of the location. Next, a block comparison may be performed between the four samples of the current block and the four reference samples around the location B (e.g., MVB=(−2,0)). Similar block comparisons may subsequently be performed for the locations C-I. The individual scores may be compared against each other to find a best score. Because the locations outside the search area 144 are not considered by the search pattern, the corresponding reference samples may not be copied into the search memory 140 before performing the initial search.
Referring to
Referring to
Consider another example using the large diamond search pattern of
Referring to
The circuit 156 may be bidirectionally coupled to the circuit 106 to receive the samples. A control signal (e.g., CNT) may be generated by the circuit 160 and presented to the circuit 156. The circuit 156 may be bidirectionally coupled to the circuit 154. The circuit 152 may be bidirectionally coupled to the circuit 152. A control signal (e.g., CNT2) may be exchanged between the circuits 152 and 160. A pattern signal (e.g., P) may be generated by the circuit 164 and transferred to the circuit 160. The circuit 152 may generate a SAD value signal (e.g., SV) received by the circuit 162. A signal (e.g., A) may be generated by the circuit 162 and received by the circuit 160.
The circuit 150 may be implemented as a cache circuit. The circuit 150 is generally operational to exchange data (e.g., samples) with the circuit 106. The circuit 150 may communicate with the circuit 152 via the signal CNT2 to decide which samples to read from the memory 106.
The circuit 152 may implement a core processor circuit. The circuit 152 is generally operational to execute a plurality of program instructions (e.g., software programs). The programs may include, but are not limited to, a block comparison process. Scores calculated by the block comparisons may be transferred in the signal SV to the circuit 162. Commands to fetch samples from the circuit 106 may be generated by the circuit 152 and presented to the circuit 160 via the signal CNT2.
The circuit 154 may implement a zero-wait state internal memory circuit. The circuit 154 may be operational to store reference samples and the current block samples used in the block comparisons. The circuit 154 may be utilized by the circuit 152 as the search memory 140.
The circuit 156 may implement a cache memory. The circuit 156 may be operational to buffer one or more subsets of the reference samples of the reference picture and the current samples of the current block to facilitate the motion estimation of the current block. The reference samples and current samples fetched from the circuit 106 may be copied to the circuit 154. The samples prefetched from the circuit 106 may be (i) buffered in the circuit 156 until requested by the circuit 152 and/or (ii) copied into the circuit 154.
The circuit 158 may implement a cache control circuit. The circuit 158 is generally operational to control all operations of the circuit 156 in response to commands receive from the circuit 152, the SAD values and the search pattern.
The circuit 160 may implement a decision logic circuit. The circuit 160 is generally operational to prefetch a next subset of the reference samples while a current search pattern is being tested. The reference samples of the next subset may be utilized by a next search pattern in the motion estimation of the current block. The prefetch of the next subset of reference samples is generally based on a geometry of the current search pattern and the scores of the locations (motion vectors) already tested.
The circuit 162 may implement a SAD aware block. The circuit 162 is generally operational to buffer the SAD values (scores) of the locations already tested by the circuit 152 in the current iteration. The scores may be presented to the circuit 160 via the signal A. The scores may be used by the circuit 160 to help determine which locations have already been tested and which locations remain to be tested.
The circuit 164 may implement a pattern aware block. The circuit 164 is generally operational to buffer the current search pattern (e.g., SDS, DS, etc.) being used in the motion estimation. The current search pattern may be presented to the circuit 160 in the signal P. The current search pattern may be used by the circuit 160 to help determine which locations have already been tested and which locations remain to be tested.
The circuit 166 may implement a probabilistic decision unit. The circuit 166 is generally operational to calculate a probability that a group of one or more additional reference samples (or blocks of reference samples) may be utilized in one or more of the next search patterns before the next search pattern is established. The circuit 166 generally enables available and unused memory access slots within the circuit 156 to be filled with reference samples from the circuit 106 that are likely (e.g., the probability is greater than a threshold) to be used in a subsequent search pattern. The circuit 166 is generally useful if the circuit 104 has a long read latency from the circuit 106. Implementation of the circuit 166 within the circuit 150 avoids consuming additional processing power in the circuit 152 to predict future reference sample prefetches.
Referring to
In the step 172, the circuit 156 may buffer a current subset of the reference samples of a reference picture to facilitate the motion estimation of the current block. Where the circuit 154 implements the search memory 140, the reference samples may also be copied into the circuit 154.
In the step 174, the circuit 152 may calculate the scores of the motion vector locations by a block comparison of the reference samples to the current samples of the current block. The centers of the block comparisons may be defined according to the current search pattern. The scores may be presented from the circuit 152 to the circuit 162 in the signal SV.
As the scores are being calculated, the circuit 158 may determine in the step 176 when and which additional reference samples should be read from the circuit 106 before the current search pattern is completed. Thus, the prefetching of the step 176 may be performed in parallel (or concurrently) with the scoring of the step 174. Prefetching of the next subset is generally based on a geometry of the current search pattern and the scores of the motion vectors locations already tested. Once the determination has been made, the circuit 158 may prefetch a next subset of the (additional) reference samples to the circuit 156. The reference samples of the next subset may be utilized by the next search pattern in the motion estimation of the current block.
In the step 178, the circuit 152 may determine if any additional searches should be performed. If the current best location is inside the search area, a local minimum score has been found and the search may end. If the current best location is on a peripheral edge of the search area, the circuit 104 may continue the motion estimation in the step 180 by updating the search area. The updating generally includes loading the next search pattern into the circuit 164 based on the winning location. After the next search pattern is established, the circuit 152 may continue calculating scores in the step 174. While the circuit 152 is generating additional scores, the circuit 158 may fetch any remaining reference samples (or blocks of reference samples) to be used in just-beginning search iteration from the circuit 106 in the step 182. If the motion estimation has concluded that the best integer-pel location has been found, the motion estimation may continue the motion estimation by testing sub-pel locations. The sub-pet locations may include, but are not limited to, half-pet locations, quarter-pel locations and eighth-pet locations. Once the circuit 152 concludes that motion estimation for the current block has completed, the circuit 152 may assign the motion vector of the best location to the current block in the step 184.
Referring to
In the step 190, the circuit 152 may begin calculating the scores for the locations in the current search pattern. The circuit 160 may analyze the results of the initial one or more scores in the step 192. If the circuit 160 concludes that the next subset of reference samples should be prefetched, the circuit 160 may perform the prefetch in the step 176. During the prefetching, or if no prefetching is appropriate at the time, the circuit 152 may continue testing locations of the current search pattern in the step 196. A check may be performed in the step 198 to see if additional locations should be considered. If more locations are tested, the circuit 160 may continue to analyze the new scores in the step 192. The loop around the steps 192 to 198 may continue until all of the locations (potential motion vectors) have been tested.
Referring to
In the step 192a, the circuit 160 may analyze the geometry of the current search pattern. If a number Y (e.g., 2) of the locations remain to be tested and the untested locations are on a periphery of the current search pattern (e.g., locations D and E), the circuit 160 may prefetch in the step 176a one or more additional reference samples (or blocks of reference samples) from a common area (e.g., D4/E4) that could be used in the next search pattern.
Referring to
In the step 192b, the circuit 166 may analyze the probability that one or more locations in the current search pattern may have the best score when the current search pattern ends. For each location having a probability above a threshold (THR), the circuit 160 may prefetch in the step 176b one or more additional reference samples (or blocks of reference samples) corresponding to each high probability area.
The functions performed by the diagrams of
The present invention may also be implemented by the preparation of ASICs (application specific integrated circuits), Platform ASICs, FPGAs (field programmable gate arrays), PLDs (programmable logic devices), CPLDs (complex programmable logic device), sea-of-gates, RFICs (radio frequency integrated circuits), ASSPs (application specific standard products), one or more monolithic integrated circuits, one or more chips or die arranged as flip-chip modules and/or multi-chip modules or by interconnecting an appropriate network of conventional component circuits, as is described herein, modifications of which will be readily apparent to those skilled in the art(s).
The present invention thus may also include a computer product which may be a storage medium or media and/or a transmission medium or media including instructions which may be used to program a machine to perform one or more processes or methods in accordance with the present invention. Execution of instructions contained in the computer product by the machine, along with operations of surrounding circuitry, may transform input data into one or more files on the storage medium and/or one or more output signals representative of a physical object or substance, such as an audio and/or visual depiction. The storage medium may include, but is not limited to, any type of disk including floppy disk, hard drive, magnetic disk, optical disk, CD-ROM, DVD and magneto-optical disks and circuits such as ROMs (read-only memories), RAMs (random access memories), EPROMs (erasable programmable ROMs), EEPROMs (electrically erasable programmable ROMs), UVPROM (ultra-violet erasable programmable ROMs), Flash memory, magnetic cards, optical cards, and/or any type of media suitable for storing electronic instructions.
The elements of the invention may form part or all of one or more devices, units, components, systems, machines and/or apparatuses. The devices may include, but are not limited to, servers, workstations, storage array controllers, storage systems, personal computers, laptop computers, notebook computers, palm computers, personal digital assistants, portable electronic devices, battery powered devices, set-top boxes, encoders, decoders, transcoders, compressors, decompressors, pre-processors, post-processors, transmitters, receivers, transceivers, cipher circuits, cellular telephones, digital cameras, positioning and/or navigation systems, medical equipment, heads-up displays, wireless devices, audio recording, audio storage and/or audio playback devices, video recording, video storage and/or video playback devices, game platforms, peripherals and/or multi-chip modules. Those skilled in the relevant art(s) would understand that the elements of the invention may be implemented in other types of devices to meet the criteria of a particular application.
While the invention has been particularly shown and described with reference to the preferred embodiments thereof, it will be understood by those skilled in the art that various changes in form and details may be made without departing from the scope of the invention.
Number | Name | Date | Kind |
---|---|---|---|
6279062 | Adiletta et al. | Aug 2001 | B1 |
6430317 | Krishnamurthy et al. | Aug 2002 | B1 |
6434196 | Sethuraman et al. | Aug 2002 | B1 |
6879266 | Dye et al. | Apr 2005 | B1 |
7129860 | Alvarez et al. | Oct 2006 | B2 |
7219173 | Sha et al. | May 2007 | B2 |
7843993 | Park | Nov 2010 | B2 |
7933331 | Gallant et al. | Apr 2011 | B2 |
8225043 | Kohn et al. | Jul 2012 | B1 |
8472527 | Madumbu et al. | Jun 2013 | B2 |
8619862 | Gaedke et al. | Dec 2013 | B2 |
8732409 | Van Der Wolf et al. | May 2014 | B2 |
20010054131 | Alvarez et al. | Dec 2001 | A1 |
20040247029 | Zhong et al. | Dec 2004 | A1 |
20070201559 | He | Aug 2007 | A1 |
20090006665 | Sankaran et al. | Jan 2009 | A1 |
20090327611 | Fang et al. | Dec 2009 | A1 |
20110093854 | Blanc et al. | Apr 2011 | A1 |
Entry |
---|
Zheng, Weiguo, et al., “Adaptive Motion Search With Elastic Diamond for MPEG-4 Video Coding”, 2001 IEEE, pp. 377-380. |
Lopez-Estrada, Alex, “Understanding Memory Access Characteristics of Motion Estimation Algorithms”, http://software.intel.com/en-us/articles/a11/1/, May 7, 2008, 8 pages. |
Dias, Tiago, et al., “Reconfigurable Architectures and Processors for Real-Time Video Motion Estimation”, J Real-Time Image Proc (2007), pp. 191-205. |
Tsai, Chuan-Yung, et al., “Low Power Cache Algorithm and Architecture Design for Fast Motion Estimation in H.264/AVC Encoder System”, 2007 International Conference on Acoustics, Speech, and Signal Processing, 2007, pp. II-97 through II-100. |
Zatt, Bruno, et al., “Run-Time Adaptive Energy-Aware Motion and Disparity Estimation in -Multiview Video Coding”, Design Automation Conference, Jun. 2011, pp. 1026-1031. |
Number | Date | Country | |
---|---|---|---|
20130136181 A1 | May 2013 | US |