Systems and methods for encoding and playing back video at different frame rates using enhancement layers

Information

  • Patent Grant
  • 9866878
  • Patent Number
    9,866,878
  • Date Filed
    Monday, April 6, 2015
    9 years ago
  • Date Issued
    Tuesday, January 9, 2018
    7 years ago
Abstract
Systems and methods in accordance with embodiments of this invention provide for encoding and playing back video at different frame rates using enhancement layers. In a number of embodiments, video is encoded using temporal scalability involving the creation of a base layer at a first frame rate and an enhancement layer including additional frames enabling playback at a second higher frame rate. The second higher frame rate can also be referred to as an enhanced frame rate. In a number of embodiments, the base and enhancement layers are stored in one or more container files that contain metadata describing the enhancement layer. Based on the capabilities of a playback device, it can select the particular frame rate at which to playback encoded video.
Description
FIELD OF THE INVENTION

The present invention generally relates to encoding and playback of video content and more specifically to the use of metadata to enable playback of media at different frame rates.


BACKGROUND OF THE INVENTION

Media distributed by content providers to content consumers can be encoded using a variety of video compression standards that facilitate the distribution of the content across a distribution channel. Well know compression standards include H.264/MPEG-4, published by the ITU-T Video Coding Experts Group (VCEG) together with the ISO/IEC JTC1 Moving Picture Experts Group (MPEG), and the newer High Efficiency Video Coding (HEVC) standard, MPEG-H Part 2, developed by MPEG and VCEG, both of which are herein incorporated by reference. Video compression or video encoding involves compressing the amount of information used to describe the frames of video in a video sequence in order to reduce the consumption of network resources that are utilized when distributing content via a network. The reduced size also facilitates the distribution of content on non-volatile storage mediums such as CD-ROMs and flash-drives.


Media playback devices can utilize video decoders to decode encoded video for playback. Video can be encoded using predetermined encoding profiles. Typically, playback devices utilize decoders that are capable of playing back video encoded using one or more profiles. A particular profile may specify parameters and limits for various video settings, including picture resolution (e.g., 720p, 1080p, 4 k etc.), frame rate (i.e., 24, 30, 48, 60 frames per second, etc.), and bitrate (e.g., 12 Mbps, 40 Mbps, etc.).


Encoded media is typically stored in one or more container files. The most commonly used media container formats are the MP4 container format specified in MPEG-4 Part 14 (i.e., ISO/IEC Standard 14496-14) and the MPEG transport stream (TS) container specified in MPEG-2 Part 1 (i.e., ISO/IEC Standard 13818-1). The Matroska container is a media container developed as an open standard project by the Matroska non-profit organization of Aussonne, France. The Matroska container is based upon Extensible Binary Markup Language (EBML), which is a binary derivative of the Extensible Markup Language (XML). Decoding of the Matroska container is supported by many consumer electronics (CE) devices. The DivX Plus file format developed by DivX, LLC of San Diego, Calif. utilizes an extension of the Matroska container format (i.e., is based upon the Matroska container format, but includes elements that are not specified within the Matroska format).


Furthermore, encoded video can be distributed to devices through different mechanisms, including downloading from a server for storage and future playback on the device, streaming the encoded video during playback on the device, and retrieving the encoded video from one or more files stored on a CD-ROM, flash drive, or other non-volatile storage medium, and various other storage and distribution mechanisms. Streaming solutions typically utilize either Hypertext Transfer Protocol (HTTP), published by the Internet Engineering Task Force and the World Wide Web Consortium as RFC 2615, or Real Time Streaming Protocol (RTSP), published by the Internet Engineering Task Force as RFC 2326, to stream media between a server and a playback device. HTTP is a stateless protocol that enables a playback device to request a byte range within a file. HTTP is described as stateless, because the server is not required to record information concerning the state of the playback device requesting information or the byte ranges requested by the playback device in order to respond to requests received from the playback device. RTSP is a network control protocol used to control streaming media servers. Playback devices issue control commands, such as “play” and “pause”, to the server streaming the media to control the playback of media files. When RTSP is utilized, the media server records the state of each client device and determines the media to stream based upon the instructions received from the client devices and the client's state. Thus, content providers utilize different distribution protocols for each of the different mechanisms (i.e., download vs. streaming) for distributing video files to different devices.


SUMMARY OF THE INVENTION

Systems and methods in accordance with embodiments of this invention encode and play back video at different frame rates using enhancement layers. In an embodiment of the invention, a non-transitory machine readable medium containing processor instructions, where execution of the instructions by a processor causes the processor to perform a process that includes receiving video having several access units and encoding the video into a set of layers that includes a base layer and at least one enhancement layer, where the encoding includes: (i) using a temporal identifier of each access unit to determine the particular layer associated with the access unit and (ii) retaining an order of the temporal identifiers of the several access units of the video.


In another embodiment, the temporal identifier of an access unit is stored in an initial set of bits of the access unit.


In yet another embodiment, a process inserts a temporal identifier for a set of access units of the several access units of the video.


In still another embodiment, a process inserts a metadata tag providing information regarding the layers available and the frame rate of each layer.


In still yet another embodiment, a process receives a request for streaming of the video, determines playback capabilities of a device requesting the video, and streams different sets of layers of the video based on the playback capabilities of the device, where (i) the base layer is streamed to a playback device capable of playing back the base layer and (ii) the base layer and at least one enhancement layer is streamed to a playback device capable of streaming the plurality of layers.


In a further embodiment, streaming the different sets of layers includes merging the different layers using the retained order of the temporal identifiers of the plurality of access units of the video.


In another embodiment, a process receives a request for downloading of the video from a playback device and provides the encoded video to the playback device.


In another embodiment again, a frame rate of at least one enhancement layer is an integer multiple of the base layer.


In yet another embodiment again, a process stores each layer as a separate stream.


In still yet another embodiment again, a process stores each layer in a separate container file.


In an embodiment of the invention provides a source encoder that includes a processor configured by a source encoder application to receive video having several access units and encode the video into a set of layers that includes a base layer and at least one enhancement layer, where the encoding includes: (i) using a temporal identifier of each access unit to determine the particular layer associated with the access unit and (ii) retaining an order of the temporal identifiers of the plurality of access units of the video;


In another embodiment, a temporal identifier of an access unit is stored in a header of the access unit.


In yet another embodiment, a source encoder inserts a temporal identifier for a set of access units of the several access units of the video.


In still a further embodiment, a source encoder inserts a metadata tag providing information regarding the layers available and the frame rate of each layer.


An embodiment of the invention includes a playback device configured to playback video that includes a processor configured to communicate with a memory, where the memory contains a client application, where the client application configures the processor to receive video that includes several access units, playback the video, where the playback device plays back the video (i) using a base layer when the playback device has a first set of playback capabilities and (ii) using the base layer and at least one enhancement layer when the playback device has a second set of playback capabilities.


In another embodiment, a client application further configures the processor to identify an order of temporal identifiers of the several access units of the video and merge the access units of the base layer and the access units of at least one enhancement layer using the order of temporal identifies of the several access units of the video.


In yet another embodiment, a client application further configures the processor to request streaming of the video to a playback server and provide information regarding playback capabilities of the playback device to the playback server and receive a first stream that includes the base layer of the video and a second stream that includes the at least one enhancement layer of the video.


In still yet another embodiment, a client application further configures the processor to request downloading of the video to a content distribution server and provide playback capabilities of the playback device to the content distribution server, receive the video from the content distribution server, where a first device receives video that includes the base layer when the first device is capable of playing back the video at a first frame rate and a second device receives video that includes the base layer and at least one enhancement layer when the second device is capable of playing back the video at a second frame rate.


In yet another embodiment again, a client application further configures the processor to retrieve a metadata tag from the video identifying the layers available and the frame rate of each layer; and determine a set of layers to playback based on the information in the metadata tag.


In a further embodiment again, a client application further configures the processor to identify the temporal identifier of an access unit by parsing an initial set of bytes of the access unit.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a network diagram of a system for encoding and playing back video at different frame rates using enhancement layers in accordance with an embodiment of the invention.



FIG. 2 conceptually illustrates a basic architecture of a playback device in accordance with an embodiment of the invention.



FIG. 3 conceptually illustrates streams for streaming to playback devices in accordance with embodiments of the invention.



FIG. 4A conceptually illustrates a Matroska container file used to store encoded video in accordance with an embodiment of the invention.



FIG. 4B conceptually illustrates a metadata tag contained within a container file that includes video encoded with temporal scalability in accordance with an embodiment of the invention.



FIG. 5A conceptually illustrates a Clusters element of a Matroska container file containing encoded video in accordance with an embodiment of the invention.



FIG. 5B conceptually illustrates a Cluster element for use in the playback of encoded video with temporal scalability.



FIG. 6 conceptually illustrates an example of separate container files storing different temporal layers in accordance with an embodiment of the invention.



FIG. 7 is a flow chart illustrating a process for embedding information describing video encoded with temporal scalability in a container file in accordance with an embodiment of the invention.



FIG. 8 is a flow chart illustrating a process for playing back encoded video including temporal layers in accordance with an embodiment of the invention.



FIG. 9 is a flow chart illustrating a process for streaming different layers of encoded video using separate streams in accordance with an embodiment of the invention.



FIG. 10 is a flow chart illustrating a process for merging separate streams of an encoded video in accordance with an embodiment of the invention.



FIG. 11A conceptually illustrates the reference dependencies that may exist between a set of video frames in accordance with an embodiment of the invention.



FIG. 11B conceptually illustrates a table providing a decode order for frames of an encoded video in accordance with an embodiment of the invention.



FIG. 12A conceptually illustrates a portion of an encoded video stream containing several frames in accordance with embodiments of the invention.



FIG. 12B conceptually illustrates separate streams generated for encoded video in accordance with embodiments of the invention.



FIG. 13 conceptually illustrates merging of different temporal streams in accordance with embodiments of the invention.



FIG. 14 illustrates streaming different temporal layers of an encoded video for playback in accordance with embodiments of the invention.





DETAILED DISCLOSURE OF THE INVENTION

Turning now to the drawings, systems and methods for encoding and playing back video at different frame rates using enhancement layers in accordance with embodiments of the invention are illustrated. In a number of embodiments, video is encoded using temporal scalability involving the creation of a base layer at a first frame rate and an enhancement layer including additional frames enabling playback at a second higher frame rate. The second higher frame rate can also be referred to as an enhanced frame rate. In a number of embodiments, the base and enhancement layers are stored in one or more container files that contain metadata describing the enhancement layer. Based on the capabilities of a playback device, it can select the particular frame rate at which to playback encoded video. For example, for a single media file containing video encoded with temporal scalability that provides both a base frame rate (e.g., 30 fps) and an enhanced frame rate (e.g., 60 fps), a first device may only be able to play back the encoded video at the base frame rate while a different device may be able to playback encoded video at the enhanced frame rate. Thus, video content can be played back at different frame rates on different devices.


In several embodiments, encoded video can be distributed to playback devices using a variety of distribution mechanisms, including downloading of one or more files containing the encoded video or streaming the encoded video to the playback device for progressive playback and/or as part of an adaptive bitrate streaming system. However, in order to avoid wasting network resources when streaming encoded video that includes temporal scalability to a device that is not capable of handling the decoding of the enhancement layer(s), in some embodiments the different video layers are separated and streamed on an “as needed” basis to the playback device. For example, for a file containing encoded video that has both a base video layer that provides a base frame rate of 30 fps and an enhancement layer that provides a frame rate of 60 fps, a first device with only the capacity to playback video at a frame rate of 30 fps can request a stream of only the base layer of the encoded video while a second device that has the capacity to playback the video at a frame rate of 60 fps can request streams containing both the base video layer and the enhancement layer.


When streaming multiple separate video layers to a user's device, the streams can be combined at the playback device into a single stream in order to allow for the playback of the encoded video on the device at the enhanced frame rate. Due to dependencies that can exist between encoded frames of video (specifically bi-directionally encoded frames of video), the frames of video in the base layer and/or the enhancement layer may not be received by the playback device in the order in which they are to be played back. In several embodiments, the frames of video in the base and/or enhancement layers are received in “decode order”, which is an order that causes the decoder to have fully decoded all frames on which a given frame depends prior to decoding the given frame. In order to determine the particular decode order, in some embodiments, one or more of the enhancement layers include metadata that specifies a sequential order for selecting frames of video from the different layers to merge the frames into a single stream for decoding and playback at the enhanced frame rate.


Some embodiments utilize an adaptive streaming mechanism that detects the present streaming conditions (e.g., the user's network bandwidth and CPU capacity) in real time and adjusts the frame rate of the streamed video accordingly. When a playback device has the capability to play back the video file at an enhanced frame rate, the playback device can stream both the base and enhancement layers when the network bandwidth is sufficient to satisfy that bitrate necessary for transmission and/or the CPU has capacity to process the encoded video at the enhanced rate. The playback device may likewise stream the encoded video at the base rate when a change in the streaming conditions is detected indicative of insufficient bandwidth for the enhanced frame rate and/or the CPU no longer has capacity to process the encoded video at the enhanced frame rate.


In several embodiments, the base layer includes a sequence of frames encoded at a first frame rate in such a way that the frames in the base layer are only dependent upon other frames in the base layer. In a number of embodiments, the enhancement layer includes additional frames that, when merged with the sequence of frames in the base layer, form a sequence of frames encoded at a second frame rate. In certain embodiments, the frames in the enhancement layer are encoded so that they are only dependent upon frames in the base layer. In a number of embodiments, the frames in the enhancement layer are further constrained so that the enhancement layer does not include any I-frames (i.e., frames that can be decoded without reference to other frames). In other embodiments, the enhancement layer can include frames that incorporate dependencies upon other frames in the enhancement layer and/or I-frames.


In some embodiments, the source video is encoded and decoded using codecs implemented in accordance with the HEVC standard. In order to signal the availability of temporal scalability (i.e., the existence of at least one enhancement layer), the files containing the encoded video can include a metadata tag that provides information regarding the available layers within the media file and the frame rate of each layer. In several embodiments, at least one enhancement layer includes metadata in the form of an ordered set of Access Unit Delimiters (AUDs) that specify a sequential order for selecting access units from different layers. In particular, each AUD identifies the specific layer containing the video data of the Access Unit and this information can be used to determine the manner in which the Access Units from the different layers are combined into a single video stream. In some embodiments, the multiple streams are combined on the user's playback device prior to being provided to the decoder on the device. In other embodiments, the separate streams are combined into a single stream by the content provider prior to their streaming to the user's device.


System and methods for encoding and playing back video at different frame rates using enhancement layers in accordance with embodiments of the invention are discussed further below.


System Architecture for Encoding and Playing Back Video at Different Frame Rates Using Enhancement Layers


A system for encoding and playing back video at different frame rates using enhancement layers in accordance with an embodiment of the invention is illustrated in FIG. 1. The system 100 includes a source encoder 102 configured to encode source media into encoded video. In many embodiments, the source encoder encodes the video using temporal scalability, which allows the encoded video to be played back at different frame rates. In the illustrated embodiment, the source encoder is a server. In other embodiments, the source encoder can be any processing device including a processor and sufficient resources to perform the transcoding of source media including (but not limited to) video, audio, and/or subtitles.


As is discussed further below, in many embodiments, the source encoder is able to encode a video with temporal scalability by creating a base layer of video frames that allow playback at a base frame rate and one or more enhancement layers of video frames that allow playback at a higher enhanced frame rate. In many embodiments, the source encoder stores the encoded video in one or more container files. In some embodiments, the encoded video is then uploaded to distribution server 104. In many embodiments, source encoder uploads the encoded video as a single file containing multiple temporal layers. In several embodiments, the encoded video is uploaded as one or more separate streams, with each stream corresponding to a particular temporal layer of the encoded video. In many embodiments, each stream can be stored in a separate container file (e.g., Matroska container file) while in other embodiments the streams are stored in the same container file. A device 105-107 may then request either to (i) download the entire file, or (ii) receive a streamed video for progressive playback. In some embodiments, the streamed video provides either the base layer of video data when the requested stream is at the base frame rate or the base layer and one or more enhancement layers when the requested stream is at a higher enhanced frame rate.


In many embodiments, the encoded video is stored in Matroska container files. As is discussed further below, the encoded video can be stored within the Matroska container file in a way that facilitates the embedding of metadata within a file containing encoded video that describes any enhancement layers that may be available to achieve playback of the content at an enhanced frame rate. In many embodiments, the Matroska container files are specialized Matroska container files that include enhancements (i.e., elements that do not form part of the Matroska file format specification) that facilitate the retrieval of the video at different frame rates via HTTP or RTSP during the streaming of the video. The enhancements to the Matroska container file can also include storing metadata that provides information regarding the temporal layers that are available for the encoded video and the frame rate of each layer.


In many embodiments, the distribution server receives and processes download requests from a variety of playback devices 105-107 that seek to download the encoded video. When the distribution server receives a download request from a playback device, it can provide the playback device with the encoded video for storage. A downloaded video file may include a header that contains metadata describing temporal layers within the video file and the video data stored within the various temporal layers. In some embodiments, the temporal layers provided to a playback device may include only the base layer when the device requests the encoded video at the base frame rate or both the base layer and one or more enhancement layers when the device requests the encoded video at the enhanced frame rate.


In some embodiments, the distribution server receives stream requests from a variety of playback devices and subsequently streams the encoded video to the playback devices for progressive playback and/or as part of an adaptive bitrate streaming system. In several embodiments, the variety of playback devices can use HTTP or another appropriate stateless protocol to request streams via a network 108 such as the Internet. In several embodiments, a variety of playback devices can use RTSP whereby the distribution server records the state of each playback device and determines the video to stream based upon instructions received from the playback devices and stored data describing the state of the playback device.


Playback devices with different playback capacities may request different streams from the distribution server. For example, for a particular video that has been encoded with temporal scalability, a device with only the capacity to playback the encoded video at a base frame rate can request a stream from the distribution server that contains only the base layer. The distribution server would then stream only the base layer of the encoded video to the playback device. Likewise, a device with the capacity to playback video at the enhanced frame rate can request the distribution server to provide streams that contain both the base layer and the one or more enhancement layers whereby the distribution server would stream both layers to the playback device. By allowing a device to request only the particular layers that the device is capable of decoding, the system is able to avoid wasting network resources that would otherwise be needed to provide all layers to every device, including those without the capacity to handle the enhancement layers.


As described above, in order to enable playback of the video, the separate streams can be merged according to the decode order of the video frames. Thus, in many embodiments, when a device requests a stream at the enhanced frame rate, the distribution server first merges the separate temporal streams and sends a single ordered stream of video to the device. In other embodiments, the playback device is responsible for merging the separate streams into the single ordered stream prior to providing the stream to a decoder on the playback device for play back of the video stream.


In the illustrated embodiment, playback devices include personal computers 105-106 and mobile phones 107. In other embodiments, playback devices can include consumer electronics devices such as DVD players, Blu-ray players, televisions, set top boxes, video game consoles, tablets, and other devices that are capable of connecting to a server via HTTP and playing back encoded video. Although a specific architecture is shown in FIG. 1 any of a variety of architectures can be utilized that enable playback devices to request video at different frame rates as appropriate to the requirements of specific applications in accordance with embodiments of the invention.


The basic architecture of a playback device in accordance with an embodiment of the invention is illustrated in FIG. 2. The playback device 200 includes a processor 210 in communication with non-volatile memory 230, volatile memory 220, and a network interface 240. In the illustrated embodiment, the non-volatile memory includes a video decoder 232 that configures the processor to decode video and a client application 234 configured to buffer streamed video and deliver the streamed video to the video decoder 232. In several embodiments, the network interface 240 may be in communication with the processor 210, the volatile memory 220, and/or the non-volatile memory 230. Although a specific playback device architecture is illustrated in FIG. 2, any of a variety of architectures including architectures where the video decoder is located on disk or some other form of storage and is loaded into volatile memory at runtime can be utilized to implement playback devices in accordance with embodiments of the invention.


Stream Selection of Video Encoded with Temporal Scalability


As described above, different classes of devices may request different streams from the distribution server in order to play back a video at different frame rates. Streams generated by a source encoder and/or stored on a distribution server for streaming to playback devices in accordance with embodiments of the invention are illustrated in FIG. 3. The files utilized in the streaming of the source video include a top-level index file 310 and a plurality of container files 320-330 that each contain a different stream, each stream corresponding to a particular temporal layer of the encoded video. In several embodiments, the top level index file describes the content of each of the container files. In a number of embodiments, the plurality of container files includes files containing additional streams encoded at different resolutions, pixel aspect ratios, and/or maximum bitrates and the top level provides information that can be utilized to perform adaptive bitrate streaming of the content contained within the container files. As is discussed further below, the container files can take a variety of forms including (but not limited to) a Matroska (MKV) container file and/or a modified or specialized version of a Matroska container file.


In many embodiments, each Matroska container file contains a single stream that corresponds to a particular temporal layer of the encoded video. For example, a first stream could contain video frames for a base layer of the encoded video and a second stream could contain the video frames for one or more enhancement layers. In some embodiments, each stream includes only the video data for the particular layer. Thus, in many embodiments, in order to play back the video at an enhanced rate, the video data from the different layers can be combined into a single stream prior to being sent to the decoder. As can readily be appreciated, the combination of streams can occur at the server and/or at the playback device. In several embodiments, at least one enhancement layer includes metadata in the form of an ordered set of Access Unit Delimiters (AUDs) that provide the order for selecting access units from different layers (or streams). In particular, each AUD identifies the particular layer containing the video data of the Access Unit and this information can be used to determine the manner in which the Access Units from the different layers are combined into a single video stream.


As is discussed further below, in many embodiments the Matroska container files are specialized files. The encoding of the video and the manner in which the video is stored within elements within the Matroska container file can be subject to constraints designed to enhance the performance of a streaming system for playing video encoded with temporal sub-layers. In addition, the Matroska container file can include index elements that facilitate the location and downloading of frames of video (i.e., Access Units) from the various Matroska container files during the streaming of the media. Specialized Matroska container files that can be used in adaptive bitrate streaming systems are proposed by DivX, LLC in U.S. patent application Ser. No. 13/221,682, entitled “Systems and Methods for Adaptive Bitrate Streaming of Media Stored in Matroska Container Files Using Hypertext Transfer Protocol”, filed Aug. 30, 2011, the disclosure of which is hereby incorporated by reference in its entirety. Matroska container files that can be used in streaming systems that distribute video encoded with temporal layers in accordance with embodiments of the invention are discussed below.


Storing Encoded Video with Temporal Layers in Matroska Files


A Matroska container file used to store encoded video in accordance with an embodiment of the invention is illustrated in FIG. 4A. The container file 410 is an Extensible Binary Markup Language (EBML) file that is an extension of the Matroska container file format. The specialized Matroska container file 410 includes a standard EBML element 411, and a standard Segment element 412 that includes a standard Seek Head element 413, a standard Segment Information element 414, and a standard Tracks element 415. These standard elements describe the video contained within the Matroska container file. The Segment element 412 also includes a standard Clusters element 416. As is described below, the manner in which encoded video is inserted within individual Cluster elements 417-419 within the Clusters element 416 is constrained to improve the playback of the media in a streaming system. In many embodiments, the constraints imposed upon the encoded video are consistent with the specification of the Matroska container file format and involve encoding the video so that each cluster includes at least one closed GOP commencing with an IDR or “I” frame. The Clusters element 416 includes a plurality of Cluster elements 417-419 that each contains a discrete portion of encoded video. In the illustrated embodiment, each Cluster element 417-419 includes two seconds of encoded video. In other embodiments, the Cluster elements include encoded video having a greater or lesser duration than two seconds. In several embodiments, the encoded video sequences in the Cluster elements have different durations.


In addition to the above standard elements, the Segment element 412 also includes a modified version of the standard Tracks element 415. As is discussed further below, the Tracks element includes a standard Codec Private element 420. The Codec Private element includes a specialized Profile Message element 421 (e.g., the DivX™ HEVC Profile Tag specified by DivX, LLC of San Diego, Calif.) that is used to (i) signal the availability of temporal scalability for the encoded video and (ii) provide information regarding the temporal layers that are available and corresponding frame rates of each available layer. In some embodiments, the temporal scalability of encoded video can be quickly detected based on the presence of this tag within the container file and/or the presence of similar information within a top level index file.



FIG. 4B illustrates an embodiment of a Profile Message element 421 contained within an enhanced Matroska container file that contains video encoded with temporal scalability. The UUID element 422 is an identifying 128-bit self-generated universally unique identifier. The UUID can be used for multiple purposes, from tagging objects with an extremely short lifetime, to reliably identifying very persistent objects across a network. The UUID may be optionally registered as an Object Identifier Repository (OID) with the International Telecommunication Union (ITU), with headquarters in Geneva, Switzerland. The Code element 423 is an identifier identifying the entity associated with the particular codec used to encode the video. For example, when the codec is a DivX HEVC codec provided by DivX, LLC, the Code element 423 can be a bit sequence spelling “DivX HEVC” when read as a sequence of unsigned characters. The Message Type element 424 is a message format indicator. For example, if the Message Type is “0x20” then the Profile Message 421 is in a text format. In some embodiments, the type zero is prohibited and several type values may be reserved. In other embodiments, any Message Type element can be utilized as appropriate to the requirements of a specific application.


The Payload element 425 includes an Asset element 426, Layers L[0] through L[ . . . ] 427, and Frame Rate Per Seconds “FPS” elements FPS[0] through FPS[ . . . ] 428. The Asset element 426 includes the UUID identifying the video file encoded with temporal scalability. As described above, the encoded video can be separated into several temporal layers, with each layer having frames of video that can be merged with a base layer to achieve a particular enhanced frame rate. Each separated layer has the same UUID, which is used to verify and track the different layers. Layers L[0] through L[ . . . ] provide a numerical value (i.e., 0 or 1) that can be used to determine whether the particular layer is available. The FPS[0] through FPS[ . . . ] provide the frame rate (i.e., frames per second) of each corresponding layer. In some embodiments, the frame rate of each layer is fixed and can be an integer multiple of the base layer. Although FIG. 4B illustrates an example of a Profile Message element that can be used to provide information regarding the temporal scalability of an encoded video, any of a variety of information can be included in the container file that enables playback devices to detect and playback video at different frame rates as appropriate to the requirements of specific applications.


As described, the encoded video can be inserted within individual Cluster elements of the MKV container. A standard (i.e., none enhanced) Clusters element of a Matroska container file containing encoded video in accordance with an embodiment of the invention is illustrated in FIG. 5A. Each Cluster element 5A00 includes a Timecode element 5A05 indicating the start time of the encoded video within the Cluster element and a plurality of BlockGroup elements 5A10. As noted above, the encoded video stored within the Cluster is constrained so that the encoded video can be played back without reference to the encoded video contained within any of the other Cluster elements in the container file. In many embodiments, encoding the video contained within the Cluster element as a GOP in which the first frame is an IDR frame (i.e., key-frame) enforces the constraint. In the illustrated embodiment, the first BlockGroup element contains an IDR frame. Therefore, the BlockGroup element does not include a ReferenceBlock element. The BlockGroup element 5A10 includes a Block element 5A11, which specifies the Timecode attribute of the video frame encoded within the Block element relative to the Timecode of the Cluster element 5A00. In the illustrated embodiment, subsequent BlockGroup elements are not restricted in the types of video frames that they can contain (other than that they cannot reference frames that are not contained within the Cluster element). Therefore, subsequent BlockGroup elements can include ReferenceBlock elements referencing other BlockGroup element(s) utilized in the decoding of the video frame contained within the Block element of the BlockGroup. Alternatively, subsequent BlockGroup elements can contain IDR frames and are similar to the first BlockGroup element. As discussed below, when an enhancement layer is contained within a container file separate from the base layer, the frames in the BlockGroup elements may be restricted to only reference frames of video from the base layer.



FIG. 5B illustrates a modified (non-standard) Cluster element 5B00 for use in the playback of encoded video with temporal scalability. In particular, each Block element 5B11 includes an Access Unit Delimiter 5B12 (“AUD”) that is used to indicate the boundaries between Blocks (i.e., Access Units or frames of video) of a video file. The AUD also contains a Temporal I.D. element 5B13 that identifies the temporal layer of a particular Block (i.e., the layer to store a particular video frame). In many embodiments, the encoder can be configured to insert an AUD and Temporal I.D. for every Block in an encoded video. In some embodiments, the AUD is only present when there is more than one temporal layer in an encoded video. In many embodiments, a decoder is able to obtain the Temporal I.D. associated with a particular Block by only parsing the first few bytes of each Block. As illustrated in FIG. 5B, Block 5B11 has a Temporal I.D. of 0, which indicates that the video data contained within this Block is for a frame that is stored within the base layer of the encoded video. Likewise, Block 5B14 has a Temporal I.D. of 1, which indicates that the video data contained within this Block is for a frame of video that is stored within one of the enhancement layers.


In the example illustrated in FIG. 5B, the different temporal layers of the encoded video are contained within a single MKV container file. However, in many other embodiments, each separate temporal layer of the encoded video can be stored in a separate MKV container file. This can be particularly useful in a streaming context where only certain temporal layers may be needed by different playback devices with different playback profiles.


An example of separate container files storing different temporal layers is illustrated in FIG. 6. In particular, FIG. 6 illustrates two container files 601 and 602, with each container file storing a particular temporal layer of an encoded video. The example illustrated in this figure illustrates the Cluster element of the Matroska container file, which, as described above, is used to store a particular duration (e.g., 2 seconds) of encoded video. Furthermore, each Cluster includes numerous BlockGroups 603, each containing a Block element 604 and (optionally) associated an Reference Block(s) 607, with each Block corresponding to a particular video frame displayed within the particular duration of encoded video. Furthermore, each Block element of the container file containing the enhancement layer 602 includes an AUD 605 containing the Temporal ID 606 of the particular Block element 604, which may or may not contain video data for an access unit depending upon whether the Temporal ID indicates that the Block is part of the enhancement layer. The Temporal ID identifies the particular temporal layer corresponding to the Block.


In order to separate the temporal layers into separate streams, many embodiments can store within a particular container file only those video frames that have a Temporal ID identifying the particular temporal layer. As illustrated in this example, Cluster 601 includes Blocks and Reference Blocks which all have a Temporal ID of 0, which indicates that the encoded video frame within these Blocks correspond to the base temporal layer. In the illustrated embodiment, these Blocks do not include AUDs. In other embodiments, the Blocks in the container file containing the base layer can include AUDs. Likewise, Cluster 602 includes Blocks (and ReferenceBlocks) which all have a Temporal ID of 1, which indicates that the encoded video frames within these Blocks belong to an enhancement layer with and ID of 1. As noted above, the container file containing the clusters that include the enhancement layer(s) can also include Blocks containing AUDs indicating the decode order of the merged layers (see discussion below). In many embodiments, storing the temporal layers in separate containers allows for the individual streaming of particular temporal layers, as requested by different devices with different playback capabilities. Although the above describes inserting information concerning the various temporal layers, and metadata identifying the frames belonging to the enhancement layers, similar techniques can be utilized to stored encoded video incorporating enhancement layers in any of a variety of different container files in accordance with embodiments of the invention.


Generating a Container File for Video Encoded with Temporal Layers


In order to facilitate the playback of encoded video with temporal scalability, metadata describing the temporal layers of the encoded video may be embedded that facilitates the playback of the encoded video at different frame rates. The metadata may be embedded in either the container file or within the encoded video data. In many embodiments, the video is encoded in accordance with the HEVC standard and an encoder can embed certain additional information during the encoding process that facilitates the video playback. A process for embedding information describing video encoded with temporal scalability in a container file in accordance with an embodiment of the invention is illustrated in FIG. 7.


The process 700 commences by initializing (705) source video for encoding with temporal scalability. The resulting encoded video may contain multiple video layers, including a base layer containing frames of video for playback at a base frame rate and one or more enhancement layers containing frames of video for playback at a higher enhanced frame rate. In some embodiments, the same process will be utilized for encoding a video without temporal scalability (i.e., no multiple temporal layers). In this situation, the process may provide an indication that the enhancement layers are unavailable.


The process inserts (710) metadata into the container file indicating the presence of one or more enhancement layers within the file and the frame rate of the enhancement layer. In the case of a Matroska container file, a Profile Message can be inserted into the file header that includes information regarding the temporal layers and the corresponding frame rate of each layer. In many embodiments, the Profile Message is the DivX HEVC Profile Message specified by DivX, LLC of San Diego, Calif. In other embodiments, any of a variety of metadata describing an enhancement layer can be stored in a container file as appropriate to the requirements of a specific application.


The process 700 encodes (715) the video with temporal scalability. As described above, in many embodiments the process utilizes the HEVC compression standard for encoding the video. During the encoding process, the process may store portions of the encoded video within Matroska container files. As described above, in some embodiments, the process may also embed an Access Unit Delimiter (AUD) within each frame of video that provides the corresponding temporal layer associated with the video frame. In some embodiments, the AUD is contained within the Block (or Reference Block) element of the MKV container, with each Block containing the encoded video frame data for a particular video frame. In other embodiments, the process may not embed the AUD into the Block, but can use a different mechanism in order to provide an indication of the temporal layer associated with a particular frame of video. For example, in many embodiments that store the temporal layers in different containers, the process may provide null values to indicate that Blocks in different containers corresponding to different temporal layers will contain the video data for certain frames.


The process 700 determines (720) whether to store the encoded video as one or more files, such as a single MKV file. The file may then be stored on a non-volatile storage medium such as a CD-ROM, flash-drive, or other storage medium. The file may also be stored and distributed to a user by allowing the user to download the file from a distribution server. If the process determines that the encoded video is to be stored as a file, the process can store (725) the file containing the encoded video on a storage medium (i.e., Distribution Server or CD-ROM, flash-drive, or other non-volatile storage etc.). In many embodiments, the encoded video is stored as a single file with multiple temporal layers of video that can be decoded by a decoder implemented on the playback device. In several other embodiments, each temporal layer of the encoded video is stored as a separate file in order to allow a playback device to obtain only the encoded video that the device is capable of playing back.


The process 700 determines (730) whether to store the encoded video in a manner suitable for streaming to playback devices. When the process determines (730) not to store streams of the encoded video, the process is complete.


When the process 700 determines (730) that the encoded video should be stored for streaming, the process generates and stores (735) separate streams of frames of video, with each stream corresponding to a temporal layer of the encoded video. In many embodiments, in order to generate the separate streams, the process analyzes a Temporal I.D. associated with each frame of video in the single video stream. In several embodiments, the video stream will include many different video frames with the frames ordered based on the decoding order.


In a number of embodiments, the Temporal I.D. may be stored within the AUD of a Block element within a Matroska container. Based on the Temporal I.D. of the frames of video, the process may separate out different frames of video to different streams. Thus each separate stream may contain only the video data for frames of video within the particular stream. For example, the base layer may contain only the video data for frames that are to be played back at the base frame rate. Thus, if a video has a base frame rate of 30 f.p.s, the base layer will contain 30 frames for one second of encoded video. Continuing with the example, the one or more enhancement layers can contain the video data for the frames that are to be played back at the higher enhanced frame rate. Thus, if a video is to be played back at an enhanced frame rate of 60 f.p.s. and has a base frame rate of 30 f.p.s., the enhancement layer of this encoded video will contain 30 additional video frames that can be combined with the 30 frames in the base layer to generate an output of 60 f.p.s. As described below, the combined frames may be provided to the decoder in a particular decode order, which is an order that causes the decoder to have fully decoded all frames on which a given frame depends prior to decoding the given frame. In order to know how the frames are to be merged, the process also retains (735) the AUD order of frames within at least one of the layers. In many embodiments, metadata describing the ordering of frames is stored in at least one of the enhancement layers. For example, prior to separating the frames to the different streams, the process can retain the order of the layers of the frames within the single stream. During the merging of the frames, the process can then identify the corresponding layer that contains the frame that should be retrieved for the encoded video. After generating and storing the separate streams, the process is complete. Although specific processes for embedding information describing video encoded with temporal scalability are described above, any of a variety of processes may be utilized for embedding information describing video encoded with temporal scalability as appropriate to the requirements of specific applications in accordance with embodiments of the invention.


Playback of Encoded Video at Different Frame Rates


Playback of encoded video with temporal scalability can allow the encoded video to be played back at different frame rates. A process for playing back an encoded video including temporal layers in accordance with an embodiment of the invention is illustrated in FIG. 8. The process 800 commences by obtaining (805) a file header for the encoded video that is to be played back on the playback device. As described above, in many embodiments the encoded video is stored in one or more Matroska container files, and the header of the Matroska container file may contain information regarding the encoded video contained within the particular container. The information stored within a Matroska container may be organized within different elements to facilitate the easy retrieval of the information when needed for playback of the encoded video. In particular, the process can access different elements to obtain different types of information that may be needed for playback. In other embodiments, any of a variety of container file formats appropriate to the requirements of a specific application can be utilized.


Metadata is obtained (810) from the header, which describes the various tracks within the encoded video. The metadata can be parsed (815) to retrieve information regarding the particular codec (i.e., compression/decompression standard) that was used to encode the video. In embodiments where the encoded video data is contained within a Matroska container file, the metadata is contained within a Codec Private element contained within a Tracks element. In many embodiments, the codec may be a codec provided by DivX, LLC of San Diego, Calif.


The metadata within the header of the container file may contain metadata that describes the temporal layers of the encoded video. If the process does not detect (820) metadata that describes temporal layers of the encoded video, the process plays back (835) the encoded video using a standard normal playback process. This would occur for a video that has been encoded without temporal scalability (i.e., there is only a single base layer of video frames). In many embodiments, the standard playback process decodes the video frames within a single track of video data contained in the container file.


If the process detects (820) metadata that describes the temporal layers of the encoded video, the metadata can be parsed (825) in order to obtain information that can be used to facilitate the playback of the encoded video at an enhanced frame rate. The obtained information can indicate whether or not the video is encoded with temporal scalability (i.e., there are multiple layers of video data). In particular, the metadata can describe the layers that are available in the encoded video and the particular frame rate of each layer. In a streaming environment, the metadata may also describe other temporal scalability streams contained within different container files. In embodiments where the encoded video data is contained within a Matroska container file, the metadata that describes the temporal layers of the encoded video can be contained within a Profile Message element within a Codec Private element. In other embodiments, metadata describing the temporal layers of the encoded video can be inserted in any of a variety of locations and/or data formats within a container file and/or other file type including (but not limited to) top level index files and/or metadata files as appropriate to the requirements of specific applications.


When the process (830) does not detect temporal scalability (i.e., the process does not detect the existence of multiple layers in the encoded video), the process plays (835) the encoded video using standard playback. When the process detects (830) temporal scalability (i.e., multiple available temporal layers), the process can play back (840) the encoded video with temporal scalability. In particular, the process plays back the encoded video either the full frame rate (e.g., 60 fps) or only at the base frame rate (e.g., 30 fps). Furthermore, for a file-based playback, the device on which the process will play back the encoded video can quickly determine which frames can be decoded by the device based on the temporal I.D. of each frame. Likewise, as described in detail below, during a streaming playback session involving separate streams for different temporal layers, the process can merge the separate streams corresponding to the different temporal layers into a single stream of encoded video prior to providing the stream to a decoding process. Various mechanisms for separating and merging streams of video data to achieve temporal scalability in accordance with embodiments of the invention are described in detail further below.


Playback of Encoded Video with Separate Streams


As described above, in many embodiments the video is encoded with one or more temporal layers, with each layer stored in a separate stream. In a distribution channel that streams the encoded video to playback devices, the separate streams allow different playback devices the ability to request only those streams that the particular playback device is capable of decoding and playing back. An example of a process for streaming encoded video utilizing separate streams in accordance with an embodiment of the invention is illustrated in FIG. 9. In this example, several of the steps in the process are similar to the steps described for both the file-based and stream-based distribution that were described in FIG. 8, and thus many of the details described in FIG. 8 are not provided in this example.


The process 900 initially detects (905) the presence of metadata within a header of the container file containing information about the temporal scalability of the encoded video. In embodiments that utilize a Matroska container file, the metadata can take the form of a Profile Message element similar to the various Profile Messages described above with respect to FIG. 4B. The metadata is parsed (910) to obtain information about the temporal scalability of the encoded video, including the number of available temporal layers and the frame rate of each layer.


Based on the playback capabilities of the device (i.e., the device's video profile), the process requests (915) streams for one or more of the temporal layers from a distribution server. In some embodiments, when the process requests only the base layer of the encoded video for playback at the base frame rate, the distribution server streams only the base layer. When the process requests the base layer and or more enhancement layers, the distribution server also streams each different temporal layer of the encoded video.


Based on whether the process has requested (i) only the base layer or (ii) the base layer and one or more enhancement layers, the process may need to merge 920 (optional) the streams of temporal layers into a single stream of frames in decode order (as opposed to playback order). In several embodiments, at least one of the layers includes metadata indicating the decode order of the frames in the base layer and the one or more enhancement layers. In embodiments in which the video is encoded in accordance with the HEVC standard, the metadata indicating decode order is a sequence of AUDs that indicate the temporal layer from which to retrieve encoded video data. The separate streams can then be merged 720 based on the AUD order contained within the one (or more) layers described above. In certain embodiments, the sequence of AUDs is contained in at least one of the enhancement layers. In other embodiments, decode order can be indicated in any of a variety of ways appropriate to the requirements of specific applications including (but not limited) by specifying the decode order of access units within metadata accompanying the access units in the container file and/or inserting null or empty access units in the container file of one of the layers.


When the process only requests a single temporal layer, the process can skip the optional merge (920) and playback (925) the encoded video. Furthermore, in many embodiments, the distribution server can merge the separate streams into a single stream prior to distributing the encoded video to a playback device. In this situation, the process may also playback (925) the encoded video without executing the optional merge (920) in the process. After playback, the process is complete. The process of merging the separate streams containing the different temporal layers may be performed by either (i) the playback device after it receives the separate streams from the distribution server or (ii) the distribution server prior to sending a single stream containing the multiple temporal layers to the playback device. Although specific processes for playback of an encoded video containing separate streams are described above, any of a variety of processes may be utilized for playback of an encoded video containing separate streams as appropriate to the requirements of specific application in accordance with embodiments of the invention. An example of a process of many embodiments for merging separate streams is described below.


Combining Separate Streams Based on AUD Order


As described above, in a streaming context, each temporal layer of the encoded video may be stored as a separate stream and different streams may be provided to different playback devices to reduce wasteful network consumption. An example of a process for merging separate streams of an encoded video in accordance with an embodiment of the invention is illustrated in FIG. 10.


The process 1000 requests (1005) streaming of a particular set of temporal layers from a distribution server. In some embodiments, the process requests the set of streams based on the playback capabilities of the playback device. In particular, when a playback device does not have the playback capability to handle the enhancement layer(s), the process requests (1005) only the encoded video within the base layer, receives (1015) a stream containing video data from only the base layer of the encoded video, and plays back (1035) the encoded video.


When (1010) the playback device has the ability to decode and playback one or more of the enhancement layers, the process requests both the base layer and enhancement layer(s). The process then receives (1020) separate streams containing the base layer and the one or more enhancement layers. The process then may need to combine the separate streams into a single stream prior to providing the stream to the decoder on the playback device. In order to combine the streams, the process identifies (1025) an AUD order for the video frames (i.e., Access Units), and determines the temporal layer associated with each frame of video. In many embodiments, the AUD order may be obtained from at least one of the layers. The AUD order identifies the order of video frames and the particular temporal layer that contains the video frame. In particular, each frame (e.g., Matroska Block described above) can be embedded with an AUD containing a Temporal I.D. that identifies a particular layer for the frame. The order that these frames are separated into separate streams may be retained within one of the temporal layers. For example, an AUD order may simply be a series of 1's and 0's, such as “001101 . . . ”, which would indicate that the order of frames (prior to being separated into separate streams) is: “base layer, base layer, enhancement layer, enhancement layer, base layer, enhancement layer, . . . ” etc.


Thus each separate layer can be recombined by selecting frames from the different temporal layers based on the AUD. In particular, an AUD with Temporal I.D. of 0 means that the process needs to merge the next frame of the base layer stream and an AUD with Temporal ID of 1 means that the process needs to merge the next frame of the particular enhancement layer stream with Temporal ID of 1. By retaining the original Temporal ID order of the video frames, the process is able to easily re-combine (1030) the base layer video data with the enhancement layer video data into a single stream of encoded video.


Having combined the separate streams, the process plays back (1035) the encoded video. After playback, the process is complete. Although specific processes for merging separate streams of an encoded video are described above, any of a variety of processes may be utilized for merging separate streams of an encoded video as appropriate to the requirements of specific application in accordance with embodiments of the invention. Several additional examples are provided below that illustrate the merging of separate streams of an encoded video.


Decoding Order of Frames


As described above, in order for a decoder to decode a given video frame, in some embodiments, the decoder of a playback device needs to have fully decoded all frames on which the given frame depends prior to decoding the given frame. FIGS. 11A and 11B illustrate an example of the decoding a set of video frames ordered in a decode order. In particular, FIG. 11A illustrates the reference dependencies that may exist between a set of video frames ordered based on the picture display order (POC) of the video frames. The POC of a frame provides the position of a given frame relative to the display order of the other frames in the same portion of encoded video, such as a Matroska Cluster element that encodes a 2-second duration of encoded video.


As illustrated, the arrows between the various frames 1110 indicate the other frames on which the particular frame is dependent. As illustrated, POC 0 does not have any outward arrows, since this is an I-frame and thus is not dependent on any other frames for its decoding. The next POC 1 is dependent on frames POC 0 and POC 2. Thus, in order for a decoder of a playback device of some embodiments to be able to decode POC 1 video frame, the decoder should have already decoded POC 0 and POC 2. Likewise, POC 2 is dependent on POC 0 and POC 4; POC 3 is dependent on POC 2 and POC 0; POC 4 is dependent on POC 0 and POC 8; and these dependencies continue for each B or P frame in the particular portion of encoded video. Thus in order to decode these video frames within the particular portion of the encoded video, the frames are provided to the decoder in an order that guarantees that for a given frame, the decoder has already decoded all frames on which the given frame depends prior to decoding the given frame. Thus the decode order for these frames is not the same as the POC order (i.e., 0, 1, 2, 3, etc.) of the frames.



FIG. 11B illustrates a table providing the required decode order for the frames illustrated in FIG. 11A. In particular, the decode order for the frames is as follows: POC 0, POC 8, POC 4, POC 2, POC 1, POC 3, POC 6, POC 5, and POC 7. Furthermore, the table also provides the Temporal ID, indicated as “Tid” for each frame. As described above, in many embodiments the Temporal ID is embedded within each frame of the encoded video. For example, the Temporal ID may be embedded within the Block element (i.e., frame) of the MKV container. In this example, the AUD temporal ID order of the set of frames is: 0, 0, 0, 0, 1, 1, 0, 1, 1. Thus during merging of the separate streams, this AUD temporal ID order may be used to determine the order in which the frames from the different streams need to be combined for the decode order.


Furthermore, the Temporal ID associated with each frame of an encoded video can be used to quickly separate the temporal layers into different streams. An example of separating an encoded video into separate streams in accordance with an embodiment of the invention is illustrated in FIGS. 12A-12B.



FIG. 12A illustrates an example of a portion of an encoded video stream containing several frames of video (0 through 8). The frames are ordered based on the decode order of the video. In particular, the decode order for this portion of the video is POC 0, 8, 4, 2, 1, 3, 6, 5 and 7. Each POC also includes an AUD (i.e., Access Unit Delimiter) that contains a Temporal ID identifying the temporal layer for the frame of video. For example, POC 0 has a TID of 0, POC 8 has a TID of 0, and this continues along the stream of encoded video. As noted above, the Temporal ID can be used to separate the frames into separate streams.



FIG. 12B illustrates an example of the separate streams that may be generated for the encoded video illustrated example illustrated FIG. 12A. In particular, the stream 0, 8, 4, 2, 1, 3, 6, 5, and 7 needs to be separated into a stream containing only frames for the base layer (i.e., Temporal ID of 0) and a stream containing only frames for the enhancement layer (i.e., Temporal ID of 1). As illustrated, the first frame (POC 0, TID 0) is separated to the base layer because it has a TID of 0, the second frame (POC 8, TID 0) is separated to the base layer (which now contains the frames 0, 8), the third frame (POC 4, TID 0) is again separated to the base layer (which now contains the frames 0,8,4), the fourth frame (POC 2, TID 0) is again separated to the base layer (which now contains the frames 0, 8, 4, 2), now at the fifth frame (POC 1, TID 1) this frame is separate to the enhancement layer because it has a TID of 1. At this point, the base layer 12B10 has frames POC: 0, 8, 4, 2 and the enhancement layer 12B20 has frame POC: 1. This process continues on through the frames of encoded video. For this portion of frames, the stream 12B10 corresponding to the base layer with Temporal ID of 0 contains the frames: 0, 8, 4, 2, and 6. Likewise, stream 12B20 corresponding to the enhancement layer with Temporal ID of 1 contains the frames 1, 3, 5, and 7. Having separated the frames for the different temporal layers into separate streams, these streams 12B10 and 12B20 can now be individually streamed to different devices, as requested by the devices. Furthermore, as described above, information regarding the AUD Temporal ID order of the frames can also be streamed, for example within one of the temporal layers or as a separate metadata, for use during the merging of the separate streams prior to playback on the device.


An example of merging of different temporal streams in accordance with an embodiment of the invention is illustrated in FIG. 13. In particular, FIG. 13 illustrates a stream 1305 corresponding to the base temporal layer and a stream 1310 corresponding to the enhancement layer. These streams correspond to the streams that were separated in FIGS. 12A-12B. In particular, stream 1305 includes the video frames (illustrated as POC Video Data) for POCs: 0, 8, 4, 2, and 6. Likewise, stream 1310 includes the video frames for POCs 1, 3, 5 and 7. Accordingly, in this example, each stream 1305 and 1310 has the video data for video frames associated with its particular temporal layer. Furthermore, in this particular example, stream 1310 also includes the AUD Temporal ID order, which can be used to merge the separate streams into a single stream.


In particular, the AUD Temporal ID order in this example is: 0, 0, 0, 0, 1, 1, 0, 1, 1. As such, this AUD Temporal ID order indicates that the first AUD has a Temporal ID of 0, and thus the combined video stream needs to retrieve and merge the video data of the 1st frame (i.e., POC 0) from the base layer stream 1305. The next AUD Temporal ID is again 0, and thus again, the combined stream is able to retrieve and merge the video data of the next frame from the base layer (i.e., POC 8). This continues through the entire AUD Temporal ID series, and thus the stream is combined as a combined stream using the following order of POCs: 0, 8, 4, 2, 6, 1, 3, 6, 5 and 7. Note that the POC order is now back to the same order that it was prior to the separation of the layers into the separate streams illustrated in FIGS. 12A-12B.


The combined stream can now be provided to a decoder of the playback device for decoding of the video frames. Although the example in FIG. 13 illustrates combining different streams containing different temporal layers using an AUD Temporal ID order of the video frames, any of a variety of mechanisms may be utilized for merging separate streams of encoded video as appropriate to the requirements of specific applications in accordance with embodiments of the invention.


Furthermore, providing separate streams for the different temporal layers allows the system to stream the individual layers that are needed for a particular device. As described above, the different streams may be requested by a playback device using HTTP, which is a stateless protocol that enables a playback device to request a byte range within a file, or RTSP which is a network control protocol used to control streaming media servers whereby playback devices issue control commands, such as “play” and “pause”, to the server streaming the media to control the playback of media files. When RTSP is utilized, the media server records the state of each client device and determines the media to stream based upon the instructions received from the client devices and the client's state. Examples of such streaming media servers are described below.


Streaming Server


Playback devices may request different temporal layers of an encoded video with temporal scalability based on the particular playback capacities of the device. A process for streaming different temporal layers of an encoded video for playback on a playback device in accordance with an embodiment of the invention is illustrated in FIG. 14.


The process 1400 receives a request (1405) for streaming of an encoded video. In some embodiments, the request may be received from a playback device and include a particular video profile of the device. For example, the video profile may provide the frame rate at which the device is able to playback an encoded video.


The process determines (1410) whether to stream the video at a base frame rate. For example, if the playback device is only capable of decoding the base layer of the encoded video, the process streams only the base layer. In an adaptive bitrate context, the process may decide to stream at the base rate based on the given streaming conditions of the network such as the bandwidth available or the CPU capacity of the device for processing the video frames.


When the process determines (1410) to stream the encoded video at the base frame rate, the process streams (1420) only the stream containing the base layer of video frames. In some embodiments, the process maintains the state of the streaming being provided to the playback device. For example, the process may use RTSP to establish and control the video streams to the playback device. Likewise, the playback device can issue commands, such as play, pause, and stop, to enable the real-time control of playback of the streaming video. In other embodiments, the process is a stateless process such as HTTP.


When the process determines (1410) not to stream the video at the base frame rate, the process determines (1415) whether to stream the video at a higher enhanced frame rate. For example, if the profile of the playback device indicates that the device is able to playback video at the enhanced frame rate, the process streams (1425) both the stream for the base layer and the one or more streams for the enhancement layer. As described above, in several embodiments, the process may merge the separate streams and stream a single stream to the playback device while in other embodiments, the process may stream the streams as separate streams. In some embodiments, the playback device can merge the separate streams into the proper decode order for decoding by a decoder implemented on the playback device. After merging, the process is complete. If the process determines (1415) not to stream the video at the enhanced frame rate, the process is complete.


A specific process for streaming different temporal layers of an encoded video for playback on a playback device is described above, however, any variety of processes may be utilized for streaming different temporal layers of an encoded video for playback on a playback device in accordance with embodiments of the invention.


Although the present invention has been described in certain specific aspects, many additional modifications and variations would be apparent to those skilled in the art. It is therefore to be understood that the present invention may be practiced otherwise than specifically described. Thus, embodiments of the present invention should be considered in all respects as illustrative and not restrictive. Accordingly, the scope of the invention should be determined not by the embodiments illustrated, but by the appended claims and their equivalents.

Claims
  • 1. A non-transitory machine readable medium containing processor instructions, where execution of the instructions by a processor causes the processor to perform a process comprising: obtain video comprising a merged plurality of access units with temporal scalability, each access unit in the merged plurality of access units associated with a particular layer of a plurality of temporal layers based on a temporal identifier of the access unit that identifies the particular layer, wherein the temporal layers include a base layer and one or more enhancement layers;obtain an ordered sequence of access units ordered based on a decoding order for decoding the video and generating metadata specifying an ordered sequence of temporal identifiers ordered based on, for each access unit in the ordered sequence of access units, identifying and retaining the temporal identifier associated with the access unit;separate, based on the temporal identifier of each access unit in the ordered sequence of access units, the ordered sequence of access units into (1) a base layer of access units sequenced in decode order to provide a base frame rate and (2) at least one enhancement layer with additional access units ordered in decode order to provide an enhanced frame rate, wherein at least some of the access units in the enhancement layer are encoded based upon dependencies to access units in the base layer, and wherein access units in the base layer are encoded without dependencies upon access units in the enhancement layer; andstoring the base layer in a first container file; andstoring the enhancement layer, including the generated metadata specifying the ordered sequence of temporal identifiers, in a second container file separate from the first container file, wherein the metadata is used to recombine in decode order the access units stored in the second container file with access units stored in the first container file for playback at the enhanced frame rate.
  • 2. The non-transitory machine readable medium of claim 1, wherein the temporal identifier of an access unit is stored in an initial set of bits of the access unit.
  • 3. The non-transitory machine readable medium of claim 1, further comprising inserting a temporal identifier for a set of access units of the plurality of access units of the video.
  • 4. The non-transitory machine readable medium of claim 1, further comprising inserting a metadata tag providing information regarding the layers available and the frame rate of each layer.
  • 5. The non-transitory machine readable medium of claim 1, further comprising: receiving a request for streaming of the video;determining playback capabilities of a device requesting the video;streaming different sets of layers of the video based on the playback capabilities of the device, wherein (i) the base layer is streamed to a playback device capable of playing back the base layer and (ii) the base layer and at least one enhancement layer is streamed to a playback device capable of streaming the plurality of layers.
  • 6. The non-transitory machine readable medium of claim 5, wherein streaming the different sets of layers comprises merging the different layers using the metadata that specifies the sequence for combining access units from the base layer with access units from the enhancement layer.
  • 7. The non-transitory machine readable medium of claim 1, further comprising: receiving a request for downloading of the video from a playback device;providing the encoded video to the playback device.
  • 8. The non-transitory machine readable medium of claim 1, wherein the frame rate of the at least one enhancement layer is an integer multiple of the base layer.
  • 9. The non-transitory machine readable medium of claim 1, further comprising storing each layer as a separate stream.
  • 10. The non-transitory machine readable medium of claim 1, further comprising storing each layer in a separate container file.
  • 11. A source encoder, comprising: a processor configured by a source encoder application to:obtain video comprising a merged plurality of access units with temporal scalability, each access unit in the merged plurality of access units associated with a particular layer of a plurality of temporal layers based on a temporal identifier of the access unit that identifies the particular layer, wherein the temporal layers include a base layer and one or more enhancement layer;obtain an ordered sequence of access units ordered based on a decoding order for decoding the video and generating metadata specifying an ordered sequence of temporal identifiers ordered based on, for each access unit in the ordered sequence of access units, identifying and retaining the temporal identifier associated with the access unit;separate, based on the temporal identifier of each access unit in the ordered sequence of access units, the ordered sequence of access units into (1) a base layer of access units sequenced in decode order to provide a base frame rate and (2) at least one enhancement layer with additional access units ordered in decode order to provide an enhanced frame rate, wherein at least some of the access units in the enhancement layer are encoded based upon dependencies to access units in the base layer, and wherein access units in the base layer are encoded without dependencies upon access units in the enhancement layer;storing the base layer in a first container file; andstoring the enhancement layer, including the generated metadata specifying the ordered sequence of temporal identifiers, in a second container file separate from the first container file, wherein the metadata is used to recombine in decoding order the access units stored in the second container file with access units stored in the first container file for playback at the enhanced frame rate.
  • 12. The source encoder of claim 11, wherein the temporal identifier of an access unit is stored in a header of the access unit.
  • 13. The source encoder of claim 11, further comprising inserting a temporal identifier for a set of access units of the plurality of access units of the video.
  • 14. The source encoder of claim 11, further comprising inserting a metadata tag providing information regarding the layers available and the frame rate of each layer.
  • 15. A playback device configured to playback video comprising: a processor configured to communicate with a memory, where the memory contains a client application;wherein the client application configures the processor to:obtain a first container file comprising a base layer of access units ordered in decode order for playback at a base frame rate;obtain, for a device capable of playing back an enhancement layer, a second container file comprising (1) at least one enhancement layer with additional access units ordered in decode order for playback at an enhanced frame rate and (2) metadata specifying an ordered sequence of temporal identifiers for combining, in decode order, access units from the base layer with access units from the at least one enhancement layer for playback at the enhanced frame rate, wherein each access unit includes a temporal identifier identifying a particular layer associated with the access unit;combine the base layer of access units with the at least one enhancement layer based on the metadata obtained from the second container file to obtain a combined sequence of access units ordered in a decoding order at the enhanced frame rate;wherein at least some of the access units in the at least enhancement layer stored in the second container file are decoded based upon dependencies to access units in the base layer stored in the first container file, and wherein access units in the base layer that are stored in the first container file are decoded without dependencies upon access units in the enhancement layer.
  • 16. The playback device of claim 15, wherein the client application further configures the processor to: request streaming of the video to a playback server and provide information regarding playback capabilities of the playback device to the playback server;receive the first container file comprising a first stream comprising the base layer of the video and the second container file comprising a second stream comprising the at least one enhancement layer of the video.
  • 17. The playback device of claim 15, wherein the client application further configures the processor to: request downloading of the video to a content distribution server and provide playback capabilities of the playback device to the content distribution server;receive the video from the content distribution server, wherein a first device receives the first container file comprising the base layer when the first device is capable of playing back the video at the base frame rate and a second device receives the first container file and the second container file comprising the base layer and at least one enhancement layer when the second device is capable of playing back the video at the enhanced frame rate.
  • 18. The playback device of claim 15, wherein the client application further configures the processor to: retrieve a metadata tag from the video identifying the layers available and the frame rate of each layer;determining a set of layers to playback based on the information in the metadata tag.
  • 19. The playback device of claim 15, wherein the client application further configures the processor to: identify the temporal identifier of an access unit by parsing an initial set of bytes of the access unit.
RELATED APPLICATIONS

This application claims priority to U.S. patent application Ser. No. 61/975,789 filed Apr. 5, 2014, which is incorporated by reference herein in its entirety.

US Referenced Citations (635)
Number Name Date Kind
4009331 Goldmark et al. Feb 1977 A
4694357 Rahman et al. Sep 1987 A
4802170 Trottier Jan 1989 A
4964069 Ely Oct 1990 A
5119474 Beitel et al. Jun 1992 A
5274758 Beitel et al. Dec 1993 A
5361332 Yoshida et al. Nov 1994 A
5396497 Veltman Mar 1995 A
5404436 Hamilton Apr 1995 A
5420801 Dockter et al. May 1995 A
5420974 Morris et al. May 1995 A
5471576 Yee Nov 1995 A
5479303 Suzuki et al. Dec 1995 A
5487167 Dinallo et al. Jan 1996 A
5502766 Boebert et al. Mar 1996 A
5509070 Schull Apr 1996 A
5533021 Branstad et al. Jul 1996 A
5537408 Branstad et al. Jul 1996 A
5539908 Chen et al. Jul 1996 A
5541662 Adams et al. Jul 1996 A
5583652 Ware Dec 1996 A
5589993 Naimpally et al. Dec 1996 A
5627936 Prasad May 1997 A
5633472 DeWitt et al. May 1997 A
5642171 Baumgartner et al. Jun 1997 A
5655117 Goldberg et al. Aug 1997 A
5664044 Ware Sep 1997 A
5675382 Bauchspies Oct 1997 A
5675511 Prasad et al. Oct 1997 A
5684542 Tsukagoshi Nov 1997 A
5715403 Stefik Feb 1998 A
5717816 Boyce et al. Feb 1998 A
5719786 Nelson et al. Feb 1998 A
5745643 Mishina Apr 1998 A
5751280 Abbott May 1998 A
5754648 Ryan et al. May 1998 A
5763800 Rossum et al. Jun 1998 A
5765164 Prasad et al. Jun 1998 A
5794018 Vrvilo et al. Aug 1998 A
5805700 Nardone et al. Sep 1998 A
5822524 Chen et al. Oct 1998 A
5828370 Moeller et al. Oct 1998 A
5841432 Carmel et al. Nov 1998 A
5844575 Reid Dec 1998 A
5848217 Tsukagoshi et al. Dec 1998 A
5867625 McLaren Feb 1999 A
5887110 Sakamoto et al. Mar 1999 A
5892900 Ginter et al. Apr 1999 A
5903261 Walsh et al. May 1999 A
5907597 Mark May 1999 A
5946446 Yanagihara Aug 1999 A
5956729 Goetz et al. Sep 1999 A
5959690 Toebes, VIII et al. Sep 1999 A
5999812 Himsworth Dec 1999 A
6018611 Nogami et al. Jan 2000 A
6031622 Ristow et al. Feb 2000 A
6038257 Brusewitz et al. Mar 2000 A
6044469 Horstmann Mar 2000 A
6046778 Nonomura et al. Apr 2000 A
6047100 McLaren Apr 2000 A
6058240 McLaren May 2000 A
6064794 McLaren et al. May 2000 A
6065050 DeMoney May 2000 A
6079566 Eleftheriadis et al. Jun 2000 A
6097877 Katayama et al. Aug 2000 A
6141754 Choy Oct 2000 A
6155840 Sallette Dec 2000 A
6169242 Fay et al. Jan 2001 B1
6175921 Rosen Jan 2001 B1
6195388 Choi et al. Feb 2001 B1
6204883 Tsukagoshi Mar 2001 B1
6222981 Rijckaert Apr 2001 B1
6282653 Berstis et al. Aug 2001 B1
6289450 Pensak et al. Sep 2001 B1
6292621 Tanaka et al. Sep 2001 B1
6308005 Ando et al. Oct 2001 B1
6330286 Lyons et al. Dec 2001 B1
6374144 Viviani et al. Apr 2002 B1
6389218 Gordon et al. May 2002 B2
6389473 Carmel et al. May 2002 B1
6395969 Fuhrer May 2002 B1
6397230 Carmel et al. May 2002 B1
6418270 Steenhof et al. Jul 2002 B1
6449719 Baker Sep 2002 B1
6466671 Maillard et al. Oct 2002 B1
6466733 Kim Oct 2002 B1
6510513 Danieli Jan 2003 B1
6510554 Gordon et al. Jan 2003 B1
6621979 Eerenberg et al. Sep 2003 B1
6625320 Ghanbari et al. Sep 2003 B1
6658056 Duruöz et al. Dec 2003 B1
6665835 Gutfreund et al. Dec 2003 B1
6671408 Kaku Dec 2003 B1
6697568 Kaku Feb 2004 B1
6725281 Zintel et al. Apr 2004 B1
6771703 Oguz et al. Aug 2004 B1
6807306 Girgensohn et al. Oct 2004 B1
6810031 Hegde et al. Oct 2004 B1
6810389 Meyer Oct 2004 B1
6819394 Nomura et al. Nov 2004 B1
6850252 Hoffberg Feb 2005 B1
6856997 Lee et al. Feb 2005 B2
6859496 Boroczky et al. Feb 2005 B1
6917652 Lyu Jul 2005 B2
6944621 Collart Sep 2005 B1
6944629 Shioi et al. Sep 2005 B1
6956901 Boroczky et al. Oct 2005 B2
6965724 Boccon-Gibod et al. Nov 2005 B1
6965993 Baker Nov 2005 B2
6985588 Glick et al. Jan 2006 B1
6988144 Luken et al. Jan 2006 B1
7007170 Morten Feb 2006 B2
7023924 Keller et al. Apr 2006 B1
7043473 Rassool et al. May 2006 B1
7127155 Ando et al. Oct 2006 B2
7150045 Koelle et al. Dec 2006 B2
7151832 Fetkovich et al. Dec 2006 B1
7151833 Candelore et al. Dec 2006 B2
7165175 Kollmyer et al. Jan 2007 B1
7185363 Narin et al. Feb 2007 B1
7197234 Chatterton Mar 2007 B1
7209892 Galuten et al. Apr 2007 B1
7231132 Davenport Jun 2007 B1
7237061 Boic Jun 2007 B1
7242772 Tehranchi Jul 2007 B1
7328345 Morten et al. Feb 2008 B2
7330875 Parasnis et al. Feb 2008 B1
7340528 Noblecourt et al. Mar 2008 B2
7349886 Morten et al. Mar 2008 B2
7356143 Morten Apr 2008 B2
7356245 Belknap et al. Apr 2008 B2
7366788 Jones et al. Apr 2008 B2
7376831 Kollmyer et al. May 2008 B2
7406174 Palmer Jul 2008 B2
7421411 Kontio et al. Sep 2008 B2
7457359 Mabey et al. Nov 2008 B2
7472280 Giobbi Dec 2008 B2
7478325 Foehr Jan 2009 B2
7484103 Woo et al. Jan 2009 B2
7493018 Kim Feb 2009 B2
7499938 Collart Mar 2009 B2
7526450 Hughes et al. Apr 2009 B2
7594271 Zhuk et al. Sep 2009 B2
7610365 Kraft et al. Oct 2009 B1
7640435 Morten Dec 2009 B2
7689510 Lamkin et al. Mar 2010 B2
7720352 Belknap et al. May 2010 B2
7747853 Candelore et al. Jun 2010 B2
7761892 Ellis et al. Jul 2010 B2
7779097 Lamkin et al. Aug 2010 B2
7817608 Rassool et al. Oct 2010 B2
7869691 Kelly et al. Jan 2011 B2
7962942 Craner Jun 2011 B1
7974714 Hoffberg Jul 2011 B2
7991156 Miller Aug 2011 B1
8023562 Zheludkov et al. Sep 2011 B2
8046453 Olaiya Oct 2011 B2
8054880 Yu et al. Nov 2011 B2
8065708 Smyth et al. Nov 2011 B1
8069260 Speicher et al. Nov 2011 B2
8201264 Grab et al. Jun 2012 B2
8225061 Greenebaum Jul 2012 B2
8233768 Soroushian et al. Jul 2012 B2
8245124 Gupta Aug 2012 B1
8249168 Graves Aug 2012 B2
8261356 Choi et al. Sep 2012 B2
8265168 Masterson et al. Sep 2012 B1
8270473 Chen et al. Sep 2012 B2
8270819 Vannier Sep 2012 B2
8289338 Priyadarshi et al. Oct 2012 B2
8291460 Peacock Oct 2012 B1
8296434 Miller et al. Oct 2012 B1
8311111 Xu Nov 2012 B2
8311115 Gu et al. Nov 2012 B2
8321556 Chatterjee et al. Nov 2012 B1
8386621 Park Feb 2013 B2
8401900 Cansler et al. Mar 2013 B2
8412841 Swaminathan et al. Apr 2013 B1
8452110 Shoham et al. May 2013 B2
8456380 Pagan Jun 2013 B2
8472792 Butt Jun 2013 B2
8473630 Galligan et al. Jun 2013 B1
8510303 Soroushian et al. Aug 2013 B2
8510404 Carmel et al. Aug 2013 B2
8515265 Kwon et al. Aug 2013 B2
8516529 Lajoie et al. Aug 2013 B2
8595378 Cohn Nov 2013 B1
8606069 Okubo et al. Dec 2013 B2
8640166 Craner et al. Jan 2014 B1
8681866 Jia Mar 2014 B1
8726264 Allen et al. May 2014 B1
RE45052 Li Jul 2014 E
8774609 Drake et al. Jul 2014 B2
8781122 Chan et al. Jul 2014 B2
8805109 Shoham et al. Aug 2014 B2
8806188 Braness et al. Aug 2014 B2
8843586 Pantos et al. Sep 2014 B2
8908984 Shoham et al. Dec 2014 B2
8909922 Kiefer et al. Dec 2014 B2
8914534 Braness et al. Dec 2014 B2
8914836 Shivadas et al. Dec 2014 B2
8918636 Kiefer Dec 2014 B2
8918908 Ziskind et al. Dec 2014 B2
8997161 Priyadarshi et al. Mar 2015 B2
8997254 Amidei et al. Mar 2015 B2
9014471 Shoham et al. Apr 2015 B2
9025659 Soroushian et al. May 2015 B2
9042670 Carmel et al. May 2015 B2
9094737 Shivadas et al. Jul 2015 B2
9124773 Chan et al. Sep 2015 B2
9184920 Grab et al. Nov 2015 B2
9191457 Van der Schaar Nov 2015 B2
9197685 Soroushian et al. Nov 2015 B2
9210481 Braness et al. Dec 2015 B2
9247311 Kiefer Jan 2016 B2
9247312 Braness et al. Jan 2016 B2
9247317 Shivadas et al. Jan 2016 B2
9264475 Shivadas et al. Feb 2016 B2
9313510 Shivadas et al. Apr 2016 B2
9343112 Amidei et al. May 2016 B2
9344517 Shivadas et al. May 2016 B2
20010030710 Werner Oct 2001 A1
20010036355 Kelly et al. Nov 2001 A1
20010046299 Wasilewski et al. Nov 2001 A1
20010053222 Wakao Dec 2001 A1
20020026560 Jordan et al. Feb 2002 A1
20020034252 Owen et al. Mar 2002 A1
20020051494 Yamaguchi et al. May 2002 A1
20020057898 Normile May 2002 A1
20020062313 Lee et al. May 2002 A1
20020076112 Devara Jun 2002 A1
20020087569 Fischer et al. Jul 2002 A1
20020091665 Van Beek et al. Jul 2002 A1
20020093571 Hyodo Jul 2002 A1
20020110193 Yoo et al. Aug 2002 A1
20020116481 Lee Aug 2002 A1
20020118953 Kim Aug 2002 A1
20020120934 Abrahams et al. Aug 2002 A1
20020136298 Anantharamu et al. Sep 2002 A1
20020143413 Fay et al. Oct 2002 A1
20020143547 Fay et al. Oct 2002 A1
20020147980 Satoda Oct 2002 A1
20020161462 Fay Oct 2002 A1
20020180929 Tseng et al. Dec 2002 A1
20020181746 Schwartz et al. Dec 2002 A1
20020184159 Tayadon et al. Dec 2002 A1
20020191112 Akiyoshi et al. Dec 2002 A1
20020191959 Lin et al. Dec 2002 A1
20020191960 Fujinami et al. Dec 2002 A1
20030001964 Masukura et al. Jan 2003 A1
20030002578 Tsukagoshi et al. Jan 2003 A1
20030005442 Brodersen et al. Jan 2003 A1
20030021296 Wee et al. Jan 2003 A1
20030031178 Haeri Feb 2003 A1
20030035488 Barrau Feb 2003 A1
20030035545 Jiang Feb 2003 A1
20030035546 Jiang et al. Feb 2003 A1
20030041257 Wee Feb 2003 A1
20030061305 Copley et al. Mar 2003 A1
20030061369 Aksu et al. Mar 2003 A1
20030065777 Mattila et al. Apr 2003 A1
20030078930 Surcouf et al. Apr 2003 A1
20030093799 Kauffman et al. May 2003 A1
20030123855 Okada et al. Jul 2003 A1
20030128296 Lee Jul 2003 A1
20030133506 Haneda Jul 2003 A1
20030152370 Otomo et al. Aug 2003 A1
20030163824 Gordon et al. Aug 2003 A1
20030165328 Grecia Sep 2003 A1
20030174844 Candelore Sep 2003 A1
20030185302 Abrams Oct 2003 A1
20030185542 McVeigh et al. Oct 2003 A1
20030206558 Parkkinen et al. Nov 2003 A1
20030216922 Gonzales et al. Nov 2003 A1
20030229900 Reisman Dec 2003 A1
20030231863 Eerenberg et al. Dec 2003 A1
20030231867 Gates Dec 2003 A1
20030233464 Walpole et al. Dec 2003 A1
20030236836 Borthwick Dec 2003 A1
20030236907 Stewart et al. Dec 2003 A1
20040006701 Kresina Jan 2004 A1
20040021684 Millner Feb 2004 A1
20040024688 Bi et al. Feb 2004 A1
20040025180 Begeja et al. Feb 2004 A1
20040031058 Reisman Feb 2004 A1
20040039916 Aldis et al. Feb 2004 A1
20040047614 Green Mar 2004 A1
20040052501 Tam Mar 2004 A1
20040071453 Valderas Apr 2004 A1
20040081333 Grab Apr 2004 A1
20040081434 Jung et al. Apr 2004 A1
20040093618 Baldwin et al. May 2004 A1
20040105549 Suzuki et al. Jun 2004 A1
20040114687 Ferris et al. Jun 2004 A1
20040117347 Seo et al. Jun 2004 A1
20040136698 Mock Jul 2004 A1
20040139335 Diamand et al. Jul 2004 A1
20040143760 Alkove et al. Jul 2004 A1
20040146276 Ogawa Jul 2004 A1
20040158878 Ratnakar et al. Aug 2004 A1
20040184534 Wang Sep 2004 A1
20040202320 Amini et al. Oct 2004 A1
20040217971 Kim Nov 2004 A1
20040255115 DeMello et al. Dec 2004 A1
20040255236 Collart Dec 2004 A1
20050015797 Noblecourt et al. Jan 2005 A1
20050038826 Bae et al. Feb 2005 A1
20050055399 Savchuk Mar 2005 A1
20050071280 Irwin et al. Mar 2005 A1
20050108320 Lord et al. May 2005 A1
20050114896 Hug May 2005 A1
20050149450 Stefik et al. Jul 2005 A1
20050180641 Clark Aug 2005 A1
20050183120 Jain et al. Aug 2005 A1
20050193070 Brown et al. Sep 2005 A1
20050193322 Lamkin et al. Sep 2005 A1
20050196147 Seo et al. Sep 2005 A1
20050204289 Mohammed et al. Sep 2005 A1
20050207442 Zoest et al. Sep 2005 A1
20050207578 Matsuyama et al. Sep 2005 A1
20050254508 Aksu et al. Nov 2005 A1
20050273695 Schnurr Dec 2005 A1
20050275656 Corbin et al. Dec 2005 A1
20060026294 Virdi et al. Feb 2006 A1
20060036549 Wu Feb 2006 A1
20060037057 Xu Feb 2006 A1
20060052095 Vazvan Mar 2006 A1
20060053080 Edmonson et al. Mar 2006 A1
20060064605 Giobbi Mar 2006 A1
20060078301 Ikeda et al. Apr 2006 A1
20060093320 Hallberg et al. May 2006 A1
20060120378 Usuki Jun 2006 A1
20060129909 Butt et al. Jun 2006 A1
20060168639 Gan et al. Jul 2006 A1
20060173887 Breitfeld et al. Aug 2006 A1
20060179239 Fluhr Aug 2006 A1
20060181965 Collart Aug 2006 A1
20060235880 Qian Oct 2006 A1
20060245727 Nakano et al. Nov 2006 A1
20060259588 Lerman et al. Nov 2006 A1
20060263056 Lin et al. Nov 2006 A1
20060267986 Bae Nov 2006 A1
20060274835 Hamilton et al. Dec 2006 A1
20060294164 Armangau et al. Dec 2006 A1
20070005333 Setiohardjo et al. Jan 2007 A1
20070031110 Rijckaert Feb 2007 A1
20070044010 Sull et al. Feb 2007 A1
20070047901 Ando et al. Mar 2007 A1
20070053513 Hoffberg Mar 2007 A1
20070058928 Naito et al. Mar 2007 A1
20070083617 Chakrabarti et al. Apr 2007 A1
20070086528 Mauchly et al. Apr 2007 A1
20070100757 Rhoads May 2007 A1
20070133603 Weaver Jun 2007 A1
20070136817 Nguyen Jun 2007 A1
20070140647 Kusunoki et al. Jun 2007 A1
20070154165 Hemmeryckx-Deleersnijder et al. Jul 2007 A1
20070168541 Gupta et al. Jul 2007 A1
20070168542 Gupta et al. Jul 2007 A1
20070178933 Nelson Aug 2007 A1
20070180125 Knowles et al. Aug 2007 A1
20070185982 Nakanowatari et al. Aug 2007 A1
20070192810 Pritchett et al. Aug 2007 A1
20070217339 Zhao Sep 2007 A1
20070217759 Dodd Sep 2007 A1
20070234391 Hunter et al. Oct 2007 A1
20070239839 Buday et al. Oct 2007 A1
20070255940 Ueno Nov 2007 A1
20070271317 Carmel et al. Nov 2007 A1
20070271385 Davis et al. Nov 2007 A1
20070274679 Yahata et al. Nov 2007 A1
20070277219 Toebes et al. Nov 2007 A1
20070277234 Bessonov et al. Nov 2007 A1
20070280298 Hearn et al. Dec 2007 A1
20070288745 Kwan Dec 2007 A1
20070292107 Yahata et al. Dec 2007 A1
20070297422 Matsuo et al. Dec 2007 A1
20080005175 Bourke et al. Jan 2008 A1
20080008455 De Lange et al. Jan 2008 A1
20080043832 Barkley et al. Feb 2008 A1
20080066099 Brodersen et al. Mar 2008 A1
20080066181 Haveson et al. Mar 2008 A1
20080086456 Rasanen et al. Apr 2008 A1
20080086747 Rasanen et al. Apr 2008 A1
20080101466 Swenson et al. May 2008 A1
20080104633 Noblecourt et al. May 2008 A1
20080120330 Reed et al. May 2008 A1
20080120342 Reed et al. May 2008 A1
20080120389 Bassali et al. May 2008 A1
20080126248 Lee et al. May 2008 A1
20080137541 Agarwal Jun 2008 A1
20080137736 Richardson et al. Jun 2008 A1
20080151817 Fitchett Jun 2008 A1
20080172441 Speicher et al. Jul 2008 A1
20080187283 Takahashi Aug 2008 A1
20080192818 DiPietro et al. Aug 2008 A1
20080195664 Maharajh et al. Aug 2008 A1
20080195744 Bowra et al. Aug 2008 A1
20080205860 Holtman Aug 2008 A1
20080240144 Kruse et al. Oct 2008 A1
20080256105 Nogawa et al. Oct 2008 A1
20080263354 Beuque Oct 2008 A1
20080279535 Haque et al. Nov 2008 A1
20080294453 Baird-Smith et al. Nov 2008 A1
20080298358 John et al. Dec 2008 A1
20080310454 Bellwood et al. Dec 2008 A1
20080310496 Fang Dec 2008 A1
20090031220 Tranchant et al. Jan 2009 A1
20090037959 Suh et al. Feb 2009 A1
20090048852 Burns et al. Feb 2009 A1
20090055546 Jung et al. Feb 2009 A1
20090060452 Chaudhri Mar 2009 A1
20090066839 Jung et al. Mar 2009 A1
20090097644 Haruki Apr 2009 A1
20090132599 Soroushian et al. May 2009 A1
20090132721 Soroushian et al. May 2009 A1
20090132824 Terada et al. May 2009 A1
20090136216 Soroushian et al. May 2009 A1
20090150557 Wormley et al. Jun 2009 A1
20090168795 Segel et al. Jul 2009 A1
20090169181 Priyadarshi et al. Jul 2009 A1
20090172201 Carmel et al. Jul 2009 A1
20090178090 Oztaskent Jul 2009 A1
20090196139 Bates et al. Aug 2009 A1
20090201988 Gazier et al. Aug 2009 A1
20090217317 White et al. Aug 2009 A1
20090226148 Nesvadba et al. Sep 2009 A1
20090228395 Wegner et al. Sep 2009 A1
20090290706 Amini et al. Nov 2009 A1
20090290708 Schneider et al. Nov 2009 A1
20090293116 DeMello Nov 2009 A1
20090303241 Priyadarshi et al. Dec 2009 A1
20090307258 Priyadarshi et al. Dec 2009 A1
20090307267 Chen et al. Dec 2009 A1
20090310933 Lee Dec 2009 A1
20090313544 Wood et al. Dec 2009 A1
20090313564 Rottler et al. Dec 2009 A1
20090316783 Au et al. Dec 2009 A1
20090328124 Khouzam et al. Dec 2009 A1
20090328228 Schnell Dec 2009 A1
20100040351 Toma et al. Feb 2010 A1
20100057928 Kapoor et al. Mar 2010 A1
20100058405 Ramakrishnan et al. Mar 2010 A1
20100074324 Qian et al. Mar 2010 A1
20100074333 Au et al. Mar 2010 A1
20100083322 Rouse Apr 2010 A1
20100094969 Zuckerman et al. Apr 2010 A1
20100095121 Shetty et al. Apr 2010 A1
20100106968 Mori et al. Apr 2010 A1
20100107260 Orrell et al. Apr 2010 A1
20100111192 Graves May 2010 A1
20100138903 Medvinsky Jun 2010 A1
20100142917 Isaji Jun 2010 A1
20100158109 Dahlby et al. Jun 2010 A1
20100161825 Ronca et al. Jun 2010 A1
20100166060 Ezure et al. Jul 2010 A1
20100186092 Takechi et al. Jul 2010 A1
20100189183 Gu et al. Jul 2010 A1
20100228795 Hahn Sep 2010 A1
20100235472 Sood et al. Sep 2010 A1
20100250532 Soroushian et al. Sep 2010 A1
20100290761 Drake et al. Nov 2010 A1
20100299522 Khambete et al. Nov 2010 A1
20100306249 Hill et al. Dec 2010 A1
20100313225 Cholas et al. Dec 2010 A1
20100313226 Cholas et al. Dec 2010 A1
20100319014 Lockett et al. Dec 2010 A1
20100319017 Cook Dec 2010 A1
20100332595 Fullagar et al. Dec 2010 A1
20110002381 Yang et al. Jan 2011 A1
20110016225 Park Jan 2011 A1
20110047209 Lindholm et al. Feb 2011 A1
20110055585 Lee Mar 2011 A1
20110060808 Martin et al. Mar 2011 A1
20110066673 Outlaw Mar 2011 A1
20110067057 Karaoguz et al. Mar 2011 A1
20110078440 Feng et al. Mar 2011 A1
20110080940 Bocharov Apr 2011 A1
20110082924 Gopalakrishnan Apr 2011 A1
20110096828 Chen et al. Apr 2011 A1
20110107379 Lajoie et al. May 2011 A1
20110116772 Kwon et al. May 2011 A1
20110126191 Hughes et al. May 2011 A1
20110129011 Cilli et al. Jun 2011 A1
20110135090 Chan Jun 2011 A1
20110138018 Raveendran et al. Jun 2011 A1
20110142415 Rhyu Jun 2011 A1
20110145726 Wei et al. Jun 2011 A1
20110149753 Bapst et al. Jun 2011 A1
20110150100 Abadir Jun 2011 A1
20110153785 Minborg et al. Jun 2011 A1
20110153835 Rimac et al. Jun 2011 A1
20110184738 Kalisky et al. Jul 2011 A1
20110191439 Dazzi et al. Aug 2011 A1
20110191803 Baldwin et al. Aug 2011 A1
20110197237 Turner Aug 2011 A1
20110213827 Kaspar et al. Sep 2011 A1
20110222786 Carmel et al. Sep 2011 A1
20110225302 Park et al. Sep 2011 A1
20110225315 Wexler et al. Sep 2011 A1
20110225417 Maharajh et al. Sep 2011 A1
20110239078 Luby et al. Sep 2011 A1
20110246657 Glow Oct 2011 A1
20110246659 Bouazizi Oct 2011 A1
20110252118 Pantos et al. Oct 2011 A1
20110264530 Santangelo et al. Oct 2011 A1
20110268178 Park Nov 2011 A1
20110276695 Maldaner et al. Nov 2011 A1
20110283012 Melnyk Nov 2011 A1
20110291723 Hashimoto Dec 2011 A1
20110302319 Ha et al. Dec 2011 A1
20110305273 He et al. Dec 2011 A1
20110314176 Frojdh et al. Dec 2011 A1
20110314500 Gordon Dec 2011 A1
20120005368 Knittle et al. Jan 2012 A1
20120023251 Pyle et al. Jan 2012 A1
20120036365 Kyslov et al. Feb 2012 A1
20120036544 Chen et al. Feb 2012 A1
20120093214 Urbach Apr 2012 A1
20120114302 Randall et al. May 2012 A1
20120124191 Lyon May 2012 A1
20120137336 Applegate et al. May 2012 A1
20120144117 Weare et al. Jun 2012 A1
20120144445 Bonta et al. Jun 2012 A1
20120166633 Baumback et al. Jun 2012 A1
20120170642 Braness et al. Jul 2012 A1
20120170643 Soroushian et al. Jul 2012 A1
20120170906 Soroushian et al. Jul 2012 A1
20120170915 Braness et al. Jul 2012 A1
20120173751 Braness et al. Jul 2012 A1
20120177101 van der Schaar Jul 2012 A1
20120179834 van der Schaar Jul 2012 A1
20120201475 Carmel et al. Aug 2012 A1
20120201476 Carmel et al. Aug 2012 A1
20120233345 Hannuksela Sep 2012 A1
20120240176 Ma et al. Sep 2012 A1
20120254455 Adimatyam et al. Oct 2012 A1
20120260277 Kosciewicz Oct 2012 A1
20120263434 Wainner et al. Oct 2012 A1
20120265562 Daouk et al. Oct 2012 A1
20120278496 Hsu Nov 2012 A1
20120289147 Raleigh et al. Nov 2012 A1
20120294355 Holcomb et al. Nov 2012 A1
20120297039 Acuna et al. Nov 2012 A1
20120307883 Graves Dec 2012 A1
20120311094 Biderman et al. Dec 2012 A1
20120314778 Salustri et al. Dec 2012 A1
20130007223 Luby et al. Jan 2013 A1
20130013730 Li et al. Jan 2013 A1
20130019107 Grab et al. Jan 2013 A1
20130019273 Ma et al. Jan 2013 A1
20130041808 Pham et al. Feb 2013 A1
20130044821 Braness et al. Feb 2013 A1
20130046849 Wolf Feb 2013 A1
20130046902 Villegas Nuñez et al. Feb 2013 A1
20130051554 Braness Feb 2013 A1
20130054958 Braness et al. Feb 2013 A1
20130055084 Soroushian et al. Feb 2013 A1
20130058480 Ziskind et al. Mar 2013 A1
20130061040 Kiefer et al. Mar 2013 A1
20130061045 Kiefer et al. Mar 2013 A1
20130064466 Carmel et al. Mar 2013 A1
20130094565 Yang et al. Apr 2013 A1
20130097309 Ma et al. Apr 2013 A1
20130114944 Soroushian et al. May 2013 A1
20130128962 Rajagopalan et al. May 2013 A1
20130152767 Katz et al. Jun 2013 A1
20130166580 Maharajh Jun 2013 A1
20130166765 Kaufman Jun 2013 A1
20130166906 Swaminathan et al. Jun 2013 A1
20130170561 Hannuksela Jul 2013 A1
20130170764 Carmel et al. Jul 2013 A1
20130173513 Chu et al. Jul 2013 A1
20130179199 Ziskind et al. Jul 2013 A1
20130179992 Ziskind et al. Jul 2013 A1
20130182952 Carmel et al. Jul 2013 A1
20130196292 Brennen et al. Aug 2013 A1
20130212228 Butler Aug 2013 A1
20130223812 Rossi Aug 2013 A1
20130226578 Bolton et al. Aug 2013 A1
20130226635 Fisher Aug 2013 A1
20130227122 Gao Aug 2013 A1
20130311670 Tarbox et al. Nov 2013 A1
20130329781 Su et al. Dec 2013 A1
20140003516 Soroushian Jan 2014 A1
20140037620 Ferree et al. Feb 2014 A1
20140052823 Gavade et al. Feb 2014 A1
20140059156 Freeman, II et al. Feb 2014 A1
20140101722 Moore Apr 2014 A1
20140119432 Wang et al. May 2014 A1
20140140396 Wang et al. May 2014 A1
20140140417 Shaffer et al. May 2014 A1
20140143301 Watson et al. May 2014 A1
20140143431 Watson et al. May 2014 A1
20140143440 Ramamurthy et al. May 2014 A1
20140177734 Carmel et al. Jun 2014 A1
20140189065 van der Schaar et al. Jul 2014 A1
20140201382 Shivadas et al. Jul 2014 A1
20140211840 Butt et al. Jul 2014 A1
20140211859 Carmel et al. Jul 2014 A1
20140241420 Orton-jay et al. Aug 2014 A1
20140241421 Orton-jay et al. Aug 2014 A1
20140247869 Su Sep 2014 A1
20140250473 Braness et al. Sep 2014 A1
20140258714 Grab Sep 2014 A1
20140269927 Naletov et al. Sep 2014 A1
20140269936 Shivadas et al. Sep 2014 A1
20140280763 Grab et al. Sep 2014 A1
20140297804 Shivadas et al. Oct 2014 A1
20140297881 Shivadas et al. Oct 2014 A1
20140355668 Shoham et al. Dec 2014 A1
20140359678 Shivadas et al. Dec 2014 A1
20140359679 Shivadas et al. Dec 2014 A1
20140359680 Shivadas et al. Dec 2014 A1
20140376720 Chan et al. Dec 2014 A1
20150006662 Braness Jan 2015 A1
20150026677 Stevens et al. Jan 2015 A1
20150049957 Shoham et al. Feb 2015 A1
20150063693 Carmel et al. Mar 2015 A1
20150104153 Braness et al. Apr 2015 A1
20150117836 Amidei et al. Apr 2015 A1
20150117837 Amidei et al. Apr 2015 A1
20150139419 Kiefer et al. May 2015 A1
20150188758 Amidei et al. Jul 2015 A1
20150188842 Amidei et al. Jul 2015 A1
20150188921 Amidei et al. Jul 2015 A1
20150189017 Amidei et al. Jul 2015 A1
20150189373 Amidei et al. Jul 2015 A1
20150288996 Van Der Schaar et al. Oct 2015 A1
20150334435 Shivadas et al. Nov 2015 A1
20150373421 Chan Dec 2015 A1
20160070890 Grab et al. Mar 2016 A1
20160112382 Kiefer et al. Apr 2016 A1
20160149981 Shivadas et al. May 2016 A1
20160219303 Braness et al. Jul 2016 A1
Foreign Referenced Citations (110)
Number Date Country
1169229 Dec 1997 CN
1221284 Jun 1999 CN
1723696 Jan 2006 CN
757484 Feb 1997 EP
813167 Dec 1997 EP
0936812 Aug 1999 EP
1056273 Nov 2000 EP
1420580 May 2004 EP
1553779 Jul 2005 EP
1657835 May 2006 EP
1718074 Nov 2006 EP
2486517 Aug 2012 EP
2486727 Aug 2012 EP
2507995 Oct 2012 EP
2564354 Mar 2013 EP
2616991 Jul 2013 EP
2617192 Jul 2013 EP
2716048 Apr 2014 EP
2721826 Apr 2014 EP
2751990 Jul 2014 EP
2807821 Dec 2014 EP
08046902 Feb 1996 JP
8111842 Apr 1996 JP
1996163488 Jun 1996 JP
08287613 Nov 1996 JP
09037225 Feb 1997 JP
11164307 Jun 1999 JP
11275576 Oct 1999 JP
11328929 Nov 1999 JP
2000201343 Jul 2000 JP
2001043668 Feb 2001 JP
2001346165 Dec 2001 JP
2002170363 Jun 2002 JP
2002518898 Jun 2002 JP
2002218384 Aug 2002 JP
2003250113 Sep 2003 JP
2004013823 Jan 2004 JP
2004515941 May 2004 JP
2004172830 Jun 2004 JP
2004187161 Jul 2004 JP
2004234128 Aug 2004 JP
2005027153 Jan 2005 JP
2005080204 Mar 2005 JP
2006524007 Oct 2006 JP
2007036666 Feb 2007 JP
2007174375 Jul 2007 JP
2007235690 Sep 2007 JP
2007535881 Dec 2007 JP
2008235999 Oct 2008 JP
2014506430 Mar 2014 JP
100221423 Jun 1999 KR
2002013664 Feb 2002 KR
1020020064888 Aug 2002 KR
669616 Sep 2007 KR
9515660 Jun 1995 WO
9613121 May 1996 WO
9731445 Apr 1998 WO
9910836 Mar 1999 WO
9965239 Dec 1999 WO
0131497 May 2001 WO
0150732 Jul 2001 WO
0165762 Sep 2001 WO
0201880 Jan 2002 WO
0208948 Jan 2002 WO
0235832 May 2002 WO
0237210 May 2002 WO
02054196 Jul 2002 WO
2004054247 Jun 2004 WO
2004097811 Nov 2004 WO
2004102571 Nov 2004 WO
2006018843 Feb 2006 WO
2006018843 Dec 2006 WO
2007044590 Apr 2007 WO
2007113836 Oct 2007 WO
2008010275 Jan 2008 WO
2008042242 Apr 2008 WO
2007113836 Nov 2008 WO
2008135932 Nov 2008 WO
2009065137 May 2009 WO
2010060106 May 2010 WO
2010080911 Jul 2010 WO
2010089962 Aug 2010 WO
2010122447 Oct 2010 WO
2010147878 Dec 2010 WO
2011042898 Apr 2011 WO
2011042900 Apr 2011 WO
2011068668 Jun 2011 WO
2011103364 Aug 2011 WO
2011132184 Oct 2011 WO
2011135558 Nov 2011 WO
2012035533 Mar 2012 WO
2012035534 Mar 2012 WO
2012035534 Jul 2012 WO
2012094171 Jul 2012 WO
2012094181 Jul 2012 WO
2012094189 Jul 2012 WO
2012035533 Aug 2012 WO
2012162806 Dec 2012 WO
2012171113 Dec 2012 WO
2013030833 Mar 2013 WO
2013032518 Mar 2013 WO
2013032518 Mar 2013 WO
2013103986 Jul 2013 WO
2013111126 Aug 2013 WO
2013111126 Aug 2013 WO
2013144942 Oct 2013 WO
2014145901 Sep 2014 WO
2014193996 Dec 2014 WO
2014193996 Dec 2014 WO
2015031982 Mar 2015 WO
Non-Patent Literature Citations (149)
Entry
Microsoft, Microsoft Media Platform: Player Framework, “Microsoft Media Platform: Player Framework v2.5 (formerly Silverlight Media Framework)”, printed on Apr. 18, 2014, 2 pgs.
Morrison, “EA IFF 85” Standard for Interchange Format Files, Jan. 14, 1985, printed from http://www.dcs.ed.ac.uk/home/mxr/gfx/2d/IFF.txt on Mar. 6, 2006, 24 pgs.
Office Action for U.S. Appl. No. 13/223,210, dated Apr. 30, 2015, 14 pgs.
Office Action for U.S. Appl. No. 14/564,003, dated Apr. 17, 2015, 28 pgs.
Open DML AVI-M-JPEG File Format Subcommittee, “Open DML AVI File Format Extensions”, Version 1.02, Feb. 28, 1996, 29 pgs.
PC World.com, “Future Gear: PC on the HiFi, and the TV”, from http://www.pcworld.com/article/id,108818-page,1/article.html, Jan. 21, 2003, printed May 4, 2007, from IDG Networks, 2 pgs.
Qtv—About BroadQ, “Overview”, printed May 11, 2009 from http://www.broadq.com/en/about.php, 1 pg.
TAXAN, “A Vel LinkPlayer2 for Consumer”, I-O Data USA—Products—Home Entertainment, printed May 4, 2007 from http://www.iodata.com/usa/products/products.php?cat=HNP&sc=AVEL&pld=AVLP2/DVDLA&ts=2&tsc, 1 pg.
The Official Microsoft IIS Site, “Smooth Streaming Client”, printed on Apr. 18, 2014, 4 pages.
“Windows Media Center Extender for Xbox”, printed May 9, 2007 from http://www.xbox.com/en-US/support/systemuse/xbox/console/mediacenterextender.htm, 2 pgs.
Windows® XP Media Center Edition 2005, “Experience more entertainment”, retrieved from http://download.microsoft.com/download/c/9/a/c9a7000a-66b3-455b-860b-1c16f2eecfec/MCE.pdf on May 9, 2007, 2 pgs.
I-O Data, Innovation of technology arrived, from http://www.iodata.com/catalogs/AVLP2DVDLA—Flyer200505.pdf, 2 pgs.
“Adaptive Streaming Comparison”, Jan. 28, 2010, 5 pgs.
“Best Practices for Multi-Device Transcoding”, Kaltura Open Source Video, Printed on Nov. 27, 2013 from knowledge.kaltura.com/best-practices-multi-device-transcoding, 13 pgs.
“Container format (digital)”, printed Aug. 22, 2009 from http://en.wikipedia.org/wiki/Container—format—(digital), 4 pgs.
“Diagram | Matroska”, Retrieved from the Internet: URL:http://web.archive.org/web/201 01217114656/http:l/matroska.org/technical/diagram/index.html [retrieved on Jan. 29, 2016], Dec. 17, 2010, 5 pgs.
“DVD—MPeg differences”, printed Jul. 2, 2009 from http://dvd.sourceforge.net/dvdinfo/dvdmpeg.html, 1 pgs.
“DVD subtitles”, sam.zoy.org/writings/dvd/subtitles, dated Jan. 9, 2001, printed Jul. 2, 2009, 4 pgs.
“Final Committee Draft of MPEG-4 streaming text format”, International Organisation for Standardisation, Feb. 2004, 22 pgs.
“IBM Spearheading Intellectual Property Protection Technology for Information on the Internet; Cryptolope Containers Have Arrived”, May 1, 1996, Business Wire, Printed on Aug. 1, 2014 from http://www.thefreelibrary.com/IBM+Spearheading+Intellectual+Property+Protection+Technology+for . . . -a018239381, 6 pg.
“Information Technology—Coding of audio-visual objects—Part 17: Streaming text”, International Organisation for Standardisation, Feb. 2004, 22 pgs.
“Information technology—Coding of audio-visual objects—Part 18: Font compression and streaming”, ISO/IEC 14496-18, First edition Jul. 1, 2004, 26 pgs.
“Matroska Streaming | Matroska”, Retrieved from the Internet: URL:http://web.archive.org/web/201 0121711431 O/http://matroska.org/technical!streaming/index.html [retrieved on Jan. 29, 2016], Dec. 17, 2010, 2 pgs.
“Netflix turns on subtitles for PC, Mac streaming”, Printed Mar. 26, 2014, 3 pgs.
“QCast Tuner for PS2”, printed May 11, 2009 from http://web.archive.org/web/20030210120605/www.divx.com/software/detail.php? ie=39, 2 pgs.
“Specifications | Matroska”, Retrieved from the Internet: URL:http://web.archive.org/web/201 00706041303/http:/1www.matroska.org/technical/specs/index.html [retrieved on Jan. 29, 2016], 14 pgs.
“Supported Media Formats”, Supported Media Formats, Android Developers, Printed on Nov. 27, 2013 from developer.android.com/guide/appendix/media-formats.html, 3 pgs.
“Text of ISO/IEC 14496-18/COR1”, ITU Study Group 16—Video Coding Experts Group—ISO/IEC MPEG & ITU-T VCEG(ISO/IEC JTC1/SC29/WG11 and ITU-T SG16 06), No. N8664, Oct. 27, 2006, 8 pgs.
“Text of ISO/IEC 14496-18/FDIS”, ITU Study Group 16—Videocoding Experts Group—ISO/IEC MPEG & ITU-T VCEG(ISO/IEC JTC1/SC29/WG11 and ITU-T SG16 06), No. N6215, Jan. 7, 2004, 26 pgs.
“Thread: SSME (Smooth Streaming Medial Element) config.xml review (Smooth Streaming Client configuration file)”, Printed on Mar. 26, 2014, 3 pgs.
“Transcoding Best Practices”, From movideo, Printed on Nov. 27, 2013 from code.movideo.com/Transcoding—Best—Practices, 5 pgs.
“Using HTTP Live Streaming”, iOS Developer Library, Retrieved from: http://developer.apple.com/library/ios/#documentation/networkinginternet/conceptual/streamingmediaguide/UsingHTTPLiveStreaming/UsingHTTPLiveStreaming.html#//apple—ref/doc/uid/TP40008332—CH102—SW1, printed on Jun. 5, 2014, 10 pgs.
“Video Manager and Video Title Set IFO file headers”, printed Aug. 22, 2009 from http://dvd.sourceforge.net/dvdinfo/ifo.htm, 6 pgs.
“What is a DVD?”, printed Aug. 22, 2009 from http://www.videohelp.com/dvd, 8 pgs.
“What is a VOB file”, http://www.mpucoder.com/DVD/vobov.html, printed on Jul. 2, 2009, 2 pgs.
“What's on a DVD?”, printed Aug. 22, 2009 from http://www.doom9.org/dvd-structure.htm, 5 pgs.
Akhshabi et al., “An Experimental Evaluation of Rate-Adaptation Algorithms in Adaptive Streaming over HTTP”, MMSys'11, Feb. 23-25, 2011, 12 pgs.
Anonymous, “Method for the encoding of a compressed video sequence derived from the same video sequence compressed at a different bit rate without loss of data”, ip.com, ip.com No. IPCOM000008165D, May 22, 2002, pp. 1-9.
Author Unknown, “Blu-ray Disc—Blu-ray Disc—Wikipedia, the free encyclopedia”, printed Oct. 30, 2008 from http://en.wikipedia.org/wiki/Blu-ray—Disc, 11 pgs.
Author Unknown, “Blu-ray Movie Bitrates Here—Blu-ray Forum”, printed Oct. 30, 2008 from http://forum.blu-ray.com/showthread.php?t=3338, 6 pgs.
“IBM Closes Cryptolopes Unit,” Dec. 17, 1997, CNET News, Printed on Apr. 25, 2014 from http://news.cnet.com/IBM-closes-Cryptolopes-unit/2100-1001—3206465.html, 3 pages.
“Information Technology—Coding of Audio Visual Objects—Part 2: Visual” International Standard, ISO/IEC 14496-2, Third Edition, Jun. 1, 2004, pp. 1-724 (presented in three parts).
“OpenDML AVI File Format Extensions,” Sep. 1997, Version 1.02, XP-002179318, OpenDML AVI M-JPEG File Format Subcommittee, 42 pgs.
Broadq—The Ultimate Home Entertainment Software, printed May 11, 2009 from ittp://web.srchive.org/web/20030401122010/www.broadq.com/qcasttuner/, 1 pg.
Cloakware Corporation, “Protecting Digital Content Using Cloakware Code Transformation Technology”, Version 1.2, May 2002, pp. 1-10.
Extended European Search Report Application No. EP10821672, completed Jan. 30, 2014, 3 pgs.
Extended European Search Report Application No. EP11824682, completed Feb. 6, 2014. 4 pgs.
European Search Report Application No. EP 08870152, Completed May 19, 2011, Mailed May 26, 2011, 9 pgs.
European Search Report for Application 11855103.5, completed Jun. 26, 2014, 9 pgs.
European Search Report for Application 11855237.1, completed Jun. 12, 2014, 9 pgs.
European Supplementary Search Report for Application EP09759600, completed Jan. 25, 2011, 11 pgs.
Extended European Search Report for European Application No. 14763140.2, Search completed Sep. 26, 2016, Mailed Oct. 5, 2016, 9 Pgs.
Supplementary European Search Report for Application No. EP 10729513, International Filing Date Jan. 7, 2010, Search Completed Dec. 9, 2013, 4 pgs.
Supplementary European Search Report for EP Application 11774529, completed Jan 31, 2014, 2 pgs.
Supplementary European Search Report for Application No. EP 04813918, Search Completed Dec. 19, 2002, 3 pgs.
Supplementary European Search Report for Application No. EP 10834935, Completed May 27, 2014, 9 pgs.
Federal Computer Week, “Tool Speeds Info to Vehicles”, Jul. 25, 1999, 5 pages.
Griffith, Eric, “The Wireless Digital Picture Fram Arrives”, Wi-Fi Planet, printed May 4, 2007 from http://www.wi-fiplanet.com/news/article.php/3093141, 3 pgs.
“HTTP Live Streaming Overview, Networking & Internet”, Apple, Inc., Apr. 1, 2011, 38 pages.
IBM Corporation and Microsoft Corporation, “Multimedia Programming Interface and Data Specifications 1.0”, Aug. 1991, printed from http://www.kk.iij4u.or.jp/˜kondo/wave/mpidata.txt on Mar. 6, 2006, 100 pgs.
Informationweek: Front End: Daily Dose, “Internet on Wheels”, Jul. 20, 1999, Printed on Mar. 26, 2014, 3 pgs.
International Preliminary Report on Patentability for International Application PCT/US14/30747, Report Issued Sep. 15, 2015, Mailed Sep. 24, 2015, 6 Pgs.
International Preliminary Report on Patentability for International Application No. PCT/US2011/068276, International Filing Date Dec. 31, 2011, Issue Date Mar. 4, 2014, 23 pgs.
International Preliminary Report on Patentability for International Application PCT/US2013/043181, Report issued Dec. 31, 2014, Mailed Jan. 8, 2015, 11 Pgs.
International Preliminary Report on Patentability for International Application PCT/US2014/039852 , Report issued Dec. 1, 2015, Mailed Dec. 5, 2015, 8 Pgs.
International Search Report and Written Opinion for International Application No. PCT/US08/87999, completed Feb. 7, 2009, mailed Mar. 19, 2009, 6 pgs.
International Search Report and Written Opinion for International Application No. PCT/US09/46588, completed Jul. 14, 2009, mailed Jul. 23, 2009, 7 pgs.
International Search Report and Written Opinion for International Application No. PCT/US2004/041667, Completed May 24, 2007, Mailed Jun. 20, 2007, 6 pgs.
International Search Report and Written Opinion for International Application No. PCT/US2005/025845, completed Feb. 5, 2007 and mailed May 10, 2007, 6 pgs.
International Search Report and Written Opinion for International Application No. PCT/US2008/083816, completed Jan. 10, 2009, mailed Jan. 22, 2009, 7 pgs.
International Search Report and Written Opinion for International Application No. PCT/US2010/56733, Completed Jan. 3, 2011, Mailed Jan. 14, 2011, 9 pgs.
International Search Report and Written Opinion for International Application No. PCT/US2013/043181, International Filing Date May 29, 2013, Search Completed Nov. 27, 2013, Mailed Dec. 6, 2013, 12 pgs.
International Search Report and Written Opinion for International Application PCT/US14/39852, Report Completed Oct. 21, 2014, Mailed Dec. 5, 2014, 11 pgs.
International Search Report and Written Opinion for International Application PCT/US2011/066927, International Filing Date Dec. 22, 2011, Report Completed Apr. 3, 2012, Mailed Apr. 20, 2012, 14 pgs.
International Search Report and Written Opinion for International Application PCT/US2011/067167, International Filing Date Dec. 23, 2011, Report Completed Jun. 19, 2012, Mailed Jul. 2, 2012, 11 pgs.
International Search Report and Written Opinion for International Application PCT/US2011/068276, International Filing Date Dec. 31, 2011, Report completed Jun. 19, 2013, Mailed Jul. 8, 2013, 24 pgs.
International Search Report and Written Opinion for PCT/US2013/020572, International Filing Date Jan. 7, 2013, Search Completed Mar. 19, 2013, Mailed Apr. 29, 2013, 10 pgs.
International Search Report and Written Opinion for International Application No. PCT/US07/63950, completed Feb. 19, 2008; mailed Mar. 19, 2008, 9 pgs.
International Search Report and Written Opinion for International Application PCT/US14/30747, report completed Jul. 30, 2014, Mailed Aug. 22, 2014, 7 Pgs.
International Search Report and Written Opinion for International Application PCT/US2010/020372, report completed Feb. 10, 2009, Search Report mailed Mar. 1, 2010, 7 pgs.
ITS International, “Fleet System Opts for Mobile Server”, Aug. 26, 1999, Printed on Mar. 26, 2014 from http://www.itsinternational.com/News/article.cfm?recordID=547, 2 pages.
10 KISS Players, “KISS DP-500”, printed from http://www.kiss-technology.com/?p=dp500 on May 4, 2007, 1 pg.
Lifehacker, “Boxqueue Bookmarklet Saves Videos for Later Boxee Watching”, Jun. 15, 2009, printed Jun. 16, 2009 from http://feeds.gawker.com/˜r/lifehacker/full/˜3/OHvDmrIgZZc/boxqueue-bookmarklet-saves-videos-for-late-boxee-watching, 2 pgs.
“Linksys Wireless-B Media Adapter Reviews”, printed May 4, 2007 from http://reviews.cnet.com/Linksys—Wireless—B—Media—Adapter/4505-6739—7-30421900.html?tag=box, 5 pgs.
Linksys, “KISS DP-500”, printed May 4, 2007 from http://www.kiss-technology.com/?p=dp500, 2 pgs.
Linksys®, “Enjoy your digital music and pictures on your home entertainment center, without stringing wires!”, Model No. WMA 11B, printed May 9, 2007 from http://www.linksys.com/servlet/Satellite?c=L—Product—C2&childpagename=US/Layout&cid=1115416830950&p, 4 pgs.
Microsoft Corporation, “Chapter 8, Multimedia File Formats” 1991, Microsoft Windows Multimedia Programmer's Reference, 3 cover pgs., pp. 8-1 to 8-20.
Microsoft Windows® XP Media Center Edition 2005, “Frequently asked Questions”, printed May 4, 2007 from http://www.microsoft.com/windowsxp/mediacenter/evaluation/faq.mspx, 6 pgs.
Microsoft Windows® XP Media Center Edition 2005, “Features”, printed May 9, 2007, from http://www.microsoft.com/windowsxp/mediacenter/evaluation/features.mspx, 4 pgs.
Microsoft, Microsoft Media Platform: Player Framework, “Silverlight Media Framework v1.1”, printed on Apr. 18, 2014, 2 pages.
Author Unknown, “O'Reilly—802.11 Wireless Networks: The Definitive Guide, Second Edition”, printed Oct. 30, 2008 from http://oreilly.com/catalog/9780596100520, 2 pgs.
Author Unknown, “Tunneling QuickTime RTSP and RTP over HTTP”, Published by Apple Computer, Inc.: 1999 (month unknown) 6 pages.
Author Unknown, “Turbo-Charge Your Internet and PC Performance”, printed Oct. 30, 2008 from Speedtest.net—The Global Broadband Speed Test, 1 pg.
Author Unknown, “When is 54 Not Equal to 54? A Look at 802.11a, b and g Throughput”, printed Oct. 30, 2008 from www.oreillynet.com/pub/a/wireless/2003/08/08/wireless—throughput.html, Aug. 8, 2003, 4 pgs.
Author Unknown, “White paper, The New Mainstream Wireless LAN Standard”, Broadcom Corporation, Jul. 2003, 12 pgs.
Blasiak, Ph.D., Darek, “Video Transrating and Transcoding: Overview of Video Transrating and Transcoding Technologies,”, Ingenient Technologies, TI Developer Conference, Aug. 6-8, 2002, 22 pgs.
Casares et al., “Simplifying Video Editing Using Metadata”, DIS2002, 2002, pp. 157-166.
Deutscher, “IIS Transform Manager Beta—Using the MP4 to Smooth Task”, Retrieved from: https://web.archive.org/web/20130328111303/http://blog.johndeutscher.com/category/smooth-streaming, Blog post of Apr. 29, 2011, 14 pgs.
Gannes, “The Lowdown on Apple's HTTP Adaptive Bitrate Streaming”, GigaOM, Jun. 10, 2009, 12 pgs.
Garg et al., “An Experimental Study of Throughput for UDP and VoIP Traffic in IEEE 802.11b Networks”, Wireless Communications and Networkings, Mar. 2003, pp. 1748-1753.
Ghosh, “Enhancing Silverlight Video Experiences with Contextual Data”, Retrieved from: http://msdn.microsoft.com/en-us/magazine/ee336025.aspx on Mar. 26, 2014, 3 pgs.
Inlet Technologies, “Adaptive Delivery to iDevices”, printed on Jun. 5, 2014, 2 pages.
Inlet Technologies, “Adaptive delivery to iPhone 3.0”, printed on Mar. 20, 2014, 2 pgs.
Inlet Technologies, “HTTP versus RTMP”, printed on Jun. 5, 2014, 3 pages.
Inlet Technologies, “The World's First Live Smooth Streaming Event: The French Open”, printed on Jun. 5, 2014, 2 pages.
Kaspar et al., “Using HTTP Pipelining to Improve Progressive Download over Multiple Heterogeneous Interfaces”, IEEE ICC proceedings, 2010, 5 pgs.
Kim, Kyuheon, “MPEG-2 ES/PES/TS/PSI”, Kyung-Hee University, Oct. 4, 2010, 66 pages.
Kozintsev et al., “Improving last-hop multicast streaming video over 802.11”, Workshop on Broadband Wireless Multimedia, Oct. 2004, pp. 1-10.
Kurzke et al., “Get Your Content Onto Google TV”, Google, Retrieved from: http://commondatastorage.googleapis.com/io2012/presentations/live%20to%20website/1300.pdf, printed on Jun. 5, 2014, 58 pgs.
Lang, “Expression Encoder, Best Practices for live smooth streaming broadcasting”, Microsoft Corporation, 20 pgs.
Levkov, “Mobile Encoding Guidelines for Android Powered Devices”, Adobe Systems Inc., Addendum B, printed on Dec. 22, 2010, 42 pgs.
Long et al., “Silver: Simplifying Video Editing with Metadata”, Demonstrations, CHI 2003: New Horizons, pp. 628-629.
MSDN, “Adaptive streaming, Expression Studio 2.0”, printed on Mar. 20, 2014, 2 pgs.
Nelson, “Arithmetic Coding + Statistical Modeling = Data Compression: Part 1—Arithmetic Coding”, Doctor Dobb's Journal, Feb. 1991, USA, pp. 1-12.
Nelson, “Smooth Streaming Deployment Guide”, Microsoft Expression Encoder, Aug. 2010, 66 pgs.
Nelson, Michael “IBM's Cryptolopes”, Complex Objects in Digital Libraries Course, Spring 2001, Retrieved from http://www.cs.odu.edu/˜mln/teaching/unc/inls210/?method=display&pkg—name=cryptolopes.pkg&element—name=cryptolopes.ppt, 12 pages.
Noboru, Takematsu, “Play Fast and Fine Video on Web! codec”, Co.9 No. 12, Dec. 1, 2003, 178-179.
Noe, A. “Matroska File Format (under construction!)”, Retrieved from the Internet: URL:http://web.archive.orgweb/20070821155146/www.matroska.org/technical/specs/matroska.pdf [retrieved on Jan. 19, 2011], Jun. 24, 2007, 1-51.
Noe, Alexander, “AVI File Format”, http://www.alexander-noe.com/video/documentation/avi.pdf, pp. 1-26.
Noe, Alexander, “Definitions”, http://www.alexander-noe.com/video/amg/definitions.html, Apr. 11, 2006.
Ooyala, “Widevine Content Protection”, Ooyala Support Center for Developers. Ooyala, Inc., 2013. Jun. 3, 2013. http://support.ooyala.com/developers/documentation/concepts/player—v3—widevine—integration.html, 7 pgs.
Ozer, “The 2012 Encoding and Transcoding Buyers' Guide”, Streamingmedia.com, Retrieved from: http://www.streamingmedia.com/Articles/Editorial/Featured-Articles/The-2012-Encoding-and-Transcoding-Buyers-Guide-84210.aspx, Aug./Sep. 2012, 8 pgs.
Pantos, “HTTP Live Streaming, draft-pantos-http-live-streaming—10”, IETF Tools, Oct. 15, 2012, Retrieved from: http://tools.ietf.org/html/draft-pantos-http-live-streaming-10, 37 pgs.
Pantos, R, “HTTP Live Streaming: draft-pantos-http-live-streaming—06”, Published by the Internet Engineering Task Force (IETF), Mar. 31, 2011, 24 pages.
Papagiannaki et al., “Experimental Characterization of Home Wireless Networks and Design Implications”, Infocom 2006, 25th IEEE International Conference of Computer Communications, Proceedings, Apr. 2006, 13 pgs.
Phamdo, Nam, “Theory of Data Compression”, printed from http://www.data-compression.com/theoroy.html on Oct. 10, 2003, 12 pgs.
RGB Networks, “Comparing Adaptive HTTP Streaming Technologies”, Nov. 2011, Retrieved from: http://btreport.net/wp-content/uploads/2012/02/RGB-Adaptive-HTTP-Streaming-Comparison-1211-01.pdf, 20 pgs.
Schulzrinne, H et al., “Real Time Streaming Protocol 2.0 (RTSP): draft-ietfmmusic-rfc2326bis-27”, MMUSIC Working Group of the Internet Engineering Task Force (IETF), Mar. 9, 2011, 296 pages (presented in two parts).
Siglin, “HTTP Streaming: What You Need to Know”, streamingmedia.com, 2010, 15 pages.
Siglin, “Unifying Global Video Strategies, MP4 File Fragmentation for Broadcast, Mobile and Web Delivery”, Nov. 16, 2011, 16 pgs.
Tan, Yap-Peng et al., “Video transcoding for fast forward/reverse video playback”, IEEE ICIP, 2002, pp. I-713 to I-716.
Unknown, “AVI RIFF File Reference (Direct X 8.1 C++ Archive)”, printed from http://msdn.microsoft.com/archive/en-us/dx81—c/directx—cpp/htm/avirifffilereference.asp?fr . . . on Mar. 6, 2006, 7 pgs.
Unknown, “Entropy and Source Coding (Compression)”, TCOM 570, 1999, pp. 1-22.
Unknown, “MPEG-4 Video Encoder: Based on International Standard ISO/IED 14496-2”, Patni Computer Systems, Ltd., printed Jan. 24, 2007, USA, pp. 1-15.
Wang et al., “Image Quality Assessment: From Error Visibility to Structural Similarity”, IEEE Transactions on Image Processing, Apr. 2004, vol. 13, No. 4, pp. 600-612.
Wu, Feng et al., “Next Generation Mobile Multimedia Communications: Media Codec and Media Transport Perspectives”, In China Communications, Oct. 2006, pp. 30-44.
Zambelli, Alex, “IIS Smooth Streaming Technical Overview”, Microsoft Corporation, Mar. 2009, 17 pgs.
“MovieLabs Specification for Next Generation Video—Version 1.0”, Motion Picture Laboratories, Inc. Retrieved from: http://movielabs.com/ngvideo/MovieLabs%20Specification%20for%20Next%20Generation%20Video%20v1.0.pdf, 5 pgs.
Bross et al., “High Efficiency Video Coding (HEVC) text specification draft 10 (for FDIS & Last Call)”, 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: JCTVC-L1003—v34, 12th Meeting: Geneva, CH, Jan. 14-23, 2013.
“Information Technology—Coding of audio-visual objects—Part 14: MP4 file format”, International Standard, ISO/IEC 14496-14, First Edition, Nov. 15, 2003, 18 pages.
“Information technology—Generic coding of moving pictures and associated audio information: Systems”, International Standard ISO/IEC 13818-1, Second Edition, Dec. 1, 2000, 174 pages.
“Information-Technology—Generic coding of moving pictures and associated audio: Systems, Recommendation H.222.0”, International Standard, ISO/IEC 13818-1, Draft 1209, Apr. 25, 1995, 151 pages.
“Information-Technology—Generic coding of moving pictures and associated audio: Systems, Recommendation H.222.0”, International Standard, ISO/IEC 13818-1, Draft 1540, Nov. 13, 1994, 161 pages.
“Matroska”, Wikipedia, Jul. 10, 2017, retrieved from https://en.wikipedia.org/wiki/Matroska on Jul. 20, 2017, 3 pages.
“MPEG-2”, Wikipedia, Jun. 13, 2017, retrieved from https://en.wikipedia.org/wiki/MPEG-2 on Jul. 20, 2017, 13 pages.
“MPEG-4 Part 14”, Wikipedia, Jul. 10, 2017, retrieved from https://en.wikipedia.org/wiki/MPEG-4—Part—14 on Jul. 20, 2017, 5 pages.
“Series H: Audiovisual and Multimedia Systems Infrastructure of audiovisual services—Coding of moving video; High efficiency video coding”, International Telecommunication Union, ITU-T H.265, Apr. 2015, 634 pages.
Matroska, “Diagram”, Matroska, Technical/Info, Diagram, 2016, retrieved from https://www.matroska.org/technical/diagram/index.html on Jul. 20, 2017, 9 pages.
Matroska, “Specifications”, Matroska, Technical/Info, Specifications, Jun. 25, 2017, https://www.matroska.org/technical/specs/index.html on Jul. 20, 2017, 20 pages.
Related Publications (1)
Number Date Country
20150288996 A1 Oct 2015 US
Provisional Applications (1)
Number Date Country
61975789 Apr 2014 US