The disclosure relates generally to video encoding and more particularly to motion compensation in encoding operations in multiview video coding (MVC).
Video coding standards, such as the H.264/AVC (hereinafter sometimes referred to as “H.264”) standard, the MPEG-2 standard, and other known standards are used to encode video that may then be, for example, transmitted to a device that is to implement decoding and playback of the video, stored for later transmission to such a device, etc. Additionally, in video transcoding, a compressed image stream that represents video content and has been encoded according to one standard, such as a standard used by a content provider, is decoded and then encoded according to the same or a different standard. In either case, the standard according to which the image data is encoded (or “re-encoded,” in the case of encoding that is performed according to the same standard) may be a standard that is supported by a device which is to implement or support playback of the video. Example devices that perform video encoding include, but are not limited to, content provider servers, home media servers, set-top boxes, smart phones, tablets, other handheld computers, laptop computers, desktop computers, etc.
Because of the large increase in providing of three-dimensional (3D) video services, e.g., by stereoscopic imaging where a different view is rendered for each eye to allow video to be perceived as being in 3D, H.264 and other standards have been extended to include multiview video coding (MVC). In MVC, multiple image streams constituting the same video content are captured by multiple image capturing devices, such as multiple video recording devices positioned in different locations and capturing images constituting the video content from different angles. Each image capturing device produces a corresponding single view video signal.
In one implementation of MVC, an image capturing device produces a base view and one or more additional image capturing devices produce one or more dependent views. The image data for each of the base view and the dependent view(s) includes a sequence of temporally adjacent frames, and the sequence(s) of temporally adjacent frames for the dependent view(s) are spatially adjacent to the sequence of temporally adjacent frames for the base view. These single view video signals produced by the image capturing devices are encoded by an MVC encoder to produce an MVC signal stream. When the MVC signal stream is subsequently decoded, the resulting video signal contains frames based primarily on the video frames of the base view, but also includes image information from one or more video frames from one or more dependent views.
In addition to use of MVC encoding for original encoding of image frames of video, such as for transmission of the encoded video to another device, MVC encoding may also be used in a video transcoder in order to encode or “re-encode” image frames of single view video signals (e.g., a base view signal and one or more dependent view signals) generated by a decoder of the video transcoder. In either case, the MVC encoding may involve motion compensation for the image frames of each of the single views. The motion compensation may include performing luma intra prediction on the macroblock level (e.g., on the level of 16×16 blocks of pixels in H.264) in an image frame. In luma intra prediction, the luma values for a macroblock are predicted using the luma values of nearby pixels in the same image frame. Various intra prediction modes are defined, each corresponding to a different way of using the luma values of the nearby pixels for luma intra prediction. A significant problem in luma intra prediction is the high computational load associated with selecting the intra prediction mode(s) to be used.
For example, a common approach to selecting the intra prediction mode(s) for a macroblock involves exhaustively calculating a rate distortion (RD) cost for each intra prediction mode supported for use with respect to the macroblock and then choosing the intra prediction mode(s) that yield the smallest RD cost. As known in the art, the RD cost of a particular intra prediction mode is essentially a measurement of the efficiency of that intra prediction mode, and reflects (i) the distortion between actual and predicted image data using a particular intra prediction mode versus (ii) the bit cost of encoding the predicted image data after applying the particular intra prediction mode.
In some encoding standards, a macroblock may be divided into smaller data blocks for intra prediction. For example, in H.264, three sizes of data blocks of pixels are defined for luma intra prediction: 4×4, 8×8, and the 16×16 macroblock. The exhaustive RD cost calculation for a macroblock may involve, for each smaller data block size that is available with respect to that macroblock: calculating the RD cost for each supported luma intra prediction mode for each data block of that size within the macroblock; identifying, for each data block of that size, the luma intra prediction mode with the smallest RD cost and further identifying what that smallest RD cost is; and adding up the smallest RD costs of each of the data blocks of that size within the macroblock to yield a smallest total RD cost for luma intra prediction of the macroblock when the macroblock is divided into data blocks of that size.
The exhaustive RD cost calculation for a macroblock may further involve calculating the RD cost for each luma intra prediction mode that is supported for luma intra prediction for the macroblock as a whole, identifying the luma intra prediction mode for the macroblock as a whole that has the smallest RD cost, and identifying that smallest RD cost. The encoder may then compare the smallest RD cost corresponding to luma intra prediction for the macroblock as a whole to the smallest total RD cost(s) for luma intra prediction of the macroblock as divided into each smaller available data block size. Finally, the encoder may identify the smallest of these RD costs, the associated data block size and mode(s), and perform luma intra prediction of the macroblock using the associated mode(s) and data block size as determined in the manner described above.
The computational load associated with such operations is extremely high. When such operations are performed for multiple views, as in MVC, this high computational cost only increases further. Depending upon considerations such as the fidelity requirements of the video playback environment, whether the video playback involves large video files and/or concurrent playback of multiple video files, and so on, this computational load may, for example, interfere with the ability to view the video content in real time (e.g., in the case of transcoding, as the video content is transcoded) and/or may result in reduced-quality video playback. As user requirements and the capabilities supported by devices used for video playback continue to increase, the computational load associated with the above-described RD cost calculations with MVC will become increasingly unacceptable.
The embodiments will be more readily understood in view of the following description when accompanied by the below figures and wherein like reference numerals represent like elements, wherein:
Briefly, in one example, a method, apparatus and system uses the intra prediction modes that were used to encode a base view data block as well as the intra prediction modes used to encode neighboring data blocks to the base view data block as a set of candidate intra prediction modes for use in encoding a collocated data block in the dependent view. A sum of absolute differences (SAD) calculation may also be used to determine and select the candidate intra prediction mode that has the smallest value and hence best encoding properties for the dependent view data block. The data block in the dependent view is then encoded using the selected candidate intra prediction mode.
The system, apparatus, and method may determine a plurality of differences between a data block of the image corresponding to a dependent view and predicted versions of the data block of the image corresponding to the dependent view as predicted using a first candidate prediction mode that was used in encoding a collocated data block in a corresponding base view, and a plurality of second candidate intra prediction modes that were used in encoding neighboring blocks of the collocated data block of the base view. The system, apparatus and method may select one of the plurality of first and second candidate intra prediction modes as a final intra prediction mode for encoding the data block of the image corresponding to the dependent view based on the plurality of determined differences. In one example, the differences are determined using a SAD calculation between an original block in the dependent view and the predicted block at the same image location and the SAD value that is the smallest among the multiple candidate prediction modes is selected as the intra prediction mode to encode the data block of the dependent view.
In another example, selecting one of the plurality of first and second candidate intra prediction modes as a final intra prediction mode for encoding the image block of the dependent view can be performed by determining an initial best candidate intra prediction mode for encoding the data block of the image corresponding to the dependent view as predicted using each of the plurality of first and second candidate intra prediction modes and evaluating the initial best candidate intra prediction mode and one or more additional candidate intra prediction modes to select the final intra prediction mode wherein the additional candidate intra prediction modes are adjacent prediction directions to the initial best candidate intra prediction mode.
In another example, the method, apparatus and system may determine that the data block of the dependent view is at an edge of the frame location and may employ a limited number of candidate intra prediction modes to encode edge data blocks compared to first and second candidate intra prediction modes that are available for use in encoding other data blocks in a dependent view that have surrounding data blocks, such as other non-edge located data blocks.
In one embodiment, a system, an apparatus and a method reduce the computational load associated with selecting an intra prediction mode for use in multiview video coding (MVC). The system and apparatus may include logic that may perform actions as described below to reduce the computational load. The system and apparatus may be or may include a device having video encoding capability, such as a content provider server, home media server, set-top box, smart phone, tablet, other handheld computer, laptop computer, desktop computer, etc. Thus, the system and apparatus may be or may include a video encoder, which in turn may include the aforementioned logic that reduces the computational load.
In some embodiments, the system and apparatus may additionally or alternatively include a video transcoder. An encoder of the video transcoder may include logic to reduce the computational load associated with selecting an intra prediction mode for an encoding or re-encoding operation performed by the transcoder. In some embodiments, the system and apparatus may also include one or more processors that decode output MVC image data that is encoded according to techniques such as those described herein. Thus, the one or more processors may generate output MVC image data. In some embodiments, the system and apparatus may also include a display, and the one or more processors may provide the output MVC image data for display on the display.
In this example, the apparatus 100 is any suitable device supporting video encoding and, in some cases, video transcoding and/or playback capability, such as but not limited to a content provider server, home media server, set-top box, smart phone, tablet, other handheld computer, laptop computer, desktop computer, etc. For purposes of illustration only, the apparatus 100 will be described as a computing device having a processor subsystem 102, which includes a first processor 104 such as a central processing unit (CPU), a second processor 106 such as a graphics processing unit (GPU), and a memory 108, such as an on-chip memory or off-chip memory.
If desired, the processor subsystem 102 may be an accelerated processing unit (APU), which as known in the art includes one or more CPU cores and one or more GPU cores on the same die. Such an APU may be, for example, an APU as sold by Advanced Micro Devices, Inc. (AMD) of Sunnyvale, Calif. Alternatively, one or more of the first and second processors 104 and 106 may perform general-purpose computing on GPU (GPGPU), may include one or more digital signal processors (DSPs), one or more application-specific integrated circuits (ASICs), or the first and second processors 104 and 106 may be any suitable processors.
The apparatus 100 includes an enhanced intra prediction mode selection multiview video coding (MVC) encoder 110 that implements the enhanced intra prediction mode selection for use in MVC. The enhanced intra prediction mode selection MVC encoder 110 may be implemented as logic, such as hardware implemented on the first processor 104 and/or the second processor 106. The enhanced intra prediction mode selection MVC encoder 110 may also be implemented as discrete logic, a state machine, one or more programmable processors, and/or other suitable hardware.
The enhanced intra prediction mode selection MVC encoder 110 may also be implemented as one or more processors executing suitable stored instructions, such as the second processor 106 (e.g., a GPU) as shown in
The enhanced intra prediction mode selection MVC encoder 110 may receive, via an interface circuit 120, first view image data 116 including, for example, data blocks of an image frame corresponding to a base view, and second view image data 118 including, for example, data blocks of an image frame corresponding to a dependent view. The enhanced intra prediction mode selection MVC encoder 110 may then receive first view image data and second view image data for subsequent image frames, and so on. The enhanced intra prediction mode selection MVC encoder 110 determines a plurality of differences between the data block of the image corresponding to the dependent view and predicted versions of the data block of the image corresponding to the dependent view as predicted using each of a of first candidate prediction mode and a plurality of second candidate intra prediction modes that were used in encoding a collocated data block in the corresponding base view. The plurality of second candidate intra prediction modes were used in encoding neighboring blocks of the collocated data block of the base view. The enhanced intra prediction mode selection MVC encoder 110 selects one of the plurality of first and second candidate intra prediction modes as a final intra prediction mode for encoding the data block of the image corresponding to the dependent view based on the plurality of differences. The enhanced intra prediction mode selection MVC encoder 110 encodes the data block of the image corresponding to the dependent view using the selected final intra prediction mode as a component of the encoded MVC image data 130. Another component is the encoded base view data.
The first view image data 116 and the second view image data 118 may be compressed bitstreams and may be provided by any suitable image source or sources and may get uncompressed via an interface or encoder 110. For example, the first and second view image data 116 and 118 may be streamed from any suitable server including any suitable Internet website, or may be received from a further additional memory such as a dynamic random access memory (DRAM) or ROM (not shown in
In some embodiments, as shown by the dashed communication link carrying the first and second view image data 116 and 118, the first and second view image data 116 and 118 may be received from one or more peripheral devices 122, which may be, for example, a Compact Disc Read-Only Memory (CD-ROM), a DVD Read-Only Memory (DVD-ROM), and/or a Blu-ray Disc (BD). In this example, the first and second view image data 116 and 118 is received from the one or more peripheral devices 122 via an expansion bus 124 of the apparatus 100. The expansion bus 124 may further connect to, for example, a display 126, the additional memory 114, and one or more input/output (I/O) devices 128 such as a touch pad, audio input/output devices, a mouse, a stylus, a transceiver, and/or any other suitable input/output device(s).
In any event, after performing the enhanced intra prediction mode selection for use in MVC as described herein, the enhanced intra prediction mode selection MVC encoder 110 may encode the first and second view image data 116 and 118, using the selected intra prediction mode to encode the second view image data 118, and then process the encoded first view image data and the encoded second view image data to generate encoded MVC image data 130. The below-described enhanced intra prediction mode selection for a data block of an image corresponding to the second view, and encoding of first view image data, may be repeated in order to provide encoded MVC image data 130 for an entire image frame incorporating the multiple views of MVC, and then for a next subsequent image frame, and so on. The encoded MVC image data 130 may be provided via the interface circuit 120 to, for example, the memory 114 for storage, one or more of the I/O devices 128 for transmission to another device, etc.
The first computing device 100 outputs encoded source MVC image data 202 based on the first and second view image data 116 and 118. The encoded source MVC image data 202 may, in one embodiment, be the encoded MVC image data 130 of
For purposes of illustration, the additional apparatus of the system 200 is shown as including aspects of a computing device such as a processor subsystem 204 (e.g., an APU similar to that described with respect to
The enhanced intra prediction mode selection MVC encoder 216 may, in one embodiment, be implemented similar to the enhanced intra prediction mode selection MVC encoder 110 of
The enhanced intra prediction mode selection MVC encoder 216 may encode the decoded first view image data (e.g., one or more data blocks of an image(s) corresponding to the first view) and the decoded second view image data (e.g., a data block of an image corresponding to the second view) using, for example, enhanced intra prediction mode selection to select the intra prediction mode for encoding the data block of the image corresponding to the second view. Additionally, the enhanced intra prediction mode selection MVC encoder 216 may process the one or more encoded data blocks of the image corresponding to the first view and the encoded data block of the image corresponding to the second view to generate encoded output MVC image data 220, which may be transmitted or stored via an interface circuit 222 in a manner similar to transmission or storage of the encoded MVC image data 130 via the interface circuit 120. The encoded output MVC image data 220 may then, for example, be decoded by one or more processors (not shown), such as one or more GPUs or other suitable processors, such as after being transmitted to the one or more processors via the interface circuit 222.
In another embodiment, after the enhanced intra prediction mode selection MVC encoder 216 generates the encoded output MVC image data 220, the second processor 208 receives the encoded output MVC image data 220 and decodes the encoded output MVC image data 220 to generate output MVC image data 224. The output MVC image data 224 may be, for example, provided via the interface circuit 222 for display on a display in the system 200.
The various logic elements, and one or both of the decoder portion 214 and the encoder portion 216, described herein may be implemented in any suitable manner. For example, logic of the decoder portion 214 and/or the encoder portion 216 may be implemented as circuitry, such as hardware implemented on the first processor 104 and/or the second processor 106, as discrete logic, a state machine, one or more programmable processors, and/or other suitable hardware. In one example, the decoder portion 200 and the encoder portion 202, may be implemented as processors executing software such as the second processor 106 and/or the first processor 104; wherein the executable instructions are stored on a computer readable storage medium. The various elogic, and one or both of the decoder portion 2214 and the encoder portion 214, may also be implemented in any other suitable manner such as but not limited to any suitable combination of the example implementations described above, and may be implemented in whole or in part as physically distinct elements or may be understood as logical elements that are part of the same physical element.
In operation, the enhanced intra prediction mode selection MVC encoder 216, like the encoder 110, determines a plurality of differences (such as SAD values between the data block of the image corresponding to the dependent view and predicted versions of the data block of the image corresponding to the dependent view as predicted, using a first candidate intra prediction mode that was used in encoding a collocated data block in the corresponding base view and a plurality of second candidate intra prediction modes that were used in encoding neighboring blocks of the collocated data block of the base view.
The enhanced intra prediction mode selection MVC encoder 216 selects one of the plurality of first and second candidate intra prediction modes as a final intra prediction mode for encoding the data block of the image corresponding to the dependent view based on the plurality of differences. For example, the one or more neighboring data blocks may be four additional data blocks, located above, below, to the left of, and to the right of the data block of the image corresponding to the collocated data block in the base view for which an intra prediction mode for encoding is selected. In another example, the one or more neighboring data blocks may be eight additional data blocks that surround the collocated data block of the image corresponding to the data block for the dependent view for which an intra prediction mode for encoding was selected, e.g., so that the data block for which the intra prediction mode was selected is at the center of a three-data-block by three-data-block arrangement that includes the eight additional data blocks.
The first view encoder 302 may include first view encoding logic 316 that receives, for each of the one or more data blocks of the image corresponding to the first view, the first residue 312 and the first view selected intra prediction mode information 314. For each of the one or more data blocks of the image corresponding to the first view, the first view encoding logic 316 may then, for example, transform, quantize, and entropy encode the residue 312 according to the selected intra prediction mode for the data block as known in the art.
The above-described operations may be repeated for each of the one or more data blocks, and for each remaining data block of an entire image frame corresponding to the first view, in order to perform intra prediction and encoding for an entire image frame (and subsequent image frames) corresponding to the first view. The first view encoding logic 316 may provide encoded first view image data 318 to MVC processing logic 320 for generation of encoded MVC image data 130 that includes data for multiviews. The encoded output image data 130 after enhanced intra prediction mode selection may be provided to any suitable device or devices for decoding and/or, for example, for suitable video playback after such decoding.
The second view encoder 304 includes enhanced intra prediction mode selection motion compensation logic 324 that is used in implementing enhanced intra prediction mode selection so as to reduce the computational load in selecting an intra prediction mode for use in encoding data blocks in dependent views. The second view encoder 304 also includes a second view encoding logic 334 that outputs encoded second view image data 336 to the MVC processing logic 320. A subtractor 328 is used in a similar manner as the subtractor 310 which subtracts a prediction 326 of the dependent view image data 118 to determine a residue 330 between the data block of the image corresponding to the dependent view and a prediction 326 of the data block using the candidate intra prediction modes 322 used in encoding collocated data block and intra prediction modes used in encoding neighboring blocks of image corresponding to the base view. As previously noted, the logic in the second view encoder 304 may be any suitable logic including portions of one or more programmed processors, state machines, or any other suitable combination of hardware and executable instructions. The final selected intra prediction mode 332 will be sent to the second view encoding logic 334. The block 324 will check all intra prediction candidates to determine the final intra prediction mode 332 which has the lowest SAD value.
As shown in block 602, the method includes selecting one of the plurality of first and second candidate intra prediction modes as a final intra prediction mode for encoding the data block 800 based on the plurality of differences that were calculated in block 600. As shown in block 604, the method includes encoding the data block 800 using the selected final intra prediction mode.
In operation, the initial candidate mode determination logic 700 receives the intra prediction modes 322 used in encoding a collocated data block in the base view and prediction modes used on its neighbor blocks. Initial candidate motion prediction logic 704 then determines which intra prediction mode can serve as best candidate intra prediction mode for use in encoding the data block of interest in the dependent view. As further set forth below, by way of example, if the collocated data block 802 has neighbor blocks, the candidate prediction modes 712 that will be provided to the difference determination logic 706 would include the prediction modes used to encode the collocated data block 802 and the prediction modes used to encode the neighboring blocks 1-8 (see
The determination logic 706 determines a plurality of differences, such as by an SAD calculation, between the data block of the image corresponding to the dependent view and predicted versions of the data block of the image corresponding to the dependent view using each of the candidate prediction modes 712. For example, there may be a candidate prediction mode associated with the collocated data block 802 as well as a plurality of candidate intra prediction modes associated with neighboring blocks 1-8 of the collocated data block of the base view.
The difference determination logic 706 selects one of the plurality of candidate intra prediction modes 712 as an initial best candidate mode 714 which may serve as a final intra prediction mode for encoding the data block 800. This may occur for example when the initial best candidate intra prediction mode is passed out of the final candidate determination logic 702 without change, or passed directly as the selected intra prediction mode information 332.
The selection of the best candidate mode for encoding is based on the plurality of differences that were determined. By way of example, as set forth below, a SAD calculation may be carried out for each candidate intra prediction mode on the data block of interest in a dependent view. The prediction mode generating the lowest SAD value may be selected as the initial best candidate mode which may be the final intra prediction mode if no refinement is done. The encoder 334 then encodes the data block of the image corresponding to the dependent view using the selected final intra prediction mode 332.
If desired, a further refinement of a selection of a final candidate intra prediction mode may be employed using the initial best candidate intra prediction mode. For example, the difference determination logic 706 determines an initial best candidate intra prediction mode 714 for encoding the data block 800 based on predicted versions of the data block of the image corresponding to the dependent view as predicted using each of the plurality of the first and second intra prediction modes 712. The final candidate mode determination logic 702 then evaluates the initial best candidate intra prediction mode 714 and one or more additional candidate intra prediction modes represented as 716 which may, for example, be stored prediction modes based on the prediction direction set forth by any standard. The additional candidate prediction mode 716 which may be, for example, stored in memory, are one or more intra prediction modes that are adjacent in direction to the initial best candidate intra prediction mode 714.
By way of example, referring to
The initial candidate motion prediction logic 704 can also evaluate the x, y coordinates of the data block of the dependent view to determine it is at an edge of frame location and the logic is operative to employ a limited number of candidate intra prediction modes for edge data blocks compared to the first and second candidate intra prediction modes available for potential use in encoding other data blocks in a dependent view having surrounding data blocks. As further set forth below for example, a block that is located on the left edge of a frame, has been determined to require only three prediction modes and therefore a faster calculation may be employed if it is determined that an edge block is being evaluated.
The difference determination logic 706, determines a SAD corresponding to each of the first and second candidate intra prediction modes and selects as the final intra prediction mode (in one example the initial best candidate mode) the intra prediction mode having the lowest SAD value.
In the embodiment employing decoding logic, such as decoder 214, the decoder logic may be coupled to a display 126 to decode the encoded data block in the dependent view using the selected final intra prediction mode 332 that may be supplied as part of encoded source MVC image data 202. The decoded block may be then provided to the display as part of a displayed dependent view.
Stated another way and referring again to
Where Orig(x,y) is the original pixel value at position (x,y) and Pred(x,y) is the predicted value using the intra prediction mode m, SAD (m) is the SAD value between the original and the reconstructed block.
If block n is the top left corner block of the dependent view picture (an edge location), then only calculating the SAD value of mode 2 (DC) is performed.
If block n is in the top row of the dependent view picture (an edge location), only the left side neighboring pixels can be used for intra prediction, so according to
If block n is in the left column of the dependent view picture, the left side neighboring pixels are not available for intra prediction, so only mode 0 (vertical), mode 3 (diagonal down left), and mode 7 (vertical left) are assessed in the SAD calculation.
For the remaining blocks in the dependent view picture, it has both the top and the left neighboring pixels available for intra prediction. Accordingly, the encoder 110 finds its co-located 4×4 block 802 in the base view picture (block n is used as an example in
If none of block n and its surrounding blocks (block 1, . . . , 8) in the base view picture are encoded as intra 4×4, only mode 2 (DC) for block n in the dependent view picture is evaluated in the SAD calculation.
For non-edge blocks, the encoder 110 uses the available intra 4×4 prediction modes of block n 802 and its surrounding blocks (block 1, . . . , 8) in the base view picture as the prediction mode candidates for block n 800 in the dependent view. The encoder 110 calculates the SAD value of all the candidate intra prediction modes and selects the one with the lowest SAD as the best candidate and final candidate.
If desired, final candidate mode determination logic 702 evaluates the surrounding (adjacent) prediction mode direction of the best candidate for block n in the dependent view. For example, if mode 6 is the best mode resulted as the best candidate, its surrounding modes 1 and 4 (the surrounding prediction mode direction can be referred from
Among other advantages, example implementations of the system, apparatus, and method described herein recognize that while the captured images in multiview video coding are different, the captured images are nonetheless different representations of, for example, the same objects. The multiview video images are captured against the same object from different angles. As a result, the system, apparatus, and method recognize that there is complementary image information due to the different viewing angles, and that the captured images are highly correlated with one another with redundancy with respect to some of the captured image information. Accordingly, by selecting the intra prediction mode for encoding a data block of the image corresponding to the second view (e.g., dependent view) based on the obtained information (e.g., obtained from a different encoder, or from the same encoder if the same encoder encodes both the image corresponding to the first view and the image corresponding to the second view), the exhaustive RD calculations can be avoided. Example techniques for advantageously selecting the intra prediction mode for encoding the dependent view based on the obtained information, without performing the exhaustive RD calculations and still obtaining an efficient result have been described (e.g., in terms of amount of distortion versus bit cost, as discussed above).
By reducing the computational load needed to select an intra prediction mode for encoding a data block of an image corresponding to a dependent view, the disclosed embodiments benefit systems with limited processing power, allow for higher-quality video playback, particularly for large and/or multiple files being played back at once, and allow video playback devices having the features of the systems, apparatus, and methods to be able to meet increasingly strict performance requirements. Other advantages, and other techniques for advantageously selecting the intra prediction mode for encoding a data block of an image corresponding to a dependent view based on obtained information regarding one or more intra prediction modes used in encoding one or more data blocks of an image corresponding to, for example, a first view (e.g., a base view), are further described herein and/or will be recognized by those of ordinary skill in the art based on the description herein.
The above detailed description of the embodiments and the examples described therein have been presented for the purposes of illustration and description only and not by limitation. It is therefore contemplated that the embodiments cover any and all modifications, variations or equivalents that fall within the spirit and scope of the basic underlying principles disclosed above and claimed herein.