The present invention relates to the field of video encoding. More specifically, the present invention relates to high efficiency video coding.
The Video Parameter Set (VPS) has been added as metadata to describe the overall characteristics of coded video sequences, including the dependencies between temporal sublayers. The primary purpose of this is to enable the compatible extensibility of the standard in terms of signaling at the systems layer, e.g., when the base layer of a future extended scalable or multiview bitstream would need to be decodable by a legacy decoder, but for which additional information about the bitstream structure that is only relevant for the advanced decoder would be ignored.
The HEVC VPS Syntax Structure is modified by re-ordering of some syntax parameters for the future HEVC Extensions in scalable video coding, multi-view coding and 3D video coding areas. This re-ordering enables external network devices such as middle-boxes to easily access of some of the useful parameters in VPS and its extension data that are able to be used for session negotiation and/or capability exchanges for better communication and system integration purposes.
In one aspect, a method programmed in a non-transitory memory of a device comprises decoding content and accessing information related to the content without performing entropy decoding. The information comprises video parameter set extension information. The information is located near a video parameter set network abstract layer unit payload. The information is fixed-length. The information is for negotiation and/capability exchange. The information defines a parameter which specifies a total number of bytes present in a profile level and video parameter set extension data. The content comprises video content. The device comprises a personal computer, a laptop computer, a computer workstation, a server, a mainframe computer, a handheld computer, a personal digital assistant, a cellular/mobile telephone, a smart appliance, a gaming console, a digital camera, a digital camcorder, a camera phone, a smart phone, a portable music player, a tablet computer, a mobile device, a video player, a video disc writer/player, a high definition disc writer/player, an ultra high definition disc writer/player), a television, a home entertainment system, or a smart watch.
In another aspect, a method programmed in a non-transitory memory of a device comprises providing content and enabling access of information related to the content, wherein the information is accessible without performing entropy decoding. The information comprises video parameter set extension information. The information is located near a video parameter set network abstract layer unit payload. The information is fixed-length. The information is for negotiation and/capability exchange. The information defines a parameter which specifies a total number of bytes present in a profile level and video parameter set extension data. The content comprises video content. The device comprises a personal computer, a laptop computer, a computer workstation, a server, a mainframe computer, a handheld computer, a personal digital assistant, a cellular/mobile telephone, a smart appliance, a gaming console, a digital camera, a digital camcorder, a camera phone, a smart phone, a portable music player, a tablet computer, a mobile device, a video player, a video disc writer/player, a high definition disc writer/player, an ultra high definition disc writer/player), a television, a home entertainment system, or a smart watch.
In another aspect, an apparatus comprises a non-transitory memory for storing an application, the application for decoding content and accessing information related to the content without performing entropy decoding and a processing component coupled to the memory, the processing component configured for processing the application. The information comprises video parameter set extension information. The information is located near a video parameter set network abstract layer unit payload. The information is fixed-length. The information is for negotiation and/capability exchange. The information defines a parameter which specifies a total number of bytes present in a profile level and video parameter set extension data. The content comprises video content.
Video Parameter Set (VPS) syntax re-ordering for easy access of extension parameters is described herein. Specifically, the syntax parameters for the VPS and VPS Extension Syntax structures available in the “straw man” designs for High Efficiency Video Coding (HEVC) extensions are re-ordered. The re-ordering allows easy access of some of the syntax parameters with fixed lengths by external network devices for better communication purposes.
On HEVC VPS Syntax Structure
The VPS syntax structure in the current Draft International Standard (DIS) specification contains three undefined syntaxes: reserved_zero bits-vps_reserved_zero_2bits, vps_reserved_zero_6bits and vps_reserved_zero 12bits.
In the previous “straw man” designs of VPS and its extensions, the last two undefined syntaxes above are utilized as max_num_layers_minus1 and next_essential_info_byte_offset. Also, in the previous designs, two design approaches are considered for the VPU Extension syntax structures, out of which either one or both may be considered for HEVC extensions.
On VPS Syntax Structure Changes
The following VPS syntax structure is available in the previous design, where the vps_reserved_zero_12bits in DIS is replaced by the syntax parameter: next_essential_info_byte_offset.
The syntax parameter next_essential_info_byte_offset has been previously defined as follows: “specifies the byte offset of the next set of fixed-length coded information in the video parameter set NAL unit, starting from its beginning of the NAL unit.”
However, the “next set of” syntax parameters of “pics” information (buffering, reorder, latency) present after this next_essential_info_byte offset are not of fixed-length sizes in the above syntax structure, but of unsigned integer 0-th order Exp-Golomb-codes, ue(v).
Also, such fixed coded length information is important “for session negotiation and/or capability exchange,” especially in network-related middle-box (e.g., a firewall) or other simpler devices. Modifying the syntax will enable easy access of the information that VPS and VPS extension provide in their respective syntax parameters without the need of any entropy decoding function. The above VPS syntax structure also contains a new syntax structure extension of vps_extension( ).
In previous designs, the VPS Extension syntax structure had two “strawman” design approaches listed, and both of them contain syntax parameters with fixed-length information. Also, for a new VPS Extension structure all such syntax parameters contain fixed-length information. Many of these VPS Extension syntax parameters will also be valuable for external network devices to browse and extract useful information for better communication purposes. The “profile_tier_level(1, vps_max_sub_layers_minus1)” syntax structure contains fixed-length syntax parameters.
However, the positioning of such VPS extension information in the VPS syntax structure as shown above, is changed as follows to enable easy access of these extension parameters:
In this syntax parameter reordering, the VPS Extension information is placed near the beginning of the VPS Network Abstract Layer Unit (NALU) payload for easy access. This is because much VPS Extension information for HEVC extensions may be directly useable by middle-boxes and other network devices. In the above syntax structures, the previously defined next_essential_info_byte_offset is renamed as next_essential_info_byte_count.
Also the semantics description of the modified syntax is changed as follows: next_essential_info_byte_count specifies the total number of bytes occupied by the optional fields: profile_tier_level(.), vps_extension( ) and any stuffing bits including the bits of the syntax parameters bit_equal_to_one and vps_extension_byte_alignment_reserved_one_bit. The next_essential_info_byte_count is the byte count independent from statistical codes bits-allocation[ue(v)]. The byte_offset from the start of the VPS NAL Unit packet to next_essential_info_byte_count is already known as 4.
Fixed addressing is able to be used. A fixed offset length in bytes for fixed addressing as shown in
Explicit addressing is only used if VPS Extension block is pushed down into the VPS data area after profile_and_level( . . . ) loop. Two possible syntaxes (entry_point_offset, offset_len_minus1) are able to be used for explicit addressing to locate VPS Extension in the NALU.
The syntax element reserved_zero_12bits in VPS is replaced by a syntax element next_essential_info_byte_offset. The syntax is located after the VPS fixed header or before the profile_and_level( . . . ) loop.
The syntax element vps_reserved_zero_2bits is 0 in bitstreams conforming to version-1 HEVC standard. Other values are reserved for future use. Decoders ignore the value of vps_reserved_zero_2bits.
The syntax element max_num_layers_minus1 plus 1 specifies the maximum number of layers in the coded video sequences referring to the VPS.
The syntax element next_essential_info_byte_offset specifies the byte offset of the next set of fixed-length coded information in the VPS NAL unit, starting from the beginning of the NAL unit. VPS information for the non-base layer or view starts from a byte-aligned position of VPS NAL unit, with fixed-length coded information that is used for session negotiation and/or capability exchange. The byte offset helps to locate and access information in VPS NAL unit without the need of entropy decoding, where some network entities may desire to access only the information in VPS for session negotiation and/or capability exchange.
Only the first syntax of vps_reserved_zero_2bits may be available to support mixed mode sequences such as 2D/3D views or Frame/Field sequences.
Width/height syntaxes in SPS may be sufficient perhaps to differentiate Frame/Field.
In the syntax below, vps_reserved_zero_2bits is changed to vps_sequence_type:
vps_sequence_type:
In the syntax below, vps_extension( ) is included:
In some embodiments, the re-ordered VPS application(s) 330 include several applications and/or modules. In some embodiments, modules include one or more sub-modules as well. In some embodiments, fewer or additional modules are able to be included.
Examples of suitable computing devices include a personal computer, a laptop computer, a computer workstation, a server, a mainframe computer, a handheld computer, a personal digital assistant, a cellular/mobile telephone, a smart appliance, a gaming console, a digital camera, a digital camcorder, a camera phone, a smart phone, a portable music player, a tablet computer, a mobile device, a video player, a video disc writer/player (e.g., DVD writer/player, high definition disc writer/player, ultra high definition disc writer/player), a television, a home entertainment system, smart jewelry (e.g., smart watch) or any other suitable computing device.
To utilize the re-ordered VPS method, external network devices are able to access parameters in VPS and its extension for better communication and system integration purposes. The re-ordered VPS method is automatically used when performing video processing or other times. The re-ordered VPS method is able to be implemented automatically without user involvement.
In operation, the HEVC VPS Syntax Structure is modified by re-ordering of some syntax parameters for the future HEVC Extensions in scalable video coding, multi-view coding and 3D video coding areas. This re-ordering will enable the external network devices for easy access of some of the useful parameters in VPS and its extension that are able to be used for better communication and system integration purposes. The VPS is generated using the re-ordered syntax structure.
Middle-boxes (network entities) extract some of the VPS syntax parameters and VPS extension data. The data contains various HEVC Extension information in scalable video coding, multi-view coding and 3D video coding areas. The data is used for session negotiation and/or capability exchanges for better communication and system integration purposes. Some syntax parameters are re-ordered inside the VPS which enables the external network devices easy access of some of the useful parameters in VPS and its extension.
U.S. patent application Ser. No. 14/035,711, titled “JCTVC-L0226: VPS AND VPS_EXTENSION UPDATES” and U.S. patent application Ser. No. 14/035,740, titled “JCTVC-L0227: VPS_EXTENSION WITH UPDATES OF PROFILE-TIER-LEVEL SYNTAX STRUCTURE” are hereby incorporated by reference in their entireties for all purposes.
Some Embodiments of Video Parameter Set (Vps) Syntax Re-Ordering for Easy Access of Extension Parameters
The present invention has been described in terms of specific embodiments incorporating details to facilitate the understanding of principles of construction and operation of the invention. Such reference herein to specific embodiments and details thereof is not intended to limit the scope of the claims appended hereto. It will be readily apparent to one skilled in the art that other various modifications may be made in the embodiment chosen for illustration without departing from the spirit and scope of the invention as defined by the claims.
This application is a continuation application of U.S. patent application Ser. No. 14/035,680, filed Sep. 24, 2013, which claims priority under 35 U.S.C. § 119(e) of the U.S. Provisional Patent Application Ser. No. 61/705,716, filed Sep. 26, 2012 and titled, “VIDEO PARAMETER SET (VPS) SYNTAX RE-ORDERING FOR EASY ACCESS OF EXTENSION PARAMETERS” and U.S. Provisional Patent Application Ser. No. 61/708,381, filed Oct. 1, 2012 and titled, “VIDEO PARAMETER SET (VPS) SYNTAX RE-ORDERING FOR EASY ACCESS OF EXTENSION PARAMETERS” which are hereby incorporated by reference in their entireties for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
5956026 | Ratakonda | Sep 1999 | A |
6438169 | Takashima | Aug 2002 | B1 |
8938004 | Boyce et al. | Jan 2015 | B2 |
9270989 | Hannuksela | Feb 2016 | B2 |
20030016755 | Tahara | Jan 2003 | A1 |
20040109502 | Luken | Jun 2004 | A1 |
20060227023 | Ahn | Oct 2006 | A1 |
20080007438 | Segall | Jan 2008 | A1 |
20080212591 | Wu | Sep 2008 | A1 |
20080310500 | Winger | Dec 2008 | A1 |
20090037959 | Suh | Feb 2009 | A1 |
20100254458 | Amon et al. | Oct 2010 | A1 |
20110286530 | Tian et al. | Nov 2011 | A1 |
20120069903 | Lim | Mar 2012 | A1 |
20120075436 | Chen et al. | Mar 2012 | A1 |
20120163452 | Horowitz | Jun 2012 | A1 |
20120207227 | Tsai et al. | Aug 2012 | A1 |
20120229602 | Chen et al. | Sep 2012 | A1 |
20120230431 | Boyce et al. | Sep 2012 | A1 |
20120275517 | Boyce et al. | Nov 2012 | A1 |
20130003830 | Misra | Jan 2013 | A1 |
20130089134 | Wang et al. | Apr 2013 | A1 |
20130089152 | Wang | Apr 2013 | A1 |
20130107942 | Chen et al. | May 2013 | A1 |
20130114675 | Guo | May 2013 | A1 |
20130182755 | Chen | Jul 2013 | A1 |
20130266077 | Boyce et al. | Oct 2013 | A1 |
20130279564 | Wang | Oct 2013 | A1 |
20130287093 | Hannuksela et al. | Oct 2013 | A1 |
20130287115 | Wang | Oct 2013 | A1 |
20130294499 | Wang | Nov 2013 | A1 |
20130294500 | Wang | Nov 2013 | A1 |
20130343465 | Chen et al. | Dec 2013 | A1 |
20140003489 | Hannuksela | Jan 2014 | A1 |
20140003491 | Chen et al. | Jan 2014 | A1 |
20140003492 | Chen et al. | Jan 2014 | A1 |
20140003493 | Chen et al. | Jan 2014 | A1 |
20140003504 | Ugur et al. | Jan 2014 | A1 |
20140078249 | Wang | Mar 2014 | A1 |
20140086303 | Wang | Mar 2014 | A1 |
20140086333 | Wang | Mar 2014 | A1 |
20140086334 | Haque et al. | Mar 2014 | A1 |
20140092996 | Wang | Apr 2014 | A1 |
20140168362 | Hannuksela et al. | Jun 2014 | A1 |
20140181885 | Rusert | Jun 2014 | A1 |
20140192858 | Haque et al. | Jul 2014 | A1 |
20140192859 | Haque et al. | Jul 2014 | A1 |
20140294063 | Chen et al. | Oct 2014 | A1 |
20140301451 | Deshpande | Oct 2014 | A1 |
20140355667 | Lei | Dec 2014 | A1 |
20150245046 | Tsukuba et al. | Aug 2015 | A1 |
20150245063 | Rusanovskyy | Aug 2015 | A1 |
Entry |
---|
Gary J. Sullivan,Overview of the High Efficiency Video Coding (HEVC) Standard, IEEE transactions on Circuits and System for Video Technology, vol. 22, No. 12, Dec. 2012, pp. 1649-1668. |
Miska M. Hannuksela, et al.,“VPS Extension Design”, Joint Collaborative Team Video Coding (JCT-VC) of ITU-T, SF 16WP 3 and ISO/IEC JTC 1/SC 29/WG 11, Document JCTV-K0274, 11th Meeting: Shanghai, CN, Oct. 10-19, 2012, 8 pages. |
Jill Boyce,“NAL Unit Header and Parameter Set Designs for HEVC Extensions”, Joint Collaborative Team on Video 3 Coding (JCT-VC) of ITU-T SG 16 WP 3 and ISO/IEC JTC 1/SC 29/WG 11, Document JCTV-K1007, 11th Meeting: Shanghai, CN, Oct. 10-19, 2012, 8 pages. |
Jill Boyce,“VPS Syntax for Scalable and 3D Extensions”, VIDYO Person Telepresence, Document, JCTVC-K0204, 14 pages. |
Munsi Haque,“On Support of Mixed Video Sequences in High Level Syntaxes”, Joint Collaborative Team on Video Coding (JCT-VC) of ITU-T SG 16 WP 3 and ISO/IEC JTC 1/SC 29/WG 11, Document JCTV-K0232, WG11 No. m26564, 11th Meeting: Shanghai, CN, Oct. 9-19, 2012, 07 pages. |
Benjamin Bross,“High Efficiency Video Coding (HEVC) Test Specification Draft 9”, Joint Collaborative Team on Video Coding (JCT-VC) of ITU-TSG 16 WP 3 and ISO/IEC JTC 1/SC 29/WG 11, 11th Meeting: Shanghai, CN, Document JCTV-K1003, Oct. 10-19, 2012, 317 pages. |
Notice of Allowance for U.S. Appl. No. 14/035,680, dated Feb. 8, 2018, 04 pages. |
Notice of Allowance for U.S. Appl. No. 14/035,680, dated Jan. 18, 2018, 05 pages. |
Non-Final Office Action for U.S. Appl. No. 14/035,680, dated Aug. 11, 2017, 06 pages. |
Advisory Action for U.S. Appl. No. 14/035,680, dated May 24, 2017, 03 pages. |
Final Office Action for U.S. Appl. No. 14/035,680, dated Mar. 30, 2017, 06 pages. |
Non-Final Office Action for U.S. Appl. No. 14/035,680, dated Nov. 14, 2016, 05 pages. |
Advisory Action for U.S. Appl. No. 14/035,680, dated Aug. 6, 2016, 03 pages. |
Final Office Action for U.S. Appl. No. 14/035,680, dated Mar. 29, 2016, 06 pages. |
Non-Final Office Action for U.S. Appl. No. 14/035,680, dated Dec. 15, 2015, 07 pages. |
Number | Date | Country | |
---|---|---|---|
20180205961 A1 | Jul 2018 | US |
Number | Date | Country | |
---|---|---|---|
61708381 | Oct 2012 | US | |
61705716 | Sep 2012 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14035680 | Sep 2013 | US |
Child | 15921836 | US |