Method and apparatus for encoding video and method and apparatus for decoding video by considering skip and split order
US-9225987-B2 · Dec 29, 2015 · US
US10659513B2 · US · B2
| Field | Value |
|---|---|
| Publication number | US-10659513-B2 |
| Application number | US-201816004056-A |
| Country | US |
| Kind code | B2 |
| Filing date | Jun 8, 2018 |
| Priority date | Apr 30, 2004 |
| Publication date | May 19, 2020 |
| Grant date | May 19, 2020 |
A practical reading order for non-experts. Skip the full description unless you need deep technical detail.
What the patent document calls the invention.
A short plain-language summary of the technical disclosure.
Who owns or filed the patent and who is credited as inventor.
Filing, priority, publication, and grant dates set the timeline.
The legal scope of protection — read this for what is actually claimed.
Technology tags used to group this patent with similar filings.
Prior art links and similar publications in this corpus.
Official abstract text for this publication.
An apparatus for multi-bitrate content streaming includes a receiving module configured to capture media content, a streamlet module configured to segment the media content and generate a plurality of streamlets, and an encoding module configured to generate a set of streamlets. The system includes the apparatus, wherein the set of streamlets comprises a plurality of streamlets having identical time indices and durations, and each streamlet of the set of streamlets having a unique bitrate, and wherein the encoding module comprises a master module configured to assign an encoding job to one of a plurality of host computing modules in response to an encoding job completion bid. A method includes receiving media content, segmenting the media content and generating a plurality of streamlets, and generating a set of streamlets.
Opening claim text (preview).
What is claimed is: 1. A system for adaptive-rate content streaming of video playable on an end user station, the system comprising: a storage device to store a plurality of different copies of a same single video, each of the different copies encoded at a different bit rate and each of the different copies divided into a plurality of streamlets that collectively store data capable of playback of the entire single video but that individually store data to playback only a portion of the single video that starts at a unique start time during playback and that has a duration that is less than the entire playback duration of the single video, wherein the start times of the streamlets are the same for the different copies of the single video such that the streamlets with the same start times from the different copies independently represent the same portions of the single video, and a web server configured to: receive, for a each start time during playback of video, at least one stream let request over one or more network connections from the end user station to retrieve a streamlet storing a portion of the video starting at that start time from a currently selected one of the different copies, wherein the at least one streamlet request from the one or more end user stations includes a request for a currently selected one of the different copies dependent upon ongoing determinations to shift the playback quality to a higher or lower quality one of the different copies, wherein shifts in playback quality occur at the start times; retrieve from the storage device the requested streamlet from the currently selected one of the different copies; and send the retrieved streamlet from the currently selected one of the different copies to the requesting end user station over the one or more network connections. 2. The system of claim 1 wherein each of the streamlets of each of the plurality of different copies is requestable and playable by the end user station. 3. The system of claim 1 , wherein each of the streamlets of each of the plurality of different copies is a separate content file that is independently requestable by the end user station according to the start time of the streamlet. 4. The system of claim 1 , wherein each of the streamlets of each of the plurality of different copies is a separately identifiable portion of one or more content files that is individually requestable by the end user station according to the start time of the streamlet. 5. The system of claim 1 , wherein each of the streamlets of each of the plurality of different copies is a portion of one or more content files. 6. The system of claim 5 , wherein the web server receives the at least one streamlet request as a Hypertext Transport Protocol (HTTP) GET request for the portion of the one or more content files. 7. The system of claim 1 , further comprising a content server that comprises a processor, and wherein the content server is configured to: receive a plurality of videos; segment the received videos to generate for each video a plurality of sequential raw streamlets that collectively store the data to playback the entire video and that individually store data to playback only the portion of the video that starts at the unique start time and that has a duration that is less than the entire duration of the video; and encode each raw streamlet to generate, for each of the raw streamlets, a set including an encoded streamlet for each bitrate supported by the adaptive-rate content streaming, wherein each encoded streamlet within each of the sets has the same start time as its corresponding raw streamlet such that the encoded streamlets of the same set independently yield on playback the same portions of the corresponding video, and wherein the streamlets within each of the sets are each requestable and playable by the end user station via the web server. 8. The system of claim 7 , wherein the storage device is configured to maintain a streamlet database, and wherein the content server is further configured to transmit the encoded streamlets to the streamlet database to be stored by the storage device, and wherein the web server retrieves the requested streamlets from the streamlet database to transmit to the requesting end user station. 9. An automated process executable by one or more servers to stream a video for playback by one or more end user stations, the process comprising: storing, by the one or more servers, a plurality of different copies of the same selected video each copy encoded at a different bit rate and each copy divided into a plurality of streamlets that collectively store data capable of playback the entire video but that individually store data to playback only a portion that starts at a unique start time and whose duration is less than the entire playback duration of the selected video, wherein the start times of the streamlets are the same for the different copies such that the streamlets with the same start times from the different copies independently represent the same portions of the selected video; receiving, for a plurality of time indexes, at least one streamlet request over one or more network connections from the one or more end user stations to retrieve a streamlet storing a portion of the video starting at that start time from a currently selected one of the different copies, wherein the streamlet request from the one or more of the end user stations includes a request for the currently selected one of the different copies dependent upon successive determinations to shift the playback quality to a higher or lower quality one of the different copies, wherein the shifts in playback quality occur at the time indexes; retrieving from the storage device the requested streamlet from the currently selected one of the different copies; and sending the retrieved streamlet from the currently selected one of the different copies from the one or more servers to the one or more end user stations over the one or more network connections. 10. The automated process of claim 9 wherein each of the streamlets of each of the plurality of different copies is requestable and playable by the one or more end user stations. 11. The automated process of claim 9 , wherein each of the streamlets is a separate content file that is independently requestable and playable by the one or more end user stations according to the start time of the streamlet. 12. The automated process of claim 9 , wherein each of the streamlets is a separately identifiable portion of one or more content files that is individually requestable by the one or more end user stations according to the start time of the streamlet. 13. The automated process of claim 9 , wherein each of the streamlets is a portion of one or more content files. 14. An automated process executable by a content player device to stream a video over a network from a server for playback of the video by the content player device, the process comprising: establishing one or more network connections between the content player device and the server, wherein the server accesses a plurality of different copies of the video that are each encoded at a different bit rate and that are each divided into a plurality of streamlets that collectively store data capable of playback of the entire video but that individually store data to playback only a portion that starts at a unique start time and that has a duration that is less than the entire playback duration of the video, wherein the start times of the streamlets are the same for the different copies such that the streamlets with the same start times from the different copies of
Controlling the complexity of the video stream, e.g. by scaling the resolution or bitrate of the video stream based on the client capabilities · CPC title
for generating different versions · CPC title
Caching operations, e.g. of an advertisement for later insertion during playback · CPC title
Session establishment or de-establishment · CPC title
Responding to QoS · CPC title
Related publications grouped by family.
Answers are generated from the same data shown on this page.