Multicasting is a technique for group communication that employs a one to many approach to communication. For example, a network infrastructure may be configured such that a single packet sent by a content provider is automatically provided to each computing device that subscribes to a multicast stream. In this way, a content provider may send once and have the content streamed to a variety of computing devices automatically by leveraging the network infrastructure, which may help to conserve resources of the content provider.
However, as multicast is a “one to many” approach each user that subscribes to a conventional multicast receives the same content. Although this may result in improved efficiency as described above, this may also limit other functionality from being available to a user. For example, conventional multicasting techniques may preclude the sending of targeted advertisements to individual ones of the computing devices, may limit navigation through the stream of content, and so on.
Hybrid stream delivery techniques are described. In one or more implementations, a multicast stream of primary content is received at a computing device for output by the computing device. Timing information in the multicast stream is identified indicating when a break in the primary content is to occur. Responsive to the identification and before output of the primary content attains to the break, supplemental content is requested by the computing device that is available via a single dedicated stream. The supplemental content received via the single dedicated stream is cached during output of the primary content and the cached supplemental content is output upon completion of the output of the primary content up to the break.
In one or more implementations, content is received at a computing device via a multicast stream. The content is reconfigured by the computing device for availability as a single dedicated stream according to a manifest. The reconfigured content is exposed as the single dedicated stream by the computing device in compliance with the manifest to one or more applications that are also executed on the computing device such that the one or more applications are not aware that the content is received at the computing device via the multicast stream.
In one or more implementations, a system includes one or more modules implemented at least partially in hardware. The one or more modules are configured to perform operations including exposing one or more controls that are selectable by a user to initiate one or more inputs to navigate content received via a multicast stream. Responsive to receipt of the inputs to navigate the content received via the multicast stream, a point in time is identified in the output of the content that corresponds to the navigation, a single dedicated stream is located that corresponds to the identified point in time, and the single dedicated stream is obtained for output.
This Summary introduces a selection of concepts in a simplified form that are further described below in the Detailed Description. As such, this Summary is not intended to identify essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
The detailed description is described with reference to the accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in different instances in the description and the figures may indicate similar or identical items. Entities represented in the figures may be indicative of one or more entities and thus reference may be made interchangeably to single or plural forms of the entities in the discussion.
Overview
Multicasting, which may be performed via native network and peer-to-peer, may be used to improve the efficiency of live media streaming, both in terms of load on servers and on shared network links. However, as previously described this may preclude desirable functionality such as targeted advertisements, navigation through the stream of content, and so on. For example, a user may not be able to “fast forward” or “jump” between different points in time in the output of the content in a conventional multicast stream as each of the individual computing devices receives the same stream of content via the multicast.
Hybrid stream delivery techniques are described. In one or more implementations, content is provided via a multicast stream. For example, an Internet Service Provider (ISP) may control a network infrastructure that is configured to provide a multicast stream of primary content (such as video, music, image slideshow, a television program, or other media) from a content provider to users that subscribe to the stream.
The network infrastructure may also be configured to support use of a single dedicated stream of supplemental content to individual computing devices and therefore provide a hybrid unicast/multicast system. Examples of use of a single dedicated stream include HTTP Dynamic Streaming (HDS) by Adobe®, HTTP Live Streaming (HLS) by Apple®, and others. These solutions leverage existing Internet infrastructure and strengths to deliver live streams in small, cache-friendly chunks. Using these techniques, each consumer/subscriber may receive a separate copy of the stream. Accordingly, these formats and delivery methods are inherently end-to-end. The dedicated end-to-end streams are thus described as “single” and “dedicated” in the sense that the streams are configured for receipt by a single computing device.
The supplemental content sent via the single dedicated stream may take a variety of forms to support a variety of different functionality. For example, the supplemental content may be configured as targeted advertisements that may be output during breaks in the multicast stream by leveraging the single dedicated stream. A computing device, for instance, may examine timing information to determine when a break is to occur and during output of the primary content received via the multicast, obtain and cache supplemental content (e.g., the targeted advertisement) for output during the break in the primary content. During the break, the multicast stream may be configured to go into a “sleep” mode to conserve network and computing device resources. In this way, the computing device may obtain targeted advertisements and yet efficiency of a multicast may be leveraged, further discussion of which may be found in relation to
The supplemental content may also be configured to support navigation performed in relation to the multicast stream. For example, the supplemental content may be downloaded, cached, and output in response to a request to initiate an output of content, such as a television program. During this output, the computing device may also subscribe to and cache the primary content (the television program also) for output. In this way, an amount of time involved in output of the content may be reduced by employing a hybrid multicast/single dedicated stream approach, further discussion of which may be found in relation to
In another example, the navigation may involve accessing different portions of a content that is streamed via a multicast. A user, for instance, may output primary content received via a multicast stream, such as a video stream. The user, during this output, may then desire to access different portions of the stream, such as to perform slow motion, rewind, fast forward, “jump” to a different point in time in the output, and so on. The user, therefore, may interact with a control to indicate this functionality and in response, may receive supplemental content via a single dedicated stream. The single dedicated stream may be configured to provide the desired user experience by interacting with the supplemental content, such as to provide slow motion playback, support rewind and/or fast forward, “jump” to a different point in time in the output, and so on. Thus, as before the advantages of a multicast stream may be leveraged without conventional drawbacks by employing a hybrid approach that also leverages a single dedicated stream, further discussion of which may be found in relation to
In the following discussion, an example environment is first described that may employ the techniques described herein. Example procedures are then described which may be performed in the example environment as well as other environments. Consequently, performance of the example procedures is not limited to the example environment and the example environment is not limited to performance of the example procedures.
Example Environment
A computing device, for instance, may be configured as a desktop computer, a laptop computer, a mobile device (e.g., assuming a handheld configuration such as a tablet or mobile phone), and so forth. Thus, a computing device may range from full resource devices with substantial memory and processor resources (e.g., personal computers, game consoles) to a low-resource device with limited memory and/or processing resources (e.g., mobile devices). Additionally, although a single computing device is shown in some instances, (e.g., computing device 102), the computing device may be representative of a plurality of different devices, such as multiple servers utilized by a business to perform operations “over the cloud” as illustrated for the primary and supplemental content providers 104, 106, further discussion of which may be found in relation to
The primary and supplemental content providers 104, 106 are illustrated as including, respectively, a primary content manager module 110 and a supplemental content manager module 112 along with primary content 114 and supplemental content 116 that are available via respective storage 118, 120. The primary content manager module 110 is representative of functionality to communicate primary content 114 via a multicast stream 122 to a computing device 102 via the network 108. The primary content 114 may be configured in a variety of ways, such as a video, audio, television program, or other type of media or data that is configured for streaming via the network 108, e.g., as one or more packets. As previously described, the multicast 122 may support a “one to many” technique for communication of data via the network, such as by leveraging a network infrastructure, via a peer-to-peer configuration, and so on.
The supplemental content manager module 112 is representative of functionality to communicate supplemental content 116 via a single dedicated stream 124 (i.e., unicast) to the computing device 102 via the network 108. For example, the single dedicated stream 124 may be configured as a sequence of digital encoded data packets that are utilized to communicate data from storage 120 via the network 108. The data packets may then be decoded and consumed in sequence to recreate the source data, such as a television program, movie, music, sporting event, and so forth.
The single dedicated stream 124 employs an end-to-end configuration in which the stream is sent to the computing device 102, individually, that requested the supplemental content 116. One example of such a configuration is Hypertext Transfer Protocol (HTTP), examples of which include RFC 2616 that defines HTTP/1.1, RFC 7230-7235, and others.
The primary content 114 and supplemental content 116 may thus be received by a communication module 126 via the network 108 using a multicast 122 and single dedicated stream 124, respectively. This content may then be output for rendering, cached in storage 128 (e.g., using buffering techniques), stored in storage 128 for later output, and so on. The communication module 126 is representative of a variety of different functionality, such as a media player, operating system, network-enabled application, plug-in module, and so forth.
The environment 100 may be configured in a variety of ways. For example, although illustrated separately the primary content provider 104 and the supplemental content provider 106 may be combined as a single content provider, may be provided by separate entities (e.g., a content provider and an advertisement provider), and so on. Additionally, although the primary content 114 and the supplemental content 116 are illustrated separately these may share a common source, such as to support the navigation techniques described below.
In another example, the environment 100 may be representative of a network domain, a portion of a network (e.g., the Internet) serviced by a single Internet Service Provider (ISP), and so forth. Thus, in this way the environment 100 may control a network infrastructure and thus support multicast, which is not generally available via the Internet as a whole. A network domain may also describe a sub-network of computing devices that may be controlled by network administrators via security and permissions for each of the computing devices included in the domain, such as for an enterprise (e.g., a business), and so forth. Other sub-networks are also contemplated, such as workgroups, collections defined by a single Internet Service Provider (ISP) as described above, and so on.
Hybrid Stream Timing Information and Caching
At the second stage 204, an example configuration of the multicast 122 is shown. The multicast 122 includes primary content 114 (e.g., the television program or video of the previous example), which may be configured as a plurality of packets or other portioned content. The multicast 122 also includes timing information 206, which is configured to describe points in time in which part of the primary content 114, illustrated at primary content 114′, 114″, 114′″ is to be output as well as one or more breaks 208′, 208″ in this output. Continuing with the previous example, for instance, the primary content 114′, 114″, 114′″ may include packets of the television program while the breaks 208′, 208″ do not include these packets. Accordingly, the communication module 126 may include a stream manager module 210, which is representative of functionality in this example to identify the breaks 208′, 208″ in the output of the primary content 114′, 114″, 114′″ which may then be filled with supplemental content, an example of which is further described in the following.
The timing information 206, for instance, may be configured to explicitly indicate when the breaks are to occur in a sequence of packets that are to be received by the computing device 102, e.g., may indicate a range of time in which primary content 114′, 114″, 114′″ is not streamed by the primary content provider 104. In another example, this may be accomplished through use of timestamps and a manifest that indicates certain periods in a timeline that are to be used for breaks. Implicit techniques may also be employed, such as to identify breaks in collections of primary content 114′, 114″, 114′″ based on the timestamps for packets in those collections and thus identify “missing” sections as the breaks 208′, 208″. For instance, primary content 114′ may include timestamps indicating output between minutes 1 through 8 and primary content 114″ may include timestamps indicating output between minutes 10-18. Accordingly, a break 208′ may be identified between minutes 8-10 in this example. Other examples are also contemplated.
Identification of the breaks by the stream manager module 210 may then be leveraged by supplemental content decision logic 310 of the communication module 126 to “fill” the breaks 208′, 208″ with supplemental content. The supplemental content decision logic 310, for instance, may be representative of functionality that may select targeted advertisements for output during the breaks 208′, 208″. The selection may be made in a variety of ways, such as based on heuristics (e.g., monitored user interaction with the computing device 102 or other computing devices), user settings, user purchases made, browsing history, content that is local to the computing device 102 that is indicative of user preferences, and so forth.
The selection of the targeted advertisements may also include location of “where” the targeted advertisements, or other forms of supplemental content, are available, e.g., which network address. Accordingly, at the second stage 304, a request 312 is formed by the communication module 126 for communication via the network 108 of
The communication module 126, through use of the timing information 206 identified in the discussion of the previous figure, may determine that a break 208′ is to occur in which the primary content is not to be streamed from the primary content provider 104 via the multicast 122. Accordingly, as shown in the second stage 404, responsive to the identification and before the break in the primary content occurs, supplemental content is requested by the computing device that is available via a single dedicated stream (block 606 of
For example, buffering techniques may be utilized to “smooth” an output of the primary content 114, such as to avoid interruptions in a network connection and so forth. Accordingly, the computing device 102 may have an amount of cached primary content 406, which in this instance is illustrated through a bracket as corresponding to an amount of time in an output of primary content 114′ before break 208′.
The primary content provider 104 may be configured to conserve network and processing resources by reducing and even eliminating a stream of the primary content 114 during the break 208′. Accordingly, this may free resources of the computing device 102 to cache supplemental content 408 from the supplemental content provider 106 received via a single dedicated stream 124 as shown in the second stage 404 during playback 308 of the cached primary content 406.
The single dedicated stream 124, for instance, may support downloads of the supplemental content at rates that are greater than rates at which the content is consumed during real-time playback, which may even be greater than a rate supported by the multicast. In this way, the cached supplemental content 408 may be completely received before playback of the primary content resumes and/or is no longer in the break period. By reducing network bandwidth consumption of the primary content during the break period, the supplemental content does not have to compete for download capacity with the primary content.
During this playback of the supplemental content from the cache 510, a cache of primary content 512 may be collected from the primary content provider 104 via the multicast 122 as shown in the second stage 504. For example, the filling of the cache of supplemental content may be performed in a lesser amount of time than involved in the output of the supplemental content.
Accordingly, once sufficient supplemental content has been received to fill the break 208′, and even subsequent breaks 208″ if sufficient time, the computing device 102 may begin caching the primary content 512 via the multicast 122. In this way, a smooth transition may be made between the output of the supplemental content and the primary content. The caching of the primary content 512 may continue during the playback of the primary content from cache 514 as shown in the third stage 506. In this way, seamless transitions may be supported between the output of the primary and supplemental content thereby enabling the environment 100 to avail itself of the efficiency of multicasts yet still provide other functionality that was otherwise not supported using conventional techniques.
Local Exposure of a Hybrid Stream by a Computing Device
The computing device 102 includes a communication module 126 having a stream manager module 210 as previously described. Although the stream manager module 210 is illustrated as part of the communication module 126, the stream manager module 210 may be implemented in a variety of ways, such as a standalone application, third-party plugin, as part of an operating system of the computing device 102, and so on.
The computing device 102 also includes applications 710 that are executable by the computing device, e.g., storable in a computer-readable storage medium and executable by one or more processors as described in relation to
Accordingly, in this instance content is received at the computing device 102 via a multicast stream 122 (block 802 of
The reconfigured content is then exposed by the computing device 102 as the single dedicated stream 124 to the one or more applications 710 that are also executed on the computing device 102 such that the one or more applications are not aware that the content is received by the computing device via the multicast 122 stream (block 806 of
Hybrid Stream Navigation by a Computing Device
One or more controls 902 are exposed that are selectable by a user to initiate one or more inputs to navigate content received via a multicast stream (block 1002 of
Responsive to receipt of the inputs to navigate the content received via the multicast stream (block 1004 of
As previously described, however, a multicast 122 is a “one to many” approach and thus navigation using the multicast would affect each computing device that has subscribed to the multicast. Accordingly, the communication module 126 may be configured to locate a single dedicated stream that corresponds to the identified point in time (block 1008 of
In this way, the supplemental content 116 may be used to support the navigation and interaction with the content. As previously described, this may also include improving a launch of the content, such as to obtain the supplemental content 116 via the single dedicated stream 124 for output while the computing device 102 subscribes to and obtains the content via the multicast 122, thereby improving a launch time of the content. A variety of other navigation examples are also contemplated.
Example System and Device
The computing device 1102 may be, for example, a server of a service provider, a device associated with a client (e.g., a client device), an on-chip system, and/or any other suitable computing device or computing system. The example computing device 1102 as illustrated includes a processing system 1104, one or more computer-readable media 1106, and one or more I/O interface 1108 that are communicatively coupled, one to another. Although not shown, the computing device 1102 may further include a system bus or other data and command transfer system that couples the various components, one to another. A system bus can include any one or combination of different bus structures, such as a memory bus or memory controller, a peripheral bus, a universal serial bus, and/or a processor or local bus that utilizes any of a variety of bus architectures. A variety of other examples are also contemplated, such as control and data lines.
The processing system 1104 is representative of functionality to perform one or more operations using hardware. Accordingly, the processing system 1104 is illustrated as including hardware element 1110 that may be configured as processors, functional blocks, and so forth. This may include implementation in hardware as an application specific integrated circuit or other logic device formed using one or more semiconductors. The hardware elements 1110 are not limited by the materials from which they are formed or the processing mechanisms employed therein. For example, processors may comprise semiconductor(s) and/or transistors (e.g., electronic integrated circuits (ICs)). In such a context, processor-executable instructions may be electronically-executable instructions.
The computer-readable storage media 1106 is illustrated as including memory/storage 1112. The memory/storage 1112 represents memory/storage capacity associated with one or more computer-readable media. The memory/storage component 1112 may include volatile media (such as random access memory (RAM)) and/or nonvolatile media (such as read only memory (ROM), Flash memory, optical disks, magnetic disks, and so forth). The memory/storage component 1112 may include fixed media (e.g., RAM, ROM, a fixed hard drive, and so on) as well as removable media (e.g., Flash memory, a removable hard drive, an optical disc, and so forth). The computer-readable media 1106 may be configured in a variety of other ways as further described below.
Input/output interface(s) 1108 are representative of functionality to allow a user to enter commands and information to computing device 1102, and also allow information to be presented to the user and/or other components or devices using various input/output devices. Examples of input devices include a keyboard, a cursor control device (e.g., a mouse), a microphone, a scanner, touch functionality (e.g., capacitive or other sensors that are configured to detect physical touch), a camera (e.g., which may employ visible or non-visible wavelengths such as infrared frequencies to recognize movement as gestures that do not involve touch), and so forth. Examples of output devices include a display device (e.g., a monitor or projector), speakers, a printer, a network card, tactile-response device, and so forth. Thus, the computing device 1102 may be configured in a variety of ways as further described below to support user interaction.
Various techniques may be described herein in the general context of software, hardware elements, or program modules. Generally, such modules include routines, programs, objects, elements, components, data structures, and so forth that perform particular tasks or implement particular abstract data types. The terms “module,” “functionality,” and “component” as used herein generally represent software, firmware, hardware, or a combination thereof. The features of the techniques described herein are platform-independent, meaning that the techniques may be implemented on a variety of commercial computing platforms having a variety of processors.
An implementation of the described modules and techniques may be stored on or transmitted across some form of computer-readable media. The computer-readable media may include a variety of media that may be accessed by the computing device 1102. By way of example, and not limitation, computer-readable media may include “computer-readable storage media” and “computer-readable signal media.”
“Computer-readable storage media” may refer to media and/or devices that enable persistent and/or non-transitory storage of information in contrast to mere signal transmission, carrier waves, or signals per se. Thus, computer-readable storage media refers to non-signal bearing media. The computer-readable storage media includes hardware such as volatile and non-volatile, removable and non-removable media and/or storage devices implemented in a method or technology suitable for storage of information such as computer readable instructions, data structures, program modules, logic elements/circuits, or other data. Examples of computer-readable storage media may include, but are not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, hard disks, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or other storage device, tangible media, or article of manufacture suitable to store the desired information and which may be accessed by a computer.
“Computer-readable signal media” may refer to a signal-bearing medium that is configured to transmit instructions to the hardware of the computing device 1102, such as via a network. Signal media typically may embody computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as carrier waves, data signals, or other transport mechanism. Signal media also include any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared, and other wireless media.
As previously described, hardware elements 1110 and computer-readable media 1106 are representative of modules, programmable device logic and/or fixed device logic implemented in a hardware form that may be employed in some embodiments to implement at least some aspects of the techniques described herein, such as to perform one or more instructions. Hardware may include components of an integrated circuit or on-chip system, an application-specific integrated circuit (ASIC), a field-programmable gate array (FPGA), a complex programmable logic device (CPLD), and other implementations in silicon or other hardware. In this context, hardware may operate as a processing device that performs program tasks defined by instructions and/or logic embodied by the hardware as well as a hardware utilized to store instructions for execution, e.g., the computer-readable storage media described previously.
Combinations of the foregoing may also be employed to implement various techniques described herein. Accordingly, software, hardware, or executable modules may be implemented as one or more instructions and/or logic embodied on some form of computer-readable storage media and/or by one or more hardware elements 1110. The computing device 1102 may be configured to implement particular instructions and/or functions corresponding to the software and/or hardware modules. Accordingly, implementation of a module that is executable by the computing device 1102 as software may be achieved at least partially in hardware, e.g., through use of computer-readable storage media and/or hardware elements 1110 of the processing system 1104. The instructions and/or functions may be executable/operable by one or more articles of manufacture (for example, one or more computing devices 1102 and/or processing systems 1104) to implement techniques, modules, and examples described herein.
The techniques described herein may be supported by various configurations of the computing device 1102 and are not limited to the specific examples of the techniques described herein. This functionality may also be implemented all or in part through use of a distributed system, such as over a “cloud” 1114 via a platform 1116 as described below.
The cloud 1114 includes and/or is representative of a platform 1116 for resources 1118. The platform 1116 abstracts underlying functionality of hardware (e.g., servers) and software resources of the cloud 1114. The resources 1118 may include applications and/or data that can be utilized while computer processing is executed on servers that are remote from the computing device 1102. Resources 1118 can also include services provided over the Internet and/or through a subscriber network, such as a cellular or Wi-Fi network.
The platform 1116 may abstract resources and functions to connect the computing device 1102 with other computing devices. The platform 1116 may also serve to abstract scaling of resources to provide a corresponding level of scale to encountered demand for the resources 1118 that are implemented via the platform 1116. Accordingly, in an interconnected device embodiment, implementation of functionality described herein may be distributed throughout the system 1100. For example, the functionality may be implemented in part on the computing device 1102 as well as via the platform 1116 that abstracts the functionality of the cloud 1114.
Although the invention has been described in language specific to structural features and/or methodological acts, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features or acts described. Rather, the specific features and acts are disclosed as example forms of implementing the claimed invention.
Number | Name | Date | Kind |
---|---|---|---|
5414455 | Hooper et al. | May 1995 | A |
5442390 | Hooper et al. | Aug 1995 | A |
5455865 | Perlman | Oct 1995 | A |
5857072 | Crowle | Jan 1999 | A |
6330671 | Aziz | Dec 2001 | B1 |
6363416 | Naeimi et al. | Mar 2002 | B1 |
6876952 | Kappler et al. | Apr 2005 | B1 |
7035214 | Seddigh et al. | Apr 2006 | B1 |
7133922 | She et al. | Nov 2006 | B1 |
7304948 | Ong | Dec 2007 | B1 |
7525965 | St Pierre | Apr 2009 | B1 |
7657644 | Zheng | Feb 2010 | B1 |
7882207 | Titmuss et al. | Feb 2011 | B1 |
8171147 | Kaufman et al. | May 2012 | B1 |
8341688 | Ngo et al. | Dec 2012 | B2 |
8380721 | Attaran et al. | Feb 2013 | B2 |
8392530 | Manapragada et al. | Mar 2013 | B1 |
9066115 | Cherry | Jun 2015 | B1 |
9066138 | Kraiman | Jun 2015 | B1 |
9591069 | Thornburgh | Mar 2017 | B2 |
20010037256 | Yazawa | Nov 2001 | A1 |
20020029256 | Zintel et al. | Mar 2002 | A1 |
20020143944 | Traversat et al. | Oct 2002 | A1 |
20020150048 | Ha et al. | Oct 2002 | A1 |
20030046336 | D'Annunzio et al. | Mar 2003 | A1 |
20030063564 | Ha et al. | Apr 2003 | A1 |
20030088696 | McCanne | May 2003 | A1 |
20030191828 | Ramanathan et al. | Oct 2003 | A1 |
20030233540 | Banerjee et al. | Dec 2003 | A1 |
20040081125 | Ranta-Aho et al. | Apr 2004 | A1 |
20040098502 | Xu et al. | May 2004 | A1 |
20040162871 | Pabla et al. | Aug 2004 | A1 |
20040193461 | Keohane et al. | Sep 2004 | A1 |
20040196785 | Janakiraman et al. | Oct 2004 | A1 |
20050041634 | Aura | Feb 2005 | A1 |
20050163050 | Hopkins | Jul 2005 | A1 |
20060029093 | Van Rossum | Feb 2006 | A1 |
20060039285 | Chapman et al. | Feb 2006 | A1 |
20060047831 | Piper | Mar 2006 | A1 |
20060053209 | Li | Mar 2006 | A1 |
20060167855 | Ishikawa et al. | Jul 2006 | A1 |
20060168320 | Kidd et al. | Jul 2006 | A1 |
20060173940 | Guntupalli et al. | Aug 2006 | A1 |
20060250999 | Zeng et al. | Nov 2006 | A1 |
20060251011 | Ramakrishnan et al. | Nov 2006 | A1 |
20070070906 | Thakur | Mar 2007 | A1 |
20070079327 | Khoo et al. | Apr 2007 | A1 |
20070091934 | Myles et al. | Apr 2007 | A1 |
20070171927 | Paik et al. | Jul 2007 | A1 |
20070201502 | Abramson | Aug 2007 | A1 |
20070220552 | Juster et al. | Sep 2007 | A1 |
20070223379 | Sivakumar et al. | Sep 2007 | A1 |
20070226365 | Hildreth et al. | Sep 2007 | A1 |
20070244982 | Scott, III | Oct 2007 | A1 |
20070250590 | Flannery et al. | Oct 2007 | A1 |
20070282905 | Karlberg | Dec 2007 | A1 |
20070288638 | Vuong et al. | Dec 2007 | A1 |
20080049607 | Xu | Feb 2008 | A1 |
20080072264 | Crayford | Mar 2008 | A1 |
20080134266 | Kang | Jun 2008 | A1 |
20080189429 | DaCosta | Aug 2008 | A1 |
20080205394 | Deshpande et al. | Aug 2008 | A1 |
20080294788 | Wu et al. | Nov 2008 | A1 |
20080301315 | Cheng et al. | Dec 2008 | A1 |
20090019174 | Ehn et al. | Jan 2009 | A1 |
20090063975 | Bull | Mar 2009 | A1 |
20090077254 | Darcie et al. | Mar 2009 | A1 |
20090094639 | Haberman | Apr 2009 | A1 |
20090285096 | Yousef | Nov 2009 | A1 |
20090287826 | Kaufman et al. | Nov 2009 | A1 |
20100057928 | Kapoor et al. | Mar 2010 | A1 |
20100067518 | Kaufman et al. | Mar 2010 | A1 |
20100226250 | Plamondon | Sep 2010 | A1 |
20100260191 | Hiie et al. | Oct 2010 | A1 |
20100284389 | Ramsay et al. | Nov 2010 | A1 |
20110029649 | Tian et al. | Feb 2011 | A1 |
20110246608 | Wu et al. | Oct 2011 | A1 |
20120054818 | Noh et al. | Mar 2012 | A1 |
20120324090 | Gu et al. | Dec 2012 | A1 |
20130003732 | Dholakia et al. | Jan 2013 | A1 |
20130110981 | Thornburgh et al. | May 2013 | A1 |
20130246578 | Moreman | Sep 2013 | A1 |
20130290555 | Einarsson | Oct 2013 | A1 |
20140068690 | Luthra | Mar 2014 | A1 |
20140150019 | Ma | May 2014 | A1 |
20150128170 | Fu | May 2015 | A1 |
Entry |
---|
“Advisory Action”, U.S. Appl. No. 13/285,904, dated Mar. 20, 2014, 4 pages. |
“Final Office Action”, U.S. Appl. No. 13/285,904, dated Dec. 19, 2013, 19 pages. |
“HTTP Dynamic Streaming on the Adobe Flash Platform”, Adobe Flash Platform Technical White Paper, Adobe Systems Inc., Sep. 2010, 18 pages. |
“Move Adaptive Stream”, Move Networks, Inc., retrieved from <http://www.movenetworks.com/wp-content/uploads/move-adaptive-stream.pdf> on Aug. 29, 2008 and accessed from Internet Archive WayBackMachine (https://archive.org/web/) on Jun. 19, 2014, 4 pages. |
“Move Media Player”, Move Networks, Inc., retrieved from <http://www.movenetworks.com/wp-content/uploads/move-media-player.pdf> on Aug. 29, 2008 and accessed from Internet Archive WayBackMachine (https://archive.org/web/) on Jun. 19, 2014, 3 pages. |
“Move Networks Solutions”, Move Networks, Inc., retrieved from <http://www.movenetworks.com/why-move/solutions> on Aug. 29, 2008 and accessed from the Internet Archive WayBackMachine (https://archive.org/web/) on Jun. 19, 2014, 3 pages. |
“Non-Final Office Action”, U.S. Appl. No. 13/285,904, dated May 24, 2013, 15 pages. |
“Our Clients”, Move Networks, Inc., retrieved from <http://www.movenetworks.com/why-move/our-clients> on Aug. 29, 2008 and accessed from the Internet Archive WayBackMachine (https://archive.org/web/) on Jun. 19, 2014, 1 page. |
“Real-Time Media Flow Protocol Frequently Asked Questions—External”, retrieved from <http://download.macromedia.com/pub/labs/flashplayer10/flashplayer10_rtmfp_faq_070208.pdf> on May 8, 2009 and accessed from <https://www.interlake.net/en/assets/File/flashplayer10_rtmfp_faq_081010.pdf> on Jun. 19, 2014, Jul. 2, 2008, 5 pages. |
Allman, “RFC 2581: TCP Congestion Control”, retrieved from <http://tools.ietf.org/html/rfc2581> on Jun. 19, 2014, Apr. 1999, 14 pages. |
Birney, “Intelligent Streaming”, Microsoft Corporation, retrieved from <http://www.microsoft.com/windows/windowsmedia/howto/articles/intstreaming.aspx?pf=true> on Aug. 29, 2008, May 2003, 7 pages. |
Crowcroft, et al.,′ “MAPEX: Application Level Multicast Architectural Requirements for APEX”, retrieved from <URL:http://ftp.ist.pt/pub/drafts/draft-crowcroft-apex-multicast-01.txt> on Dec. 12, 2008 and accessed from <http://tools.ietf.org/html/draft-crowcroft-apex-multicast-01> on Jun. 19, 2014, Oct. 2, 2001, 9 pages. |
IXIA, “Support: Enpoint Library”, retrieved from <http://www.ixiacom.com/support/endpoint_library> on Jun. 19, 2014, 2 pages. |
Kaufman, et al.,′ “Network Multicast Peer Discovery Methods”, U.S. Appl. No. 12/485,821, Jun. 16, 2009, 31 pages. |
Kaufman, et al.,′ “Self Organizing Peer-to-Peer System, Method, and/or Apparatus”, U.S. Appl. No. 11/969,186, Jan. 3, 2008, 25 pages. |
Narten, et al.,′ “Neighbor Discovery for IP Version 6 (IPv6)”, IETF Network Working Group, Dec. 1998, 87 pages. |
Plummer, “An Ethernet Address Resolution Protocol—or—Converting Network Protocol Addresses to 48.bit Ethernet Address for Transmission on Ethernet Hardware”, RFC 826, retrieved from <https://tools.ietf.org/rfc/rfc826.txt> on Jun. 19, 2014, Nov. 1982, 14 pages. |
Postel, “User Datagram Protocol”, Identified as page ftp://ftp.isi.edu/in-notes/rfc768.txt, Aug. 28, 1980, 3 pages. |
Sano, et al.,′ “Improving Efficiency of Application-Level Multicast with Network Support”, Abstract Only, retrieved from <URL: http://cat.inist.fr/?aModele=afficheN&cpsidt=15670193> on Dec. 12, 2008 and accessed from <http://link.springer.com/chapter/10.1007/978-3-540-39405-1_2> on Jun. 19, 2014, 2003, 5 pages. |
Wikipedia, “Communication Endpoint”, retrieved from <http://en.wikipedia.org/wiki/Communication_endpoint> on Jun. 19, 2014, 1 page. |
“Non-Final Office Action”, U.S. Appl. No. 13/285,904, dated Apr. 22, 2015, 17 pages. |
“Final Office Action”, U.S. Appl. No. 13/285,904, dated Nov. 17, 2015, 19 pages. |
“Non-Final Office Action”, U.S. Appl. No. 13/285,904, dated Jun. 9, 2016, 20 pages. |
“Notice of Allowance”, U.S. Appl. No. 13/285,904, dated Jan. 17, 2017, 10 pages. |
Number | Date | Country | |
---|---|---|---|
20160029050 A1 | Jan 2016 | US |