US20120183077A1 - NAL Unit Header - Google Patents
NAL Unit Header Download PDFInfo
- Publication number
- US20120183077A1 US20120183077A1 US13/347,381 US201213347381A US2012183077A1 US 20120183077 A1 US20120183077 A1 US 20120183077A1 US 201213347381 A US201213347381 A US 201213347381A US 2012183077 A1 US2012183077 A1 US 2012183077A1
- Authority
- US
- United States
- Prior art keywords
- layer
- nal unit
- flag
- temporal
- descriptions
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/65—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using error resilience
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/30—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using hierarchical techniques, e.g. scalability
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/70—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by syntax aspects related to video coding, e.g. related to compression standards
Definitions
- This application relates to video compression systems, and more particularly to systems that use scalable/simulcast/multiview video coding techniques where two or more layers are used to represent a given video signal.
- Certain commercial video compression techniques can use video coding standards to allow for cross-vendor interoperability.
- the present disclosure can be used with such a video coding standard, specifically ITU-T Rec. H.264, “Advanced video coding for generic audiovisual services”, 03/2010, available from the International Telecommunication Union (“ITU”), Place de Nations, CH-1211 Geneva 20, Switzerland or http://www.itu.int/rec/T-REC-H.264, and incorporated herein by reference in its entirety.
- H.264's An initial version of H.264's was ratified in 2003, and included coding tools, for example a flexible reference picture selection model, that allows for temporal scalability.
- a subsequent version ratified in 2007, added in Annex G an extension towards scalable video coding (SVC), including techniques for spatial scalability and quality scalability, also known as signal-to-noise (SNR) scalability.
- SVC scalable video coding
- SNR signal-to-noise
- a bitstream is logically subdivided into NAL units.
- Each coded picture is coded in one or more slice NAL units.
- Many other NAL unit categories are also defined for different types of data, such as, for example, parameter sets, SEI messages, and so forth.
- a NAL unit can be “parsing-independent” in that a loss of a NAL unit may not prevent the meaningful decoding and use of other NAL units. Accordingly, NAL units can be the placed into packets of packet networks subject to packet losses. This use case was one of the motivations for the introduction of the NAL unit concept over the bitstream concept known from earlier video compression standards such as MPEG-2 (ITU-T Rec.
- H.262 Information technology—Generic coding of moving pictures and associated audio information: Video”, 02/2000, available from http://www.itu.int/ree/T-REC-H.262, which is also known as MPEG-2 video, incorporated herein by reference).
- syntax table diagrams following the conventions specified in H.264 are being used. To briefly summarize those conventions, a C-style notation is used. A boldface character string refers to a syntax element fetched from the bitstream (which can consist of NAL units separated by, for example, start codes or packet headers).
- the “Descriptor” column of the syntax diagram table provides information of the type of data. For example, u( 2 ) refers to an unsigned integer of 2 bits length, f( 1 ) refers to a single bit of a predefined value.
- FIG. 1 shows a NAL unit header of baseline H.264 and the SVC and MVC extensions.
- the baseline NAL unit header is part of the NAL unit syntax specification, which is shown ( 101 ) with certain parts omitted so not to obscure the disclosure.
- the NAL unit header includes a forbidden_zero_bit ( 102 ), two bits indicating the relative importance of the NAL unit for the decoding process (nal_ref_idc, 103 ), and five bits indicating the NAL unit type ( 104 ).
- a further svc_extension_flag bit ( 106 ) is included as well as either ( 107 ) a nal_unit_header_svc_extension()( 108 ) or a nal_unit_header mvc_extension( )( 109 ), as indicated ( 107 ) by the svc_extension_flag.
- nal_unit_header_svc_extension() and nal_unit_header_mvc_extension() refer to syntax tables as shown as the SVC NAL unit header extension ( 110 ), and the MVC NAL unit header extension ( 120 ), respectively.
- the priority_id field ( 111 ) can be used to linearly signal the relative importance, as determined by the encoder, of a layer relative to other layers of the same scalable bitstream, where a layer can be any of a temporal, spatial, or SNR scalable layer.
- a dependent layer has a higher priority_id than the layer it depends on.
- Priority_id is not used by the H.264 decoding process definition, but can be used, for example by decoders or Media-Aware Network Elements (MANEs) to identify NAL units not required for the decoding of a certain layer (where that layer is lower in the layer hierarchy than the layer to which the NAL unit with the high priority_id value belongs).
- H.264 specifies certain constraints of its value based on the values of dependency_id, quality_id, and temporal_id.
- the no_inter_layer-Pred_flag ( 112 ) indicates that the layer the NAL unit belongs to is not referring to any other layer for prediction. If set for all NAL units of a given layer, this flag can indicate that the layer can be decoded without regards of any other layer, allowing for techniques such as simulcasting.
- the dependency_id field ( 113 ) indicates the spatial layer or coarse grain SNR scalable layer the NAL unit belongs to—the higher the value, the higher the layer.
- Quality_id and temporal_id indicate similar properties for SNR scalable and temporal scalable layers.
- the MVC NAL unit extension header ( 120 ) includes the following pertinent fields.
- Priority_id ( 121 ) and temporal_id ( 123 ) have similar semantics as described above for the SVC header priority_id ( 111 ) and temporal_id ( 115 ) fields.
- View_id identifies one out of up to 1024 “views” of a multiview system, which can, for example, be coded signals from different cameras at different geometric positions capturing the same scene in 3D space.
- MVC allows for prediction across views, based on the observation that there can be redundancies between views that can be eliminated through prediction.
- One goal during the specification of the scalable extension of H.264 has been to allow for the decoding of a scalable base layer by a legacy decoder that was designed before the ratification of the scalable extension, for example by a decoder conforming to any profile of the 2003 version of H.264.
- no backward incompatible changes have been introduced to the base layer syntax.
- control information related to, or even affecting, base layer decoding in a scalable coding context i.e. in conjunction with at least one enhancement layer
- Some of this information can also be relevant for MVC. Syntax for information of this category was added to the scalable extension of H.264 by, for example, the mechanisms described next.
- a first mechanism is the use of different NAL unit types for slice data belonging to scalable or multiview coding, which can trigger the presence of additional fields in the NAL unit header, as already described.
- a second mechanism is the introduction of a prefix NAL unit. It uses one of the previously reserved NAL unit types, which means that a legacy decoder that does not recognize the reserved type would ignore its content, whereas a scalable or multiview decoder can interpret its content.
- the syntax of the prefix NAL unit ( 201 ) is shown in FIG. 2 .
- the NAL unit can include a store_ref base_pic_flag ( 202 ) indicating, among other things and only if additional conditions are met, the presence of base picture marking information ( 203 ). Though the precise nature of such information may not be particularly relevant for this disclosure, its content is required for the decoding process in a scalable decoding situation.
- SEI Supplementary Enhancement Information
- the scalability information SEI message can be viewed as a description of the scalable bitstream, including aspects such as description of its layers, inter-layer dependencies, and so forth.
- the syntax table of the SEI message in the H.264 specification is approximately two pages long. Some parts of it relevant for this disclosure are reproduced in FIG. 3 .
- the scalability information SEI message ( 301 ) includes a number of flags concerned with the scalable bitstream (i.e. all layers), which is followed by an integer indicating the number of layers ( 302 ). For each of the layers, the following fields are available.
- a layer_id ( 303 ) field provides for an identification of the layer. It can be used, for example, to cross-reference the layer with other layer descriptions that are located in parts of the SEI message not depicted (such as, for example, inter-layer dependency descriptions). For example, the binding between a dependent layer and the layer it depends on, within the SEI message, is established through layer_id.
- the priority_id ( 304 ), dependency_id ( 305 ), quality_id ( 306 ), and temporal_id ( 307 ) fields field have a meaning similar to what was already described in the context of the SVC NAL unit header fields with the same name.
- the overhead for a given NAL unit in the bitstream is at least four octets for the startcode.
- the overhead can be 40 octets or more (12 octets for the IP header, 8 octets for the UDP header, and 20 octets for the RTP header). While aggregation techniques as well as header compression techniques can reduce that overhead to a certain extent, reducing overhead further and/or avoiding it altogether would be preferable.
- FIG. 4 shows a simplified block diagram of a video conferencing system.
- An encoder ( 401 ) can produce a scalable bitstream ( 402 ) comprising NAL units belonging to more than one layer.
- Bitstream ( 402 ) is depicted as a bold line to indicate that it has a certain bitrate.
- the bitstream ( 402 ) can be forwarded over a network link to a media aware network element (MANE) ( 403 ).
- the MANE's ( 403 ) function can be to “prune” the bitstream down to a certain bitrate provided by second network link, for example by selectively removing those NAL units belonging to the highest layer.
- bitstream ( 404 ) This is shown by the dotted line for the bitstream ( 404 ) sent from the MANE ( 103 ) to a decoder ( 405 ). If the scalable bitstream, ( 402 ) contains only NAL units of a base layer and one enhancement layer, then, after pruning, bitstream ( 404 ) contains only NAL units of the base layer.
- the decoder ( 405 ) can receive the pruned bitstream ( 404 ) from the MANE ( 403 ), and decode and render it.
- the potential unavailability of a scalability information SEI message at the MANE very early in the connection—ideally before any coded slice NAL unit of any layer is received by the MANE in bitstream ( 402 ), can have negative consequences on the decoder behavior and/or incur unnecessarily high cost in the decoder implementation.
- the MANE ( 403 ) may need to forward, and the decoder ( 405 ) may need to buffer and, to the extent possible, decode all NAL units it receives, even those it will not be using for rendering (for example because they belong to a spatial layer of a higher resolution than the display of a handheld device).
- the MANE ( 403 ) can have great difficulty in deciding which NAL units to forward to a decoder of limited capability if it receives a scalable bitstream of high complexity (many layers), but is aware that a receiving decoder can process only a non-scalable bitstream or a scalable bitstream of low complexity (few layers).
- An SEI message including the scalability information SEI message, can be unavailable because, for example, it was lost during the transmission of bitstream ( 402 ), or because the encoder ( 401 ) decides not to send the SEI message, for example to save the bits of the message (which is conforming to the standard, although not advisable from an application design viewpoint).
- a MANE also needs to maintain state, especially with respect to the content of the Scalability Information SEI message, so to make informed decisions about pruning. Such state can be established only by intercepting and interpreting all such SEI messages. While most MANEs need to intercept and interpret some bitstream information, such as parameter set information to make meaningful decisions, very few of the numerous SEI messages have any meaning to a MANE. Intercepting all SEI messages just to extract and interpret those few which are meaningful for the MANE can be an onerous and computationally expensive process.
- H.264's scalable and multiview syntax related to the NAL unit header contains several potential shortcomings as a result of the “bolt-on” design of the scalable and multiview extension.
- the NAL unit header for NAL units of extension headers can be unnecessarily large.
- Information pertaining to picture buffer management is sent in its own NAL unit (the prefix NAL unit), which can incur unnecessarily high overhead.
- SEI messages which (a) does not reflect their critical nature (SEI can be discarded), and (b) may require unnecessary duplication of some information in, for example, the NAL unit header (such as: dependency_id, quality_id, view_id).
- HEVC High Efficiency Video Coding
- the disclosed subject matter provides for a NAL unit header that can be more efficient than the one described in H.264 or WD4, and can allow for lightweight MANE and decoder implementations, In conjunction with other techniques such as a Dependency Parameter set (DPS), as described in co-pending Ser. No. 61/451,454, and embedded in a high level syntax architecture as described in our co-pending patent application entitled “Techniques for Layered Video Encoding and Decoding,” filed concurrently with the present application and assigned to the common assignee, the disclosure of which is incorporated by reference herein, the disclosed subject matter can overcome the potential shortcomings mentioned above.
- DPS Dependency Parameter set
- a NAL unit header includes a layer_id.
- the layer_id can, for example, be represented by an integer of, for example, six bits.
- the layer_id can refer to a description of the layer located in table of layer descriptions.
- the table of layer descriptions is included in a dependency parameter set or a high level syntax structure serving a purpose substantially similar to a dependency parameter set.
- the layer description referred to be the layer_id in the NAL unit header includes fields for at least one of a dependency_id, quality_id, view_id, a depth_map_flag, and a dependent_flag.
- the depth_map_flag can indicate that the layer or layers it is associated with is/are a depth map. Association with a depth map, which can indicate, on a per sample basis, a third dimension (depth) of a sample, with a view, can be established using the view_id.
- the NAL unit header includes a temporal_id and a layer_id.
- the temporal_id can refer to a temporal sub-layer of the (spatial/quality/view/depth-map) layer defined by the description referenced by the layer_id.
- this results in temporal layers not being considered layers in the sense that they have assigned a layer_id, which maps to HEVC's architecture in that HEVC's version 1, currently under development, is expected to allow for temporal scalability but not spatial/quality scalability or multiview features.
- one pre-defined value of layer_id is reserved for an extension mechanism.
- layer_id can co-serve as an indication of the position of the layer in layer hierarchy, not dissimilar to the common use (but not representation, constraints, or derivation mechanism) of priority_id in H.264.
- the NAL unit header includes at least one of store_ref_base_pic_flag, and use_ref_base_pic_flag.
- a slice header includes at least one of store_ref_base_pic_flag, and use_ref_base_pic_flag.
- an encoder can create at least one NAL unit header as described above.
- a MANE or a decoder can prune a scalable bitstream based on the layer_id, taking into account that the layer_id can indicate the position of the layer in a layer hierarchy.
- FIG. 1 presents syntax diagrams of NAL unit header and extensions in accordance with H.264.
- FIG. 2 presents a syntax diagram of the prefix NAL unit in accordance with H.264.
- FIG. 3 presents a syntax diagram of a scalability information SET message in accordance with H.264.
- FIG. 4 presents a schematic illustration of a video conferencing system comprising encoder, MANE, and decoder.
- FIG. 5 presents a syntax diagram of an improved NAL unit header in accordance with an embodiment of the disclosed subject matter.
- FIG. 6 presents a schematic illustration of the layer_id and temporal_id used by layers of a layer hierarchy and referencing a layer description in a table of layer descriptions.
- FIG. 7 presents a syntax diagram of an improved NAL unit header in accordance with an embodiment of the disclosed subject matter.
- FIG. 8 presents a schematic illustration of the layer_id used by layers of a layer hierarchy and referencing a layer description in a table of layer descriptions.
- FIG. 9 presents a schematic illustration of the layer_id used by simulcast layers of two layer hierarchy and referencing a layer description in a table of layer descriptions.
- FIG. 10 presents a flowchart of a decoder using a NAL unit header.
- FIG. 11 shows a computer system for video coding in accordance with an embodiment of the disclosed subject matter.
- FIG. 5 presents a syntax diagram of a NAL unit header ( 501 ) in accordance with the disclosed subject matter.
- the NAL unit header can include the following flags and fields:
- a forbidden_zero_bit ( 502 ) (for example 1 bit long, and forced to be 0) can be included so to prevent start code emulation with certain multiplex formats, such as MPEG-2 systems.
- a nal_ref flag ( 503 ) (for example 1 bit long) can be included. When set to 1, the flag can indicate that the NAL unit is required for the decoding process. This flag can allow a MANE and/or a decoder to identify NAL units not required for the decoding process, and, for example, discard such identified NAL units in case of insufficient bitrate and/or processing cycles.
- a nal_unit_type ( 504 ), for example 6 bits long) can be included.
- the nal_unit_type indicates the type of the NAL unit. H.264 used up almost all of its allocated 24 NAL unit types and required certain extension mechanism to multiplex different NAL unit types to the same value of nal unit type; a six bit field allows for up to 64 NAL unit types and should, therefore, help to avoid the use of such extension mechanisms.
- NAL unit types can, for example, refer to parameter set NAL units of different types (such as: dependency parameter set, sequence parameter set, picture parameter set), slice NAL units of different types (such as: IDR-slice, P-slice, B-slice), SEI message NAL units, and so forth.
- the NAL unit header can additionally include a temporal_id (3 bits) ( 506 ) identifying the temporal sublayer to which the NAL unit belongs.
- Temporal layers have been described, for example, in Ser. No. 13/343,266.
- Also included in NAL unit headers for coded slices can be a layer_id ( 506 ) (5 bits).
- the fields of the NAL unit header are shown as fixed length integers or as flags.
- the use of fixed length integers or flags has advantages from an implementation and specification viewpoint in the light that the NAL unit header can also be used as, for example, an RTP payload header. While an integer or Boolean representation of data in the NAL unit header may be preferable from this viewpoint, there are other considerations that can speak in favor of other entropy coding mechanisms of the NAL unit header information.
- FIG. 6 shows an example of the use of the improved NAL unit header ( 601 ).
- the NAL unit type is 1, indicating a slice.
- Layer_id is set to 2
- temporal_id is set to 1, indicating a reference to a first temporal enhancement sub-layer.
- the layer_id can be used to reference ( 602 ) an entry with the same layer_id ( 603 ) in a table of layer descriptions ( 604 ).
- the dependency_id is set to 1 and the quality_id is also set to 1.
- This reference ( 602 ) is shown in a punctuated line to differentiate the logical referencing between the layer_id in the NAL unit header and the layer_id in the table of layer descriptions from inter-layer prediction relationships, as described later.
- a layer structure is also depicted.
- a base layer ( 605 ) with a temporal_id of 0 (as indicated by “T0” in the drawing) is used for prediction by a spatial enhancement layer ( 606 ), also with a temporal_id of 0.
- the spatial enhancement layer ( 606 ) is being referred to by a quality enhancement layer ( 607 ).
- the inter-layer prediction references as shown as boldface arrows, ( 608 ) and ( 609 ). Representations of these inter-layer prediction relationships may also be present in the table of layer descriptions, as already mentioned.
- temporal enhancement sub-layers denoted as T 1 or T 2 (for first and second temporal enhancement sub-layer, respectively).
- the quality enhancement layer ( 607 ) has two temporal enhancement sub-layers, T 1 ( 610 ) and T 2 ( 611 ).
- Temporal enhancement sub-layers and their inter-layer prediction relationships are depicted in dotted in contrast to the boldface lines used to show base and enhancement layers and their inter-layer prediction relationship.
- the temporal_id field refers directly to the temporal_enhancement sub-layer that is based on base, or enhancement layer (indirectly) referred to by layer_id.
- the layer_id can also co-serve as an indication of the position of a given layer in a layer hierarchy.
- layer ( 605 ) has a layer_id 0
- layer ( 606 ) has a layer_id 1
- layer ( 607 ) has a layer_id 2.
- a MANE or a decoder in need of discarding NAL units of a layer or sub-layer can identify NAL units belonging to layers that can be discarded.
- FIG. 7 shows a syntax diagram of a different design of a NAL unit header ( 701 ).
- the first octet can be similar to the NAL unit header shown and described in FIG. 5 .
- the second octet is at least partly populated by a layer_id ( 702 ), but omitting the temporal_id.
- Zero or more bits of the second octet can be left as reserved; shown is one such bit ( 703 ).
- temporal layers are not considered sub-layers but qualify as layers, as shown in FIG. 8 .
- the layer structure is similar to that of FIG. 6 .
- the layer description table ( 801 ) is populated by all spatial, quality, and temporal enhancement layers.
- a NAL unit header ( 802 ) contains a layer_id ( 803 ), referring ( 804 ) to one entry ( 805 ) in the layer description table ( 801 ).
- This entry identifies, possibly among other fields, the dependency_id, quality_id, and temporal_id, and can be used to identify ( 806 ) the layer in all spatial, quality and temporal dimensions.
- the layer description table can also include entries for other dimensions, such as, for example, view_id, and/or depth_map_flag.
- Simulcasting refers herein to a mechanism in which there can be multiple base layers, as shown in FIG. 9 .
- a no_inter_layer_prediction_flag can be used to identify those layers that do not require any other layers for inter layer prediction.
- the flag can be located in entries in the layer description table.
- FIG. 9 shows two layer structures.
- Base layer ( 901 ) is used for prediction by quality enhancement layer ( 902 ), which, in turn, is being referred to by a temporal enhancement layer ( 903 ).
- a second base layer ( 904 ) can be enhanced by a temporal enhancement layer ( 905 ).
- the two base layers can differ, for example, in their spatial resolution, which is one use case for simulcasting.
- base layer ( 904 ) is assumed to have a higher spatial resolution than base layer ( 901 ).
- the spatial size of any enhancement layer can be the same as its respective (referenced) base layer.
- available in the scalable/simulcast bitstream are two resolutions, at different temporal and/or quality versions.
- a layer description table ( 906 ) can be populated with entries ( 907 ) ( 909 ) for the two base layers ( 902 ) ( 904 ), respectively, and with an entry ( 908 ) for the spatial enhancement layer ( 903 ).
- the two base layers are identified by the no_inter_layer_prediction_flag ( 910 ) set to 1, whereas in the layer description table entry for the spatial enhancement layer (which can require another layer for prediction) the no_inter_layer_prediction_flag is set to 0.
- An encoder can control the values used for layer_id.
- the encoder has exercised this control by dividing the numbering range allowed by the (in the example) 5 bit binary coded layer_id field such that one base layer uses layer_0, and the other uses layer_id 16.
- NAL unit header ( 911 ), containing a layer_id ( 912 ) referring ( 914 ) to the corresponding entry in the table ( 909 ), and a temporal_id ( 913 ) referring ( 915 ) to the selected temporal layer ( 905 ).
- an extension mechanism can be added by reserving a pre-defined layer_id, for example layer_id 31 (the highest layer_id representable with a 5 bit binary coded integer) as an indication that at least one more octet of NAL unit header information follows.
- the syntax of this extension octet may not necessarily need to be defined today.
- a decoder not compliant with a standard version before enacting of the extension can, for example, ignore the extension octets.
- this NAL unit can include two flags: use_ref_base_pic_flag and store_ref base_pic_flag.
- MGS Medium Grain Scalability
- these flags can be located in the slice header of base layer slices.
- a use_ref_base_pic_flag can indicate that an enhancement quality layer picture is coded using inter layer prediction from a base layer picture.
- the flag can be located in the slice header of a slice belonging to a base layer picture.
- a store_ref_base_pic_flag can require a decoder to store the current base layer picture in the reference picture buffer for possible later use.
- the store_ref_base_pic_flag can be located in the slice header of a slice belonging to a base layer picture to be stored in the reference picture buffer.
- the use_ref_base_pic_flag and/or store_ref_base_pic_flag can also be located in fields in the NAL unit header, serving a similar purpose as already described.
- the overhead of placing the flags in the slice header or NAL unit header can be approximately the same.
- the aforementioned syntax can be used, for example, in a decoder as follows.
- a decoder can receive and decode a coded table of layer descriptions ( 1001 ).
- Co-pending U.S. patent application Ser. No. 61/451,454 (DPS) describes, among other things, a mechanism for this step.
- the table of layer descriptions can be assumed to be static during, for example, a sequence (identified by IDR pictures in all layers), or a group of pictures.
- Co-pending Ser. No. 61/451,454 describes an activation mechanism for a dependency parameter set that can be used to ensure that a change in the table of layer descriptions can only occur at well-defined points in the scalable bitstream.
- any decoder including a decoder incapable of decoding a scalable bitstream, can be capable of receiving and decoding a table of layer descriptions.
- a decoder incapable of decoding for example, a quality enhancement layer, can, by interpreting the table of layer description, identify layer_id values for quality enhancement layers and react accordingly, for example by discarding all such NAL units it may receive.
- Even a decoder incapable of any scalable mechanism can still identify the layer_ids of the one or more (in case of simulcast) independently decodable base layers.
- NAL units of the layers described in the table of layer descriptions can commence.
- a NAL unit can be received ( 1002 ).
- Non-slice NAL units such as parameter set NAL units, SEI messages, and others, can be identified ( 1003 ) by interpreting the nal_unit_type field, and can be dealt with ( 1004 ).
- a slice NAL unit can contain a layer_id, which can be interpreted ( 1005 ) and can trigger, for example, decoding or discarding of the NAL unit.
- the interpretation can involve, for example, de-referencing the layer_id to address an entry in the table of layer descriptions as already described.
- the decoder can determine whether the NAL unit belongs to a layer that should be decoded. This determination can involve many options. For example, a decoder can decide not to decode a NAL unit, if it is incapable of decoding it because it does not understand its type of layer, because it has not enough decoding cycles, because it knows that a layer on which the received NAL unit depends on has been damaged (i.e.
- the layer does not give a sufficient benefit for the user (i.e. the screen resolution is too small to make rendering of the high spatial resolution of the layer practical or helpful), and so on.
- Some of this options can be static in the sense that they apply to all NAL units of a coded bitstream nature (i.e. a decoder that is not implementing the decoding techniques for a certain enhancement layer type can discard any NAL units that are of that type), and others can be dynamic (i.e. NAL units of dependent enhancement layers can normally be decoded, but can be discarded if the base layer is damaged).
- Any NAL unit with a layer_id not present in the table of layer descriptions can be an indication of a non-conforming scalable bitstream. Many reactions of a decoder are possible to non-conforming bitstreams. In this situation, one sensible decoder design can be to discard the received NAL unit.
- a decoder decides ( 1006 ) to decode ( 1007 ) the NAL unit, or to discard it.
- Operation continues ( 1008 ) with the next NAL unit of the scalable bitstream.
- a MANE can perform similar steps, with the exception that a MANE will normally not decode a slice NAL unit, but rather selectively forward it to decoder(s).
- FIG. 11 illustrates a computer system 1100 suitable for implementing embodiments of the present disclosure.
- Computer system 1100 can have many physical forms including an integrated circuit, a printed circuit board, a small handheld device (such as a mobile telephone or PDA), a personal computer or a super computer.
- Computer system 1100 includes a display 1132 , one or more input devices 1133 (e.g., keypad, keyboard, mouse, stylus, etc.), one or more output devices 1134 (e.g., speaker), one or more storage devices 1135 , various types of storage medium 1136 .
- input devices 1133 e.g., keypad, keyboard, mouse, stylus, etc.
- output devices 1134 e.g., speaker
- storage devices 1135 e.g., various types of storage medium 1136 .
- the system bus 1140 link a wide variety of subsystems.
- a “bus” refers to a plurality of digital signal lines serving a common function.
- the system bus 1140 can be any of several types of bus structures including a memory bus, a peripheral bus, and a local bus using any of a variety of bus architectures.
- bus architectures include the Industry Standard Architecture (ISA) bus, Enhanced ISA (EISA) bus, the Micro Channel Architecture (MCA) bus, the Video Electronics Standards Association local (VLB) bus, the Peripheral Component Interconnect (PCI) bus, the PCI-Express bus (PCI-X), and the Accelerated Graphics Port (AGP) bus.
- Processor(s) 1101 also referred to as central processing units, or CPUs optionally contain a cache memory unit 1102 for temporary local storage of instructions, data, or computer addresses.
- Processor(s) 1101 are coupled to storage devices including memory 1103 .
- Memory 1103 includes random access memory (RAM) 1104 and read-only memory (ROM) 1105 .
- RAM random access memory
- ROM read-only memory
- RAM 1104 acts to transfer data and instructions uni-directionally to the processor(s) 1101
- RAM 1104 is used typically to transfer data and instructions in a bi-directional Both of these types of memories can include any suitable of the computer-readable media described below.
- a fixed storage 1108 is also coupled bi-directionally to the processor(s) 1101 , optionally via a storage control unit 1107 . It provides additional data storage capacity and can also include any of the computer-readable media described below.
- Storage 1108 can be used to store operating system 1109 , EXECs 1110 , application programs 1112 , data 1111 and the like and is typically a secondary storage medium (such as a hard disk) that is slower than primary storage. It should be appreciated that the information retained within storage 1108 , can, in appropriate cases, be incorporated in standard fashion as virtual memory in memory 1103 .
- Processor(s) 1101 is also coupled to a variety of interfaces such as graphics control 1121 , video interface 1122 , input interface 1123 , output interface 1124 , storage interface 1125 , and these interfaces in turn are coupled to the appropriate devices.
- an input/output device can be any of: video displays, track balls, mice, keyboards, microphones, touch-sensitive displays, transducer card readers, magnetic or paper tape readers, tablets, styluses, voice or handwriting recognizers, biometrics readers, or other computers.
- Processor(s) 1101 can be coupled to another computer or telecommunications network 1130 using network interface 1120 .
- the CPU 1101 might receive information from the network 1130 , or might output information to the network in the course of performing the above-described method.
- method embodiments of the present disclosure can execute solely upon CPU 1101 or can execute over a network 1130 such as the Internet in conjunction with a remote CPU 1101 that shares a portion of the processing.
- computer system 1100 when in a network environment, i.e., when computer system 1100 is connected to network 1130 , computer system 1100 can communicate with other devices that are also connected to network 1130 . Communications can be sent to and from computer system 1100 via network interface 1120 . For example, incoming communications, such as a request or a response from another device, in the form of one or more packets, can be received from network 1130 at network interface 1120 and stored in selected sections in memory 1103 for processing. Outgoing communications, such as a request or a response to another device, again in the form of one or more packets, can also be stored in selected sections in memory 1103 and sent out to network 1130 at network interface 1120 . Processor(s) 1101 can access these communication packets stored in memory 1103 for processing.
- embodiments of the present disclosure further relate to computer storage products with a computer-readable medium that have computer code thereon for performing various computer-implemented operations.
- the media and computer code can be those specially designed and constructed for the purposes of the present disclosure, or they can be of the kind well known and available to those having skill in the computer software arts.
- Examples of computer-readable media include, but are not limited to: magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD-ROMs and holographic devices; magneto-optical media such as optical disks; and hardware devices that are specially configured to store and execute program code, such as application-specific integrated circuits (ASICs), programmable logic devices (PLDs) and ROM and RAM devices.
- ASICs application-specific integrated circuits
- PLDs programmable logic devices
- Examples of computer code include machine code, such as produced by a compiler, and files containing higher-level code that are executed by a computer using an interpreter.
- machine code such as produced by a compiler
- files containing higher-level code that are executed by a computer using an interpreter.
- interpreter Those skilled in the art should also understand that term “computer readable media” as used in connection with the presently disclosed subject matter does not encompass transmission media, carrier waves, or other transitory signals.
- the computer system having architecture 1100 can provide functionality as a result of processor(s) 1101 executing software embodied in one or more tangible, computer-readable media, such as memory 1103 .
- the software implementing various embodiments of the present disclosure can be stored in memory 1103 and executed by processor(s) 1101 .
- a computer-readable medium can include one or more memory devices, according to particular needs.
- Memory 1103 can read the software from one or more other computer-readable media, such as mass storage device(s) 1135 or from one or more other sources via communication interface.
- the software can cause processor(s) 1101 to execute particular processes or particular parts of particular processes described herein, including defining data structures stored in memory 1103 and modifying such data structures according to the processes defined by the software.
- the computer system can provide functionality as a result of logic hardwired or otherwise embodied in a circuit, which can operate in place of or together with software to execute particular processes or particular parts of particular processes described herein.
- Reference to software can encompass logic, and vice versa, where appropriate.
- Reference to a computer-readable media can encompass a circuit (such as an integrated circuit (IC)) storing software for execution, a circuit embodying logic for execution, or both, where appropriate.
- IC integrated circuit
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
Description
- This application claims priority to U.S. provisional application Ser. No. 61/432,836, filed Jan. 14, 2011, titled “Improved NAL Unit Header for Supporting Quality/Spatial Scalability,” the disclosure of which is hereby incorporated by reference in its entirety.
- This application relates to video compression systems, and more particularly to systems that use scalable/simulcast/multiview video coding techniques where two or more layers are used to represent a given video signal.
- Certain commercial video compression techniques can use video coding standards to allow for cross-vendor interoperability. The present disclosure can be used with such a video coding standard, specifically ITU-T Rec. H.264, “Advanced video coding for generic audiovisual services”, 03/2010, available from the International Telecommunication Union (“ITU”), Place de Nations, CH-1211 Geneva 20, Switzerland or http://www.itu.int/rec/T-REC-H.264, and incorporated herein by reference in its entirety.
- An initial version of H.264's was ratified in 2003, and included coding tools, for example a flexible reference picture selection model, that allows for temporal scalability. A subsequent version, ratified in 2007, added in Annex G an extension towards scalable video coding (SVC), including techniques for spatial scalability and quality scalability, also known as signal-to-noise (SNR) scalability. Yet another version ratified in 2009, included in Annex H multi-view coding (MVC),
- Earlier versions of H.264 were designed without paying special regards to the requirements of later versions. This has resulted in a number of certain architectural shortcomings, for example in the design of the Network Adaptation Layer (NAL) Unit header, some of which are being addressed by the disclosed subject matter. Co-pending U.S. application Ser. No. 13/343,266, filed Jan. 4, 2012, titled “High Layer Syntax for Temporal Scalability,” the disclosure of which is incorporated by reference herein in its entirety, addresses potential shortcomings at least in the signaling of temporal scalability, while co-pending U.S. provisional patent application Ser. No. 61/451,454, filed Mar. 10, 2012, titled “Dependency Parameter Set for Scalable Video Coding, the disclosure of which is incorporated by reference herein in its entirety, addresses potential shortcomings at least related to the signaling of layer dependencies.
- In H.264, a bitstream is logically subdivided into NAL units. Each coded picture is coded in one or more slice NAL units. Many other NAL unit categories are also defined for different types of data, such as, for example, parameter sets, SEI messages, and so forth. In some cases, a NAL unit can be “parsing-independent” in that a loss of a NAL unit may not prevent the meaningful decoding and use of other NAL units. Accordingly, NAL units can be the placed into packets of packet networks subject to packet losses. This use case was one of the motivations for the introduction of the NAL unit concept over the bitstream concept known from earlier video compression standards such as MPEG-2 (ITU-T Rec. H.262 “Information technology—Generic coding of moving pictures and associated audio information: Video”, 02/2000, available from http://www.itu.int/ree/T-REC-H.262, which is also known as MPEG-2 video, incorporated herein by reference).
- Throughout the disclosure, syntax table diagrams following the conventions specified in H.264 are being used. To briefly summarize those conventions, a C-style notation is used. A boldface character string refers to a syntax element fetched from the bitstream (which can consist of NAL units separated by, for example, start codes or packet headers). The “Descriptor” column of the syntax diagram table provides information of the type of data. For example, u(2) refers to an unsigned integer of 2 bits length, f(1) refers to a single bit of a predefined value.
-
FIG. 1 shows a NAL unit header of baseline H.264 and the SVC and MVC extensions. The baseline NAL unit header is part of the NAL unit syntax specification, which is shown (101) with certain parts omitted so not to obscure the disclosure. Specifically, the NAL unit header includes a forbidden_zero_bit (102), two bits indicating the relative importance of the NAL unit for the decoding process (nal_ref_idc, 103), and five bits indicating the NAL unit type (104). For certain NAL unit types, namelytypes - The C-function-style references of nal_unit_header_svc_extension()and nal_unit_header_mvc_extension()refer to syntax tables as shown as the SVC NAL unit header extension (110), and the MVC NAL unit header extension (120), respectively.
- Of the SVC NAL unit header extension (110), of particular relevance in the context of this disclosure are the following fields:
- The priority_id field (111) can be used to linearly signal the relative importance, as determined by the encoder, of a layer relative to other layers of the same scalable bitstream, where a layer can be any of a temporal, spatial, or SNR scalable layer. A dependent layer has a higher priority_id than the layer it depends on. Priority_id is not used by the H.264 decoding process definition, but can be used, for example by decoders or Media-Aware Network Elements (MANEs) to identify NAL units not required for the decoding of a certain layer (where that layer is lower in the layer hierarchy than the layer to which the NAL unit with the high priority_id value belongs). H.264 specifies certain constraints of its value based on the values of dependency_id, quality_id, and temporal_id.
- The no_inter_layer-Pred_flag (112) indicates that the layer the NAL unit belongs to is not referring to any other layer for prediction. If set for all NAL units of a given layer, this flag can indicate that the layer can be decoded without regards of any other layer, allowing for techniques such as simulcasting.
- The dependency_id field (113) indicates the spatial layer or coarse grain SNR scalable layer the NAL unit belongs to—the higher the value, the higher the layer. Quality_id and temporal_id indicate similar properties for SNR scalable and temporal scalable layers.
- The MVC NAL unit extension header (120) includes the following pertinent fields.
- Priority_id (121) and temporal_id (123) have similar semantics as described above for the SVC header priority_id (111) and temporal_id (115) fields. View_id identifies one out of up to 1024 “views” of a multiview system, which can, for example, be coded signals from different cameras at different geometric positions capturing the same scene in 3D space. MVC allows for prediction across views, based on the observation that there can be redundancies between views that can be eliminated through prediction.
- One goal during the specification of the scalable extension of H.264 has been to allow for the decoding of a scalable base layer by a legacy decoder that was designed before the ratification of the scalable extension, for example by a decoder conforming to any profile of the 2003 version of H.264. For this and other reasons, no backward incompatible changes have been introduced to the base layer syntax. However, there can be certain control information related to, or even affecting, base layer decoding in a scalable coding context (i.e. in conjunction with at least one enhancement layer), that may be not required in context of decoding of the base layer in isolation and, therefore, was not included in, for example the 2003 version of H.264. Some of this information can also be relevant for MVC. Syntax for information of this category was added to the scalable extension of H.264 by, for example, the mechanisms described next.
- A first mechanism is the use of different NAL unit types for slice data belonging to scalable or multiview coding, which can trigger the presence of additional fields in the NAL unit header, as already described.
- A second mechanism is the introduction of a prefix NAL unit. It uses one of the previously reserved NAL unit types, which means that a legacy decoder that does not recognize the reserved type would ignore its content, whereas a scalable or multiview decoder can interpret its content. The syntax of the prefix NAL unit (201) is shown in
FIG. 2 . The NAL unit can include a store_ref base_pic_flag (202) indicating, among other things and only if additional conditions are met, the presence of base picture marking information (203). Though the precise nature of such information may not be particularly relevant for this disclosure, its content is required for the decoding process in a scalable decoding situation. - A third mechanism is known as the scalability_info SEI message. Supplementary Enhancement Information (SEI) messages, as defined in H.264, should not include information required for the decoding process, but are intended for information helpful for a decoder, MANE, or other parts of the overall system layout such as rendering.
- The scalability information SEI message can be viewed as a description of the scalable bitstream, including aspects such as description of its layers, inter-layer dependencies, and so forth. The syntax table of the SEI message in the H.264 specification is approximately two pages long. Some parts of it relevant for this disclosure are reproduced in
FIG. 3 . The scalability information SEI message (301) includes a number of flags concerned with the scalable bitstream (i.e. all layers), which is followed by an integer indicating the number of layers (302). For each of the layers, the following fields are available. - A layer_id (303) field provides for an identification of the layer. It can be used, for example, to cross-reference the layer with other layer descriptions that are located in parts of the SEI message not depicted (such as, for example, inter-layer dependency descriptions). For example, the binding between a dependent layer and the layer it depends on, within the SEI message, is established through layer_id.
- The priority_id (304), dependency_id (305), quality_id (306), and temporal_id (307) fields field have a meaning similar to what was already described in the context of the SVC NAL unit header fields with the same name.
- All three mechanisms can be described as “bolt-on” to the non-scalable versions of H.264 (versions ratified before 2007). While preserving backward compatibility, the design is generally not characterized as elegant, can incur an unnecessarily high overhead for NAL units and pictures of the scalable extension, and can have error resilience issues.
- As an example of unnecessarily high overhead, when using H.264's byte stream syntax, the overhead for a given NAL unit in the bitstream is at least four octets for the startcode. Similarly, when using an IP network and placing a NAL unit into its own packet, the overhead can be 40 octets or more (12 octets for the IP header, 8 octets for the UDP header, and 20 octets for the RTP header). While aggregation techniques as well as header compression techniques can reduce that overhead to a certain extent, reducing overhead further and/or avoiding it altogether would be preferable.
- With respect to error resilience,
FIG. 4 shows a simplified block diagram of a video conferencing system. An encoder (401) can produce a scalable bitstream (402) comprising NAL units belonging to more than one layer. Bitstream (402) is depicted as a bold line to indicate that it has a certain bitrate. The bitstream (402) can be forwarded over a network link to a media aware network element (MANE) (403). The MANE's (403) function can be to “prune” the bitstream down to a certain bitrate provided by second network link, for example by selectively removing those NAL units belonging to the highest layer. This is shown by the dotted line for the bitstream (404) sent from the MANE (103) to a decoder (405). If the scalable bitstream, (402) contains only NAL units of a base layer and one enhancement layer, then, after pruning, bitstream (404) contains only NAL units of the base layer. The decoder (405) can receive the pruned bitstream (404) from the MANE (403), and decode and render it. - In such an application, the potential unavailability of a scalability information SEI message at the MANE very early in the connection—ideally before any coded slice NAL unit of any layer is received by the MANE in bitstream (402), can have negative consequences on the decoder behavior and/or incur unnecessarily high cost in the decoder implementation. For example, without knowing the scalability structure (for example: number of layers and their dependency), the MANE (403) may need to forward, and the decoder (405) may need to buffer and, to the extent possible, decode all NAL units it receives, even those it will not be using for rendering (for example because they belong to a spatial layer of a higher resolution than the display of a handheld device). Similarly, the MANE (403) can have great difficulty in deciding which NAL units to forward to a decoder of limited capability if it receives a scalable bitstream of high complexity (many layers), but is aware that a receiving decoder can process only a non-scalable bitstream or a scalable bitstream of low complexity (few layers). An SEI message, including the scalability information SEI message, can be unavailable because, for example, it was lost during the transmission of bitstream (402), or because the encoder (401) decides not to send the SEI message, for example to save the bits of the message (which is conforming to the standard, although not advisable from an application design viewpoint).
- A MANE also needs to maintain state, especially with respect to the content of the Scalability Information SEI message, so to make informed decisions about pruning. Such state can be established only by intercepting and interpreting all such SEI messages. While most MANEs need to intercept and interpret some bitstream information, such as parameter set information to make meaningful decisions, very few of the numerous SEI messages have any meaning to a MANE. Intercepting all SEI messages just to extract and interpret those few which are meaningful for the MANE can be an onerous and computationally expensive process.
- In short, H.264's scalable and multiview syntax related to the NAL unit header contains several potential shortcomings as a result of the “bolt-on” design of the scalable and multiview extension. First, the NAL unit header for NAL units of extension headers can be unnecessarily large. Information pertaining to picture buffer management is sent in its own NAL unit (the prefix NAL unit), which can incur unnecessarily high overhead. In addition, information important for certain applications (such as information carried in the scalable information SEI message) are carried in SEI messages, which (a) does not reflect their critical nature (SEI can be discarded), and (b) may require unnecessary duplication of some information in, for example, the NAL unit header (such as: dependency_id, quality_id, view_id).
- Recently, a High Efficiency Video Coding (HEVC) has been considered for standardization. A working draft of HEVC can be found at (B. Bross et. al., “WD4:
Working Draft 4 of High-Efficiency Video Coding”, available from http://wftp3.itu.int/av-arch/jctvc-site/2011—07_F_Torino/), referred to as “WD4” henceforth, which is incorporated herein by reference. HEVC inherits many high level syntax features of H.264. It can be advantageous to the success of HEVC if the potential shortcomings of H.264 described above were addressed before the standard is ratified. - The disclosed subject matter provides for a NAL unit header that can be more efficient than the one described in H.264 or WD4, and can allow for lightweight MANE and decoder implementations, In conjunction with other techniques such as a Dependency Parameter set (DPS), as described in co-pending Ser. No. 61/451,454, and embedded in a high level syntax architecture as described in our co-pending patent application entitled “Techniques for Layered Video Encoding and Decoding,” filed concurrently with the present application and assigned to the common assignee, the disclosure of which is incorporated by reference herein, the disclosed subject matter can overcome the potential shortcomings mentioned above.
- In an embodiment, a NAL unit header includes a layer_id. The layer_id can, for example, be represented by an integer of, for example, six bits. The layer_id can refer to a description of the layer located in table of layer descriptions.
- In the same or another embodiment, the table of layer descriptions is included in a dependency parameter set or a high level syntax structure serving a purpose substantially similar to a dependency parameter set.
- In the same or another embodiment, the layer description referred to be the layer_id in the NAL unit header includes fields for at least one of a dependency_id, quality_id, view_id, a depth_map_flag, and a dependent_flag.
- In the same or another embodiment, the depth_map_flag can indicate that the layer or layers it is associated with is/are a depth map. Association with a depth map, which can indicate, on a per sample basis, a third dimension (depth) of a sample, with a view, can be established using the view_id.
- In the same or another embodiment, the NAL unit header includes a temporal_id and a layer_id. The temporal_id can refer to a temporal sub-layer of the (spatial/quality/view/depth-map) layer defined by the description referenced by the layer_id. Conceptually, this results in temporal layers not being considered layers in the sense that they have assigned a layer_id, which maps to HEVC's architecture in that HEVC's
version 1, currently under development, is expected to allow for temporal scalability but not spatial/quality scalability or multiview features. - In the same or another embodiment, one pre-defined value of layer_id is reserved for an extension mechanism.
- In the same or another embodiment, layer_id can co-serve as an indication of the position of the layer in layer hierarchy, not dissimilar to the common use (but not representation, constraints, or derivation mechanism) of priority_id in H.264.
- In the same or another embodiment, the NAL unit header includes at least one of store_ref_base_pic_flag, and use_ref_base_pic_flag.
- In the same or another embodiment, a slice header includes at least one of store_ref_base_pic_flag, and use_ref_base_pic_flag.
- In the same or another embodiment, an encoder can create at least one NAL unit header as described above.
- In the same or another embodiment, a MANE or a decoder can prune a scalable bitstream based on the layer_id, taking into account that the layer_id can indicate the position of the layer in a layer hierarchy.
-
FIG. 1 presents syntax diagrams of NAL unit header and extensions in accordance with H.264. -
FIG. 2 presents a syntax diagram of the prefix NAL unit in accordance with H.264. -
FIG. 3 presents a syntax diagram of a scalability information SET message in accordance with H.264. -
FIG. 4 presents a schematic illustration of a video conferencing system comprising encoder, MANE, and decoder. -
FIG. 5 presents a syntax diagram of an improved NAL unit header in accordance with an embodiment of the disclosed subject matter. -
FIG. 6 presents a schematic illustration of the layer_id and temporal_id used by layers of a layer hierarchy and referencing a layer description in a table of layer descriptions. -
FIG. 7 presents a syntax diagram of an improved NAL unit header in accordance with an embodiment of the disclosed subject matter. -
FIG. 8 presents a schematic illustration of the layer_id used by layers of a layer hierarchy and referencing a layer description in a table of layer descriptions. -
FIG. 9 presents a schematic illustration of the layer_id used by simulcast layers of two layer hierarchy and referencing a layer description in a table of layer descriptions. -
FIG. 10 presents a flowchart of a decoder using a NAL unit header. -
FIG. 11 shows a computer system for video coding in accordance with an embodiment of the disclosed subject matter. - The Figures are incorporated and constitute part of this disclosure. Throughout the Figures the same reference numerals and characters, unless otherwise stated, are used to denote like features, elements, components or portions of the illustrated embodiments. Moreover, while the disclosed subject matter will now be described in detail with reference to the Figures, it is done o in connection with the illustrative embodiments.
-
FIG. 5 presents a syntax diagram of a NAL unit header (501) in accordance with the disclosed subject matter. The NAL unit header can include the following flags and fields: - A forbidden_zero_bit (502) (for example 1 bit long, and forced to be 0) can be included so to prevent start code emulation with certain multiplex formats, such as MPEG-2 systems.
- A nal_ref flag (503) (for example 1 bit long) can be included. When set to 1, the flag can indicate that the NAL unit is required for the decoding process. This flag can allow a MANE and/or a decoder to identify NAL units not required for the decoding process, and, for example, discard such identified NAL units in case of insufficient bitrate and/or processing cycles.
- A nal_unit_type (504), for example 6 bits long) can be included. The nal_unit_type indicates the type of the NAL unit. H.264 used up almost all of its allocated 24 NAL unit types and required certain extension mechanism to multiplex different NAL unit types to the same value of nal unit type; a six bit field allows for up to 64 NAL unit types and should, therefore, help to avoid the use of such extension mechanisms. NAL unit types can, for example, refer to parameter set NAL units of different types (such as: dependency parameter set, sequence parameter set, picture parameter set), slice NAL units of different types (such as: IDR-slice, P-slice, B-slice), SEI message NAL units, and so forth.
- For those NAL unit types referring to coded slices (expressed by if()statement 505), the NAL unit header can additionally include a temporal_id (3 bits) (506) identifying the temporal sublayer to which the NAL unit belongs. Temporal layers have been described, for example, in Ser. No. 13/343,266. Also included in NAL unit headers for coded slices can be a layer_id (506) (5 bits).
- The fields of the NAL unit header are shown as fixed length integers or as flags. The use of fixed length integers or flags has advantages from an implementation and specification viewpoint in the light that the NAL unit header can also be used as, for example, an RTP payload header. While an integer or Boolean representation of data in the NAL unit header may be preferable from this viewpoint, there are other considerations that can speak in favor of other entropy coding mechanisms of the NAL unit header information.
-
FIG. 6 shows an example of the use of the improved NAL unit header (601). In this example, the NAL unit type is 1, indicating a slice. Layer_id is set to 2, and temporal_id is set to 1, indicating a reference to a first temporal enhancement sub-layer. - The layer_id can be used to reference (602) an entry with the same layer_id (603) in a table of layer descriptions (604). In the entry for layer_id 2 (603) the dependency_id is set to 1 and the quality_id is also set to 1. Not shown is the information that indicates the prediction relationships between layers; co-pending US patent application Ser. No. 61/451,454 (DPS) includes a detailed description of this information. This reference (602) is shown in a punctuated line to differentiate the logical referencing between the layer_id in the NAL unit header and the layer_id in the table of layer descriptions from inter-layer prediction relationships, as described later.
- A layer structure is also depicted. A base layer (605) with a temporal_id of 0 (as indicated by “T0” in the drawing) is used for prediction by a spatial enhancement layer (606), also with a temporal_id of 0. The spatial enhancement layer (606) is being referred to by a quality enhancement layer (607). The inter-layer prediction references as shown as boldface arrows, (608) and (609). Representations of these inter-layer prediction relationships may also be present in the table of layer descriptions, as already mentioned.
- The entry in the table of layer descriptions referenced by layer_id=2 (603) refers through the values of dependency_id and quality_id to the quality enhancement layer (607) in the same way as the NAL unit de-referencing of dependency_id and quality_id was used to identify a target layer in H.264.
- Also shown are numerous temporal enhancement sub-layers, denoted as T1 or T2 (for first and second temporal enhancement sub-layer, respectively). For example, the quality enhancement layer (607) has two temporal enhancement sub-layers, T1 (610) and T2 (611). Temporal enhancement sub-layers and their inter-layer prediction relationships are depicted in dotted in contrast to the boldface lines used to show base and enhancement layers and their inter-layer prediction relationship. The temporal_id field refers directly to the temporal_enhancement sub-layer that is based on base, or enhancement layer (indirectly) referred to by layer_id.
- The layer_id can also co-serve as an indication of the position of a given layer in a layer hierarchy. In the example, layer (605) has a
layer_id 0, layer (606) has alayer_id 1, and layer (607) has alayer_id 2. A MANE or a decoder in need of discarding NAL units of a layer or sub-layer can identify NAL units belonging to layers that can be discarded. For example, if the MANE or decoder finds itself in need to discard NAL units belonging to layer (606) (identified by layer_id 1), then it is clear that the inter-layer prediction relationship (609) may not be maintained and, accordingly, the MANE or decoder can also discard NAL units with layer_id larger than 1, for example layer_id=2. The same is true with respect to removing NAL units belonging to temporal sub-layers. -
FIG. 7 shows a syntax diagram of a different design of a NAL unit header (701). The first octet can be similar to the NAL unit header shown and described inFIG. 5 . However, the second octet is at least partly populated by a layer_id (702), but omitting the temporal_id. Zero or more bits of the second octet can be left as reserved; shown is one such bit (703). In such a design, temporal layers are not considered sub-layers but qualify as layers, as shown inFIG. 8 . The layer structure is similar to that ofFIG. 6 . However, the layer description table (801) is populated by all spatial, quality, and temporal enhancement layers. Accordingly, there are now 7 entries in the table. A NAL unit header (802) contains a layer_id (803), referring (804) to one entry (805) in the layer description table (801). This entry identifies, possibly among other fields, the dependency_id, quality_id, and temporal_id, and can be used to identify (806) the layer in all spatial, quality and temporal dimensions. As already described, the layer description table can also include entries for other dimensions, such as, for example, view_id, and/or depth_map_flag. - The mechanism described above also supports simulcasting. Simulcasting refers herein to a mechanism in which there can be multiple base layers, as shown in
FIG. 9 . - In order to support multiple base layer in a layering structure, a no_inter_layer_prediction_flag can be used to identify those layers that do not require any other layers for inter layer prediction. The flag can be located in entries in the layer description table.
-
FIG. 9 shows two layer structures. Base layer (901) is used for prediction by quality enhancement layer (902), which, in turn, is being referred to by a temporal enhancement layer (903). A second base layer (904) can be enhanced by a temporal enhancement layer (905). The two base layers can differ, for example, in their spatial resolution, which is one use case for simulcasting. In this example, base layer (904) is assumed to have a higher spatial resolution than base layer (901). As, in this example, only temporal and quality enhancement layers are in use, the spatial size of any enhancement layer can be the same as its respective (referenced) base layer. As a result, available in the scalable/simulcast bitstream are two resolutions, at different temporal and/or quality versions. - A layer description table (906) can be populated with entries (907) (909) for the two base layers (902) (904), respectively, and with an entry (908) for the spatial enhancement layer (903). The two base layers are identified by the no_inter_layer_prediction_flag (910) set to 1, whereas in the layer description table entry for the spatial enhancement layer (which can require another layer for prediction) the no_inter_layer_prediction_flag is set to 0.
- An encoder can control the values used for layer_id. In the example, the encoder has exercised this control by dividing the numbering range allowed by the (in the example) 5 bit binary coded layer_id field such that one base layer uses layer_0, and the other uses layer_id 16.
- Also shown is a NAL unit header (911), containing a layer_id (912) referring (914) to the corresponding entry in the table (909), and a temporal_id (913) referring (915) to the selected temporal layer (905).
- One potential shortcoming of H.264 with respect to the pre-SVC (pre 2007) NAL unit header syntax has been its lack of an extension mechanism. In an embodiment, an extension mechanism can be added by reserving a pre-defined layer_id, for example layer_id 31 (the highest layer_id representable with a 5 bit binary coded integer) as an indication that at least one more octet of NAL unit header information follows. The syntax of this extension octet may not necessarily need to be defined today. A decoder not compliant with a standard version before enacting of the extension can, for example, ignore the extension octets.
- Another potential shortcoming of H.264's high level syntax was the existence of the prefix NAL unit. As already described, this NAL unit can include two flags: use_ref_base_pic_flag and store_ref base_pic_flag. In H.264, these flags are used for a technique known as Medium Grain Scalability (MGS). In order to support MGS in HEVC, these flags can be located in the slice header of base layer slices.
- A use_ref_base_pic_flag can indicate that an enhancement quality layer picture is coded using inter layer prediction from a base layer picture. The flag can be located in the slice header of a slice belonging to a base layer picture.
- A store_ref_base_pic_flag can require a decoder to store the current base layer picture in the reference picture buffer for possible later use. The store_ref_base_pic_flag can be located in the slice header of a slice belonging to a base layer picture to be stored in the reference picture buffer.
- The use_ref_base_pic_flag and/or store_ref_base_pic_flag can also be located in fields in the NAL unit header, serving a similar purpose as already described. The overhead of placing the flags in the slice header or NAL unit header can be approximately the same.
- The aforementioned syntax can be used, for example, in a decoder as follows.
- Referring to
FIG. 10 , a decoder can receive and decode a coded table of layer descriptions (1001). Co-pending U.S. patent application Ser. No. 61/451,454 (DPS) describes, among other things, a mechanism for this step. The table of layer descriptions can be assumed to be static during, for example, a sequence (identified by IDR pictures in all layers), or a group of pictures. Co-pending Ser. No. 61/451,454 describes an activation mechanism for a dependency parameter set that can be used to ensure that a change in the table of layer descriptions can only occur at well-defined points in the scalable bitstream. - According to the disclosed subject matter, any decoder, including a decoder incapable of decoding a scalable bitstream, can be capable of receiving and decoding a table of layer descriptions. A decoder incapable of decoding, for example, a quality enhancement layer, can, by interpreting the table of layer description, identify layer_id values for quality enhancement layers and react accordingly, for example by discarding all such NAL units it may receive. Even a decoder incapable of any scalable mechanism can still identify the layer_ids of the one or more (in case of simulcast) independently decodable base layers.
- With the layer descriptions received and decoded, the decoding of NAL units of the layers described in the table of layer descriptions can commence. A NAL unit can be received (1002). Non-slice NAL units, such as parameter set NAL units, SEI messages, and others, can be identified (1003) by interpreting the nal_unit_type field, and can be dealt with (1004).
- A slice NAL unit can contain a layer_id, which can be interpreted (1005) and can trigger, for example, decoding or discarding of the NAL unit. The interpretation can involve, for example, de-referencing the layer_id to address an entry in the table of layer descriptions as already described. Based on this information, the decoder can determine whether the NAL unit belongs to a layer that should be decoded. This determination can involve many options. For example, a decoder can decide not to decode a NAL unit, if it is incapable of decoding it because it does not understand its type of layer, because it has not enough decoding cycles, because it knows that a layer on which the received NAL unit depends on has been damaged (i.e. through packet loss), the layer does not give a sufficient benefit for the user (i.e. the screen resolution is too small to make rendering of the high spatial resolution of the layer practical or helpful), and so on. Some of this options can be static in the sense that they apply to all NAL units of a coded bitstream nature (i.e. a decoder that is not implementing the decoding techniques for a certain enhancement layer type can discard any NAL units that are of that type), and others can be dynamic (i.e. NAL units of dependent enhancement layers can normally be decoded, but can be discarded if the base layer is damaged).
- Any NAL unit with a layer_id not present in the table of layer descriptions can be an indication of a non-conforming scalable bitstream. Many reactions of a decoder are possible to non-conforming bitstreams. In this situation, one sensible decoder design can be to discard the received NAL unit.
- Based on the above, a decoder decides (1006) to decode (1007) the NAL unit, or to discard it.
- Operation continues (1008) with the next NAL unit of the scalable bitstream.
- A MANE can perform similar steps, with the exception that a MANE will normally not decode a slice NAL unit, but rather selectively forward it to decoder(s).
- The methods for video coding, described above, can be implemented as computer software using computer-readable instructions and physically stored in computer-readable medium. The computer software can be encoded using any suitable computer languages. The software instructions can be executed on various types of computers. For example,
FIG. 11 illustrates acomputer system 1100 suitable for implementing embodiments of the present disclosure. - The components shown in
FIG. 11 forcomputer system 1100 are exemplary in nature and are not intended to suggest any limitation as to the scope of use or functionality of the computer software implementing embodiments of the present disclosure. Neither should the configuration of components be interpreted as having any dependency or requirement relating to any one or combination of components illustrated in the exemplary embodiment of a computer system.Computer system 1100 can have many physical forms including an integrated circuit, a printed circuit board, a small handheld device (such as a mobile telephone or PDA), a personal computer or a super computer. -
Computer system 1100 includes adisplay 1132, one or more input devices 1133 (e.g., keypad, keyboard, mouse, stylus, etc.), one or more output devices 1134 (e.g., speaker), one ormore storage devices 1135, various types ofstorage medium 1136. - The
system bus 1140 link a wide variety of subsystems. As understood by those skilled in the art, a “bus” refers to a plurality of digital signal lines serving a common function. Thesystem bus 1140 can be any of several types of bus structures including a memory bus, a peripheral bus, and a local bus using any of a variety of bus architectures. By way of example and not limitation, such architectures include the Industry Standard Architecture (ISA) bus, Enhanced ISA (EISA) bus, the Micro Channel Architecture (MCA) bus, the Video Electronics Standards Association local (VLB) bus, the Peripheral Component Interconnect (PCI) bus, the PCI-Express bus (PCI-X), and the Accelerated Graphics Port (AGP) bus. - Processor(s) 1101 (also referred to as central processing units, or CPUs) optionally contain a
cache memory unit 1102 for temporary local storage of instructions, data, or computer addresses. Processor(s) 1101 are coupled to storagedevices including memory 1103.Memory 1103 includes random access memory (RAM) 1104 and read-only memory (ROM) 1105. As is well known in the art,ROM 1105 acts to transfer data and instructions uni-directionally to the processor(s) 1101, andRAM 1104 is used typically to transfer data and instructions in a bi-directional Both of these types of memories can include any suitable of the computer-readable media described below. - A fixed
storage 1108 is also coupled bi-directionally to the processor(s) 1101, optionally via astorage control unit 1107. It provides additional data storage capacity and can also include any of the computer-readable media described below.Storage 1108 can be used to storeoperating system 1109,EXECs 1110,application programs 1112,data 1111 and the like and is typically a secondary storage medium (such as a hard disk) that is slower than primary storage. It should be appreciated that the information retained withinstorage 1108, can, in appropriate cases, be incorporated in standard fashion as virtual memory inmemory 1103. - Processor(s) 1101 is also coupled to a variety of interfaces such as graphics control 1121,
video interface 1122,input interface 1123,output interface 1124,storage interface 1125, and these interfaces in turn are coupled to the appropriate devices. In general, an input/output device can be any of: video displays, track balls, mice, keyboards, microphones, touch-sensitive displays, transducer card readers, magnetic or paper tape readers, tablets, styluses, voice or handwriting recognizers, biometrics readers, or other computers. Processor(s) 1101 can be coupled to another computer ortelecommunications network 1130 usingnetwork interface 1120. With such anetwork interface 1120, it is contemplated that theCPU 1101 might receive information from thenetwork 1130, or might output information to the network in the course of performing the above-described method. Furthermore, method embodiments of the present disclosure can execute solely uponCPU 1101 or can execute over anetwork 1130 such as the Internet in conjunction with aremote CPU 1101 that shares a portion of the processing. - According to various embodiments, when in a network environment, i.e., when
computer system 1100 is connected tonetwork 1130,computer system 1100 can communicate with other devices that are also connected tonetwork 1130. Communications can be sent to and fromcomputer system 1100 vianetwork interface 1120. For example, incoming communications, such as a request or a response from another device, in the form of one or more packets, can be received fromnetwork 1130 atnetwork interface 1120 and stored in selected sections inmemory 1103 for processing. Outgoing communications, such as a request or a response to another device, again in the form of one or more packets, can also be stored in selected sections inmemory 1103 and sent out tonetwork 1130 atnetwork interface 1120. Processor(s) 1101 can access these communication packets stored inmemory 1103 for processing. - In addition, embodiments of the present disclosure further relate to computer storage products with a computer-readable medium that have computer code thereon for performing various computer-implemented operations. The media and computer code can be those specially designed and constructed for the purposes of the present disclosure, or they can be of the kind well known and available to those having skill in the computer software arts. Examples of computer-readable media include, but are not limited to: magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD-ROMs and holographic devices; magneto-optical media such as optical disks; and hardware devices that are specially configured to store and execute program code, such as application-specific integrated circuits (ASICs), programmable logic devices (PLDs) and ROM and RAM devices. Examples of computer code include machine code, such as produced by a compiler, and files containing higher-level code that are executed by a computer using an interpreter. Those skilled in the art should also understand that term “computer readable media” as used in connection with the presently disclosed subject matter does not encompass transmission media, carrier waves, or other transitory signals.
- As an example and not by way of limitation, the computer
system having architecture 1100 can provide functionality as a result of processor(s) 1101 executing software embodied in one or more tangible, computer-readable media, such asmemory 1103. The software implementing various embodiments of the present disclosure can be stored inmemory 1103 and executed by processor(s) 1101. A computer-readable medium can include one or more memory devices, according to particular needs.Memory 1103 can read the software from one or more other computer-readable media, such as mass storage device(s) 1135 or from one or more other sources via communication interface. The software can cause processor(s) 1101 to execute particular processes or particular parts of particular processes described herein, including defining data structures stored inmemory 1103 and modifying such data structures according to the processes defined by the software. In addition or as an alternative, the computer system can provide functionality as a result of logic hardwired or otherwise embodied in a circuit, which can operate in place of or together with software to execute particular processes or particular parts of particular processes described herein. Reference to software can encompass logic, and vice versa, where appropriate. Reference to a computer-readable media can encompass a circuit (such as an integrated circuit (IC)) storing software for execution, a circuit embodying logic for execution, or both, where appropriate. The present disclosure encompasses any suitable combination of hardware and software. - While this disclosure has described several exemplary embodiments, there are alterations, permutations, and various substitute equivalents, which fall within the scope of the disclosure. It will thus be appreciated that those skilled in the art will be able to devise numerous systems and methods which, although not explicitly shown or described herein, embody the principles of the disclosure and are thus within the spirit and scope thereof.
Claims (26)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/347,381 US20120183077A1 (en) | 2011-01-14 | 2012-01-10 | NAL Unit Header |
US13/539,864 US8649441B2 (en) | 2011-01-14 | 2012-07-02 | NAL unit header |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201161432836P | 2011-01-14 | 2011-01-14 | |
US13/347,381 US20120183077A1 (en) | 2011-01-14 | 2012-01-10 | NAL Unit Header |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/539,864 Continuation US8649441B2 (en) | 2011-01-14 | 2012-07-02 | NAL unit header |
Publications (1)
Publication Number | Publication Date |
---|---|
US20120183077A1 true US20120183077A1 (en) | 2012-07-19 |
Family
ID=46490762
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/347,381 Abandoned US20120183077A1 (en) | 2011-01-14 | 2012-01-10 | NAL Unit Header |
US13/539,864 Active US8649441B2 (en) | 2011-01-14 | 2012-07-02 | NAL unit header |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/539,864 Active US8649441B2 (en) | 2011-01-14 | 2012-07-02 | NAL unit header |
Country Status (7)
Country | Link |
---|---|
US (2) | US20120183077A1 (en) |
EP (1) | EP2664075A4 (en) |
JP (1) | JP5738434B2 (en) |
CN (1) | CN103416003B (en) |
AU (1) | AU2012205650B2 (en) |
CA (1) | CA2824741C (en) |
WO (1) | WO2012096981A1 (en) |
Cited By (32)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20130105214A (en) * | 2012-03-12 | 2013-09-25 | 삼성전자주식회사 | Method and apparatus for scalable video encoding, method and apparatus for scalable video decoding |
US20130266077A1 (en) * | 2012-04-06 | 2013-10-10 | Vidyo, Inc. | Level signaling for layered video coding |
US8649441B2 (en) | 2011-01-14 | 2014-02-11 | Vidyo, Inc. | NAL unit header |
US20140086303A1 (en) * | 2012-09-24 | 2014-03-27 | Qualcomm Incorporated | Bitstream conformance test in video coding |
US20140092996A1 (en) * | 2012-10-02 | 2014-04-03 | Qualcomm Incorporated | Signaling of layer identifiers for operation points |
US20140126652A1 (en) * | 2011-06-30 | 2014-05-08 | Telefonaktiebolaget L M Ericsson (Publ) | Indicating Bit Stream Subsets |
WO2014074879A1 (en) * | 2012-11-09 | 2014-05-15 | Qualcomm Incorporated | Mpeg frame compatible video coding |
WO2014092445A2 (en) * | 2012-12-11 | 2014-06-19 | 엘지전자 주식회사 | Method for decoding image and apparatus using same |
US8798165B2 (en) * | 2013-01-04 | 2014-08-05 | Vidyo, Inc. | Techniques for prediction of unavailable samples in inter-layer predicted video coding |
US20140294062A1 (en) * | 2013-04-01 | 2014-10-02 | Qualcomm Incorporated | Inter-layer reference picture restriction for high level syntax-only scalable video coding |
JP2015005976A (en) * | 2013-06-18 | 2015-01-08 | パナソニック インテレクチュアル プロパティ コーポレーション オブアメリカPanasonic Intellectual Property Corporation of America | Transmission method |
US8938004B2 (en) | 2011-03-10 | 2015-01-20 | Vidyo, Inc. | Dependency parameter set for scalable video coding |
US20150078455A1 (en) * | 2012-04-24 | 2015-03-19 | Telefonaktiebolaget L M Ericsson (Publ) | Identifying a parameter set for decoding a multi-layer video representation |
US20150085938A1 (en) * | 2012-06-12 | 2015-03-26 | Lg Electronics Inc. | Image decoding method and apparatus using same |
US20150103888A1 (en) * | 2013-10-15 | 2015-04-16 | Qualcomm Incorporated | Support of multi-mode extraction for multi-layer video codecs |
US20150163505A1 (en) * | 2012-09-28 | 2015-06-11 | Sony Corporation | Image processing device |
US20150172679A1 (en) * | 2012-07-06 | 2015-06-18 | Samsung Electronics Co., Ltd. | Method and apparatus for coding multilayer video, and method and apparatus for decoding multilayer video |
US20150319453A1 (en) * | 2012-12-26 | 2015-11-05 | Electronics And Telecommunications Research Institute | Method for encoding/decoding images, and apparatus using same |
US9313486B2 (en) | 2012-06-20 | 2016-04-12 | Vidyo, Inc. | Hybrid video coding techniques |
US20160134895A1 (en) * | 2013-07-15 | 2016-05-12 | Ge Video Compression, Llc | Layer characteristic signaling in multi-layered coding |
JP2016518771A (en) * | 2013-04-08 | 2016-06-23 | クゥアルコム・インコーポレイテッドQualcomm Incorporated | Device and method for scalable coding of video information |
JP2016519887A (en) * | 2013-03-29 | 2016-07-07 | クゥアルコム・インコーポレイテッドQualcomm Incorporated | Improved RTP payload format design |
US20160227229A1 (en) * | 2015-02-04 | 2016-08-04 | Harris Corporation | Mobile ad hoc network media aware networking element |
US9426499B2 (en) | 2005-07-20 | 2016-08-23 | Vidyo, Inc. | System and method for scalable and low-delay videoconferencing using scalable video coding |
US9838702B2 (en) | 2013-07-15 | 2017-12-05 | Electronics And Telecommunications Research Institute | Method and apparatus for predicting inter-layer based on temporal sub-layer information |
US9912941B2 (en) | 2012-07-02 | 2018-03-06 | Sony Corporation | Video coding system with temporal layers and method of operation thereof |
US20180146225A1 (en) * | 2015-06-03 | 2018-05-24 | Nokia Technologies Oy | A method, an apparatus, a computer program for video coding |
EP3243329A4 (en) * | 2015-01-07 | 2018-10-10 | C/o Canon Kabushiki Kaisha | Image decoding apparatus, image decoding method, and storage medium |
US10110890B2 (en) | 2012-07-02 | 2018-10-23 | Sony Corporation | Video coding system with low delay and method of operation thereof |
US10546402B2 (en) * | 2014-07-02 | 2020-01-28 | Sony Corporation | Information processing system, information processing terminal, and information processing method |
US10595026B2 (en) | 2012-04-16 | 2020-03-17 | Electronics And Telecommunications Research Institute | Decoding method and device for bit stream supporting plurality of layers |
US10666964B2 (en) * | 2012-07-06 | 2020-05-26 | Ntt Docomo, Inc. | Video predictive encoding device and system, video predictive decoding device and system |
Families Citing this family (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2013137697A1 (en) * | 2012-03-16 | 2013-09-19 | 엘지전자 주식회사 | Method for storing image information, method for parsing image information and apparatus using same |
US20130272371A1 (en) * | 2012-04-16 | 2013-10-17 | Sony Corporation | Extension of hevc nal unit syntax structure |
EP2876882A4 (en) * | 2012-09-09 | 2016-03-09 | Lg Electronics Inc | Image decoding method and apparatus using same |
WO2014049205A1 (en) | 2012-09-28 | 2014-04-03 | Nokia Corporation | An apparatus, a method and a computer program for video coding and decoding |
EP3809707B1 (en) | 2013-01-04 | 2024-05-08 | GE Video Compression, LLC | Efficient scalable coding concept |
US20160134879A1 (en) * | 2013-04-05 | 2016-05-12 | Samsung Electronics Co., Ltd. | Multi-layer video coding method and device, and multi-layer video decoding method and device |
KR102327617B1 (en) * | 2013-04-08 | 2021-11-17 | 지이 비디오 컴프레션, 엘엘씨 | Coding concept allowing efficient multi-view/layer coding |
JP5789004B2 (en) * | 2013-08-09 | 2015-10-07 | ソニー株式会社 | Transmitting apparatus, transmitting method, receiving apparatus, receiving method, encoding apparatus, and encoding method |
JP5774652B2 (en) | 2013-08-27 | 2015-09-09 | ソニー株式会社 | Transmitting apparatus, transmitting method, receiving apparatus, and receiving method |
US20150103887A1 (en) * | 2013-10-14 | 2015-04-16 | Qualcomm Incorporated | Device and method for scalable coding of video information |
CN105075251B (en) * | 2014-01-02 | 2016-11-23 | 维迪奥股份有限公司 | Utilize the video encoding/decoding method of covering, device and the system of auxiliary picture |
US9813719B2 (en) * | 2014-06-18 | 2017-11-07 | Qualcomm Incorporated | Signaling HRD parameters for bitstream partitions |
AU2020320295A1 (en) * | 2019-09-24 | 2022-04-21 | Huawei Technologies Co., Ltd. | Scalable nesting SEI messages for specified layers |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070110150A1 (en) * | 2005-10-11 | 2007-05-17 | Nokia Corporation | System and method for efficient scalable stream adaptation |
US20100098157A1 (en) * | 2007-03-23 | 2010-04-22 | Jeong Hyu Yang | method and an apparatus for processing a video signal |
US20100150232A1 (en) * | 2006-10-31 | 2010-06-17 | Gottfried Wilhelm Leibniz Universitat Hannover | Method for concealing a packet loss |
US20110134994A1 (en) * | 2008-07-26 | 2011-06-09 | Thomson Licensing | Real-time transport protocol (rtp) packetization method for fast channel change applications using scalable video coding (svc) |
US20110182353A1 (en) * | 2008-04-24 | 2011-07-28 | Tae Meon Bae | Scalable video providing and reproducing system and methods thereof |
US20120050475A1 (en) * | 2009-05-01 | 2012-03-01 | Dong Tian | Reference picture lists for 3dv |
Family Cites Families (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070086515A1 (en) | 2003-12-09 | 2007-04-19 | Koninkiljke Phillips Electronics N.V. | Spatial and snr scalable video coding |
CN101120593A (en) * | 2005-04-13 | 2008-02-06 | 诺基亚公司 | Coding, storage and signalling of scalability information |
US8693549B2 (en) | 2006-01-16 | 2014-04-08 | Electronics And Telecommunications Research Institute | Method and apparatus for selective inter-layer prediction on macroblock basis |
JP5697332B2 (en) * | 2006-03-27 | 2015-04-08 | ヴィドヨ,インコーポレーテッド | System and method for management of scalability information using control messages in a scalable video and audio coding system |
US7535383B2 (en) | 2006-07-10 | 2009-05-19 | Sharp Laboratories Of America Inc. | Methods and systems for signaling multi-layer bitstream data |
US8396134B2 (en) * | 2006-07-21 | 2013-03-12 | Vidyo, Inc. | System and method for scalable video coding using telescopic mode flags |
WO2008030068A1 (en) * | 2006-09-07 | 2008-03-13 | Lg Electronics Inc. | Method and apparatus for decoding/encoding of a video signal |
US20080089411A1 (en) | 2006-10-16 | 2008-04-17 | Nokia Corporation | Multiple-hypothesis cross-layer prediction |
EP2080275B1 (en) | 2006-10-16 | 2019-03-20 | Vidyo, Inc. | Method for signaling and performing temporal level switching in scalable video coding |
KR100896290B1 (en) | 2006-11-17 | 2009-05-07 | 엘지전자 주식회사 | Method and apparatus for decoding/encoding a video signal |
US9445128B2 (en) | 2006-12-08 | 2016-09-13 | Freescale Semiconductor, Inc. | System and method of determining deblocking control flag of scalable video system for indicating presentation of deblocking parameters for multiple layers |
WO2008085013A1 (en) * | 2007-01-12 | 2008-07-17 | University-Industry Cooperation Group Of Kyung Hee University | Packet format of network abstraction layer unit, and algorithm and apparatus for video encoding and decoding using the format, qos control algorithm and apparatus for ipv6 label switching using the format |
BR122012013077A2 (en) * | 2007-04-18 | 2015-07-14 | Thomson Licensing | Signal having decoding parameters for multi-view video encoding |
US8855199B2 (en) | 2008-04-21 | 2014-10-07 | Nokia Corporation | Method and device for video coding and decoding |
KR20110106465A (en) * | 2009-01-28 | 2011-09-28 | 노키아 코포레이션 | Method and apparatus for video coding and decoding |
JP5738434B2 (en) | 2011-01-14 | 2015-06-24 | ヴィディオ・インコーポレーテッド | Improved NAL unit header |
US20120230431A1 (en) | 2011-03-10 | 2012-09-13 | Jill Boyce | Dependency parameter set for scalable video coding |
-
2012
- 2012-01-10 JP JP2013549495A patent/JP5738434B2/en active Active
- 2012-01-10 WO PCT/US2012/020809 patent/WO2012096981A1/en active Application Filing
- 2012-01-10 EP EP12734429.9A patent/EP2664075A4/en not_active Withdrawn
- 2012-01-10 US US13/347,381 patent/US20120183077A1/en not_active Abandoned
- 2012-01-10 AU AU2012205650A patent/AU2012205650B2/en not_active Ceased
- 2012-01-10 CA CA2824741A patent/CA2824741C/en active Active
- 2012-01-10 CN CN201280012703.5A patent/CN103416003B/en active Active
- 2012-07-02 US US13/539,864 patent/US8649441B2/en active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070110150A1 (en) * | 2005-10-11 | 2007-05-17 | Nokia Corporation | System and method for efficient scalable stream adaptation |
US20100150232A1 (en) * | 2006-10-31 | 2010-06-17 | Gottfried Wilhelm Leibniz Universitat Hannover | Method for concealing a packet loss |
US20100098157A1 (en) * | 2007-03-23 | 2010-04-22 | Jeong Hyu Yang | method and an apparatus for processing a video signal |
US20110182353A1 (en) * | 2008-04-24 | 2011-07-28 | Tae Meon Bae | Scalable video providing and reproducing system and methods thereof |
US20110134994A1 (en) * | 2008-07-26 | 2011-06-09 | Thomson Licensing | Real-time transport protocol (rtp) packetization method for fast channel change applications using scalable video coding (svc) |
US20120050475A1 (en) * | 2009-05-01 | 2012-03-01 | Dong Tian | Reference picture lists for 3dv |
Non-Patent Citations (1)
Title |
---|
ITU-T Recommendation H.264, 11/2007 * |
Cited By (108)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9426499B2 (en) | 2005-07-20 | 2016-08-23 | Vidyo, Inc. | System and method for scalable and low-delay videoconferencing using scalable video coding |
US8649441B2 (en) | 2011-01-14 | 2014-02-11 | Vidyo, Inc. | NAL unit header |
US8938004B2 (en) | 2011-03-10 | 2015-01-20 | Vidyo, Inc. | Dependency parameter set for scalable video coding |
US20140126652A1 (en) * | 2011-06-30 | 2014-05-08 | Telefonaktiebolaget L M Ericsson (Publ) | Indicating Bit Stream Subsets |
US10944994B2 (en) * | 2011-06-30 | 2021-03-09 | Telefonaktiebolaget Lm Ericsson (Publ) | Indicating bit stream subsets |
KR20130105214A (en) * | 2012-03-12 | 2013-09-25 | 삼성전자주식회사 | Method and apparatus for scalable video encoding, method and apparatus for scalable video decoding |
KR102047492B1 (en) | 2012-03-12 | 2019-11-22 | 삼성전자주식회사 | Method and apparatus for scalable video encoding, method and apparatus for scalable video decoding |
US20150023432A1 (en) * | 2012-03-12 | 2015-01-22 | Samsung Electronics Co., Ltd. | Scalable video-encoding method and apparatus, and scalable video-decoding method and apparatus |
US20130266077A1 (en) * | 2012-04-06 | 2013-10-10 | Vidyo, Inc. | Level signaling for layered video coding |
US9787979B2 (en) * | 2012-04-06 | 2017-10-10 | Vidyo, Inc. | Level signaling for layered video coding |
US20230035462A1 (en) | 2012-04-16 | 2023-02-02 | Electronics And Telecommunications Research Institute | Image information decoding method, image decoding method, and device using same |
US11949890B2 (en) | 2012-04-16 | 2024-04-02 | Electronics And Telecommunications Research Institute | Decoding method and device for bit stream supporting plurality of layers |
US10958918B2 (en) | 2012-04-16 | 2021-03-23 | Electronics And Telecommunications Research Institute | Decoding method and device for bit stream supporting plurality of layers |
US11483578B2 (en) | 2012-04-16 | 2022-10-25 | Electronics And Telecommunications Research Institute | Image information decoding method, image decoding method, and device using same |
US11490100B2 (en) | 2012-04-16 | 2022-11-01 | Electronics And Telecommunications Research Institute | Decoding method and device for bit stream supporting plurality of layers |
US10602160B2 (en) * | 2012-04-16 | 2020-03-24 | Electronics And Telecommunications Research Institute | Image information decoding method, image decoding method, and device using same |
US12028538B2 (en) | 2012-04-16 | 2024-07-02 | Electronics And Telecommunications Research Institute | Image information decoding method, image decoding method, and device using same |
US10958919B2 (en) | 2012-04-16 | 2021-03-23 | Electronics And Telecommunications Resarch Institute | Image information decoding method, image decoding method, and device using same |
US10595026B2 (en) | 2012-04-16 | 2020-03-17 | Electronics And Telecommunications Research Institute | Decoding method and device for bit stream supporting plurality of layers |
US20150078455A1 (en) * | 2012-04-24 | 2015-03-19 | Telefonaktiebolaget L M Ericsson (Publ) | Identifying a parameter set for decoding a multi-layer video representation |
US10491913B2 (en) * | 2012-04-24 | 2019-11-26 | Telefonaktiebolaget L M Ericsson (Publ) | Identifying a parameter set for decoding a multi-layer video representation |
US10863187B2 (en) * | 2012-06-12 | 2020-12-08 | Lg Electronics Inc. | Image decoding method and apparatus using same |
US10469861B2 (en) * | 2012-06-12 | 2019-11-05 | Lg Electronics Inc. | Image decoding method and apparatus using same |
US10448039B2 (en) * | 2012-06-12 | 2019-10-15 | Lg Electronics Inc. | Image decoding method and apparatus using same |
US9794582B2 (en) * | 2012-06-12 | 2017-10-17 | Lg Electronics Inc. | Image decoding method and apparatus using same |
US20200045327A1 (en) * | 2012-06-12 | 2020-02-06 | Lg Electronics Inc. | Image decoding method and apparatus using same |
US11546622B2 (en) | 2012-06-12 | 2023-01-03 | Lg Electronics Inc. | Image decoding method and apparatus using same |
US20180027253A1 (en) * | 2012-06-12 | 2018-01-25 | Lg Electronics Inc. | Image decoding method and apparatus using same |
US20150085938A1 (en) * | 2012-06-12 | 2015-03-26 | Lg Electronics Inc. | Image decoding method and apparatus using same |
US9313486B2 (en) | 2012-06-20 | 2016-04-12 | Vidyo, Inc. | Hybrid video coding techniques |
US10542251B2 (en) | 2012-07-02 | 2020-01-21 | Sony Corporation | Video coding system with low delay and method of operation thereof |
US10805604B2 (en) | 2012-07-02 | 2020-10-13 | Sony Corporation | Video coding system with low delay and method of operation thereof |
US10110890B2 (en) | 2012-07-02 | 2018-10-23 | Sony Corporation | Video coding system with low delay and method of operation thereof |
US9912941B2 (en) | 2012-07-02 | 2018-03-06 | Sony Corporation | Video coding system with temporal layers and method of operation thereof |
US10659799B2 (en) | 2012-07-02 | 2020-05-19 | Sony Corporation | Video coding system with temporal layers and method of operation thereof |
US10327005B2 (en) | 2012-07-02 | 2019-06-18 | Sony Corporation | Video coding system with temporal layers and method of operation thereof |
US10666964B2 (en) * | 2012-07-06 | 2020-05-26 | Ntt Docomo, Inc. | Video predictive encoding device and system, video predictive decoding device and system |
US20150172679A1 (en) * | 2012-07-06 | 2015-06-18 | Samsung Electronics Co., Ltd. | Method and apparatus for coding multilayer video, and method and apparatus for decoding multilayer video |
US10681368B2 (en) * | 2012-07-06 | 2020-06-09 | Ntt Docomo, Inc. | Video predictive encoding device and system, video predictive decoding device and system |
US10666965B2 (en) * | 2012-07-06 | 2020-05-26 | Ntt Docomo, Inc. | Video predictive encoding device and system, video predictive decoding device and system |
US10116947B2 (en) * | 2012-07-06 | 2018-10-30 | Samsung Electronics Co., Ltd. | Method and apparatus for coding multilayer video to include scalable extension type information in a network abstraction layer unit, and method and apparatus for decoding multilayer video |
CN104662914A (en) * | 2012-09-24 | 2015-05-27 | 高通股份有限公司 | Bitstream conformance test in video coding |
US20140086303A1 (en) * | 2012-09-24 | 2014-03-27 | Qualcomm Incorporated | Bitstream conformance test in video coding |
US10021394B2 (en) | 2012-09-24 | 2018-07-10 | Qualcomm Incorporated | Hypothetical reference decoder parameters in video coding |
US9351005B2 (en) * | 2012-09-24 | 2016-05-24 | Qualcomm Incorporated | Bitstream conformance test in video coding |
CN105611293A (en) * | 2012-09-28 | 2016-05-25 | 索尼公司 | Image processing device and method |
CN106210720A (en) * | 2012-09-28 | 2016-12-07 | 索尼公司 | Image processing apparatus and method |
US10009619B2 (en) * | 2012-09-28 | 2018-06-26 | Sony Corporation | Image processing device for suppressing deterioration in encoding efficiency |
US20150163505A1 (en) * | 2012-09-28 | 2015-06-11 | Sony Corporation | Image processing device |
US20210014516A1 (en) * | 2012-09-28 | 2021-01-14 | Sony Corporation | Image processing device for suppressing deterioration in encoding efficiency |
US10848778B2 (en) * | 2012-09-28 | 2020-11-24 | Sony Corporation | Image processing device for suppressing deterioration in encoding efficiency |
US11503321B2 (en) * | 2012-09-28 | 2022-11-15 | Sony Corporation | Image processing device for suppressing deterioration in encoding efficiency |
US10212446B2 (en) * | 2012-09-28 | 2019-02-19 | Sony Corporation | Image processing device for suppressing deterioration in encoding efficiency |
TWI566582B (en) * | 2012-10-02 | 2017-01-11 | 高通公司 | Method, device, and apparatus for processing and encoding video data and computer readable storage medium |
RU2656827C2 (en) * | 2012-10-02 | 2018-06-06 | Квэлкомм Инкорпорейтед | Improved signaling of the layer identifiers for the working points of the video coder |
CN104685890A (en) * | 2012-10-02 | 2015-06-03 | 高通股份有限公司 | Improved signaling of layer identifiers for operation points of a video coder |
US20140092996A1 (en) * | 2012-10-02 | 2014-04-03 | Qualcomm Incorporated | Signaling of layer identifiers for operation points |
US9781413B2 (en) * | 2012-10-02 | 2017-10-03 | Qualcomm Incorporated | Signaling of layer identifiers for operation points |
WO2014074879A1 (en) * | 2012-11-09 | 2014-05-15 | Qualcomm Incorporated | Mpeg frame compatible video coding |
US9674519B2 (en) | 2012-11-09 | 2017-06-06 | Qualcomm Incorporated | MPEG frame compatible video coding |
WO2014092445A3 (en) * | 2012-12-11 | 2014-10-23 | 엘지전자 주식회사 | Method for decoding image and apparatus using same |
WO2014092445A2 (en) * | 2012-12-11 | 2014-06-19 | 엘지전자 주식회사 | Method for decoding image and apparatus using same |
US20150319453A1 (en) * | 2012-12-26 | 2015-11-05 | Electronics And Telecommunications Research Institute | Method for encoding/decoding images, and apparatus using same |
US10154278B2 (en) * | 2012-12-26 | 2018-12-11 | Electronics And Telecommunications Research Institute | Method for encoding/decoding images, and apparatus using same |
US10531115B2 (en) | 2012-12-26 | 2020-01-07 | Electronics And Telecommunications Research Institute | Method for encoding/decoding images, and apparatus using same |
US11245917B2 (en) | 2012-12-26 | 2022-02-08 | Electronics And Telecommunications Research Institute | Method for encoding/decoding images, and apparatus using same |
US8798165B2 (en) * | 2013-01-04 | 2014-08-05 | Vidyo, Inc. | Techniques for prediction of unavailable samples in inter-layer predicted video coding |
JP2016519887A (en) * | 2013-03-29 | 2016-07-07 | クゥアルコム・インコーポレイテッドQualcomm Incorporated | Improved RTP payload format design |
US9992493B2 (en) * | 2013-04-01 | 2018-06-05 | Qualcomm Incorporated | Inter-layer reference picture restriction for high level syntax-only scalable video coding |
US20140294063A1 (en) * | 2013-04-01 | 2014-10-02 | Qualcomm Incorporated | Inter-layer reference picture restriction for high level syntax-only scalable video coding |
US9998735B2 (en) * | 2013-04-01 | 2018-06-12 | Qualcomm Incorporated | Inter-layer reference picture restriction for high level syntax-only scalable video coding |
US20140294062A1 (en) * | 2013-04-01 | 2014-10-02 | Qualcomm Incorporated | Inter-layer reference picture restriction for high level syntax-only scalable video coding |
JP2016518771A (en) * | 2013-04-08 | 2016-06-23 | クゥアルコム・インコーポレイテッドQualcomm Incorporated | Device and method for scalable coding of video information |
US11206436B2 (en) | 2013-06-18 | 2021-12-21 | Sun Patent Trust | Transmitting method of transmitting hierarchically encoded data |
JP2015005976A (en) * | 2013-06-18 | 2015-01-08 | パナソニック インテレクチュアル プロパティ コーポレーション オブアメリカPanasonic Intellectual Property Corporation of America | Transmission method |
US10616591B2 (en) * | 2013-07-15 | 2020-04-07 | Ge Video Compression, Llc | Layer ID signaling using extension mechanism |
US11546618B2 (en) | 2013-07-15 | 2023-01-03 | Ge Video Compression, Llc | Cluster-based dependency signaling |
US20160134896A1 (en) * | 2013-07-15 | 2016-05-12 | Ge Video Compression, Llc | Layer id signaling using extension mechanism |
US20160134895A1 (en) * | 2013-07-15 | 2016-05-12 | Ge Video Compression, Llc | Layer characteristic signaling in multi-layered coding |
US10595027B2 (en) * | 2013-07-15 | 2020-03-17 | Ge Video Compression, Llc | Layer characteristic signaling in multi-layered coding |
US11792415B2 (en) | 2013-07-15 | 2023-10-17 | Ge Video Compression, Llc | Low delay concept in multi-layered video coding |
US11647209B2 (en) | 2013-07-15 | 2023-05-09 | Ge Video Compression, Llc | Layer characteristic signaling in multi-layered coding |
JP2016527795A (en) * | 2013-07-15 | 2016-09-08 | ジーイー ビデオ コンプレッション エルエルシー | Layer feature signals in multi-layer coding. |
US10869047B2 (en) * | 2013-07-15 | 2020-12-15 | Ge Video Compression, Llc | Layer ID signaling using extension mechanism |
US11616964B2 (en) * | 2013-07-15 | 2023-03-28 | Ge Video Compression, Llc | Layer ID signaling using extension mechanism |
US20210044814A1 (en) * | 2013-07-15 | 2021-02-11 | Ge Video Compression, Llc | Layer id signaling using extension mechanism |
US10924752B2 (en) | 2013-07-15 | 2021-02-16 | Electronics And Telecommunications Research Institute | Method and apparatus for predicting inter-layer based on temporal sub-layer information |
US10142639B2 (en) | 2013-07-15 | 2018-11-27 | Ge Video Compression, Llc | Cluster-based dependency signaling |
JP2016527794A (en) * | 2013-07-15 | 2016-09-08 | ジーイー ビデオ コンプレッション エルエルシー | Dependent signal based on cluster |
US10523954B2 (en) | 2013-07-15 | 2019-12-31 | Ge Video Compression, Llc | Low delay concept in multi-layered video coding |
US10609399B2 (en) | 2013-07-15 | 2020-03-31 | Ge Video Compression, Llc | Cluster-based dependency signaling |
US11006136B2 (en) | 2013-07-15 | 2021-05-11 | Ge Video Compression, Llc | Cluster-based dependency signaling |
US11012700B2 (en) * | 2013-07-15 | 2021-05-18 | Ge Video Compression, Llc | Layer characteristic signaling in multi-layered coding |
US11025929B2 (en) | 2013-07-15 | 2021-06-01 | Ge Video Compression, Llc | Low delay concept in multi-layered video coding |
US10425651B2 (en) | 2013-07-15 | 2019-09-24 | Ge Video Compression, Llc | Cluster-based dependency signaling |
US10397589B2 (en) | 2013-07-15 | 2019-08-27 | Electronics And Telecommunications Research Institute | Method and apparatus for predicting inter-layer based on temporal sub-layer information |
US11252422B2 (en) | 2013-07-15 | 2022-02-15 | Ge Video Compression, Llc | Network device and error handling |
US10349066B2 (en) * | 2013-07-15 | 2019-07-09 | Ge Video Compression, Llc | Layer ID signaling using extension mechanism |
US10349065B2 (en) | 2013-07-15 | 2019-07-09 | Ge Video Compression, Llc | Network device and error handling |
US9838702B2 (en) | 2013-07-15 | 2017-12-05 | Electronics And Telecommunications Research Institute | Method and apparatus for predicting inter-layer based on temporal sub-layer information |
US10284858B2 (en) * | 2013-10-15 | 2019-05-07 | Qualcomm Incorporated | Support of multi-mode extraction for multi-layer video codecs |
US20150103888A1 (en) * | 2013-10-15 | 2015-04-16 | Qualcomm Incorporated | Support of multi-mode extraction for multi-layer video codecs |
US10546402B2 (en) * | 2014-07-02 | 2020-01-28 | Sony Corporation | Information processing system, information processing terminal, and information processing method |
EP3243329A4 (en) * | 2015-01-07 | 2018-10-10 | C/o Canon Kabushiki Kaisha | Image decoding apparatus, image decoding method, and storage medium |
US20160227229A1 (en) * | 2015-02-04 | 2016-08-04 | Harris Corporation | Mobile ad hoc network media aware networking element |
US10979743B2 (en) * | 2015-06-03 | 2021-04-13 | Nokia Technologies Oy | Method, an apparatus, a computer program for video coding |
US10582231B2 (en) * | 2015-06-03 | 2020-03-03 | Nokia Technologies Oy | Method, an apparatus, a computer program for video coding |
US20180146225A1 (en) * | 2015-06-03 | 2018-05-24 | Nokia Technologies Oy | A method, an apparatus, a computer program for video coding |
Also Published As
Publication number | Publication date |
---|---|
WO2012096981A1 (en) | 2012-07-19 |
JP2014504118A (en) | 2014-02-13 |
EP2664075A1 (en) | 2013-11-20 |
AU2012205650B2 (en) | 2016-08-11 |
EP2664075A4 (en) | 2015-08-19 |
AU2012205650A1 (en) | 2013-08-01 |
CA2824741C (en) | 2016-08-30 |
CN103416003A (en) | 2013-11-27 |
CA2824741A1 (en) | 2012-07-19 |
US8649441B2 (en) | 2014-02-11 |
CN103416003B (en) | 2015-05-27 |
JP5738434B2 (en) | 2015-06-24 |
US20120269276A1 (en) | 2012-10-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8649441B2 (en) | NAL unit header | |
US10560706B2 (en) | High layer syntax for temporal scalability | |
JP7209832B2 (en) | Method, apparatus, computer program and video encoding method for decoding a video sequence | |
AU2012225513B2 (en) | Dependency parameter set for scalable video coding | |
US20130195201A1 (en) | Techniques for layered video encoding and decoding | |
US9380313B2 (en) | Techniques for describing temporal coding structure | |
CN113892260B (en) | Video encoding and decoding method and related device | |
CA2869132A1 (en) | Level signaling for layered video coding | |
US9179145B2 (en) | Cross layer spatial intra prediction | |
CN113711605B (en) | Method, apparatus, system and computer readable medium for video encoding and decoding | |
US9402083B2 (en) | Signaling conformance points using profile space | |
CN114270715B (en) | Video encoding and decoding method and device | |
CN113678447B (en) | Method and equipment for reconstructing network abstraction layer unit and electronic equipment |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: VIDYO, INC., NEW JERSEY Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:HONG, DANNY;BOYCE, JILL;JANG, WON KAP;AND OTHERS;SIGNING DATES FROM 20120214 TO 20120221;REEL/FRAME:027796/0561 |
|
AS | Assignment |
Owner name: VENTURE LENDING & LEASING VI, INC., CALIFORNIA Free format text: SECURITY AGREEMENT;ASSIGNOR:VIDYO, INC.;REEL/FRAME:029291/0306 Effective date: 20121102 |
|
STCB | Information on status: application discontinuation |
Free format text: EXPRESSLY ABANDONED -- DURING EXAMINATION |
|
AS | Assignment |
Owner name: VIDYO, INC., NEW JERSEY Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:VENTURE LENDING AND LEASING VI, INC.;REEL/FRAME:046634/0325 Effective date: 20140808 |