USRE48748E1 - Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content - Google Patents

Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content Download PDF

Info

Publication number
USRE48748E1
USRE48748E1 US15/950,988 US201815950988A USRE48748E US RE48748 E1 USRE48748 E1 US RE48748E1 US 201815950988 A US201815950988 A US 201815950988A US RE48748 E USRE48748 E US RE48748E
Authority
US
United States
Prior art keywords
network bandwidth
initial
estimate
encoded media
measurements
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
US15/950,988
Inventor
Kourosh Soroushian
Jason A. Braness
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Divx LLC
Original Assignee
Divx LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Divx LLC filed Critical Divx LLC
Priority to US15/950,988 priority Critical patent/USRE48748E1/en
Assigned to DIVX, LLC reassignment DIVX, LLC CHANGE OF NAME (SEE DOCUMENT FOR DETAILS). Assignors: DIVX CF HOLDINGS LLC
Assigned to DIVX CF HOLDINGS LLC reassignment DIVX CF HOLDINGS LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: SONIC IP, INC.
Assigned to SONIC IP, INC. reassignment SONIC IP, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: DIVX, LLC
Assigned to DIVX, LLC reassignment DIVX, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BRANESS, JASON, SOROUSHIAN, KOUROSH
Application granted granted Critical
Publication of USRE48748E1 publication Critical patent/USRE48748E1/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/234Processing of video elementary streams, e.g. splicing of video streams, manipulating MPEG-4 scene graphs
    • H04N21/2343Processing of video elementary streams, e.g. splicing of video streams, manipulating MPEG-4 scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
    • H04N21/23439Processing of video elementary streams, e.g. splicing of video streams, manipulating MPEG-4 scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements for generating different versions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/08Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters
    • H04L43/0876Network utilisation, e.g. volume of load or congestion level
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/12Avoiding congestion; Recovering from congestion
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/1066Session management
    • H04L65/1069Session establishment or de-establishment
    • H04L65/607
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/70Media network packetisation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/80Responding to QoS
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/239Interfacing the upstream path of the transmission network, e.g. prioritizing client content requests
    • H04N21/2393Interfacing the upstream path of the transmission network, e.g. prioritizing client content requests involving handling client requests
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/25Management operations performed by the server for facilitating the content distribution or administrating data related to end-users or client devices, e.g. end-user or client device authentication, learning user preferences for recommending movies
    • H04N21/266Channel or content management, e.g. generation and management of keys and entitlement messages in a conditional access system, merging a VOD unicast channel into a multicast channel
    • H04N21/2662Controlling the complexity of the video stream, e.g. by scaling the resolution or bitrate of the video stream based on the client capabilities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/442Monitoring of processes or resources, e.g. detecting the failure of a recording device, monitoring the downstream bandwidth, the number of times a movie has been viewed, the storage space available from the internal hard disk
    • H04N21/44209Monitoring of downstream path of the transmission network originating from a server, e.g. bandwidth variations of a wireless network
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/0001Systems modifying transmission characteristics according to link quality, e.g. power backoff
    • H04L1/0002Systems modifying transmission characteristics according to link quality, e.g. power backoff by adapting the transmission rate

Definitions

  • the present invention generally relates to streaming media and more specifically to selecting an initial stream from a number of streams encoded with different maximum bitrates.
  • streaming media describes the playback of media on a playback device, where the media is stored on a server and continuously sent to the playback device over a network during playback.
  • the playback device stores a sufficient quantity of media in a buffer at any given time during playback to prevent disruption of playback due to the playback device completing playback of all the buffered media prior to receipt of the next portion of media.
  • Adaptive bit rate streaming or adaptive streaming involves detecting the present streaming conditions (e.g. the user's network bandwidth and CPU capacity) in real time and adjusting the quality of the streamed media accordingly.
  • the source media is encoded at multiple bit rates and the playback device or client switches between streaming the different encodings depending on available resources.
  • the playback device When a playback device commences adaptive bitrate streaming, the playback device typically starts by requesting portions of media from the lowest bitrate streams (where alternative streams are available). As the playback device downloads the requested media, the playback device can measure the available bandwidth. In the event that there is additional bandwidth available, the playback device can Witch to higher bitrate streams.
  • HTTP Hypertext Transfer Protocol
  • RFC 2616 World Wide Web Consortium
  • 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.
  • the source media is typically stored on a media server as a top level index file pointing to a number of alternate streams that contain the actual video and audio data. Each stream is typically stored in one or more container files.
  • Different adaptive streaming solutions typically utilize different index and media containers.
  • the Synchronized Multimedia Integration language (SMIL) developed by the World Wide Web Consortium is utilized to create indexes in several adaptive streaming solutions including IIS Smooth Streaming developed by Microsoft Corporation of Redmond, Wash., and Flash Dynamic Streaming developed by Adobe Systems incorporated of San Jose, Calif.
  • HTTP Adaptive Bitrate Streaming developed by Apple Computer Incorporated of Cupertino, Calif.
  • M3U playlist file (.M3U8), which is a text file containing a list of URIs that typically identify a media container file.
  • the most commonly used media container formats are the MP4 container format specified in MPEG-4 Part 14 (i.e. ISO/IEC 14496-14) and the MPEG transport stream (TS) container specified in MPEG-2 Part 1 (i.e. ISO/IEC Standard 13818-1).
  • the MP4 container format is utilized in IIS Smooth Streaming and Flash Dynamic Streaming.
  • the TS container is used in HTTP Adaptive Bitrate Streaming.
  • Systems and methods in accordance with embodiments of the invention estimate available bandwidth and perform initial stream selection when commencing streaming of media.
  • One embodiment of the method of the invention includes measuring network bandwidth using a playback device, determining an initial network bandwidth estimate using the network bandwidth measurements, selecting an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates rates using the playback device based upon the maximum bitrates of the plurality of streams and the initial bandwidth estimate; and commencing streaming of encoded media by requesting portions of the encoded media from the initial streams using the playback device.
  • the playback device performs the initial bandwidth estimate using the network bandwidth measurements.
  • Another embodiment of the method of the invention also includes providing the network bandwidth measurements to a performance server.
  • the performance server determines the initial bandwidth estimate using the network bandwidth measurements.
  • measuring network bandwidth includes requesting a block of data and measuring the time taken to download the data.
  • measuring network bandwidth includes associating a timestamp with the network bandwidth measurement.
  • measuring network bandwidth includes associating a content distribution network identifier with the network bandwidth measurement.
  • measuring network bandwidth includes associating a server IP address with the network bandwidth measurement.
  • measuring network bandwidth includes associating a server hostname with the network bandwidth measurement.
  • measuring bandwidth includes associating a video maximum bitrate with the network bandwidth measurement.
  • determining an initial network bandwidth estimate using the network bandwidth measurements includes determining an average network bandwidth using the network bandwidth measurements.
  • the average network bandwidth is determined by filtering the network bandwidth measurements based upon at least one piece of information associated with the network bandwidth measurements selected from the group consisting of time of day, day of week, content distribution network, server, and maximum bitrate.
  • determining an initial network bandwidth estimate using the network bandwidth measurements further includes determining the accuracy of the initial bandwidth estimate.
  • the initial stream is selected for use in the adaptive bitrate streaming of the encoded media.
  • the initial stream is selected by initially allocating available bandwidth to streams which have no alternative and allocating the remaining bandwidth to the selection from the plurality of streams of encoded media that are encoded at different maximum bitrates rates.
  • Still another embodiment again of the method of the invention also includes selecting a stream from each of a number of sets of streams of encoded media that are encoded at different maximum bitrates.
  • the user can instruct the playback device concerning allocation of bandwidth to at least one of the selections subject to the remaining available bandwidth.
  • a further embodiment of the invention includes a processor configured, via a client application, to request portions of files from a remote server.
  • the client application further configures the processor to measure network bandwidth using a playback device, obtain an initial network bandwidth estimate using the network bandwidth measurements, select an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates rates using, the playback device based upon the maximum bitrates of the plurality of streams and the initial bandwidth estimate, and commence streaming of encoded media by requesting portions of the encoded media from the initial streams using the playback device.
  • the client application further configures the processor to measure network bandwidth by requesting a block of data and measuring the time taken to download the data.
  • the client application further configures the processor to associate a time stamp with the network bandwidth measurement.
  • the client application further configures the processor to associate a content distribution network identifier with the network bandwidth measurement.
  • the client application further configures the processor to associate a server IP address with the network bandwidth measurement.
  • the client application further configures the processor to associate a server host name with the network bandwidth measurement.
  • the client application further configures the processor to associate a video maximum bitrate with the network bandwidth measurement.
  • the client application further configures the processor to associate the playback device IP address with the network bandwidth measurement.
  • the client application further configures the processor to perform an initial bandwidth estimate using the network bandwidth measurements.
  • the client application further configures the processor to determine an initial network bandwidth estimate using the network bandwidth measurements by determining an average network bandwidth using the network bandwidth measurements.
  • the client application further configures the processor to determine the average network bandwidth by filtering the network bandwidth measurements based upon at least one piece of information associated with the network bandwidth measurements selected from the group consisting of time of day, day of week, content distribution network, server and maximum bitrate.
  • the client application further configures the processor to determine the accuracy of the initial bandwidth estimate.
  • the client application further configures the processor to provide the network bandwidth measurements to a performance server, and receive an initial bandwidth estimate from the performance server.
  • the initial stream is selected for use in the adaptive bitrate streaming of the encoded media.
  • the client application farther configures the processor to select the initial stream by initially allocating available bandwidth to streams which have no alternative and allocating the remaining bandwidth to the selection from the plurality of streams of encoded media that are encoded at different maximum bitrates rates.
  • the client application further configures the processor to select a stream front each of a number of sets of streams of encoded media that are encoded at different maximum bitrates.
  • a further additional embodiment includes a machine readable medium containing processor instructions, where execution of the instructions by a processor causes the processor to perform a process including measuring network bandwidth using a playback device, obtaining an initial network bandwidth estimate using the network bandwidth measurements, selecting an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates rates using the playback device based upon the maximum bitrates of the plurality of streams and the initial bandwidth estimate, and commencing streaming of encoded media by requesting portions of the encoded media from the initial streams using the playback device.
  • execution of the instructions by a processor causes the process to obtain an initial network bandwidth estimate by calculating an initial bandwidth estimate using the network bandwidth measurements.
  • execution of the instructions by a processor causes the process to obtain an initial network bandwidth estimate by transmitting the network bandwidth measurements to a server, and receiving an initial so bandwidth estimate from the server.
  • Another further embodiment of the invention includes recording performance data concerning playback of streamed content by a playback device, obtaining a maximum bitrate of a piece of content, comparing the maximum bitrate of the piece of content to recorded performance data for playback of streamed content by the playback device, and verify that the playback device can support playback of content based upon the comparison of the maximum bitrate of the piece of content and the recorded performance data for playback of streamed content by the playback device.
  • the performance data includes information concerning the amount of time spent buffering streamed content.
  • comparing the maximum bitrate of the piece of content to recorded performance data for playback of streamed content by the playback device includes comparing an amount of time spent buffering streamed content encoded at a maximum bitrate corresponding to the maximum bitrate of the piece of content to a predetermined threshold.
  • the performance data includes information concerning the amount of time spent streaming content streams encoded at different maximum bitrates during adaptive bitrate streaming.
  • comparing the maximum bitrate of the piece of content to recorded performance data for playback of streamed content by the playback device includes comparing the proportion of time spent streaming content streams encoded at a maximum bitrate corresponding to the maximum bitrate of the piece of content to a predetermined threshold.
  • FIG. 1 is a network diagram of a media streaming system including a performance server in accordance with an embodiment of the invention.
  • FIG. 2 is a system diagram of a playback device in accordance with an embodiment of the invention.
  • FIG. 3 is a flow chart illustrating a process for measuring network bandwidth in accordance with an embodiment of the invention.
  • FIG. 4 is a flow chart illustrating a process for estimating network bandwidth using historical network bandwidth measurements in accordance with an embodiment of the invention.
  • FIG. 5 is a flow chart illustrating a process or performing initial stream selection.
  • FIG. 6 is a flow chart illustrating a process for determining whether a playback device can support playback of a particular piece of content based upon the maximum bitrate at which the piece of content is encoded in accordance with an embodiment of the invention.
  • playback devices record performance information during the streaming session.
  • previously recorded performance information can then be utilized to estimate available bandwidth.
  • the bandwidth estimate can then be used to select between streams encoded at different maximum bitrates for commencement of conventional or adaptive bitrate streaming. Where audio and/or subtitle tracks are only available at a single bitrate, the bitrate of any audio and/or subtitle streams is subtracted from the bandwidth estimate.
  • a specific stream such as (but not limited to) a video stream is selected from a number at alternative streams encoded at different maximum bitrates
  • a video stream is selected having a maximum bitrate equal to or fess than the estimated remaining available bandwidth.
  • alternative audio and video stream combinations are available, the system can default or rely on user selections to choose either a higher bitrate audio stream or a higher bitrate video stream.
  • the historical performance information is utilized to estimate available bandwidth using a technique appropriate to a specific application.
  • the last network bandwidth measurement recorded by a playback device is utilized to generate a bandwidth estimate.
  • the network bandwidth measurements recorded by a playback device over a predetermined time period are utilized to generate a bandwidth estimate.
  • correlation between the time of day and the network bandwidth measurements recorded by the playback device can be utilized in determining an initial bandwidth estimate.
  • the process of determining a bandwidth estimate also includes providing information concerning the accuracy of the estimate.
  • one or more accuracy factors are generated that can he utilized in selection of initial streams based upon a bandwidth estimate.
  • a playback device can determine the margin to allow between the bandwidth requirements of selected streams and the estimated available bandwidth.
  • the accuracy factor is determined based upon the correlation between bandwidth estimates made with respect to the playback device and the actual streaming conditions subsequently experienced by the playback device.
  • playback devices report network bandwidth measurements to a performance server and, the performance server makes recommendations concerning initial stream selection.
  • the playback devices can report back the identity of the content distribution network and/or specific server from which content was streaming at the time the network bandwidth measurement was taken.
  • the performance server can also provide recommendations concerning the specific content distribution network and/or servers from which to stream content to the playback device to achieve the best network performance.
  • a performance server in accordance with embodiments of the invention can perform bandwidth estimations and recommendations concerning content distribution networks and/or servers utilizing bandwidth measurements taken from multiple playback devices within a geographic area that utilize the same Internet Service Provider (ISP).
  • ISP Internet Service Provider
  • playback devices can purchase content for streaming from online content stores and the price for the same content at different resolutions may vary.
  • the performance server utilizes recorded network bandwidth measurements to determine whether the playback device is likely to experience network bandwidth performance capable of supporting, the streaming of the content at a specific resolution. In this way, the recorded performance information can be utilized to make recommendations concerning the purchase of content at different resolutions.
  • the recommendation can also include an indication of the accuracy or likelihood that the recommendation is correct. In a number of embodiments, an accuracy factor can be generated based upon the total time spent rebuffering content streamed at the recommended level during previous streaming sessions.
  • an accuracy factor can be generated with respect to an adaptive bitrate streaming system based upon the proportion of time spent streaming below the recommended level during previous streaming sessions. In other embodiments, any of a variety of accuracy metrics can be utilized as appropriate to the requirements of a specific application.
  • the performance server can the network bandwidth measurements in any of a variety of ways appropriate to a specific application including but not limited to enabling online content stores to offer premium content not only based upon resolution, but also based upon distribution from a specific content distribution network that has historically achieved higher network performance with respect to a specific playback device. Performance servers and processes for collecting network bandwidth measurements and estimating network bandwidth performance in accordance with embodiments of the invention are discussed further below.
  • Streaming systems in accordance with many embodiments of the invention include a server on which content is stored, playback devices that request streaming of content and that perform bandwidth measurements, and a performance server configured to aggregate network bandwidth measurements and to provide bandwidth estimates.
  • a streaming system in accordance with an embodiment of the invention is illustrated in FIG. 1 .
  • the streaming system 10 includes a number of playback devices 12 configured to request streaming of content from remote servers within content distribution networks 14 via a network 14 such as the Internet.
  • the playback devices can select between alternative streams when requesting content.
  • Alternative streams are streams that encode the same media content indifferent ways.
  • alternative streams encode media content (such as but not limited to video) at different maximum bitrates.
  • the alternative streams are encoded with different resolutions and/or at different frame rates.
  • the playback device can select one or more streams for conventional streaming or can switch between alternative streams to perform adaptive bitrate streaming.
  • the playback devices 12 perform network bandwidth or data rate measurements. Each network bandwidth measurement can be timestamped and stored locally and/or sent to a performance server 18 that can store the network bandwidth measurement in a database 20 .
  • the playback device sends network bandwidth measurements to the performance server continuously. In a number of embodiments, the playback device sends network bandwidth measurements to the performance server in batches.
  • a playback device 12 When a playback device 12 initiates a new streaming session, previous measurements of network bandwidth made by a playback device can be utilized to estimate the available network bandwidth. Any of a variety of techniques appropriate to a specific application can be utilized to generate a network bandwidth estimate in accordance with embodiments of the invention. The generation of network bandwidth. estimates is discussed further below.
  • the playback device Based upon the network bandwidth estimate, the playback device can determine the initial streams from which to commence requesting portions of encoded media based upon the maximum bitrates of the available streams.
  • the network performance server 18 generates the network bandwidth estimate and provides the network bandwidth estimate to the playback device. in a number of embodiments, the network performance server 18 generates a network bandwidth estimate and uses the estimate to provide initial stream selection recommendations to a playback device 12 .
  • the playback device 12 generates the network bandwidth estimate based upon locally stored network bandwidth measurements. As is discussed .further below, the process of generating a network bandwidth estimate can also include determining the accuracy of the network bandwidth estimate. In a number of embodiments, the accuracy of a network bandwidth estimate is considered during the initial stream selection.
  • playback devices 12 are able to purchase content for streaming via one or more online content stores 22 .
  • the online content store will provide different pricing for content encoded at different resolutions. For example, a content store can charge a premium for content encoded at high definition resolution relative to content encoded at standard definition resolution. if insufficient network bandwidth is available to a playback device to stream the high definition content, the playback device may prefer to purchase the lower resolution content.
  • the playback device will experience frequent buffering interruptions by purchasing the premium content.
  • the majority of the content received by the playback device likely will be at the lower resolution irrespective of whether the playback device purchases the premium content.
  • the bandwidth available to the playback device can be estimated using the recorded network performance measurements and recommendations provided to the user concerning whether the premium content can be supported.
  • the process of generating a recommendation also involves determining the likelihood that the recommendation is correct.
  • the servers of the online content store 22 communicate with the performance server 18 to obtain a network performance estimate.
  • the playback device 12 generates the network performance estimate based upon locally stored records of past network bandwidth measurements.
  • performance servers can be incorporated into any of a variety of streaming system architectures where playback devices perform network bandwidth measurements in accordance with embodiments of the invention.
  • individual playback devices can store network bandwidth measurements and perform network bandwidth estimates in accordance with embodiments of the invention. Playback devices that can be utilized to perform network bandwidth measurements during a streaming session in accordance with embodiments of the invention are discussed further below.
  • playback devices include personal computers, CE players, and mobile phones. 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 and playing back encoded media.
  • the basic architecture of a playback device in accordance with an embodiment of the invention is illustrated in FIG. 2 .
  • the playback device 30 includes a processor 32 in communication with non-volatile memory 34 and volatile memory 36 .
  • the non-volatile memory includes a client application 38 that configures the processor and the playback device to stream content from a remote server.
  • the nonvolatile memory 34 also includes cryptographic data 39 that can be utilized in accessing encrypted content.
  • the client application can configure the playback device to measure network bandwidth.
  • the time taken to receive a requested block of data is used to measure network bandwidth.
  • Network bandwidth measurements can be performed throughout a streaming session and can include information concerning the content distribution network and/or server from which the playback device requested the block of content.
  • the client application configures the playback device to record the specific stream requested.
  • the client application can configure the playback device to store the network bandwidth measurements in the volatile or non-volatile memory of the playback device,
  • the client application can configure the playback device to transmit the network bandwidth measurements to a performance server.
  • the playback device can transmit network bandwidth measurements to a performance server as they are made and/or the playback device can buffer network bandwidth measurements and send them in batches to the performance server. Where bandwidth measurements are locally stored, the client application 38 can utilize the bandwidth measurements in making an initial stream selection(s). Where bandwidth measurements are provided to a performance server, the client application 38 configures the playback device to request an initial bandwidth estimate and/or accuracy information from the performance server.
  • the playback device is configured to perform adaptive bitrate streaming.
  • a top level index file is stored and/or generated by a server within the content distribution network 14 or a server associated with the online content store 22 .
  • the top level index file specifies the alternative streams available to the playback device and the maximum bitrate of each stream. Therefore, a performance server and/or a playback device can utilize the index file to perform initial stream selections based upon a bandwidth estimate generated in accordance with embodiments of the invention.
  • Examples of adaptive bitrate streaming systems that can be utilized in accordance with embodiments of the invention include but are not limited to the adaptive bitrate streaming systems disclosed in U.S. Provisional Patent Application Ser. No. 61/430,110, “Systems and Methods For Adaptive Bitrate Streaming of Media Stored in Matroska Files Using Hypertext Transfer Protocol”, filed Jan. 5, 2011, the entirety of which is incorporated herein by reference.
  • any of a variety of architectures including architectures where the client application 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 for use in multiphase adaptive bitrate streaming systems in accordance with embodiments of the invention.
  • any of a variety of system architectures including (but not limited) to the system architecture illustrated in FIG. 1 can be utilized to measure network bandwidth and utilize the network bandwidth measurements to estimate network bandwidth when a playback device initiates a streaming session in accordance with embodiments of the invention.
  • a process for measuring network performance in accordance with an embodiment of the invention is illustrated in FIG. 3 .
  • the process 40 includes determining ( 42 ) network bandwidth.
  • one process for determining network bandwidth or data rate is to request a block of data and to measure the time taken to download the data.
  • any of a variety of techniques for measuring network bandwidth can be utilized.
  • decoder performance is also measured ( 44 ). Decoder performance can be measured in any of a variety of different ways including measuring the time it takes to decode a frame of video, the average time taken to decode a frame of video, and/or CPU load.
  • the playback device can send ( 46 ) the timestamped information to the performance server and can include additional information including (but not limited to) the IP address or host name of the server from which the stream was received, the size of the data downloaded, and/or the maximum bitrate at which the stream is encoded.
  • the timestamped performance information can then be stored ( 48 ) for retrieval and use in the estimation of available bandwidth.
  • any of a variety of processes appropriate to a specific application can be utilized in accordance with embodiments of the invention.
  • estimation of available bandwidth can be performed either at the playback device or using, a performance server. Processes for estimating available bandwidth in accordance with embodiments of the invention are discussed below.
  • Historical network bandwidth measurements can be utilized to select one or more initial streams when streaming content.
  • a process for generating a bandwidth estimate using historical network bandwidth measurements in accordance with embodiments of the invention is illustrated in FIG. 4 .
  • the process 50 can be performed using a playback device, a performance server or a combination of a playback device and a performance server.
  • a performance server is utilized in the process, the process commences with the receipt ( 52 ) of a network bandwidth estimate request.
  • the network bandwidth estimate is determined by retrieving ( 54 ) historical performance data and using the historical performance data to generate ( 56 ) an initial bandwidth recommendation.
  • the initial bandwidth recommendation is generated by averaging network bandwidth measurements included in the performance data.
  • network bandwidth measurements collected over a predetermined time period are averaged.
  • the network bandwidth measurements that occurred within a corresponding time of day and/or day of the week are averaged.
  • network bandwidth measurements taken when content was streamed from a specific content distribution network and/or server are averaged.
  • the network bandwidth measurements and associated data can be filtered in any of a variety of ways to determine an initial bandwidth estimate.
  • the process of generating an initial bandwidth estimate also includes generating an estimate of the accuracy of the bandwidth estimate.
  • the accuracy of the bandwidth estimate can be determined as the ratio of previous bandwidth estimates to actual bandwidth or as a statistical measure such as (but not limited to) the standard deviation of the network bandwidth measurements utilized to generate the initial bandwidth estimate.
  • any of a variety of techniques can be utilized to determine the accuracy of an initial bandwidth estimate including (but not limited to) looking at trends for certain times of day.
  • a playback device can select one or more initial streams and commence streaming of the encoded content.
  • a process for selecting initial stream(s) in accordance with an embodiment of the invention is illustrated in FIG. 5 .
  • the source video is typically encoded as a number of alternative streams. Other portions of the source content, however, may simply he provided as a single stream (e.g. a specific audio track or a specific subtitle track).
  • the process 70 involves initially allocating bandwidth ( 72 ) to streams for which there are no alternatives. In many embodiments, bandwidth is initially allocated to streams for which there is no alternative and so the maximum bitrate is a fixed value.
  • the total bitrate allocated to these fixed streams is then subtracted from the estimated available bitrate to obtain the remaining available bitrate for use by other streams.
  • a selection ( 74 ) can then be made concerning alternative streams based upon the remaining available bandwidth. Where there are multiple sets of alternative streams from which selections can be made (e.g. multiple video streams encoded at different bitrates and multiple audio streams encoded at different bitrates), a tradeoff occurs between Which stream will be allocated the greater share of the available bandwidth.
  • the playback device makes a predetermined selection. In many embodiments, the predetermined selection is made based upon the available bandwidth and the maximum bitrates of the streams within the two sets of alternative streams. In several embodiments, the user can force the selection of a higher bitrate stream (e.g.
  • the playback device can commence requesting portions of encoded media from the initial streams and, in adaptive bitrate systems, can adjust the stream selections based upon the streaming conditions experienced by the playback device.
  • any of a variety of processes can be utilized to select initial streams based upon an initial bandwidth estimate in accordance with embodiments of the invention.
  • the initial bandwidth estimate is used as a conservative estimate and an adjustment factor can be applied to the initial bandwidth estimate.
  • the adjustment factor is a unction of the accuracy of the initial bandwidth estimate.
  • any of a variety of techniques can be utilized to apply an adjustment factor to the initial bandwidth estimate. Indeed, in many embodiments an adjustment is made during the process of determining the initial bandwidth estimate.
  • FIG. 6 A process for determining whether a playback device can support playback of a piece of content at a specific resolution in accordance with an embodiment of the invention is illustrated in FIG. 6 .
  • the process 90 can be performed using a performance server or using a playback device.
  • the process 90 commences by obtaining ( 92 ) the bandwidth requirements of a specific piece of content.
  • Historical network bandwidth measurements are retrieved ( 94 ) arid a determination made concerning whether playback is supported.
  • the determination concerning whether playback is supported can be made in any of a variety of ways. Where a specific stream of content is concerned, a determination can be made based upon the proportion of time spent buffering content during playback of content encoded at a similar maximum bitrate.
  • network bandwidth measurements can be reviewed to estimate the bandwidth throughout playback to estimate the proportion of time that is likely to be spent buffering content.
  • modifications can be made to the amount of content that is buffered before playback commences based upon the bandwidth estimates to reduce the amount of time spent buffering during playback.
  • a determination can be made based upon the proportion of time spent streaming at or above the maximum bitrate of the content. Estimates of the network bandwidth for the duration of the content can also be utilized to estimate the proportion of time content at the specified resolution will be streamed.
  • the network bandwidth measurements utilized to determine whether the bandwidth requirements of the content are supported can be filtered based upon one or more pieces of additional information associated with the network measurements including (but not limited to) time of day, date, and the content distribution network and/or server streaming the content.
  • the determination concerning whether the network bandwidth requirements are supported can be accompanied by a confidence factor or accuracy metric.
  • the confidence factor or accuracy metric can represent the proportion of time that is likely to be spent buffering or streaming at a lower resolution or reflect variation in the network bandwidth measurement data utilized to determine whether the network bandwidth requirements of the content can be supported.
  • the process 90 can involve generating ( 98 ) a user notification that the playback requirements can be met and/or authorizing the transaction.
  • the determination can be integrated within the user interface of a content distribution system and/or the determination can be integrated into the purchase process.
  • a notification is generated ( 100 ) informing the user that they should not proceed with purchasing and/or streaming the content.
  • any of a variety of processes for determining whether to stream and/or purchase a specific piece of content encoded with specific maximum bandwidth requirements including processes that utilize network bandwidth measurements collected by multiple playback devices from a similar geographic region and that utilize the same Internet service provider can be performed in accordance with embodiments.
  • a similar process is utilized to generate the number of interruptions and the amount of time spent buffering during playback, which can be displayed accompanying content selections.
  • similar processes can be used to estimate the proportion of time the content will be streamed at the displayed resolution. In both instances these estimates can be qualified by high end and low end estimates representing a predetermined confidence interval.
  • network bandwidth measurements can be utilized in a variety of additional ways related to the purchase of content discussed below.
  • the data rate of a network connection experienced by a specific playback device can vary depending upon the content distribution network utilized to distribute content.
  • a content distribution system can offer premium content based not just on the resolution of the content but the content distribution network utilized to deliver the content.
  • a streaming system can provide a performance metric such as (but not limited to) an estimate of the amount of time the playback device will spend buffering during playback from different content distribution networks and can charge a premium based the higher playback performance anticipated when streaming from a premium content distribution network.
  • an adaptive bitrate streaming system can display a performance metric such as (but not limited to) an estimate of the proportion of time that a playback device will receive content encoded at the highest available resolution and charge a premium based upon the higher playback performance anticipated when streaming from a premium content distribution network.
  • a performance metric such as (but not limited to) an estimate of the proportion of time that a playback device will receive content encoded at the highest available resolution and charge a premium based upon the higher playback performance anticipated when streaming from a premium content distribution network.

Abstract

Systems and methods for determining available bandwidth and performing initial stream selection when commencing adaptive bitrate streaming using Hypertext Transfer Protocol (HTTP) in accordance with embodiments of the invention are disclosed. One embodiment of the invention includes measuring network bandwidth using a playback device, determining an initial network bandwidth estimate using the network bandwidth measurements, selecting an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates rates using the playback device based upon the maximum bitrates of the plurality of streams and the initial bandwidth estimate; and commencing streaming of encoded media by requesting portions of the encoded media from the initial streams using the playback device.

Description

CROSS REFERENCE TO RELATED APPLICATIONS
This application is a continuation of U.S. patent application Ser. No. 13/341,838, filed Dec. 30, 2011, which claimed priority to U.S. Provisional Application Ser. No. 61/502,767, entitled “Client-Server Bandwidth Hinting for Adaptive Streaming Enhancements”, filed Jun. 29, 2011, the entirety of which are incorporated herein by reference.
FIELD OF THE INVENTION
The present invention generally relates to streaming media and more specifically to selecting an initial stream from a number of streams encoded with different maximum bitrates.
BACKGROUND
The term streaming media describes the playback of media on a playback device, where the media is stored on a server and continuously sent to the playback device over a network during playback. Typically, the playback device stores a sufficient quantity of media in a buffer at any given time during playback to prevent disruption of playback due to the playback device completing playback of all the buffered media prior to receipt of the next portion of media. Adaptive bit rate streaming or adaptive streaming involves detecting the present streaming conditions (e.g. the user's network bandwidth and CPU capacity) in real time and adjusting the quality of the streamed media accordingly. Typically, the source media is encoded at multiple bit rates and the playback device or client switches between streaming the different encodings depending on available resources. When a playback device commences adaptive bitrate streaming, the playback device typically starts by requesting portions of media from the lowest bitrate streams (where alternative streams are available). As the playback device downloads the requested media, the playback device can measure the available bandwidth. In the event that there is additional bandwidth available, the playback device can Witch to higher bitrate streams.
Adaptive streaming solutions typically utilize Hypertext Transfer Protocol (HTTP), published by the Internet Engineering Task Force and the World Wide Web Consortium as RFC 2616, 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.
In adaptive streaming systems, the source media is typically stored on a media server as a top level index file pointing to a number of alternate streams that contain the actual video and audio data. Each stream is typically stored in one or more container files. Different adaptive streaming solutions typically utilize different index and media containers. The Synchronized Multimedia Integration language (SMIL) developed by the World Wide Web Consortium is utilized to create indexes in several adaptive streaming solutions including IIS Smooth Streaming developed by Microsoft Corporation of Redmond, Wash., and Flash Dynamic Streaming developed by Adobe Systems incorporated of San Jose, Calif. HTTP Adaptive Bitrate Streaming developed by Apple Computer Incorporated of Cupertino, Calif. implements index files using an extended M3U playlist file (.M3U8), which is a text file containing a list of URIs that typically identify a media container file. The most commonly used media container formats are the MP4 container format specified in MPEG-4 Part 14 (i.e. ISO/IEC 14496-14) and the MPEG transport stream (TS) container specified in MPEG-2 Part 1 (i.e. ISO/IEC Standard 13818-1). The MP4 container format is utilized in IIS Smooth Streaming and Flash Dynamic Streaming. The TS container is used in HTTP Adaptive Bitrate Streaming.
SUMMARY OF THE INVENTION
Systems and methods in accordance with embodiments of the invention estimate available bandwidth and perform initial stream selection when commencing streaming of media. One embodiment of the method of the invention includes measuring network bandwidth using a playback device, determining an initial network bandwidth estimate using the network bandwidth measurements, selecting an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates rates using the playback device based upon the maximum bitrates of the plurality of streams and the initial bandwidth estimate; and commencing streaming of encoded media by requesting portions of the encoded media from the initial streams using the playback device.
In a further embodiment of the method. of the invention, the playback device performs the initial bandwidth estimate using the network bandwidth measurements.
Another embodiment of the method of the invention also includes providing the network bandwidth measurements to a performance server. In addition, the performance server determines the initial bandwidth estimate using the network bandwidth measurements.
In a still further embodiment of the method of the invention, measuring network bandwidth includes requesting a block of data and measuring the time taken to download the data.
In still another embodiment of the method of the invention, measuring network bandwidth includes associating a timestamp with the network bandwidth measurement.
In a yet further embodiment of the method of the invention, measuring network bandwidth includes associating a content distribution network identifier with the network bandwidth measurement.
In yet another embodiment of the method of the invention, measuring network bandwidth includes associating a server IP address with the network bandwidth measurement.
In a further embodiment again of the method of the invention, measuring network bandwidth includes associating a server hostname with the network bandwidth measurement.
In another embodiment again of the method of the invention, measuring bandwidth includes associating a video maximum bitrate with the network bandwidth measurement.
In a further additional embodiment of the method of the invention, determining an initial network bandwidth estimate using the network bandwidth measurements includes determining an average network bandwidth using the network bandwidth measurements.
In another additional embodiment of tile method of the invention, the average network bandwidth is determined by filtering the network bandwidth measurements based upon at least one piece of information associated with the network bandwidth measurements selected from the group consisting of time of day, day of week, content distribution network, server, and maximum bitrate.
In a still yet further embodiment of the method of the invention, determining an initial network bandwidth estimate using the network bandwidth measurements further includes determining the accuracy of the initial bandwidth estimate.
In still vet another embodiment of the method of the invention, the initial stream is selected for use in the adaptive bitrate streaming of the encoded media.
In a still further embodiment again of the method of the invention, the initial stream is selected by initially allocating available bandwidth to streams which have no alternative and allocating the remaining bandwidth to the selection from the plurality of streams of encoded media that are encoded at different maximum bitrates rates.
Still another embodiment again of the method of the invention, also includes selecting a stream from each of a number of sets of streams of encoded media that are encoded at different maximum bitrates.
In a still further additional embodiment, the user can instruct the playback device concerning allocation of bandwidth to at least one of the selections subject to the remaining available bandwidth.
A further embodiment of the invention includes a processor configured, via a client application, to request portions of files from a remote server. In addition, the client application further configures the processor to measure network bandwidth using a playback device, obtain an initial network bandwidth estimate using the network bandwidth measurements, select an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates rates using, the playback device based upon the maximum bitrates of the plurality of streams and the initial bandwidth estimate, and commence streaming of encoded media by requesting portions of the encoded media from the initial streams using the playback device.
In another embodiment, the client application further configures the processor to measure network bandwidth by requesting a block of data and measuring the time taken to download the data.
In a still further embodiment, the client application further configures the processor to associate a time stamp with the network bandwidth measurement.
In still another embodiment, the client application further configures the processor to associate a content distribution network identifier with the network bandwidth measurement.
In a yet further embodiment, the client application further configures the processor to associate a server IP address with the network bandwidth measurement.
In yet another embodiment, the client application further configures the processor to associate a server host name with the network bandwidth measurement.
In a further embodiment again, the client application further configures the processor to associate a video maximum bitrate with the network bandwidth measurement.
In another embodiment again, the client application further configures the processor to associate the playback device IP address with the network bandwidth measurement.
In a further additional embodiment, the client application further configures the processor to perform an initial bandwidth estimate using the network bandwidth measurements.
In another additional embodiment, the client application further configures the processor to determine an initial network bandwidth estimate using the network bandwidth measurements by determining an average network bandwidth using the network bandwidth measurements.
In a still further embodiment, the client application further configures the processor to determine the average network bandwidth by filtering the network bandwidth measurements based upon at least one piece of information associated with the network bandwidth measurements selected from the group consisting of time of day, day of week, content distribution network, server and maximum bitrate.
In still another embodiment, the client application further configures the processor to determine the accuracy of the initial bandwidth estimate.
In a yet further embodiment, the client application further configures the processor to provide the network bandwidth measurements to a performance server, and receive an initial bandwidth estimate from the performance server.
In yet another embodiment, the initial stream is selected for use in the adaptive bitrate streaming of the encoded media.
In a further embodiment again, the client application farther configures the processor to select the initial stream by initially allocating available bandwidth to streams which have no alternative and allocating the remaining bandwidth to the selection from the plurality of streams of encoded media that are encoded at different maximum bitrates rates.
In another embodiment again, the client application further configures the processor to select a stream front each of a number of sets of streams of encoded media that are encoded at different maximum bitrates.
A further additional embodiment includes a machine readable medium containing processor instructions, where execution of the instructions by a processor causes the processor to perform a process including measuring network bandwidth using a playback device, obtaining an initial network bandwidth estimate using the network bandwidth measurements, selecting an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates rates using the playback device based upon the maximum bitrates of the plurality of streams and the initial bandwidth estimate, and commencing streaming of encoded media by requesting portions of the encoded media from the initial streams using the playback device.
In a still yet further embodiment, execution of the instructions by a processor causes the process to obtain an initial network bandwidth estimate by calculating an initial bandwidth estimate using the network bandwidth measurements.
In still yet another embodiment, execution of the instructions by a processor causes the process to obtain an initial network bandwidth estimate by transmitting the network bandwidth measurements to a server, and receiving an initial so bandwidth estimate from the server.
Another further embodiment of the invention includes recording performance data concerning playback of streamed content by a playback device, obtaining a maximum bitrate of a piece of content, comparing the maximum bitrate of the piece of content to recorded performance data for playback of streamed content by the playback device, and verify that the playback device can support playback of content based upon the comparison of the maximum bitrate of the piece of content and the recorded performance data for playback of streamed content by the playback device.
In still another further embodiment, the performance data includes information concerning the amount of time spent buffering streamed content.
In yet another further embodiment, comparing the maximum bitrate of the piece of content to recorded performance data for playback of streamed content by the playback device includes comparing an amount of time spent buffering streamed content encoded at a maximum bitrate corresponding to the maximum bitrate of the piece of content to a predetermined threshold.
In another further embodiment again, the performance data includes information concerning the amount of time spent streaming content streams encoded at different maximum bitrates during adaptive bitrate streaming.
In another further additional embodiment, comparing the maximum bitrate of the piece of content to recorded performance data for playback of streamed content by the playback device includes comparing the proportion of time spent streaming content streams encoded at a maximum bitrate corresponding to the maximum bitrate of the piece of content to a predetermined threshold.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a network diagram of a media streaming system including a performance server in accordance with an embodiment of the invention.
FIG. 2 is a system diagram of a playback device in accordance with an embodiment of the invention.
FIG. 3 is a flow chart illustrating a process for measuring network bandwidth in accordance with an embodiment of the invention.
FIG. 4 is a flow chart illustrating a process for estimating network bandwidth using historical network bandwidth measurements in accordance with an embodiment of the invention.
FIG. 5 is a flow chart illustrating a process or performing initial stream selection.
FIG. 6 is a flow chart illustrating a process for determining whether a playback device can support playback of a particular piece of content based upon the maximum bitrate at which the piece of content is encoded in accordance with an embodiment of the invention.
DETAILED DISCLOSURE OF THE INVENTION
Turning now to the drawings, systems and methods for estimating available bandwidth and performing initial stream selection when commencing streaming of media in accordance with embodiments of the invention are illustrated. In many embodiments, playback devices record performance information during the streaming session. When a playback device initiates a new streaming session, previously recorded performance information cart be utilized to estimate available bandwidth. The bandwidth estimate can then be used to select between streams encoded at different maximum bitrates for commencement of conventional or adaptive bitrate streaming. Where audio and/or subtitle tracks are only available at a single bitrate, the bitrate of any audio and/or subtitle streams is subtracted from the bandwidth estimate. Where a specific stream such as (but not limited to) a video stream is selected from a number at alternative streams encoded at different maximum bitrates, a video stream is selected having a maximum bitrate equal to or fess than the estimated remaining available bandwidth. Where alternative audio and video stream combinations are available, the system can default or rely on user selections to choose either a higher bitrate audio stream or a higher bitrate video stream.
In many embodiments, the historical performance information is utilized to estimate available bandwidth using a technique appropriate to a specific application. In a number of embodiments, the last network bandwidth measurement recorded by a playback device is utilized to generate a bandwidth estimate. In several embodiments, the network bandwidth measurements recorded by a playback device over a predetermined time period are utilized to generate a bandwidth estimate. In many embodiments, correlation between the time of day and the network bandwidth measurements recorded by the playback device can be utilized in determining an initial bandwidth estimate.
In various embodiments, the process of determining a bandwidth estimate also includes providing information concerning the accuracy of the estimate. In many embodiments, one or more accuracy factors are generated that can he utilized in selection of initial streams based upon a bandwidth estimate. Depending on the accuracy factor(s), a playback device can determine the margin to allow between the bandwidth requirements of selected streams and the estimated available bandwidth. In many embodiments, the accuracy factor is determined based upon the correlation between bandwidth estimates made with respect to the playback device and the actual streaming conditions subsequently experienced by the playback device.
In a number of embodiments, playback devices report network bandwidth measurements to a performance server and, the performance server makes recommendations concerning initial stream selection. In several embodiments, the playback devices can report back the identity of the content distribution network and/or specific server from which content was streaming at the time the network bandwidth measurement was taken. In addition to providing stream selection recommendations, the performance server can also provide recommendations concerning the specific content distribution network and/or servers from which to stream content to the playback device to achieve the best network performance. By aggregating network performance measurements from multiple playback devices, a performance server in accordance with embodiments of the invention can perform bandwidth estimations and recommendations concerning content distribution networks and/or servers utilizing bandwidth measurements taken from multiple playback devices within a geographic area that utilize the same Internet Service Provider (ISP).
The availability of network bandwidth measurements on a performance server can also enable other possible functionality. In several embodiments, playback devices can purchase content for streaming from online content stores and the price for the same content at different resolutions may vary. In a number of embodiments, the performance server utilizes recorded network bandwidth measurements to determine whether the playback device is likely to experience network bandwidth performance capable of supporting, the streaming of the content at a specific resolution. In this way, the recorded performance information can be utilized to make recommendations concerning the purchase of content at different resolutions. In several embodiments, the recommendation can also include an indication of the accuracy or likelihood that the recommendation is correct. In a number of embodiments, an accuracy factor can be generated based upon the total time spent rebuffering content streamed at the recommended level during previous streaming sessions. In many embodiments, an accuracy factor can be generated with respect to an adaptive bitrate streaming system based upon the proportion of time spent streaming below the recommended level during previous streaming sessions. In other embodiments, any of a variety of accuracy metrics can be utilized as appropriate to the requirements of a specific application.
In other embodiments, the performance server can the network bandwidth measurements in any of a variety of ways appropriate to a specific application including but not limited to enabling online content stores to offer premium content not only based upon resolution, but also based upon distribution from a specific content distribution network that has historically achieved higher network performance with respect to a specific playback device. Performance servers and processes for collecting network bandwidth measurements and estimating network bandwidth performance in accordance with embodiments of the invention are discussed further below.
Streaming System Architecture
Streaming systems in accordance with many embodiments of the invention include a server on which content is stored, playback devices that request streaming of content and that perform bandwidth measurements, and a performance server configured to aggregate network bandwidth measurements and to provide bandwidth estimates. A streaming system in accordance with an embodiment of the invention is illustrated in FIG. 1. The streaming system 10 includes a number of playback devices 12 configured to request streaming of content from remote servers within content distribution networks 14 via a network 14 such as the Internet. In, many embodiments, the playback devices can select between alternative streams when requesting content. Alternative streams are streams that encode the same media content indifferent ways. In many instances, alternative streams encode media content (such as but not limited to video) at different maximum bitrates. In a number of embodiments, the alternative streams are encoded with different resolutions and/or at different frame rates. The playback device can select one or more streams for conventional streaming or can switch between alternative streams to perform adaptive bitrate streaming.
During streaming of content, the playback devices 12 perform network bandwidth or data rate measurements. Each network bandwidth measurement can be timestamped and stored locally and/or sent to a performance server 18 that can store the network bandwidth measurement in a database 20. In many embodiments, the playback device sends network bandwidth measurements to the performance server continuously. In a number of embodiments, the playback device sends network bandwidth measurements to the performance server in batches.
When a playback device 12 initiates a new streaming session, previous measurements of network bandwidth made by a playback device can be utilized to estimate the available network bandwidth. Any of a variety of techniques appropriate to a specific application can be utilized to generate a network bandwidth estimate in accordance with embodiments of the invention. The generation of network bandwidth. estimates is discussed further below. Based upon the network bandwidth estimate, the playback device can determine the initial streams from which to commence requesting portions of encoded media based upon the maximum bitrates of the available streams. In several embodiments, the network performance server 18 generates the network bandwidth estimate and provides the network bandwidth estimate to the playback device. in a number of embodiments, the network performance server 18 generates a network bandwidth estimate and uses the estimate to provide initial stream selection recommendations to a playback device 12. In many embodiments, the playback device 12 generates the network bandwidth estimate based upon locally stored network bandwidth measurements. As is discussed .further below, the process of generating a network bandwidth estimate can also include determining the accuracy of the network bandwidth estimate. In a number of embodiments, the accuracy of a network bandwidth estimate is considered during the initial stream selection.
In several embodiments, playback devices 12 are able to purchase content for streaming via one or more online content stores 22. In many instances, the online content store will provide different pricing for content encoded at different resolutions. For example, a content store can charge a premium for content encoded at high definition resolution relative to content encoded at standard definition resolution. if insufficient network bandwidth is available to a playback device to stream the high definition content, the playback device may prefer to purchase the lower resolution content. In the context of conventional streaming, the playback device will experience frequent buffering interruptions by purchasing the premium content. In the context of adaptive bitrate streaming, the majority of the content received by the playback device likely will be at the lower resolution irrespective of whether the playback device purchases the premium content. In order to reduce the likelihood that a playback device 12 purchases premium content that cannot be supported by the available network bandwidth, the bandwidth available to the playback device can be estimated using the recorded network performance measurements and recommendations provided to the user concerning whether the premium content can be supported. In several embodiments, the process of generating a recommendation also involves determining the likelihood that the recommendation is correct. In a number of embodiments, the servers of the online content store 22 communicate with the performance server 18 to obtain a network performance estimate. In other embodiments, the playback device 12 generates the network performance estimate based upon locally stored records of past network bandwidth measurements.
Although a specific streaming system is illustrated in FIG. 1, performance servers can be incorporated into any of a variety of streaming system architectures where playback devices perform network bandwidth measurements in accordance with embodiments of the invention. In addition, individual playback devices can store network bandwidth measurements and perform network bandwidth estimates in accordance with embodiments of the invention. Playback devices that can be utilized to perform network bandwidth measurements during a streaming session in accordance with embodiments of the invention are discussed further below.
Playback Devices
In the embodiment illustrated in FIG. 1, playback devices include personal computers, CE players, and mobile phones. 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 and playing back encoded media. The basic architecture of a playback device in accordance with an embodiment of the invention is illustrated in FIG. 2. The playback device 30 includes a processor 32 in communication with non-volatile memory 34 and volatile memory 36. In the illustrated embodiment, the non-volatile memory includes a client application 38 that configures the processor and the playback device to stream content from a remote server. The nonvolatile memory 34 also includes cryptographic data 39 that can be utilized in accessing encrypted content. During operation, the client application can configure the playback device to measure network bandwidth. In many embodiments, the time taken to receive a requested block of data is used to measure network bandwidth. Network bandwidth measurements can be performed throughout a streaming session and can include information concerning the content distribution network and/or server from which the playback device requested the block of content. In many embodiments, the client application configures the playback device to record the specific stream requested. The client application can configure the playback device to store the network bandwidth measurements in the volatile or non-volatile memory of the playback device, In addition, the client application can configure the playback device to transmit the network bandwidth measurements to a performance server. The playback device can transmit network bandwidth measurements to a performance server as they are made and/or the playback device can buffer network bandwidth measurements and send them in batches to the performance server. Where bandwidth measurements are locally stored, the client application 38 can utilize the bandwidth measurements in making an initial stream selection(s). Where bandwidth measurements are provided to a performance server, the client application 38 configures the playback device to request an initial bandwidth estimate and/or accuracy information from the performance server.
In a number of embodiments, the playback device is configured to perform adaptive bitrate streaming. In several embodiments, a top level index file is stored and/or generated by a server within the content distribution network 14 or a server associated with the online content store 22. The top level index file specifies the alternative streams available to the playback device and the maximum bitrate of each stream. Therefore, a performance server and/or a playback device can utilize the index file to perform initial stream selections based upon a bandwidth estimate generated in accordance with embodiments of the invention. Examples of adaptive bitrate streaming systems that can be utilized in accordance with embodiments of the invention include but are not limited to the adaptive bitrate streaming systems disclosed in U.S. Provisional Patent Application Ser. No. 61/430,110, “Systems and Methods For Adaptive Bitrate Streaming of Media Stored in Matroska Files Using Hypertext Transfer Protocol”, filed Jan. 5, 2011, the entirety of which is incorporated herein by reference.
Although a specific playback device architecture is illustrated in FIG. 2, any of a variety of architectures including architectures where the client application 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 for use in multiphase adaptive bitrate streaming systems in accordance with embodiments of the invention. Furthermore, any of a variety of system architectures including (but not limited) to the system architecture illustrated in FIG. 1 can be utilized to measure network bandwidth and utilize the network bandwidth measurements to estimate network bandwidth when a playback device initiates a streaming session in accordance with embodiments of the invention.
Measuring Network Bandwidth
Any of a variety of processes can be utilized to measure network bandwidth arid decoder performance. A process for measuring network performance in accordance with an embodiment of the invention is illustrated in FIG. 3. The process 40 includes determining (42) network bandwidth. As discussed above, one process for determining network bandwidth or data rate is to request a block of data and to measure the time taken to download the data. In other embodiments, any of a variety of techniques for measuring network bandwidth can be utilized. in several embodiments, decoder performance is also measured (44). Decoder performance can be measured in any of a variety of different ways including measuring the time it takes to decode a frame of video, the average time taken to decode a frame of video, and/or CPU load. When the playback device performing the bandwidth measurements provides the bandwidth measurements to a performance server, the playback device can send (46) the timestamped information to the performance server and can include additional information including (but not limited to) the IP address or host name of the server from which the stream was received, the size of the data downloaded, and/or the maximum bitrate at which the stream is encoded. The timestamped performance information cart then be stored (48) for retrieval and use in the estimation of available bandwidth.
Although a specific process for estimating network bandwidth is illustrated in FIG. 3, any of a variety of processes appropriate to a specific application can be utilized in accordance with embodiments of the invention. Once the network bandwidth measurements are collected, estimation of available bandwidth can be performed either at the playback device or using, a performance server. Processes for estimating available bandwidth in accordance with embodiments of the invention are discussed below.
Estimating Network Bandwidth
Historical network bandwidth measurements can be utilized to select one or more initial streams when streaming content. A process for generating a bandwidth estimate using historical network bandwidth measurements in accordance with embodiments of the invention is illustrated in FIG. 4. The process 50 can be performed using a playback device, a performance server or a combination of a playback device and a performance server. When a performance server is utilized in the process, the process commences with the receipt (52) of a network bandwidth estimate request. The network bandwidth estimate is determined by retrieving (54) historical performance data and using the historical performance data to generate (56) an initial bandwidth recommendation. In a number of embodiments, the initial bandwidth recommendation is generated by averaging network bandwidth measurements included in the performance data. In several embodiments, network bandwidth measurements collected over a predetermined time period are averaged. In many embodiments, the network bandwidth measurements that occurred within a corresponding time of day and/or day of the week are averaged. In certain embodiments, network bandwidth measurements taken when content was streamed from a specific content distribution network and/or server are averaged. In other embodiments, the network bandwidth measurements and associated data can be filtered in any of a variety of ways to determine an initial bandwidth estimate. In a number of embodiments, the process of generating an initial bandwidth estimate also includes generating an estimate of the accuracy of the bandwidth estimate. In several embodiments, the accuracy of the bandwidth estimate can be determined as the ratio of previous bandwidth estimates to actual bandwidth or as a statistical measure such as (but not limited to) the standard deviation of the network bandwidth measurements utilized to generate the initial bandwidth estimate. In other embodiments, any of a variety of techniques can be utilized to determine the accuracy of an initial bandwidth estimate including (but not limited to) looking at trends for certain times of day. When the initial bandwidth estimate has been obtained, initial stream(s) are selected (58).
Although a specific process is illustrated in FIG. 4, any of a variety of processes for generating an initial bandwidth estimate and selecting streams can be utilized in accordance with embodiments of the invention. Processes for performing stream selection based upon an initial bandwidth estimate in accordance with embodiments of the invention are discussed further below.
Selecting initial Steams
When an estimate of the available bandwidth or bitrate has been obtained, a playback device can select one or more initial streams and commence streaming of the encoded content. A process for selecting initial stream(s) in accordance with an embodiment of the invention is illustrated in FIG. 5. When encoding content for adaptive bitrate streaming or conventional streaming at different resolutions, the source video is typically encoded as a number of alternative streams. Other portions of the source content, however, may simply he provided as a single stream (e.g. a specific audio track or a specific subtitle track). In the illustrated embodiment, the process 70 involves initially allocating bandwidth (72) to streams for which there are no alternatives. In many embodiments, bandwidth is initially allocated to streams for which there is no alternative and so the maximum bitrate is a fixed value. The total bitrate allocated to these fixed streams is then subtracted from the estimated available bitrate to obtain the remaining available bitrate for use by other streams. A selection (74) can then be made concerning alternative streams based upon the remaining available bandwidth. Where there are multiple sets of alternative streams from which selections can be made (e.g. multiple video streams encoded at different bitrates and multiple audio streams encoded at different bitrates), a tradeoff occurs between Which stream will be allocated the greater share of the available bandwidth. In a number of embodiments, the playback device makes a predetermined selection. In many embodiments, the predetermined selection is made based upon the available bandwidth and the maximum bitrates of the streams within the two sets of alternative streams. In several embodiments, the user can force the selection of a higher bitrate stream (e.g. the user can chose to force the selection of a higher rate video stream or a higher rate audio stream). Once the initial streams are selected, the playback device can commence requesting portions of encoded media from the initial streams and, in adaptive bitrate systems, can adjust the stream selections based upon the streaming conditions experienced by the playback device.
Although a specific process for selecting initial streams based upon an initial bandwidth estimate is discussed above with respect to FIG. 5, any of a variety of processes can be utilized to select initial streams based upon an initial bandwidth estimate in accordance with embodiments of the invention. In many embodiments, the initial bandwidth estimate is used as a conservative estimate and an adjustment factor can be applied to the initial bandwidth estimate. In several embodiments, the adjustment factor is a unction of the accuracy of the initial bandwidth estimate. In other embodiments, any of a variety of techniques can be utilized to apply an adjustment factor to the initial bandwidth estimate. Indeed, in many embodiments an adjustment is made during the process of determining the initial bandwidth estimate.
Premium Content Recommendations
Many content distribution systems charge a premium for higher resolution content, which is typically encoded at a higher maximum bitrate relative to lower resolution content. At the time of purchase, however, information is typically not available concerning the data rate of a network connection that can be established between the content distribution system and a playback device. In many instances, purchase of higher resolution content may result in an inferior playback experience due to repeated interruptions to buffer content. In adaptive bitrate streaming systems, insufficient network bandwidth may cause the majority of the video streamed to a playback device to be at a lower resolution than the resolution paid for by a user. Initial bandwidth estimates generated using stored network bandwidth measurements can be utilized to make recommendations concerning whether a user's playback device and network connection can support playback at a specific resolution.
A process for determining whether a playback device can support playback of a piece of content at a specific resolution in accordance with an embodiment of the invention is illustrated in FIG. 6. the process 90 can be performed using a performance server or using a playback device. The process 90 commences by obtaining (92) the bandwidth requirements of a specific piece of content. Historical network bandwidth measurements are retrieved (94) arid a determination made concerning whether playback is supported. The determination concerning whether playback is supported can be made in any of a variety of ways. Where a specific stream of content is concerned, a determination can be made based upon the proportion of time spent buffering content during playback of content encoded at a similar maximum bitrate. In several embodiments, network bandwidth measurements can be reviewed to estimate the bandwidth throughout playback to estimate the proportion of time that is likely to be spent buffering content. In a number of embodiments, modifications can be made to the amount of content that is buffered before playback commences based upon the bandwidth estimates to reduce the amount of time spent buffering during playback. In adaptive bitrate streaming systems, a determination can be made based upon the proportion of time spent streaming at or above the maximum bitrate of the content. Estimates of the network bandwidth for the duration of the content can also be utilized to estimate the proportion of time content at the specified resolution will be streamed.
As is the case with the initial bandwidth estimates discussed above, the network bandwidth measurements utilized to determine whether the bandwidth requirements of the content are supported can be filtered based upon one or more pieces of additional information associated with the network measurements including (but not limited to) time of day, date, and the content distribution network and/or server streaming the content. In many embodiments, the determination concerning whether the network bandwidth requirements are supported can be accompanied by a confidence factor or accuracy metric. In several embodiments, the confidence factor or accuracy metric can represent the proportion of time that is likely to be spent buffering or streaming at a lower resolution or reflect variation in the network bandwidth measurement data utilized to determine whether the network bandwidth requirements of the content can be supported. When the network bandwidth requirements can be met, the process 90 can involve generating (98) a user notification that the playback requirements can be met and/or authorizing the transaction. In embodiments Where a performance server makes the determination, the determination can be integrated within the user interface of a content distribution system and/or the determination can be integrated into the purchase process. In the event a determination is made that the network bandwidth requirements of a specific content resolution exceed the data rate that is likely to be available to a playback device, then a notification is generated (100) informing the user that they should not proceed with purchasing and/or streaming the content.
Although a specific process is illustrated in FIG. 6, any of a variety of processes for determining whether to stream and/or purchase a specific piece of content encoded with specific maximum bandwidth requirements including processes that utilize network bandwidth measurements collected by multiple playback devices from a similar geographic region and that utilize the same Internet service provider can be performed in accordance with embodiments. In several embodiments, a similar process is utilized to generate the number of interruptions and the amount of time spent buffering during playback, which can be displayed accompanying content selections. In adaptive bitrate streaming systems, similar processes can be used to estimate the proportion of time the content will be streamed at the displayed resolution. In both instances these estimates can be qualified by high end and low end estimates representing a predetermined confidence interval. In addition to making determinations concerning whether to purchase and/or stream a specific piece of content, network bandwidth measurements can be utilized in a variety of additional ways related to the purchase of content discussed below.
Content Distribution Network Recommendations
The data rate of a network connection experienced by a specific playback device can vary depending upon the content distribution network utilized to distribute content. In a number of embodiments, a content distribution system can offer premium content based not just on the resolution of the content but the content distribution network utilized to deliver the content. In many embodiments, a streaming system can provide a performance metric such as (but not limited to) an estimate of the amount of time the playback device will spend buffering during playback from different content distribution networks and can charge a premium based the higher playback performance anticipated when streaming from a premium content distribution network. In several embodiments, an adaptive bitrate streaming system can display a performance metric such as (but not limited to) an estimate of the proportion of time that a playback device will receive content encoded at the highest available resolution and charge a premium based upon the higher playback performance anticipated when streaming from a premium content distribution network.
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, including various changes in the implementation such as utilizing encoders and decoders that support features beyond those specified within a particular standard with which they comply, without departing from the scope and spirit of the present invention. Thus, embodiments of the present invention should be considered in all respects as illustrative and not restrictive.

Claims (23)

What is claimed:
1. A method of selecting an initial stream of encoded media from a plurality of streams of encoded media that are encoded at different maximum bitrates rates, the method comprising:
retrieving historical network performance data comprising a plurality of network bandwidth measurements from a memory of a playback device;
filtering the plurality of network bandwidth measurements based upon at least one piece of information associated with the network bandwidth measurements selected from the group consisting of time of day and day of week;
determining, using the playback device and prior to commencing streaming of encoded media, an initial network bandwidth estimate using the filtered network bandwidth measurements, wherein the initial network bandwidth estimate is determined by performing statistical analysis using the filtered network bandwidth measurements;
generating, using the playback device, an estimate of the accuracy of the initial network bandwidth estimate by (i) determining a ratio of previous bandwidth estimates to actual bandwidth or (ii) computing a standard deviation of the filtered network bandwidth measurements utilized to generate the initial bandwidth estimate;
selecting an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates rates using the playback device for commencing streaming of encoded media based upon the maximum bitrates of the plurality of streams, the initial network bandwidth estimate, and the accuracy of the initial network bandwidth estimate; and
commencing streaming of encoded media by requesting portions of the encoded media from the initial streams using the playback device.
2. The method of claim 1, wherein the statistical analysis comprises averaging the filtered network bandwidth measurements.
3. The method of claim 2, wherein the network bandwidth measurements are for content streamed from a particular content distribution network.
4. The method of claim 2, wherein the network bandwidth measurements occurred within a predetermined time period.
5. The method of claim 1, wherein the network bandwidth measurements occurred within a time of day or day of week.
6. The method of claim 1, wherein the initial network bandwidth estimate is determined by filtering the network bandwidth measurements based upon at least one piece of information associated with the network bandwidth measurements selected from the group consisting of time of day, day of week, content distribution network, server, and maximum bitrate.
7. A method of selecting an initial stream of encoded media from a plurality of streams of encoded media that are encoded at different maximum bitrates rates, the method comprising:
retrieving historical network performance data comprising a plurality of network bandwidth measurements from a memory of a playback device;
determining, using the playback device and prior to commencing streaming of encoded media, an initial network bandwidth estimate using the network bandwidth measurements, wherein the initial network bandwidth estimate is determined by performing statistical analysis using the network bandwidth measurements;
selecting an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates rates using the playback device for commencing streaming of encoded media based upon the maximum bitrates of the plurality of streams and the initial network bandwidth estimate, wherein the initial stream is selected by initially allocating available bandwidth to streams at least one secondary stream which have has no alternative and allocating the remaining bandwidth to the selection selecting the initial stream from the plurality of streams of encoded media that are encoded at different maximum bitrates based on the remaining bandwidth, wherein the at least one secondary stream is at least one selected from the group consisting of an audio stream and a subtitle stream; and
commencing streaming of encoded media by requesting portions of the encoded media from the initial streams using the playback device.
8. The method of claim 1, wherein the playback device performs the initial network bandwidth estimate using the filtered network bandwidth measurements.
9. The method of claim 1, further comprising:
providing the network bandwidth measurements to a performance server; wherein filtering the network bandwidth measurements is performed by the performance server and the performance server determines the initial network bandwidth estimate using the network bandwidth measurements.
10. The method of claim 1, wherein the initial stream is selected for use in the adaptive bitrate streaming of the encoded media.
11. The method of claim 1, further comprising selecting a stream from each of a number of sets of streams of encoded media that are encoded at different maximum bitrates.
12. The method of claim 1, further comprising measuring current network bandwidth using the playback device.
13. The method of claim 12, further comprising determining the initial network bandwidth estimate using the measured current network bandwidth measurements.
14. 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:
retrieving historical network performance data comprising a plurality of network bandwidth measurements;
filtering the plurality of network bandwidth measurements based upon at least one piece of information associated with the network bandwidth measurements selected from the group consisting of time of day and day of week;
determining, prior to commencing streaming of encoded media, an initial network bandwidth estimate using the filtered network bandwidth measurements, wherein the initial network bandwidth estimate is determined by performing statistical analysis using the filtered network bandwidth measurements;
generating an estimate of the accuracy of the initial network bandwidth estimate by (i) determining a ratio of previous bandwidth estimates to actual bandwidth or (ii) computing a standard deviation of the filtered network bandwidth measurements utilized to generate the initial bandwidth estimate
selecting an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates rates for commencing streaming of encoded media based upon the maximum bitrates of the plurality of streams, the initial network bandwidth estimate and the estimate of the accuracy of the initial network bandwidth estimate; and
commencing streaming of encoded media by requesting portions of the encoded media from the initial streams.
15. The non-transitory machine readable medium of claim 14, wherein performing the statistical analysis comprises averaging the filtered network bandwidth measurements.
16. The non-transitory machine readable medium of claim 14, wherein the network bandwidth measurements are for content streamed from a particular content distribution network.
17. The non-transitory machine readable medium of claim 14, wherein the network bandwidth measurements occurred within a predetermined time period.
18. The non-transitory machine readable medium of claim 14, wherein the network bandwidth measurements occurred within a time of day or day of week.
19. The method of claim 7, further comprising generating an estimate of the accuracy of the initial network bandwidth estimate by (i) determining a ratio of previous bandwidth estimates to actual bandwidth or (ii) computing a standard deviation of the network bandwidth measurements utilized to generate the initial bandwidth estimate.
20. The method of claim 7, wherein the initial network bandwidth estimate is determined by filtering the network bandwidth measurements based upon at least one piece of information associated with the network bandwidth measurements selected from the group consisting of time of day, day of week, content distribution network, server, and maximum bitrate.
21. A method of selecting an initial stream of encoded media from a plurality of streams of encoded media that are encoded at different maximum bitrates, the method comprising:
retrieving historical network performance data comprising a plurality of network bandwidth measurements;
filtering the plurality of network bandwidth measurements based upon at least one piece of information associated with the network bandwidth measurements selected from the group consisting of time of day and day of week to identify at least one network bandwidth measurement;
determining, using the playback device and prior to commencing streaming of encoded media, an initial network bandwidth estimate using the at least one network bandwidth measurement;
generating, using the playback device, an estimate of the accuracy of the initial network bandwidth estimate by (i) determining a ratio of the bandwidth estimate to actual bandwidth or (ii) when the at least one network bandwidth measurement comprises a filtered plurality of network bandwidth measurements, computing a standard deviation of the filtered plurality of network bandwidth measurements utilized to generate the initial bandwidth estimate;
selecting an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates rates using the playback device for commencing streaming of encoded media based upon the maximum bitrates of the plurality of streams, the initial network bandwidth estimate, and the accuracy of the initial network bandwidth estimate; and
commencing streaming of encoded media by requesting portions of the encoded media from the initial streams using the playback device.
22. 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:
retrieving historical network performance data comprising a plurality of network bandwidth measurements;
filtering the plurality of network bandwidth measurements based upon at least one piece of information associated with the network bandwidth measurements selected from the group consisting of time of day and day of week to identify at least one network bandwidth measurement;
determining, using the playback device and prior to commencing streaming of encoded media, an initial network bandwidth estimate using the at least one network bandwidth measurement;
generating, using the playback device, an estimate of the accuracy of the initial network bandwidth estimate by (i) determining a ratio of the bandwidth estimate to actual bandwidth or (ii) when the at least one network bandwidth measurement comprises a filtered plurality of bandwidth measurements, computing a standard deviation of the filtered plurality of network bandwidth measurements utilized to generate the initial bandwidth estimate;
selecting an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates using the playback device for commencing streaming of encoded media based upon the maximum bitrates of the plurality of streams, the initial network bandwidth estimate, and the accuracy of the initial network bandwidth estimate; and
commencing streaming of encoded media by requesting portions of the encoded media from the initial streams using the playback device.
23. A method of selecting an initial stream of encoded media from a plurality of streams of encoded media that are encoded at different maximum bitrates rates, the method comprising:
retrieving historical network performance data comprising at least one network bandwidth measurement from a memory of a playback device;
determining, using the playback device and prior to commencing streaming of encoded media, an initial network bandwidth estimate using the at least one network bandwidth measurement, wherein the initial network bandwidth estimate is determined by performing statistical analysis using the at least one network bandwidth measurement;
selecting an initial stream from said plurality of streams of encoded media that are encoded at different maximum bitrates rates using the playback device for commencing streaming of encoded media based upon the maximum bitrates of the plurality of streams and the initial network bandwidth estimate, wherein the initial stream is selected by initially allocating available bandwidth to at least one secondary stream which has no alternative and selecting the initial stream from the plurality of streams of encoded media that are encoded at different maximum bitrates based on the remaining bandwidth, wherein the at least one secondary stream is at least one selected from the group consisting of an audio stream and a subtitle stream; and
commencing streaming of encoded media by requesting portions of the encoded media from the initial streams using the playback device.
US15/950,988 2011-06-29 2018-04-11 Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content Active USRE48748E1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US15/950,988 USRE48748E1 (en) 2011-06-29 2018-04-11 Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US201161502767P 2011-06-29 2011-06-29
US13/341,838 US8812662B2 (en) 2011-06-29 2011-12-30 Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content
US14/461,674 US9313249B2 (en) 2011-06-29 2014-08-18 Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content
US15/950,988 USRE48748E1 (en) 2011-06-29 2018-04-11 Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US14/461,674 Reissue US9313249B2 (en) 2011-06-29 2014-08-18 Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content

Publications (1)

Publication Number Publication Date
USRE48748E1 true USRE48748E1 (en) 2021-09-21

Family

ID=47391807

Family Applications (3)

Application Number Title Priority Date Filing Date
US13/341,838 Active US8812662B2 (en) 2011-06-29 2011-12-30 Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content
US14/461,674 Ceased US9313249B2 (en) 2011-06-29 2014-08-18 Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content
US15/950,988 Active USRE48748E1 (en) 2011-06-29 2018-04-11 Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content

Family Applications Before (2)

Application Number Title Priority Date Filing Date
US13/341,838 Active US8812662B2 (en) 2011-06-29 2011-12-30 Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content
US14/461,674 Ceased US9313249B2 (en) 2011-06-29 2014-08-18 Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content

Country Status (2)

Country Link
US (3) US8812662B2 (en)
WO (1) WO2013002835A1 (en)

Families Citing this family (44)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9769231B1 (en) * 2011-04-01 2017-09-19 Arris Enterprises Llc QoS for adaptable HTTP video
US9954788B2 (en) * 2011-06-03 2018-04-24 Apple Inc. Bandwidth estimation based on statistical measures
US8812662B2 (en) 2011-06-29 2014-08-19 Sonic Ip, Inc. Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content
US9219765B2 (en) * 2012-05-10 2015-12-22 International Business Machines Corporation End user QoS selection
US8843656B2 (en) * 2012-06-12 2014-09-23 Cisco Technology, Inc. System and method for preventing overestimation of available bandwidth in adaptive bitrate streaming clients
US9402114B2 (en) 2012-07-18 2016-07-26 Cisco Technology, Inc. System and method for providing randomization in adaptive bitrate streaming environments
US9936267B2 (en) 2012-08-31 2018-04-03 Divx Cf Holdings Llc System and method for decreasing an initial buffering period of an adaptive streaming system
US9848213B2 (en) * 2012-09-20 2017-12-19 The Hong Kong University Of Science And Technology Linear programming based distributed multimedia storage and retrieval
US9516078B2 (en) 2012-10-26 2016-12-06 Cisco Technology, Inc. System and method for providing intelligent chunk duration
JP6123368B2 (en) * 2013-03-11 2017-05-10 株式会社リコー Information processing apparatus, communication control method, and program
US8984569B2 (en) * 2013-03-15 2015-03-17 Echostar Technologies L.L.C. Chunking of multiple track audio for adaptive bit rate streaming
US10110647B2 (en) * 2013-03-28 2018-10-23 Qualcomm Incorporated Method and apparatus for altering bandwidth consumption
CN103248962B (en) 2013-04-23 2016-12-28 华为技术有限公司 Obtain the method for stream medium data, equipment and system
US9552363B2 (en) 2013-04-30 2017-01-24 Microsoft Technology Licensing, Llc File management with placeholders
US9405767B2 (en) 2013-05-01 2016-08-02 Microsoft Technology Licensing, Llc Streaming content and placeholders
KR102046287B1 (en) * 2013-05-06 2019-11-18 콘비다 와이어리스, 엘엘씨 Internet of things(iot) adaptation services
WO2014194286A1 (en) 2013-05-31 2014-12-04 Level 3 Communications, Llc Storing content on a content delivery network
US9179355B2 (en) * 2014-01-09 2015-11-03 Apple Inc. Cell utilization estimation by a wireless device
US9628405B2 (en) 2014-04-07 2017-04-18 Ericsson Ab Merging multicast ABR and unicast ABR with progressive download ABR in a customer premises device within the same video delivery pipe
WO2016068873A1 (en) * 2014-10-28 2016-05-06 Hewlett Packard Enterprise Development Lp Media content download time
CN104394441B (en) * 2014-11-27 2019-06-14 北京奇艺世纪科技有限公司 A kind of dispatching method, the apparatus and system of video content distribution
US10291545B2 (en) 2014-12-08 2019-05-14 Samsung Electronics Co., Ltd. Method and apparatus for setting communicating session
US10666698B1 (en) * 2014-12-19 2020-05-26 Amazon Technologies, Inc. Bit rate selection for streaming media
US10708331B1 (en) * 2014-12-19 2020-07-07 Amazon Technologies, Inc. Generating requests for streaming media
US9686332B1 (en) 2014-12-19 2017-06-20 Amazon Technologies, Inc. Live stream manifests for on demand content
US10244270B2 (en) * 2015-03-25 2019-03-26 Amazon Technologies, Inc. Determining initial bit rate for adaptive bit rate video playback
US10993069B2 (en) * 2015-07-16 2021-04-27 Snap Inc. Dynamically adaptive media content delivery
US10164893B2 (en) 2015-08-19 2018-12-25 Samsung Electronics Co., Ltd. Data transfer apparatus, data transfer controlling method and data stream
US20170149613A1 (en) * 2015-11-25 2017-05-25 Aquto Corporation Distributing bandwidth capacity of a mobile communication network
US10194183B2 (en) 2015-12-29 2019-01-29 DISH Technologies L.L.C. Remote storage digital video recorder streaming and related methods
US10454987B2 (en) 2016-10-28 2019-10-22 Google Llc Bitrate optimization for multi-representation encoding using playback statistics
US10491645B2 (en) 2017-03-01 2019-11-26 At&T Intellectual Property I, L.P. System and method for switching between adaptive bit rate and fixed rate streams
US10523727B2 (en) * 2017-12-28 2019-12-31 Sling Media Pvt Ltd Adaptive bitrate optimization upon video streaming initialization
TWI681362B (en) * 2018-03-01 2020-01-01 瑞昱半導體股份有限公司 bandwidth-limited system and method for dynamically limiting memory bandwidth for GPU under bandwidth-limited system
CN108966008B (en) * 2018-08-02 2020-08-11 腾讯科技(深圳)有限公司 Live video playback method and device
CN109039833B (en) * 2018-09-30 2022-11-22 网宿科技股份有限公司 Method and device for monitoring bandwidth state
US11330317B2 (en) * 2018-12-28 2022-05-10 Dish Network L.L.C. Methods and systems for discovery of a processing offloader
CN111510747B (en) * 2019-01-30 2022-02-08 上海哔哩哔哩科技有限公司 Video definition determination method, system, computer device and storage medium
US11716508B2 (en) * 2019-02-01 2023-08-01 Ntt Docomo, Inc. Information processing apparatus, server apparatus, and information processing system
US11343551B1 (en) * 2019-07-23 2022-05-24 Amazon Technologies, Inc. Bandwidth estimation for video streams
US11647242B2 (en) 2019-07-30 2023-05-09 Comcast Cable Communications, Llc Methods and systems for low latency streaming
US11770318B2 (en) * 2021-03-15 2023-09-26 T-Mobile Usa, Inc. Systems and methods for estimating throughput
US20220400297A1 (en) * 2021-06-04 2022-12-15 Netskrt Systems, Inc. Method and apparatus for multicast control of a live video stream
US11743198B1 (en) * 2021-06-09 2023-08-29 T-Mobile Usa, Inc. Systems and methods for traffic classification

Citations (192)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5400401A (en) 1992-10-30 1995-03-21 Scientific Atlanta, Inc. System and method for transmitting a plurality of digital services
US5574785A (en) 1994-05-31 1996-11-12 Fujitsu Limited Enciphered communication system
US5600721A (en) 1993-07-30 1997-02-04 Sony Corporation Apparatus for scrambling a digital video signal
US5621794A (en) 1994-12-06 1997-04-15 Fujitsu Limited Moving-picture encipherment method and system, and enciphered moving-picture decipherment method and system
US5642338A (en) 1993-10-08 1997-06-24 Matsushita Electric Industrial Co., Ltd. Information recording medium and apparatus and method for recording and reproducing information
CA2237293A1 (en) 1995-12-29 1997-07-10 Scientific-Atlanta, Inc. Method and apparatus for providing conditional access in connection-oriented, interactive networks with a multiplicity of service providers
US5805700A (en) 1996-10-15 1998-09-08 Intel Corporation Policy based selective encryption of compressed video data
US5813010A (en) 1995-04-14 1998-09-22 Kabushiki Kaisha Toshiba Information storage and information transmission media with parental control
US5854873A (en) 1995-09-29 1998-12-29 Matsushita Electric Industrial Co., Ltd. Method and an apparatus for encoding a bitstream with plural possible searching reproduction paths information
US5907658A (en) 1995-08-21 1999-05-25 Matsushita Electric Industrial Co., Ltd. Multimedia optical disk, reproduction apparatus and method for achieving variable scene development based on interactive control
US5923869A (en) 1995-09-29 1999-07-13 Matsushita Electric Industrial Co., Ltd. Method and an apparatus for reproducing bitstream having non-sequential system clock data seamlessly therebetween
US6002834A (en) 1995-02-24 1999-12-14 Hitachi, Ltd. Optical disk having table relating sector address and time and optical disk reproducing apparatus
US6009237A (en) 1995-02-24 1999-12-28 Hitachi Ltd. Optical disk and optical disk reproduction apparatus
US6016381A (en) 1995-04-14 2000-01-18 Kabushiki Kaisha Toshiba Apparatus for reproducing information
US6057832A (en) 1997-12-02 2000-05-02 V Soft Ltd. Method and apparatus for video-on-demand with fast play capability
US6065050A (en) 1996-06-05 2000-05-16 Sun Microsystems, Inc. System and method for indexing between trick play and normal play video streams in a video delivery system
WO2000049763A1 (en) 1999-02-16 2000-08-24 Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. Method and device for generating an encoded user data stream and method and device for decoding such a data stream
WO2000049762A2 (en) 1999-02-16 2000-08-24 Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. Method and device for generating an encoded useful data stream and method and device for playing back an encoded user data stream
US6266483B1 (en) 1998-10-12 2001-07-24 Marsushita Electric Industrial Co Information recording medium, apparatus and method for recording or reproducing data thereof
US6282320B1 (en) 1997-03-19 2001-08-28 Sony Corporation Video data decoding apparatus and method and video signal reproduction apparatus and method
US20010021276A1 (en) 1998-11-30 2001-09-13 Equator Technologies, Inc. Image processing circuit and method for reducing a difference between pixel values across an image boundary
US6320905B1 (en) 1998-07-08 2001-11-20 Stream Machine Company Postprocessing system for removing blocking artifacts in block-based codecs
US20010052127A1 (en) 2000-06-09 2001-12-13 Lg Electronics Inc. Recording medium menu supporting method
US20010052077A1 (en) 1999-01-26 2001-12-13 Infolio, Inc. Universal mobile ID system and method for digital rights management
US6351538B1 (en) 1998-10-06 2002-02-26 Lsi Logic Corporation Conditional access and copy protection scheme for MPEG encoded video data
US6373803B2 (en) 1999-02-05 2002-04-16 Kabushiki Kaisha Toshiba Stream data generation method and partial erase processing method
US20020048450A1 (en) 2000-09-15 2002-04-25 International Business Machines Corporation System and method of processing MPEG streams for file index insertion
US6385673B1 (en) 1999-10-06 2002-05-07 Sun Microsystems, Inc. System and method for adjusting performance of a media storage by decreasing a maximum throughput by a primary derate parameter to specify available & guaranteed rate parameters and determining ring buffer sizes for streams
US20020067432A1 (en) 2000-10-20 2002-06-06 Satoshi Kondo Block distortion detection method, block distortion detection apparatus, block distortion removal method, and block distortion removal apparatus
US6415031B1 (en) 1999-03-12 2002-07-02 Diva Systems Corporation Selective and renewable encryption for secure distribution of video on-demand
US6445877B1 (en) 1998-11-19 2002-09-03 Matsushita Electric Industrial Co., Ltd. Information recording medium, apparatus and method for recording or reproducing data thereof
US6453115B1 (en) 2000-08-31 2002-09-17 Keen Personal Media, Inc. Digital video recording system which generates an index data structure for displaying a video stream in trickplay mode
US6453116B1 (en) 1999-02-18 2002-09-17 Kabushiki Kaisha Toshiba Recording medium of stream data, and recording method and playback method of the same
US20020135607A1 (en) 2000-04-21 2002-09-26 Motoki Kato Information processing apparatus and method, program, and recorded medium
US20020141503A1 (en) 1997-12-26 2002-10-03 Sony Corporation Picture signal processing method and apparatus
US20020154779A1 (en) 2000-01-26 2002-10-24 Tomoyuki Asano Data recording/reproducing device and saved data processing method, and program proving medium
US20020164024A1 (en) 2000-08-25 2002-11-07 Hiroshi Arakawa Data transmission method and data relay method
US20020169971A1 (en) 2000-01-21 2002-11-14 Tomoyuki Asano Data authentication system
US20030002577A1 (en) 2001-06-29 2003-01-02 Pinder Howard G. In a subscriber network receiving digital packets and transmitting digital packets below a predetermined maximum bit rate
US6504873B1 (en) 1997-06-13 2003-01-07 Nokia Mobile Phones Ltd. Filtering based on activities inside the video blocks and at their boundary
US6512883B2 (en) 1997-06-28 2003-01-28 Samsung Electronics Co., Ltd. Control apparatus and method for reproducing data from a digital video disk at high speed
US20030044080A1 (en) 2001-09-05 2003-03-06 Emblaze Systems Ltd Method for reducing blocking artifacts
US20030053541A1 (en) 2001-09-14 2003-03-20 Shijun Sun Adaptive filtering based upon boundary strength
US20030063675A1 (en) 2001-09-06 2003-04-03 Samsung Electronics Co., Ltd. Image data providing system and method thereof
US20030077071A1 (en) 2001-10-23 2003-04-24 Shu Lin Fast forward trick mode and reverse trick mode using an information file
WO2003047262A2 (en) 2001-11-29 2003-06-05 Matsushita Electric Industrial Co., Ltd. Coding distortion removal method and video encoding end decoding methods
US6594699B1 (en) 1997-10-10 2003-07-15 Kasenna, Inc. System for capability based multimedia streaming over a network
US20030135742A1 (en) 2002-01-16 2003-07-17 Evans Glenn F. Secure video card methods and systems
US20030142594A1 (en) 2002-01-31 2003-07-31 Kabushiki Kaisha Tobisha Information storage medium and information recording apparatus
US20030206717A1 (en) 2001-04-20 2003-11-06 Front Porch Digital Inc. Methods and apparatus for indexing and archiving encoded audio/video data
US6654933B1 (en) 1999-09-21 2003-11-25 Kasenna, Inc. System and method for media stream indexing
US6671408B1 (en) 1999-01-27 2003-12-30 Sanyo Electric Co., Ltd. Motion image reproducing apparatus
US20040001594A1 (en) 2002-06-28 2004-01-01 Microsoft Corporation Systems and methods for providing secure server key operations
WO2004012378A2 (en) 2002-07-30 2004-02-05 Digital Interactive Streams, Inc. Digital content security system and method
US20040022391A1 (en) 2002-07-30 2004-02-05 O'brien Royal Digital content security system and method
US20040028227A1 (en) 2002-08-08 2004-02-12 Yu Hong Heather Partial encryption of stream-formatted media
US20040037421A1 (en) 2001-12-17 2004-02-26 Truman Michael Mead Parital encryption of assembled bitstreams
US20040047592A1 (en) 2002-09-05 2004-03-11 Seo Kang Soo Recording medium having data structure of playlist marks for managing reproduction of still images recorded thereon and recording and reproducing methods and apparatuses
US20040047607A1 (en) 2002-09-06 2004-03-11 Seo Kang Soo Recording medium having data structure for managing reproduction of still images recorded thereon and recording and reproducing methods and apparatuses
US6724944B1 (en) 1997-03-13 2004-04-20 Nokia Mobile Phones, Ltd. Adaptive filter
US20040081333A1 (en) 2002-10-23 2004-04-29 Grab Eric W. Method and system for securing compressed digital video
KR20040039852A (en) 2002-11-05 2004-05-12 주식회사 디지털앤디지털 Trick play embodiment method using frame index
US20040093494A1 (en) 2001-11-15 2004-05-13 Yusei Nishimoto Control of usage of contents in digital broadcasts
US20040101059A1 (en) 2002-11-21 2004-05-27 Anthony Joch Low-complexity deblocking filter
US20040107356A1 (en) 1999-03-16 2004-06-03 Intertrust Technologies Corp. Methods and apparatus for persistent control and protection of content
US6751623B1 (en) 1998-01-26 2004-06-15 At&T Corp. Flexible interchange of coded multimedia facilitating access and streaming
US6813437B2 (en) 1999-01-14 2004-11-02 Kabushiki Kaisha Toshiba Digital video recording system and its recording medium
WO2004100158A1 (en) 2003-05-10 2004-11-18 Samsung Electronics Co., Ltd. Multimedia data reproducing apparatus, audio data receiving method and audio data structure therein
US20050013494A1 (en) 2003-07-18 2005-01-20 Microsoft Corporation In-loop deblocking filter
WO2005008385A2 (en) 2003-07-07 2005-01-27 Cryptography Research, Inc. Reprogrammable security for controlling piracy and enabling interactive content
WO2005015935A1 (en) 2003-08-07 2005-02-17 Pervenio Limited Server for determining and storing mobile device capability data
US6871006B1 (en) 2000-06-30 2005-03-22 Emc Corporation Processing of MPEG encoded video for trick mode operation
US20050063541A1 (en) 2002-11-05 2005-03-24 Candelore Brant L. Digital rights management of a digital device
US20050076232A1 (en) 2003-08-01 2005-04-07 Sony Corporation Client apparatus and content processing method in client apparatus, and content provision system
US6912513B1 (en) 1999-10-29 2005-06-28 Sony Corporation Copy-protecting management using a user scrambling key
US20050144468A1 (en) 2003-01-13 2005-06-30 Northcutt J. D. Method and apparatus for content protection in a personal digital network environment
US20050177741A1 (en) 2004-02-05 2005-08-11 Iue-Shuenn Chen System and method for security key transmission with strong pairing to destination client
US6931531B1 (en) 1998-09-02 2005-08-16 Matsushita Electric Industrial Co., Ltd. Image object recording, compression, and encryption method and system
US6957350B1 (en) 1996-01-30 2005-10-18 Dolby Laboratories Licensing Corporation Encrypted and watermarked temporal and resolution layering in advanced television
US20050243912A1 (en) 2004-04-29 2005-11-03 Do-Kyoung Kwon Adaptive de-blocking filtering apparatus and method for mpeg video decoder
US6970564B1 (en) 1998-07-13 2005-11-29 Sony Corporation Data multiplexing device, program distribution system, program transmission system, pay broadcast system, program transmission method, conditional access system, and data reception device
US20050265555A1 (en) 2004-05-12 2005-12-01 Nokia Corporation Integrity protection of streamed content
US6983079B2 (en) 2001-09-20 2006-01-03 Seiko Epson Corporation Reducing blocking and ringing artifacts in low-bit-rate coding
US20060002425A1 (en) 2004-06-30 2006-01-05 Mane Pravin D Determining available bandwidth in a network
US20060013568A1 (en) 2004-07-14 2006-01-19 Rodriguez Arturo A System and method for playback of digital video pictures in compressed streams
US20060031564A1 (en) 2004-05-24 2006-02-09 Brassil John T Methods and systems for streaming data at increasing transmission rates
US7006757B2 (en) 1999-03-17 2006-02-28 Kabushiki Kaisha Toshiba Recording method of stream data and data structure thereof
US7007170B2 (en) 2003-03-18 2006-02-28 Widevine Technologies, Inc. System, method, and apparatus for securely providing content viewable on a secure device
US7020287B2 (en) 2002-09-30 2006-03-28 Sony Corporation Method and system for key insertion for stored encrypted content
US7047309B2 (en) 2000-08-23 2006-05-16 International Business Machines Corporation Load balancing and dynamic control of multiple data streams in a network
US20060165163A1 (en) 2003-03-03 2006-07-27 Koninklijke Philips Electronics N.V. Video encoding
KR20060106250A (en) 2005-04-07 2006-10-12 (주)아이티너스 코리아 System for receiving or transmitting video contents and information security module used in the same
EP1283640B1 (en) 2001-07-24 2006-10-18 Seiko Epson Corporation Image processor and image processing program, and image processing method
US7151832B1 (en) 1999-11-18 2006-12-19 International Business Machines Corporation Dynamic encryption and decryption of a stream of data
US20070047645A1 (en) 2005-08-31 2007-03-01 Sony Corporation Information processing device, information recording medium manufacturing device, information recording medium, methods thereof, and computer program
US7188183B1 (en) 2000-08-04 2007-03-06 Oracle International Corporation Maintaining state information in mobile applications
US20070067472A1 (en) 2005-09-20 2007-03-22 Lsi Logic Corporation Accurate and error resilient time stamping method and/or apparatus for the audio-video interleaved (AVI) format
US20070083467A1 (en) 2005-10-10 2007-04-12 Apple Computer, Inc. Partial encryption techniques for media data
US20070086485A1 (en) 2001-06-14 2007-04-19 Microsoft Corporation Method and system for providing adaptive bandwith control for real-time communication
US7242772B1 (en) 2000-09-07 2007-07-10 Eastman Kodak Company Encryption apparatus and method for synchronizing multiple encryption keys with a data stream
US20070180051A1 (en) 2006-02-02 2007-08-02 Microsoft Corporation Version-specific content searching
US7274861B2 (en) 2003-04-10 2007-09-25 Matsushita Electric Industrial Co., Ltd. Information recording medium, and apparatus and method for recording information to information recording medium
US7349886B2 (en) 2005-03-25 2008-03-25 Widevine Technologies, Inc. Securely relaying content using key chains
US7352956B1 (en) 1999-03-19 2008-04-01 Thomson Licensing Method for implementing trickplay modes in a data stream recorder
US20080086570A1 (en) 2006-10-10 2008-04-10 Ortiva Wireless Digital content buffer for adaptive streaming
US20080101718A1 (en) 2006-10-25 2008-05-01 Realtek Semiconductor Corp. Apparatus and method for deblock filtering
US7382879B1 (en) 2003-07-23 2008-06-03 Sprint Communications Company, L.P. Digital rights management negotiation for streaming media over a network
US20080137847A1 (en) 2002-01-02 2008-06-12 Candelore Brant L Video slice and active region based multiple partial encryption
US7397853B2 (en) 2004-04-29 2008-07-08 Mediatek Incorporation Adaptive de-blocking filtering apparatus and method for MPEG video decoder
US7400679B2 (en) 2004-04-29 2008-07-15 Mediatek Incorporation Adaptive de-blocking filtering apparatus and method for MPEG video decoder
US7418132B2 (en) 2003-07-01 2008-08-26 Nikon Corporation Signal processing apparatus, signal processing program and electronic camera
US7457415B2 (en) 1998-08-20 2008-11-25 Akikaze Technologies, Llc Secure information distribution system utilizing information segment scrambling
US20090013195A1 (en) 2005-01-18 2009-01-08 Matsushita Electric Industrial Co., Ltd. Data Storing Method, Data Playback Method, Data Recording Device, Data Playback Device, and Recording Medium
US20090010622A1 (en) 2004-08-17 2009-01-08 Hiroshi Yahata Information Recording Medium, Data Sorting Device, and Data Reproduction Device
WO2009006302A1 (en) 2007-06-29 2009-01-08 Widevine Technologies, Inc. Progressive download or streaming of digital media securely through a localized container and communication protocol proxy
US7499930B2 (en) 2004-01-28 2009-03-03 Canon Kabushiki Kaisha Data processing apparatus, data processing method, and data processing program
US20090077143A1 (en) 2003-06-30 2009-03-19 Macy Jr William W Nonlinear filtering and deblocking applications utilizing SIMD sign and absolute value operations
US20090106082A1 (en) 2007-10-23 2009-04-23 Senti Thad E System and method to facilitate targeted advertising
US20090132599A1 (en) 2007-11-16 2009-05-21 Kourosh Soroushian Hierarchical and reduced index structures for multimedia files
US20090144425A1 (en) * 2007-12-04 2009-06-04 Sony Computer Entertainment Inc. Network bandwidth detection, distribution and traffic prioritization
US7546641B2 (en) 2004-02-13 2009-06-09 Microsoft Corporation Conditional access to digital rights management conversion
US20090178090A1 (en) 2007-10-01 2009-07-09 Cabot Communications Method and apparatus for streaming digital media content and a communication system
WO2009109976A2 (en) 2008-03-05 2009-09-11 Webtview Ltd. Distributing internet channels to a media viewer
US20090249081A1 (en) 2008-03-31 2009-10-01 Kabushiki Kaisha Toshiba-1 Shibaura 1-Chomominatoku Storage device encryption and method
US20090282162A1 (en) 2008-05-12 2009-11-12 Microsoft Corporation Optimized client side rate control and indexed file layout for streaming media
US20090300203A1 (en) * 2008-05-30 2009-12-03 Microsoft Corporation Stream selection for enhanced media streaming
US20090310819A1 (en) 2006-07-19 2009-12-17 Panasonic Corporation Media data processing apparatus and media data processing method
US7639921B2 (en) 2002-11-20 2009-12-29 Lg Electronics Inc. Recording medium having data structure for managing reproduction of still images recorded thereon and recording and reproducing methods and apparatuses
EP2180664A1 (en) 2008-10-22 2010-04-28 Vivendi Mobile Entertainment System and method for accessing multi-media content via a mobile terminal
US7711052B2 (en) 2000-05-15 2010-05-04 Nokia Corporation Video coding
US20100142915A1 (en) 2008-06-06 2010-06-10 Deluxe Digital Studios, Inc. Methods and systems for use in providing playback of variable length content in a fixed length framework
US7770200B2 (en) * 2007-07-24 2010-08-03 Time Warner Cable Inc. Methods and apparatus for format selection for network optimization
US20100235542A1 (en) 2008-11-24 2010-09-16 Zubair Visharam Dynamic Variable Rate Media Delivery System
US20100306810A1 (en) 2007-07-24 2010-12-02 Time Warner Cable Inc. Methods and apparatus for format selection for network optimization
US20100306373A1 (en) 2009-06-01 2010-12-02 Swarmcast, Inc. Data retrieval based on bandwidth cost and delay
US7853980B2 (en) 2003-10-31 2010-12-14 Sony Corporation Bi-directional indices for trick mode video-on-demand
US7864186B2 (en) 2000-08-07 2011-01-04 Robotham John S Device-specific content versioning
US20110010466A1 (en) 2008-03-21 2011-01-13 Huawei Technologies Co., Ltd. Dynamic content delivery method and apparatus
US20110058675A1 (en) 2009-09-04 2011-03-10 Brueck David F Controlling access to copies of media content by a client device
US20110066673A1 (en) 2009-09-14 2011-03-17 Adobe Systems Incorporated Dynamic stream switch control
US20110096828A1 (en) 2009-09-22 2011-04-28 Qualcomm Incorporated Enhanced block-request streaming using scalable encoding
US20110103374A1 (en) 2009-10-30 2011-05-05 Lajoie Michael L Methods and apparatus for packetized content delivery over a content delivery network
US7945143B2 (en) 2001-07-23 2011-05-17 Panasonic Corporation Information recording medium, and apparatus and method for recording information on information recording medium
US20110135090A1 (en) 2009-12-04 2011-06-09 Divx, Llc. Elementary bitstream cryptographic material transport systems and methods
US20110145858A1 (en) 2009-11-19 2011-06-16 Gregory Philpott System And Method For Delivering Content To Mobile Devices
US20110173345A1 (en) 2009-08-17 2011-07-14 Akamai Technologies, Inc. Method and system for HTTP-based stream delivery
US20110179185A1 (en) 2010-01-20 2011-07-21 Futurewei Technologies, Inc. System and Method for Adaptive Differentiated Streaming
WO2011087449A1 (en) 2010-01-18 2011-07-21 Telefonaktiebolaget L M Ericsson (Publ) Methods and arrangements for http media stream distribution
US20110197261A1 (en) 2008-09-22 2011-08-11 Huawei Device Co., Ltd. Service activation method, service providing method, terminal device, and server
EP2360923A1 (en) 2010-02-24 2011-08-24 Thomson Licensing Method for selectively requesting adaptive streaming content and a device implementing the method
WO2011103364A1 (en) 2010-02-17 2011-08-25 Verimatrix, Inc. Systems and methods for securing content delivered using a playlist
WO2011101371A1 (en) 2010-02-19 2011-08-25 Thomson Licensing Multipath delivery for adaptive streaming
US8009575B1 (en) * 2006-10-12 2011-08-30 Sprint Communications Company L.P. Network capacity forecasting and maintenance
US20110246661A1 (en) 2010-04-02 2011-10-06 Disney Enterprises, Inc. Streaming playback and dynamic Ad insertion
US20110296048A1 (en) 2009-12-28 2011-12-01 Akamai Technologies, Inc. Method and system for stream handling using an intermediate format
US20110314130A1 (en) 2010-04-08 2011-12-22 Nery Strasman Managing streaming bandwidth for multiple clients
US20120005312A1 (en) 2010-06-30 2012-01-05 Unicorn Media, Inc. Dynamic chunking for media streaming
US8099757B2 (en) * 2007-10-15 2012-01-17 Time Warner Cable Inc. Methods and apparatus for revenue-optimized delivery of content in a network
US20120042090A1 (en) 2010-08-10 2012-02-16 Qualcomm Incorporated Manifest file updates for network streaming of coded multimedia data
US20120047542A1 (en) 2010-08-20 2012-02-23 Disney Enterprises, Inc. System and method for rule based dynamic server side streaming manifest files
US8131875B1 (en) 2007-11-26 2012-03-06 Adobe Systems Incorporated Device profile assignment based on device capabilities
US8169916B1 (en) 2007-11-23 2012-05-01 Media Melon, Inc. Multi-platform video delivery configuration
US20120110120A1 (en) 2010-11-02 2012-05-03 Johannes Willig Methods and Devices for Media Description Delivery
US20120141089A1 (en) * 2010-12-06 2012-06-07 Hunt Neil D Variable Bit Video Streams for Adaptive Streaming
US20120167132A1 (en) 2010-12-23 2012-06-28 Verizon Patent And Licensing Inc. Advertising insertion for playback of video streams on user devices
US20120173751A1 (en) 2011-01-05 2012-07-05 Rovi Technologies Corporation Systems and methods for adaptive bitrate streaming of media stored in matroska container files using hypertext transfer protocol
US20120179834A1 (en) 2011-01-06 2012-07-12 Divx, Llc Systems and Methods for Performing Adaptive Bitrate Streaming Based Upon the Delay of Each Stream and the Channel Rate
US8286213B2 (en) 2003-05-13 2012-10-09 Lg Electronics Inc. HTTP based video streaming apparatus and method in mobile communication system
US8312079B2 (en) 2009-09-22 2012-11-13 Thwapr, Inc. Adaptive rendering for mobile media sharing
US20120324519A1 (en) 2011-06-15 2012-12-20 Microsoft Corporation Streaming media bandwidth reduction
US20120331167A1 (en) 2011-06-22 2012-12-27 Hunt Neil D Fast start of streaming digital media playback with deferred license retrieval
US20130007297A1 (en) 2011-06-29 2013-01-03 Divx, Llc Systems and Methods for Performing Multiphase Adaptive Bitrate Streaming
WO2013002828A2 (en) 2011-06-30 2013-01-03 Divx, Llc Systems and methods for determining available bandwidth and performing initial stream selection when commencing streaming using hypertext transfer protocol
US20130007263A1 (en) 2011-06-29 2013-01-03 Divx, Llc Systems and Methods for Estimating Available Bandwidth and Performing Initial Stream Selection When Streaming Content
US20130013803A1 (en) 2010-04-01 2013-01-10 Guillaume Bichot Method for recovering content streamed into chunk
US8369421B2 (en) 2001-11-29 2013-02-05 Panasonic Corporation Coding distortion removal method by selectively filtering based on a pixel difference
US20130080267A1 (en) 2011-09-26 2013-03-28 Unicorn Media, Inc. Single-url content delivery
US8516144B2 (en) 2011-04-29 2013-08-20 Cbs Interactive Inc. Startup bitrate in adaptive bitrate streaming
US20140068096A1 (en) 2012-08-31 2014-03-06 Divx, Llc System and Method for Decreasing an Initial Buffering Period of an Adaptive Streaming System
US8683066B2 (en) 2007-08-06 2014-03-25 DISH Digital L.L.C. Apparatus, system, and method for multi-bitrate content streaming
US20140140253A1 (en) 2011-06-28 2014-05-22 Telefonaktiebolaget L M Ericsson (Publ) Technique for managing streaming media traffic at a network entity
US20140149557A1 (en) 2011-07-07 2014-05-29 Telefonaktiebolaget L M Ericsson (Publ) Network-Capacity Optimized Adaptive HTTP Streaming
US8782268B2 (en) 2010-07-20 2014-07-15 Microsoft Corporation Dynamic composition of media
US8819116B1 (en) 2010-03-08 2014-08-26 Amazon Technologies, Inc. Providing services using a device capabilities service
US8849950B2 (en) 2011-04-07 2014-09-30 Qualcomm Incorporated Network streaming of video data using byte range requests
US8918533B2 (en) 2010-07-13 2014-12-23 Qualcomm Incorporated Video switching for streaming video data
US9038116B1 (en) 2009-12-28 2015-05-19 Akamai Technologies, Inc. Method and system for recording streams
US9088527B2 (en) * 2011-02-08 2015-07-21 Avaya Inc. Method and system for communication session bandwidth control based on actual bandwidth usage
US9124642B2 (en) 2009-10-16 2015-09-01 Qualcomm Incorporated Adaptively streaming multimedia
US20150288530A1 (en) 2011-08-11 2015-10-08 Ozgur Oyman Methods for switching between a mbms download and an http-based delivery of dash formatted content over an ims network
US9420024B2 (en) * 2010-10-25 2016-08-16 Gregory A. Pearson, Inc. Dynamic content delivery systems and methods for providing same
US9521178B1 (en) 2009-12-21 2016-12-13 Amazon Technologies, Inc. Dynamic bandwidth thresholds

Patent Citations (216)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5400401A (en) 1992-10-30 1995-03-21 Scientific Atlanta, Inc. System and method for transmitting a plurality of digital services
US5600721A (en) 1993-07-30 1997-02-04 Sony Corporation Apparatus for scrambling a digital video signal
US5642338A (en) 1993-10-08 1997-06-24 Matsushita Electric Industrial Co., Ltd. Information recording medium and apparatus and method for recording and reproducing information
US5574785A (en) 1994-05-31 1996-11-12 Fujitsu Limited Enciphered communication system
US5621794A (en) 1994-12-06 1997-04-15 Fujitsu Limited Moving-picture encipherment method and system, and enciphered moving-picture decipherment method and system
US6009237A (en) 1995-02-24 1999-12-28 Hitachi Ltd. Optical disk and optical disk reproduction apparatus
US6002834A (en) 1995-02-24 1999-12-14 Hitachi, Ltd. Optical disk having table relating sector address and time and optical disk reproducing apparatus
US6016381A (en) 1995-04-14 2000-01-18 Kabushiki Kaisha Toshiba Apparatus for reproducing information
US5813010A (en) 1995-04-14 1998-09-22 Kabushiki Kaisha Toshiba Information storage and information transmission media with parental control
US5907658A (en) 1995-08-21 1999-05-25 Matsushita Electric Industrial Co., Ltd. Multimedia optical disk, reproduction apparatus and method for achieving variable scene development based on interactive control
US5854873A (en) 1995-09-29 1998-12-29 Matsushita Electric Industrial Co., Ltd. Method and an apparatus for encoding a bitstream with plural possible searching reproduction paths information
US5923869A (en) 1995-09-29 1999-07-13 Matsushita Electric Industrial Co., Ltd. Method and an apparatus for reproducing bitstream having non-sequential system clock data seamlessly therebetween
CA2237293A1 (en) 1995-12-29 1997-07-10 Scientific-Atlanta, Inc. Method and apparatus for providing conditional access in connection-oriented, interactive networks with a multiplicity of service providers
US6957350B1 (en) 1996-01-30 2005-10-18 Dolby Laboratories Licensing Corporation Encrypted and watermarked temporal and resolution layering in advanced television
US6065050A (en) 1996-06-05 2000-05-16 Sun Microsystems, Inc. System and method for indexing between trick play and normal play video streams in a video delivery system
US5805700A (en) 1996-10-15 1998-09-08 Intel Corporation Policy based selective encryption of compressed video data
US6724944B1 (en) 1997-03-13 2004-04-20 Nokia Mobile Phones, Ltd. Adaptive filter
US6282320B1 (en) 1997-03-19 2001-08-28 Sony Corporation Video data decoding apparatus and method and video signal reproduction apparatus and method
US6504873B1 (en) 1997-06-13 2003-01-07 Nokia Mobile Phones Ltd. Filtering based on activities inside the video blocks and at their boundary
US6512883B2 (en) 1997-06-28 2003-01-28 Samsung Electronics Co., Ltd. Control apparatus and method for reproducing data from a digital video disk at high speed
US6594699B1 (en) 1997-10-10 2003-07-15 Kasenna, Inc. System for capability based multimedia streaming over a network
US6057832A (en) 1997-12-02 2000-05-02 V Soft Ltd. Method and apparatus for video-on-demand with fast play capability
US20020141503A1 (en) 1997-12-26 2002-10-03 Sony Corporation Picture signal processing method and apparatus
US6751623B1 (en) 1998-01-26 2004-06-15 At&T Corp. Flexible interchange of coded multimedia facilitating access and streaming
US6320905B1 (en) 1998-07-08 2001-11-20 Stream Machine Company Postprocessing system for removing blocking artifacts in block-based codecs
US6970564B1 (en) 1998-07-13 2005-11-29 Sony Corporation Data multiplexing device, program distribution system, program transmission system, pay broadcast system, program transmission method, conditional access system, and data reception device
US7457415B2 (en) 1998-08-20 2008-11-25 Akikaze Technologies, Llc Secure information distribution system utilizing information segment scrambling
US6931531B1 (en) 1998-09-02 2005-08-16 Matsushita Electric Industrial Co., Ltd. Image object recording, compression, and encryption method and system
US6351538B1 (en) 1998-10-06 2002-02-26 Lsi Logic Corporation Conditional access and copy protection scheme for MPEG encoded video data
US6266483B1 (en) 1998-10-12 2001-07-24 Marsushita Electric Industrial Co Information recording medium, apparatus and method for recording or reproducing data thereof
US6445877B1 (en) 1998-11-19 2002-09-03 Matsushita Electric Industrial Co., Ltd. Information recording medium, apparatus and method for recording or reproducing data thereof
US20010021276A1 (en) 1998-11-30 2001-09-13 Equator Technologies, Inc. Image processing circuit and method for reducing a difference between pixel values across an image boundary
US6690838B2 (en) 1998-11-30 2004-02-10 Equator Technologies, Inc. Image processing circuit and method for reducing a difference between pixel values across an image boundary
US6813437B2 (en) 1999-01-14 2004-11-02 Kabushiki Kaisha Toshiba Digital video recording system and its recording medium
US20010052077A1 (en) 1999-01-26 2001-12-13 Infolio, Inc. Universal mobile ID system and method for digital rights management
US6671408B1 (en) 1999-01-27 2003-12-30 Sanyo Electric Co., Ltd. Motion image reproducing apparatus
US6373803B2 (en) 1999-02-05 2002-04-16 Kabushiki Kaisha Toshiba Stream data generation method and partial erase processing method
WO2000049762A2 (en) 1999-02-16 2000-08-24 Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. Method and device for generating an encoded useful data stream and method and device for playing back an encoded user data stream
WO2000049763A1 (en) 1999-02-16 2000-08-24 Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. Method and device for generating an encoded user data stream and method and device for decoding such a data stream
US6453116B1 (en) 1999-02-18 2002-09-17 Kabushiki Kaisha Toshiba Recording medium of stream data, and recording method and playback method of the same
US6415031B1 (en) 1999-03-12 2002-07-02 Diva Systems Corporation Selective and renewable encryption for secure distribution of video on-demand
US20040107356A1 (en) 1999-03-16 2004-06-03 Intertrust Technologies Corp. Methods and apparatus for persistent control and protection of content
US7006757B2 (en) 1999-03-17 2006-02-28 Kabushiki Kaisha Toshiba Recording method of stream data and data structure thereof
US7352956B1 (en) 1999-03-19 2008-04-01 Thomson Licensing Method for implementing trickplay modes in a data stream recorder
US6654933B1 (en) 1999-09-21 2003-11-25 Kasenna, Inc. System and method for media stream indexing
US6385673B1 (en) 1999-10-06 2002-05-07 Sun Microsystems, Inc. System and method for adjusting performance of a media storage by decreasing a maximum throughput by a primary derate parameter to specify available & guaranteed rate parameters and determining ring buffer sizes for streams
US6912513B1 (en) 1999-10-29 2005-06-28 Sony Corporation Copy-protecting management using a user scrambling key
US7151832B1 (en) 1999-11-18 2006-12-19 International Business Machines Corporation Dynamic encryption and decryption of a stream of data
US20020169971A1 (en) 2000-01-21 2002-11-14 Tomoyuki Asano Data authentication system
US20020154779A1 (en) 2000-01-26 2002-10-24 Tomoyuki Asano Data recording/reproducing device and saved data processing method, and program proving medium
US20020135607A1 (en) 2000-04-21 2002-09-26 Motoki Kato Information processing apparatus and method, program, and recorded medium
US7711052B2 (en) 2000-05-15 2010-05-04 Nokia Corporation Video coding
US20010052127A1 (en) 2000-06-09 2001-12-13 Lg Electronics Inc. Recording medium menu supporting method
US6871006B1 (en) 2000-06-30 2005-03-22 Emc Corporation Processing of MPEG encoded video for trick mode operation
US7188183B1 (en) 2000-08-04 2007-03-06 Oracle International Corporation Maintaining state information in mobile applications
US7864186B2 (en) 2000-08-07 2011-01-04 Robotham John S Device-specific content versioning
US7047309B2 (en) 2000-08-23 2006-05-16 International Business Machines Corporation Load balancing and dynamic control of multiple data streams in a network
US20020164024A1 (en) 2000-08-25 2002-11-07 Hiroshi Arakawa Data transmission method and data relay method
US6453115B1 (en) 2000-08-31 2002-09-17 Keen Personal Media, Inc. Digital video recording system which generates an index data structure for displaying a video stream in trickplay mode
US7242772B1 (en) 2000-09-07 2007-07-10 Eastman Kodak Company Encryption apparatus and method for synchronizing multiple encryption keys with a data stream
US20020048450A1 (en) 2000-09-15 2002-04-25 International Business Machines Corporation System and method of processing MPEG streams for file index insertion
US7212726B2 (en) 2000-09-15 2007-05-01 International Business Machines Corporation System and method of processing MPEG streams for file index insertion
US20020067432A1 (en) 2000-10-20 2002-06-06 Satoshi Kondo Block distortion detection method, block distortion detection apparatus, block distortion removal method, and block distortion removal apparatus
US20030206717A1 (en) 2001-04-20 2003-11-06 Front Porch Digital Inc. Methods and apparatus for indexing and archiving encoded audio/video data
US20070086485A1 (en) 2001-06-14 2007-04-19 Microsoft Corporation Method and system for providing adaptive bandwith control for real-time communication
US20030002577A1 (en) 2001-06-29 2003-01-02 Pinder Howard G. In a subscriber network receiving digital packets and transmitting digital packets below a predetermined maximum bit rate
US7945143B2 (en) 2001-07-23 2011-05-17 Panasonic Corporation Information recording medium, and apparatus and method for recording information on information recording medium
EP1283640B1 (en) 2001-07-24 2006-10-18 Seiko Epson Corporation Image processor and image processing program, and image processing method
US20030044080A1 (en) 2001-09-05 2003-03-06 Emblaze Systems Ltd Method for reducing blocking artifacts
US20030063675A1 (en) 2001-09-06 2003-04-03 Samsung Electronics Co., Ltd. Image data providing system and method thereof
US20030053541A1 (en) 2001-09-14 2003-03-20 Shijun Sun Adaptive filtering based upon boundary strength
US6983079B2 (en) 2001-09-20 2006-01-03 Seiko Epson Corporation Reducing blocking and ringing artifacts in low-bit-rate coding
US20030077071A1 (en) 2001-10-23 2003-04-24 Shu Lin Fast forward trick mode and reverse trick mode using an information file
US20040093494A1 (en) 2001-11-15 2004-05-13 Yusei Nishimoto Control of usage of contents in digital broadcasts
US20040076237A1 (en) 2001-11-29 2004-04-22 Shinya Kadono Coding distortion removal method, moving picture coding method, moving picture decoding method, and apparatus for realizing the same, program
US8369421B2 (en) 2001-11-29 2013-02-05 Panasonic Corporation Coding distortion removal method by selectively filtering based on a pixel difference
EP1453319A1 (en) 2001-11-29 2004-09-01 Matsushita Electric Industrial Co., Ltd. Coding distortion removal method; moving picture coding method; moving picture decoding method; and apparatus for realizing the same; program
WO2003047262A2 (en) 2001-11-29 2003-06-05 Matsushita Electric Industrial Co., Ltd. Coding distortion removal method and video encoding end decoding methods
US20040037421A1 (en) 2001-12-17 2004-02-26 Truman Michael Mead Parital encryption of assembled bitstreams
US20080137847A1 (en) 2002-01-02 2008-06-12 Candelore Brant L Video slice and active region based multiple partial encryption
US20030135742A1 (en) 2002-01-16 2003-07-17 Evans Glenn F. Secure video card methods and systems
US20030142594A1 (en) 2002-01-31 2003-07-31 Kabushiki Kaisha Tobisha Information storage medium and information recording apparatus
US20040001594A1 (en) 2002-06-28 2004-01-01 Microsoft Corporation Systems and methods for providing secure server key operations
US20040022391A1 (en) 2002-07-30 2004-02-05 O'brien Royal Digital content security system and method
WO2004012378A2 (en) 2002-07-30 2004-02-05 Digital Interactive Streams, Inc. Digital content security system and method
US20040028227A1 (en) 2002-08-08 2004-02-12 Yu Hong Heather Partial encryption of stream-formatted media
US20040047592A1 (en) 2002-09-05 2004-03-11 Seo Kang Soo Recording medium having data structure of playlist marks for managing reproduction of still images recorded thereon and recording and reproducing methods and apparatuses
US20040047607A1 (en) 2002-09-06 2004-03-11 Seo Kang Soo Recording medium having data structure for managing reproduction of still images recorded thereon and recording and reproducing methods and apparatuses
US7020287B2 (en) 2002-09-30 2006-03-28 Sony Corporation Method and system for key insertion for stored encrypted content
US20040081333A1 (en) 2002-10-23 2004-04-29 Grab Eric W. Method and system for securing compressed digital video
US7295673B2 (en) 2002-10-23 2007-11-13 Divx, Inc. Method and system for securing compressed digital video
KR20040039852A (en) 2002-11-05 2004-05-12 주식회사 디지털앤디지털 Trick play embodiment method using frame index
US20050063541A1 (en) 2002-11-05 2005-03-24 Candelore Brant L. Digital rights management of a digital device
US7639921B2 (en) 2002-11-20 2009-12-29 Lg Electronics Inc. Recording medium having data structure for managing reproduction of still images recorded thereon and recording and reproducing methods and apparatuses
US20040101059A1 (en) 2002-11-21 2004-05-27 Anthony Joch Low-complexity deblocking filter
US20050144468A1 (en) 2003-01-13 2005-06-30 Northcutt J. D. Method and apparatus for content protection in a personal digital network environment
US20060165163A1 (en) 2003-03-03 2006-07-27 Koninklijke Philips Electronics N.V. Video encoding
US7640435B2 (en) 2003-03-18 2009-12-29 Widevine Technologies, Inc. System, method, and apparatus for securely providing content viewable on a secure device
US7007170B2 (en) 2003-03-18 2006-02-28 Widevine Technologies, Inc. System, method, and apparatus for securely providing content viewable on a secure device
US7274861B2 (en) 2003-04-10 2007-09-25 Matsushita Electric Industrial Co., Ltd. Information recording medium, and apparatus and method for recording information to information recording medium
RU2328040C2 (en) 2003-05-10 2008-06-27 Самсунг Электроникс Ко., Лтд. Multimedia data reproducing device, method and structure of audio data receipt
WO2004100158A1 (en) 2003-05-10 2004-11-18 Samsung Electronics Co., Ltd. Multimedia data reproducing apparatus, audio data receiving method and audio data structure therein
US8286213B2 (en) 2003-05-13 2012-10-09 Lg Electronics Inc. HTTP based video streaming apparatus and method in mobile communication system
US20090077143A1 (en) 2003-06-30 2009-03-19 Macy Jr William W Nonlinear filtering and deblocking applications utilizing SIMD sign and absolute value operations
US7418132B2 (en) 2003-07-01 2008-08-26 Nikon Corporation Signal processing apparatus, signal processing program and electronic camera
WO2005008385A2 (en) 2003-07-07 2005-01-27 Cryptography Research, Inc. Reprogrammable security for controlling piracy and enabling interactive content
US20050013494A1 (en) 2003-07-18 2005-01-20 Microsoft Corporation In-loop deblocking filter
US7382879B1 (en) 2003-07-23 2008-06-03 Sprint Communications Company, L.P. Digital rights management negotiation for streaming media over a network
US20050076232A1 (en) 2003-08-01 2005-04-07 Sony Corporation Client apparatus and content processing method in client apparatus, and content provision system
WO2005015935A1 (en) 2003-08-07 2005-02-17 Pervenio Limited Server for determining and storing mobile device capability data
US7853980B2 (en) 2003-10-31 2010-12-14 Sony Corporation Bi-directional indices for trick mode video-on-demand
US7499930B2 (en) 2004-01-28 2009-03-03 Canon Kabushiki Kaisha Data processing apparatus, data processing method, and data processing program
US20050177741A1 (en) 2004-02-05 2005-08-11 Iue-Shuenn Chen System and method for security key transmission with strong pairing to destination client
US7546641B2 (en) 2004-02-13 2009-06-09 Microsoft Corporation Conditional access to digital rights management conversion
US7397853B2 (en) 2004-04-29 2008-07-08 Mediatek Incorporation Adaptive de-blocking filtering apparatus and method for MPEG video decoder
US7400679B2 (en) 2004-04-29 2008-07-15 Mediatek Incorporation Adaptive de-blocking filtering apparatus and method for MPEG video decoder
US20050243912A1 (en) 2004-04-29 2005-11-03 Do-Kyoung Kwon Adaptive de-blocking filtering apparatus and method for mpeg video decoder
US20050265555A1 (en) 2004-05-12 2005-12-01 Nokia Corporation Integrity protection of streamed content
US20060031564A1 (en) 2004-05-24 2006-02-09 Brassil John T Methods and systems for streaming data at increasing transmission rates
US20060002425A1 (en) 2004-06-30 2006-01-05 Mane Pravin D Determining available bandwidth in a network
US20060013568A1 (en) 2004-07-14 2006-01-19 Rodriguez Arturo A System and method for playback of digital video pictures in compressed streams
US20090010622A1 (en) 2004-08-17 2009-01-08 Hiroshi Yahata Information Recording Medium, Data Sorting Device, and Data Reproduction Device
US20090013195A1 (en) 2005-01-18 2009-01-08 Matsushita Electric Industrial Co., Ltd. Data Storing Method, Data Playback Method, Data Recording Device, Data Playback Device, and Recording Medium
US7349886B2 (en) 2005-03-25 2008-03-25 Widevine Technologies, Inc. Securely relaying content using key chains
KR20060106250A (en) 2005-04-07 2006-10-12 (주)아이티너스 코리아 System for receiving or transmitting video contents and information security module used in the same
US20070047645A1 (en) 2005-08-31 2007-03-01 Sony Corporation Information processing device, information recording medium manufacturing device, information recording medium, methods thereof, and computer program
US20070067472A1 (en) 2005-09-20 2007-03-22 Lsi Logic Corporation Accurate and error resilient time stamping method and/or apparatus for the audio-video interleaved (AVI) format
US20070083467A1 (en) 2005-10-10 2007-04-12 Apple Computer, Inc. Partial encryption techniques for media data
US20070180051A1 (en) 2006-02-02 2007-08-02 Microsoft Corporation Version-specific content searching
US20090310819A1 (en) 2006-07-19 2009-12-17 Panasonic Corporation Media data processing apparatus and media data processing method
US20080086570A1 (en) 2006-10-10 2008-04-10 Ortiva Wireless Digital content buffer for adaptive streaming
US8009575B1 (en) * 2006-10-12 2011-08-30 Sprint Communications Company L.P. Network capacity forecasting and maintenance
US20080101718A1 (en) 2006-10-25 2008-05-01 Realtek Semiconductor Corp. Apparatus and method for deblock filtering
WO2009006302A1 (en) 2007-06-29 2009-01-08 Widevine Technologies, Inc. Progressive download or streaming of digital media securely through a localized container and communication protocol proxy
US8243924B2 (en) 2007-06-29 2012-08-14 Google Inc. Progressive download or streaming of digital media securely through a localized container and communication protocol proxy
US9491498B2 (en) * 2007-07-24 2016-11-08 Time Warner Cable Enterprises Llc Methods and apparatus for format selection for network optimization
US7770200B2 (en) * 2007-07-24 2010-08-03 Time Warner Cable Inc. Methods and apparatus for format selection for network optimization
US20100306810A1 (en) 2007-07-24 2010-12-02 Time Warner Cable Inc. Methods and apparatus for format selection for network optimization
US8683066B2 (en) 2007-08-06 2014-03-25 DISH Digital L.L.C. Apparatus, system, and method for multi-bitrate content streaming
US20090178090A1 (en) 2007-10-01 2009-07-09 Cabot Communications Method and apparatus for streaming digital media content and a communication system
US8099757B2 (en) * 2007-10-15 2012-01-17 Time Warner Cable Inc. Methods and apparatus for revenue-optimized delivery of content in a network
US20090106082A1 (en) 2007-10-23 2009-04-23 Senti Thad E System and method to facilitate targeted advertising
US20090132599A1 (en) 2007-11-16 2009-05-21 Kourosh Soroushian Hierarchical and reduced index structures for multimedia files
US8169916B1 (en) 2007-11-23 2012-05-01 Media Melon, Inc. Multi-platform video delivery configuration
US8131875B1 (en) 2007-11-26 2012-03-06 Adobe Systems Incorporated Device profile assignment based on device capabilities
US20090144425A1 (en) * 2007-12-04 2009-06-04 Sony Computer Entertainment Inc. Network bandwidth detection, distribution and traffic prioritization
US7908393B2 (en) * 2007-12-04 2011-03-15 Sony Computer Entertainment Inc. Network bandwidth detection, distribution and traffic prioritization
WO2009109976A2 (en) 2008-03-05 2009-09-11 Webtview Ltd. Distributing internet channels to a media viewer
US20110010466A1 (en) 2008-03-21 2011-01-13 Huawei Technologies Co., Ltd. Dynamic content delivery method and apparatus
US20090249081A1 (en) 2008-03-31 2009-10-01 Kabushiki Kaisha Toshiba-1 Shibaura 1-Chomominatoku Storage device encryption and method
US20090282162A1 (en) 2008-05-12 2009-11-12 Microsoft Corporation Optimized client side rate control and indexed file layout for streaming media
US7949775B2 (en) * 2008-05-30 2011-05-24 Microsoft Corporation Stream selection for enhanced media streaming
US20090300203A1 (en) * 2008-05-30 2009-12-03 Microsoft Corporation Stream selection for enhanced media streaming
US20100142915A1 (en) 2008-06-06 2010-06-10 Deluxe Digital Studios, Inc. Methods and systems for use in providing playback of variable length content in a fixed length framework
US20110197261A1 (en) 2008-09-22 2011-08-11 Huawei Device Co., Ltd. Service activation method, service providing method, terminal device, and server
EP2180664A1 (en) 2008-10-22 2010-04-28 Vivendi Mobile Entertainment System and method for accessing multi-media content via a mobile terminal
US20100235542A1 (en) 2008-11-24 2010-09-16 Zubair Visharam Dynamic Variable Rate Media Delivery System
US20100306373A1 (en) 2009-06-01 2010-12-02 Swarmcast, Inc. Data retrieval based on bandwidth cost and delay
US20110173345A1 (en) 2009-08-17 2011-07-14 Akamai Technologies, Inc. Method and system for HTTP-based stream delivery
US20110058675A1 (en) 2009-09-04 2011-03-10 Brueck David F Controlling access to copies of media content by a client device
US20110066673A1 (en) 2009-09-14 2011-03-17 Adobe Systems Incorporated Dynamic stream switch control
US20110096828A1 (en) 2009-09-22 2011-04-28 Qualcomm Incorporated Enhanced block-request streaming using scalable encoding
US8312079B2 (en) 2009-09-22 2012-11-13 Thwapr, Inc. Adaptive rendering for mobile media sharing
US9124642B2 (en) 2009-10-16 2015-09-01 Qualcomm Incorporated Adaptively streaming multimedia
US20110103374A1 (en) 2009-10-30 2011-05-05 Lajoie Michael L Methods and apparatus for packetized content delivery over a content delivery network
US20110145858A1 (en) 2009-11-19 2011-06-16 Gregory Philpott System And Method For Delivering Content To Mobile Devices
US20110135090A1 (en) 2009-12-04 2011-06-09 Divx, Llc. Elementary bitstream cryptographic material transport systems and methods
US9521178B1 (en) 2009-12-21 2016-12-13 Amazon Technologies, Inc. Dynamic bandwidth thresholds
US20110296048A1 (en) 2009-12-28 2011-12-01 Akamai Technologies, Inc. Method and system for stream handling using an intermediate format
US9038116B1 (en) 2009-12-28 2015-05-19 Akamai Technologies, Inc. Method and system for recording streams
WO2011087449A1 (en) 2010-01-18 2011-07-21 Telefonaktiebolaget L M Ericsson (Publ) Methods and arrangements for http media stream distribution
US20110179185A1 (en) 2010-01-20 2011-07-21 Futurewei Technologies, Inc. System and Method for Adaptive Differentiated Streaming
WO2011103364A1 (en) 2010-02-17 2011-08-25 Verimatrix, Inc. Systems and methods for securing content delivered using a playlist
US20120311174A1 (en) 2010-02-19 2012-12-06 Guillaume Bichot Multipath delivery for adaptive streaming
WO2011101371A1 (en) 2010-02-19 2011-08-25 Thomson Licensing Multipath delivery for adaptive streaming
EP2360923A1 (en) 2010-02-24 2011-08-24 Thomson Licensing Method for selectively requesting adaptive streaming content and a device implementing the method
US8819116B1 (en) 2010-03-08 2014-08-26 Amazon Technologies, Inc. Providing services using a device capabilities service
US20130013803A1 (en) 2010-04-01 2013-01-10 Guillaume Bichot Method for recovering content streamed into chunk
US20110246661A1 (en) 2010-04-02 2011-10-06 Disney Enterprises, Inc. Streaming playback and dynamic Ad insertion
US20110314130A1 (en) 2010-04-08 2011-12-22 Nery Strasman Managing streaming bandwidth for multiple clients
US20120005312A1 (en) 2010-06-30 2012-01-05 Unicorn Media, Inc. Dynamic chunking for media streaming
US8918533B2 (en) 2010-07-13 2014-12-23 Qualcomm Incorporated Video switching for streaming video data
US8782268B2 (en) 2010-07-20 2014-07-15 Microsoft Corporation Dynamic composition of media
US20120042090A1 (en) 2010-08-10 2012-02-16 Qualcomm Incorporated Manifest file updates for network streaming of coded multimedia data
US20120047542A1 (en) 2010-08-20 2012-02-23 Disney Enterprises, Inc. System and method for rule based dynamic server side streaming manifest files
US9420024B2 (en) * 2010-10-25 2016-08-16 Gregory A. Pearson, Inc. Dynamic content delivery systems and methods for providing same
US20120110120A1 (en) 2010-11-02 2012-05-03 Johannes Willig Methods and Devices for Media Description Delivery
US20120141089A1 (en) * 2010-12-06 2012-06-07 Hunt Neil D Variable Bit Video Streams for Adaptive Streaming
US8997160B2 (en) 2010-12-06 2015-03-31 Netflix, Inc. Variable bit video streams for adaptive streaming
US20120167132A1 (en) 2010-12-23 2012-06-28 Verizon Patent And Licensing Inc. Advertising insertion for playback of video streams on user devices
US8649669B2 (en) 2011-01-05 2014-02-11 Sonic Ip, Inc. Systems and methods for performing smooth visual search of media encoded for adaptive bitrate streaming via hypertext transfer protocol using trick play streams
US20120173751A1 (en) 2011-01-05 2012-07-05 Rovi Technologies Corporation Systems and methods for adaptive bitrate streaming of media stored in matroska container files using hypertext transfer protocol
US20120177101A1 (en) 2011-01-06 2012-07-12 Divx, Llc Systems and Methods for Encoding Alternative Streams of Video for Use in Adaptive Bitrate Streaming
US20120179834A1 (en) 2011-01-06 2012-07-12 Divx, Llc Systems and Methods for Performing Adaptive Bitrate Streaming Based Upon the Delay of Each Stream and the Channel Rate
US9088527B2 (en) * 2011-02-08 2015-07-21 Avaya Inc. Method and system for communication session bandwidth control based on actual bandwidth usage
US8849950B2 (en) 2011-04-07 2014-09-30 Qualcomm Incorporated Network streaming of video data using byte range requests
US8516144B2 (en) 2011-04-29 2013-08-20 Cbs Interactive Inc. Startup bitrate in adaptive bitrate streaming
US20120324519A1 (en) 2011-06-15 2012-12-20 Microsoft Corporation Streaming media bandwidth reduction
US20120331167A1 (en) 2011-06-22 2012-12-27 Hunt Neil D Fast start of streaming digital media playback with deferred license retrieval
US20140140253A1 (en) 2011-06-28 2014-05-22 Telefonaktiebolaget L M Ericsson (Publ) Technique for managing streaming media traffic at a network entity
WO2013002834A1 (en) 2011-06-29 2013-01-03 Divx, Llc Systems and methods for performing multiphase adaptive bitrate streaming
US9313249B2 (en) 2011-06-29 2016-04-12 Sonic Ip, Inc. Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content
US8812662B2 (en) 2011-06-29 2014-08-19 Sonic Ip, Inc. Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content
US20140365651A1 (en) 2011-06-29 2014-12-11 Sonic Ip, Inc. Systems and Methods for Estimating Available Bandwidth and Performing Initial Stream Selection When Streaming Content
US20130007297A1 (en) 2011-06-29 2013-01-03 Divx, Llc Systems and Methods for Performing Multiphase Adaptive Bitrate Streaming
US8832297B2 (en) * 2011-06-29 2014-09-09 Sonic Ip, Inc. Systems and methods for performing multiphase adaptive bitrate streaming
US20130007263A1 (en) 2011-06-29 2013-01-03 Divx, Llc Systems and Methods for Estimating Available Bandwidth and Performing Initial Stream Selection When Streaming Content
WO2013002835A1 (en) 2011-06-29 2013-01-03 Divx, Llc Estimating available bandwidth and performing initial stream selection when streaming content
US20130007200A1 (en) 2011-06-30 2013-01-03 Divx, Llc Systems and methods for determining available bandwidth and performing initial stream selection when commencing streaming using hypertext transfer protocol
WO2013002828A2 (en) 2011-06-30 2013-01-03 Divx, Llc Systems and methods for determining available bandwidth and performing initial stream selection when commencing streaming using hypertext transfer protocol
US20140149557A1 (en) 2011-07-07 2014-05-29 Telefonaktiebolaget L M Ericsson (Publ) Network-Capacity Optimized Adaptive HTTP Streaming
US20150288530A1 (en) 2011-08-11 2015-10-08 Ozgur Oyman Methods for switching between a mbms download and an http-based delivery of dash formatted content over an ims network
US20130080267A1 (en) 2011-09-26 2013-03-28 Unicorn Media, Inc. Single-url content delivery
US20140068096A1 (en) 2012-08-31 2014-03-06 Divx, Llc System and Method for Decreasing an Initial Buffering Period of an Adaptive Streaming System
US9936267B2 (en) 2012-08-31 2018-04-03 Divx Cf Holdings Llc System and method for decreasing an initial buffering period of an adaptive streaming system
US20180288498A1 (en) 2012-08-31 2018-10-04 Divx, Llc System and Method for Decreasing an Initial Buffering Period of an Adaptive Streaming System

Non-Patent Citations (102)

* Cited by examiner, † Cited by third party
Title
"Apple HTTP Live Streaming specification", Aug. 2017, 60 pgs.
"Data Encryption Decryption using AES Algorithm, Key and Salt with Java Cryptography Extension", Available at https://www.digizol.com/2009/10/java-encrypt-decrypt-jce-salt.html, Oct. 200, 6 pgs.
"Delivering Live and On-Demand Smooth Streaming", Microsoft Silverlight, 2009, 28 pgs.
"HTTP Based Adaptive Streaming over HSPA", Apr. 2011, 73 pgs.
"HTTP Live Streaming", Mar. 2011, 24 pgs.
"HTTP Live Streaming", Sep. 2011, 33 pgs.
"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).
"Java Cryptography Architecture API Specification & Reference", Available at https://docs.oracle.com/javase/1.5.0/docs/guide/security/CryptoSpec.html, Jul. 25, 2004, 68 pgs.
"Java Cryptography Extension, javax.crypto.Cipher class", Available at https://docs.oracle.com/javase/1.5.0/docs/api/javax/crypto/Cipher.html, 2004, 24 pgs.
"JCE Encryption—Data Encryption Standard (DES) Tutorial", Available at https://mkyong.com/java/jce-encryption-data-encryption-standard-des-tutorial/, Feb. 25, 2009, 2 pgs.
"Live and On-Demand Video with Silverlight and IIS Smooth Streaming", Microsoft Silverlight, Windows Server Internet Information Services 7.0, Feb. 2010, 15 pgs.
"Microsoft Smooth Streaming Protocol specification", Jul. 22, 2013, 56 pgs.
"MPEG-2, Part 1, ISO/IEC 13818-1", Information technology—Generic Coding of Moving Pictures and Associated Audio: Systems, Nov. 13, 1994, 161 pgs.
"MPEG-4, Part 14, ISO/IEC 14496-14", Information technology—Coding of audio-visual objects, Nov. 15, 2003, 18 pgs.
"OpenDML AVI File Format Extensions Version 1.02", OpenDMLAVI MJPEG File Format Subcommittee. Last revision: Feb. 28, 1996. Reformatting: Sep. 1997, 42 pgs.
"Single-Encode Streaming for Multiple Screen Delivery", Telestream Wowza Media Systems, 2009, 6 pgs.
"The MPEG-DASH Standard for Multimedia Streaming Over the Internet", IEEE MultiMedia, vol. 18, No. 4, 2011, 7 pgs.
"Video Publishers Turning to HD Online Video to Boost Competitive Edge and Increase Revenues", Business Wire, Inc., Apr. 22, 2009, 2 pages, retrieved from https://global.factiva.com/ga/default.aspx.
"Windows Media Player 9", Microsoft, Mar. 23, 2017, 3 pgs.
Abomhara et al., "Enhancing Selective Encryption for H.264/AVC Using Advanced Encryption Standard", International Journal of computer Theory and Engineering, Apr. 2010, vol. 2, No. 2, pp. 223-229.
Alattar et al., "Improved selective encryption techniques for secure transmission of MPEG video bit-streams", In Proceedings 1999 International Conference on Image Processing (Cat. 99CH36348), vol. 4, IEEE, 1999, pp. 256-260.
Antoniou et al., "Adaptive Methods for the Transmission of Video Streams in Wireless Networks", 2015, 50 pgs.
Apostolopoulos et al., "Secure Media Streaming and Secure Transcoding", Multimedia Security Technologies for Digital Rights Management, 2006, 33 pgs.
Asai et al., "Essential Factors for Full-Interactive VOD Server: Video File System, Disk Scheduling, Network", Proceedings of Globecom '95, Nov. 14-16, 1995, 6 pgs.
Begen et al., "Watching Video over the Web Part 1: Streaming Protocols", IEEE Internet Computing, Mar. 1, 2011, vol. 15, Issue 2, pp. 54-63.
Beker et al., "Cipher Systems, The Protection of Communications", 1982, 40 pgs.
Bocharov et al., "Portable Encoding of Audio-Video Objects, The Protected Interoperable File Format (PIFF)", Microsoft Corporation, First Edition Sep. 8, 2009, 30 pgs.
Bulterman et al., "Synchronized Multimedia Integration Language (SMIL 3.0)", W3C Recommendation, Dec. 1, 2008, https://www.w3.org/TR/2008/REC-SMIL3-20081201/, 321 pgs. (Presented in five parts).
Cahill et al., "Locally Adaptive Deblocking Filter for Low Bit Rate Video", Proceedings 2000 International Conference on Image Processing, Sep. 10-13, 2000, Vancouver, BC, Canada, 4 pgs.
Candelore, U.S. Appl. No. 60/372,901, filed Apr. 16, 2002, 5 pgs.
Chaddha et al., "A Frame-work for Live Multicast of Video Streams over the Internet", Proceedings of 3rd IEEE International Conference on Image Processing, Sep. 19, 1996, Lausanne, Switzerland, 4 pgs.
Cheng et al., "Partial encryption of compressed images and videos", IEEE Transactions on Signal Processing, vol. 48, No. 8, Aug. 2000, 13 pgs.
Cheng, "Partial Encryption for Image and Video Communication", Thesis, Fall 1998, 95 pgs.
Cheung et al., "On the Use of Destination Set Grouping to Improve Fairness in Multicast Video Distribution", Proceedings of IEEE INFOCOM'96, Conference on Computer Communications, vol. 2, IEEE, 1996, 23 pgs.
Collet, "Delivering Protected Content, An Approach for Next Generation Mobile Technologies", Thesis, 2010, 84 pgs.
Diamantis et al., "Real Time Video Distribution using Publication through a Database", Proceedings SIBGRAPI'98. International Symposium on Computer Graphics, Image Processing, and Vision (Cat. No. 98EX237), Oct. 1990, 8 pgs.
Dworkin, "Recommendation for Block Cipher Modes of Operation: Methods and Techniques", NIST Special Publication 800-38A, 2001, 66 pgs.
Fang et al., "Real-time deblocking filter for MPEG-4 systems", Asia-Pacific Conference on Circuits and Systems, Oct. 28-31, 2002, Bail, Indonesia, 4 pgs.
Fecheyr-Lippens, "A Review of HTTP Live Streaming", Jan. 2010, 38 pgs.
Fielding et al., "Hypertext Transfer Protocol—HTTP1.1", Network Working Group, RFC 2616, Jun. 1999, 114 pgs.
Fukuda et al., "Reduction of Blocking Artifacts by Adaptive DCT Coefficient Estimation in Block-Based Video Coding", Proceedings 2000 International Conference on Image Processing, Sep. 10-13, 2000, Vancouver, BC, Canada, 4 pgs.
Gannes, "The Lowdown on Apple's HTTP Adaptive Bitrate Streaming", GigaOM, Jun. 10, 2009, 12 pgs.
Huang et al., "Adaptive MLP post-processing for block-based coded images", IEEE Proceedings—Vision, Image and Signal Processing, vol. 147, No. 5, Oct. 2000, pp. 463-473.
Huang et al., "Architecture Design for Deblocking Filter in H.264/JVT/AVC", 2003 International Conference on Multimedia and Expo., Jul. 6-9, 2003, Baltimore, MD, 4 pgs.
Huang, U.S. Pat. No. 7,729,426, U.S. Appl. No. 11/230,794, filed Sep. 20, 2005, 143 pgs.
Information Technology—MPEG Systems Technologies—Part 7: Common Encryption in ISO Base Media File Format Files (ISO/IEC 23001-7), Apr. 2015, 24 pgs.
International Preliminary Report on Patentability for International Application No. PCT/US2011/064684, dated Mar. 4, 2014, 5 pgs.
International Preliminary Report on Patentability for International Application No. PCT/US2011/068156, Report dated Jan. 7, 2014, 9 Pgs.
International Preliminary Report on Patentability for International Application No. PCT/US2011/068264, Search Completed Jan. 7, 2014, dated Jan. 16, 2014, 5 pgs.
International Search Report and Written Opinion for Application PCT/US2011/068264, Search Completed Mar. 30, 2012, dated May 1, 2012, 6 pgs.
International Search Report and Written Opinion for International Application No. PCT/US2011/068156, Search completed Apr. 7, 2012, dated May 1, 2012, 11 Pgs.
International Search Report and Written Opinion for International Application PCT/US2011/064684, Search Completed Mar. 26, 2012, dated Apr. 10, 2012, 7 pgs.
ISO/IEC 14496-12 Information technology—Coding of audio-visual objects—Part 12: ISO base media file format, Feb. 2004 ("MPEG-4 Part 12 Standard"), 62 pgs.
ISO/IEC 14496-12:2008(E) Informational Technology—Coding of Audio-Visual Objects Part 12: ISO Base Media Filea Format, Oct. 2008, 120 pgs.
ISO/IEC FCD 23001-6 MPEG systems technologies Part 6: Dynamic adaptive streaming over HTTP (DASH), Jan. 28, 2011, 86 pgs.
Jain et al., U.S. Appl. No. 61/522,623, filed Aug. 11, 2011, 44 pgs.
Jung et al., "Design and Implementation of an Enhanced Personal Video Recorder for DTV", IEEE Transactions on Consumer Electronics, vol. 47, No. 4, Nov. 2001, 6 pgs.
Kalva, "Delivering MPEG-4 Based Audio-Visual Services", 2001, 113 pgs.
Kang et al., "Access Emulation and Buffering Techniques for Steaming of Non-Stream Format Video Files", IEEE Transactions on Consumer Electronics, vol. 43, No. 3, Aug. 2001, 7 pgs.
Kim et al., "A Deblocking Filter with Two Separate Modes in Block-based Video Coding", IEEE transactions on circuits and systems for video technology, vol. 9, No. 1, 1999, pp. 156-160.
Kim et al., "Tree-Based Group Key Agreement", Feb. 2004, 37 pgs.
Laukens, "Adaptive Streaming—A Brief Tutorial", EBU Technical Review, 2011, 6 pgs.
Legault et al., "Professional Video Under 32-bit Windows Operating Systems", SMPTE Journal, vol. 105, No. 12, Dec. 1996, 8 pgs.
Li et al., "Layered Video Multicast with Retransmission (LVMR): Evaluation of Hierarchical Rate Control", Proceedings of IEEE INFOCOM'98, the Conference on Computer Communications. Seventeenth Annual Joint Conference of the IEEE Computer and Communications Societies. Gateway to the 21st Century, Cat. No. 98, vol. 3, 1998, 26 pgs.
List et al., "Adaptive deblocking filter", IEEE transactions on circuits and systems for video technology, vol. 13, No. 7, Jul. 2003, pp. 614-619.
Liu et al., "Rate adaptation for adaptive HTTP streaming", MMSys '11 Proceedings of the second annual ACM conference on Multimedia systems, Feb. 23-25, 2011, San Jose, CA, USA, pp. 169-174.
Massoudi et al., "Overview on Selective Encryption of Image and Video: Challenges and Perspectives", EURASIP Journal on Information Security, Nov. 2008, 18 pgs.
McCanne et al., "Receiver-driven Layered Multicast", Conference proceedings on Applications, technologies, architectures, and protocols for computer communications, Aug. 1996, 14 pgs.
Meier, "Reduction of Blocking Artifacts in Image and Video Coding", IEEE Transactions on Circuits and Systems for Video Technology, vol. 9, No. 3, Apr. 1999, pp. 490-500.
Microsoft Corporation, Advanced Systems Format (ASF) Specification, Revision 01.20.03, Dec. 2004, 121 pgs.
MPEG-DASH presentation at Streaming Media West 2011, Nov. 2011, 14 pgs.
Nelson, "Smooth Streaming Deployment Guide", Microsoft Expression Encoder, Aug. 2010, 66 pgs.
Newton et al., "Preserving Privacy by De-identifying Facial Images", Carnegie Mellon University School of Computer Science, Technical Report, CMU-CS-03-119, Mar. 2003, 26 pgs.
O'Brien, U.S. Appl. No. 60/399,846, filed Jul. 30, 2002, 27 pgs.
O'Rourke, "Improved Image Decompression for Reduced Transform Coding Artifacts", IEEE Transactions on Circuits and Systems for Video Technology, vol. 5, No. 6, Dec. 1995, pp. 490-499.
Park et al., "A postprocessing method for reducing quantization effects in low bit-rate moving picture coding", IEEE Transactions on Circuits and Systems for Video Technology, vol. 9, No. 1, Feb. 1999, pp. 161-171.
Pomelo, LLC Tech Memo, Analysis of Netflix's Security Framework for ‘Watch Instantly’ Service, Mar.-Apr. 2009, 18 pgs.
Richardson, "H.264 and MPEG-4 Video Compression", Wiley, 2003, 306 pgs. (Presented in 2 parts).
Riiser et al., "Video Streaming Using a Location-based Bandwidth-Lookup Service for Bitrate Planning", ACM Transactions on Multimedia Computing, Communications, and Applications, vol. 8, Issue 3, Article No. 24, Jul. 2012, 24 pages.
Schulzrinne, "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 page.
Server-Side Stream Repackaging (Streaming Video Technologies Panorama, Part 2), Jul. 2011, 15 pgs.
Sima et al., "An Efficient Architecture for Adaptive Deblocking Filter of H.264 AVC Video Coding", IEEE Transactions on Consumer Electronics, vol. 50, No. 1, Feb. 2004, pp. 292-296.
Spanos et al., "Performance Study of a Selective Encryption Scheme for the Security of Networked, Real-Time Video", Proceedings of the Fourth International Conference on Computer Communications and Networks, IC3N'95, Sep. 20-23, 1995, Las Vegas, NV, pp. 2-10.
Srinivasan et al., "Windows Media Video 9: overview and applications", Signal Processing: Image Communication, 2004, 25 pgs.
Stockhammer, "Dynamic Adaptive Streaming over HTTP—Standards and Design Principles", Proceedings of the second annual ACM conference on Multimedia, Feb. 2011, pp. 133-145.
Text of ISO/IEC 23001-6: Dynamic adaptive streaming over HTTP (DASH), Oct. 2010, 71 pgs.
Timmerer et al., "HTTP Streaming of MPEG Media", Proceedings of Streaming Day, 2010, 4 pgs.
Tiphaigne et al., "A Video Package for Torch", Jun. 2004, 46 pgs.
Trappe et al., "Key Management and Distribution for Secure Multimedia Multicast", IEEE Transaction on Multimedia, vol. 5, No. 4, Dec. 2003, pp. 544-557.
Universal Mobile Telecommunications System (UMTS), ETSI TS 126 233 V9.1.0 (Jun. 2011) 3GPP TS 26.233 version 9.1.0 Release 9, 18 pgs.
Universal Mobile Telecommunications Systems (UMTS); ETSI TS 126 244 V9.4.0 (May 2011) 3GPP TS 26.244 version 9.4.0 Release 9, 58 pgs.
Van Deursen et al., "On Media Delivery Protocols in the Web", 2010 IEEE International Conference on Multimedia and Expo, Jul. 19-23, 2010, 6 pgs.
Ventura, "Streaming of Multimedia Learning Objects", AG Integrated Communication System, Mar. 2003, 101 pgs.
Waggoner, "Compression for Great Digital Video", 2002, 184 pgs.
Watanabem et al., "MPEG-2 decoder enables DTV trick plays", esearcher System LSI Development Lab, Fujitsu Laboratories Ltd., Kawasaki, Japan, Jun. 2001, 2 pgs.
Wiegand, "Joint Video Team (JVT) of ISO/IEC MPEG and ITU-T VCEG", Jan. 2002, 70 pgs.
Willig et al., U.S. Appl. No. 61/409,285, filed Nov. 2, 2010, 43 pgs.
Yang et al., "Projection-Based Spatially Adaptive Reconstruction of Block-Transform Compressed Images", IEEE Transactions on Image Processing, vol. 4, No. 7, Jul. 1995, pp. 896-908.
Yang et al., "Regularized Reconstruction to Reduce Blocking Artifacts of Block Discrete Cosine Transform Compressed Images", IEEE Transactions on Circuits and Systems for Video Technology, vol. 3, No. 6, Dec. 1993, pp. 421-432.
Yu et al., "Video deblocking with fine-grained scalable complexity for embedded mobile computing", Proceedings 7th International Conference on Signal Processing, Aug. 31-Sep. 4, 2004, pp. 1173-1178.
Zakhor, "Iterative Procedures for Reduction of Blocking Effects in Transform Image Coding", IEEE Transactions on Circuits and Systems for Video Technology, vol. 2, No. 1, Mar. 1992, pp. 91-95.
Zambelli, "IIS Smooth Streaming Technical Overview", Microsoft Corporation, Mar. 2009, 17 pages.

Also Published As

Publication number Publication date
US20140365651A1 (en) 2014-12-11
US8812662B2 (en) 2014-08-19
US9313249B2 (en) 2016-04-12
WO2013002835A1 (en) 2013-01-03
US20130007263A1 (en) 2013-01-03

Similar Documents

Publication Publication Date Title
USRE48748E1 (en) Systems and methods for estimating available bandwidth and performing initial stream selection when streaming content
US11716371B2 (en) Systems and methods for automatically generating top level index files
US11343300B2 (en) Systems and methods for adaptive switching between multiple content delivery networks during adaptive bitrate streaming
EP3473005B1 (en) Systems and methods for encoding video content
US20130007200A1 (en) Systems and methods for determining available bandwidth and performing initial stream selection when commencing streaming using hypertext transfer protocol
Krishnappa et al. Optimizing the video transcoding workflow in content delivery networks
US10979782B2 (en) System and method for decreasing an initial buffering period of an adaptive streaming system

Legal Events

Date Code Title Description
FEPP Fee payment procedure

Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

AS Assignment

Owner name: DIVX, LLC, CALIFORNIA

Free format text: CHANGE OF NAME;ASSIGNOR:DIVX CF HOLDINGS LLC;REEL/FRAME:050421/0253

Effective date: 20180212

Owner name: DIVX CF HOLDINGS LLC, NEW YORK

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SONIC IP, INC.;REEL/FRAME:050421/0219

Effective date: 20180212

Owner name: SONIC IP, INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:DIVX, LLC;REEL/FRAME:050421/0174

Effective date: 20131121

Owner name: DIVX, LLC, CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:SOROUSHIAN, KOUROSH;BRANESS, JASON;REEL/FRAME:050421/0166

Effective date: 20120413

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8