US10791157B2 - Multi-tenant over-the-top multicast - Google Patents
Multi-tenant over-the-top multicast Download PDFInfo
- Publication number
- US10791157B2 US10791157B2 US15/693,696 US201715693696A US10791157B2 US 10791157 B2 US10791157 B2 US 10791157B2 US 201715693696 A US201715693696 A US 201715693696A US 10791157 B2 US10791157 B2 US 10791157B2
- Authority
- US
- United States
- Prior art keywords
- multicast address
- time position
- multicast
- media stream
- different
- 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, expires
Links
- 238000000034 method Methods 0.000 claims description 82
- 230000004044 response Effects 0.000 claims description 25
- 238000005304 joining Methods 0.000 claims description 10
- 230000003111 delayed effect Effects 0.000 claims description 5
- 230000000153 supplemental effect Effects 0.000 claims 8
- 230000011664 signaling Effects 0.000 claims 2
- 230000001934 delay Effects 0.000 claims 1
- 238000000638 solvent extraction Methods 0.000 claims 1
- 239000013589 supplement Substances 0.000 abstract description 4
- 230000008569 process Effects 0.000 description 58
- 238000003860 storage Methods 0.000 description 11
- 230000005540 biological transmission Effects 0.000 description 10
- 238000005457 optimization Methods 0.000 description 5
- 238000012545 processing Methods 0.000 description 5
- 230000006835 compression Effects 0.000 description 4
- 238000007906 compression Methods 0.000 description 4
- 238000012544 monitoring process Methods 0.000 description 4
- 230000007704 transition Effects 0.000 description 4
- 230000008901 benefit Effects 0.000 description 3
- 230000006399 behavior Effects 0.000 description 2
- 230000003139 buffering effect Effects 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 230000001413 cellular effect Effects 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 239000003795 chemical substances by application Substances 0.000 description 1
- 238000009826 distribution Methods 0.000 description 1
- 239000002355 dual-layer Substances 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 238000009877 rendering Methods 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 238000001228 spectrum Methods 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 238000012360 testing method Methods 0.000 description 1
Images
Classifications
-
- H04L65/4076—
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/1066—Session management
- H04L65/1069—Session establishment or de-establishment
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/61—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
- H04L65/611—Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for multicast or broadcast
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/80—Responding to QoS
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/06—Protocols specially adapted for file transfer, e.g. file transfer protocol [FTP]
Definitions
- IP networks Contrary to television broadcasts which are waning or stagnating in viewership, the viewership of content over Internet Protocol (IP) networks is continually increasing. This is due to many factors including the increasing availability of major content provider and television network content on the IP networks and the breadth of user content that individuals upload and share via video-sharing sites. IP networks also allow for on-demand content viewing and often provide digital video recorder (DVR) like functionality (e.g., rewinding, pausing, fast-forwarding, etc.). Moreover, content delivered through IP networks can be customized on a per user basis while allowing the user to view the content wherever and whenever the user wants using any device with wired or wireless network connectivity.
- DVR digital video recorder
- unicast is a one-to-one transmission methodology, whereby one copy of content is passed between one source and only one destination. Even if the same content is requested from the same source by a different destination, a new copy of the content will be passed from the source to the different destination over a unique connection or session established between the source and destination. Consequently, unicast produces a linear increase in the demand that is placed on IP networks for each additional stream or item of content that is delivered to a user.
- Multicast provides a one-to-many transmission of content.
- a source is the origin for a multicast group and streams the packets encapsulating content to one or more hosts and routers that have joined the multicast group. These hosts and routers then fan-out the packets to other hosts and routers that join the multicast group until the packets arrive at users that have also joined the multicast group. Specifically, the users receive the packets from a host or router in the multicast group that is closest to them rather than from the origin directly.
- Multicast is an efficient transmission methodology because it requires little to no overhead once the multicast group is configured. Hosts and routers that have joined the multicast group perform little or no processing on the multicast group packets and simply forward those packets to other group members that join the group through the host or router.
- a first shortcoming is that the one-to-many transmission methodology of multicast prevents a content source from offering users the ability to start the stream whenever they want. It further restricts the content source from offering DVR-like functionality such that users could rewind, fast-forward, or pause the transmission of the stream as they please.
- Another shortcoming is that the one-to-many transmission methodology of multicast prevents a content source from optimizing and customizing the stream on a per user basis.
- the content distributor can offer the stream in multiple bit rates and adjust the stream per user depending on the network connectivity to the user and capabilities of the user device. Also through unicast, the content distributor can change advertising accompanying the stream on a per user basis so that the content can itself be customized on a per user basis. Multicast requires that the same content with the same advertisements be presented to all users in the multicast group.
- FIG. 1 conceptually illustrates a manifest file in accordance with some embodiments.
- FIG. 2 illustrates initializing the intelligent client application with a manifest file in accordance with some embodiments.
- FIG. 3 illustrates initializing the intelligent client application with metadata in accordance with some embodiments.
- FIG. 4 illustrates providing DVR like functionality to a user device using different multicast groups in accordance with some embodiments.
- FIG. 5 presents a hybrid solution leveraging multicast and unicast to facilitate streaming of an event with DVR like functionality.
- FIG. 6 presents a process performed by the intelligent client application running on a user device to optimize presentation of an event stream for the user device by dynamically changing quality of the event by switching between different multicast groups in accordance with some embodiments.
- FIG. 7 presents a process performed by a content source to stream an event at different quality levels over multicast.
- FIG. 8 presents different timelines conceptually illustrating the use of multicast to deliver customized or targeted secondary content to different user devices in accordance with some embodiments.
- FIG. 9 provides a process implementing a hybrid solution whereby primary content is delivered using multicast and secondary content is delivered using unicast.
- FIG. 10 presents a process describing the hybrid multicast and unicast failover implementation.
- FIG. 11 illustrates a computer system or server with which some embodiments are implemented.
- Streaming content or a content stream involves the transmission of content over a digital medium or network.
- the transmission involves passing packets that encapsulate different digitally encoded segments of the content.
- Packets encapsulating streaming content may be transmitted over a packet-switched network, such as an Internet Protocol (IP) network using the User Datagram Protocol (UDP), Real-time Transport Protocol (RTP), or other networking protocol, wherein the IP network can route the packets based on either IPv4 or IPv6 addressing.
- IP Internet Protocol
- UDP User Datagram Protocol
- RTP Real-time Transport Protocol
- Unicast and multicast configuration and operation are well known and the description of each is omitted herein for purposes of simplicity.
- Some embodiments provide a multi-tenant over-the-top multicast solution.
- the solution integrates the per user stream customizability of unicast with the large scale streaming efficiencies of multicast.
- the multi-tenant over-the-top multicast solution provides an intelligent client application and configures different multicast groups that the intelligent client application can dynamically switch between in order to realize the per user stream customizability of unicast while receiving multicast streamed content.
- the intelligent client application is intended as a cross-platform, cross-vendor, cross-content provider, cross-user device, and cross-network application that can be reused for receiving streaming content from different content sources, networks, sites, etc.
- the intelligent client application can be obtained from any content source or third party site and is configured to execute on any user device having at least one processor. Components of a user device that can execute the intelligent client application are described with reference to FIG. 11 below.
- the different multicast groups serve different variants of content or content customizations using different multicast addresses.
- Each variant or customization is a separate content stream that is accessed by a user device with a different multicast address.
- the different multicast addresses for the multicast groups providing the different content stream variants or customizations for a given event can be specified or identified using the same address but different port numbers.
- the different multicast addresses for the multicast groups of a given event can be specified or identified with unique addresses.
- IP such as IP version 4 (IPv4) or version 6 (IPv6)—the IP addressing may be restricted to class D IPv4 addresses and IPv6 addresses with the ff00::/8 prefix for compliance with standard multicast addresses.
- a first variant of content may be streamed using a first multicast group that is identified with the class D multicast address 225.0.0.1
- a second variant of content may be streamed using a second multicast group that is identified with the class D multicast address 225.0.0.2
- the intelligent client application switches between these different multicast groups in order to optimize and customize the presentation of the content for a particular user or user device running that instance of the intelligent client application.
- the multi-tenant over-the-top multicast solution of some embodiments leverages multicast to provide DVR-like functionality.
- the solution streams content using multicast in a manner that allows for customizability in the playback of the content via rewinding, pausing, and forwarding functionality as some examples.
- some embodiments configure several multicast groups to stream a given event with each multicast group providing the event content with a different time shift.
- the intelligent client application provides digital video recorder (DVR) like functionality on a user device by switching between the different time shifted multicast groups in response to user input to rewind, pause, or forward through the event.
- the intelligent client application limits the time shifting increments offered to the user to match those available from the different multicast groups.
- the intelligent client application allows the user to specify any arbitrary time shift with the application switching to the multicast group that provides the closest time shift to the one specified by the user.
- the intelligent client application of some embodiments is configured to dynamically switch between multicast and unicast in order to supplement or alternatively realize the per user multicast stream customizability of some embodiments.
- the multi-tenant over-the-top multicast solution offers a hybrid implementation that leverages multicast and unicast to provide the DVR-like functionality.
- a source streams a live feed or primary feed of an event via multicast.
- An instance of the intelligent client application running on a user device joins the multicast group to provide the user with the live or primary feed. Since most users watch the live feed, network load will be greatly reduced relative to providing the live feed via unicast to each user.
- the intelligent client application switches from multicast to unicast. In so doing, the intelligent client application establishes a connection directly with the source in order to request and receive the event with the user specified time shift. If that same user again time shifts to return to the live or primary feed, the intelligent client application switches from unicast back to the multicast group providing the live or primary feed.
- a set amount of time shifting is supported through different multicast groups that are configured for an event. Should the user exceed the set amount of time shifting available through the different multicast groups, the intelligent client application then switches from multicast to unicast in order to present the content with the desired amount of time shifting extending beyond the set amount of time shifting provided though the different multicast groups. As most users are expected to remain within the set amount of time shifting, the majority of the content streaming will still be conducted using multicast, thereby reducing the load on the network and on the event source significantly.
- the multi-tenant over-the-top multicast solution of some embodiments leverages multicast to dynamically customize the quality of multicast streamed content on a per user or per user device basis.
- the solution streams event content over different multicast groups in a manner that allows each user device receiving the content to dynamically increase or decrease the quality of the content based on capabilities of that user device and network connectivity to that user device.
- content for an event is transcoded at different quality levels with each quality level encoding of the content being streamed over one of the multicast groups that are configured for the event.
- the different quality levels can represent any of different bitrate encodings, different amounts of compression, and different resolutions for the content as some examples.
- the intelligent client application dynamically adjusts the quality of the stream on the user device to match the user device's resources and network connectivity by switching between the different quality level multicast groups.
- the multi-tenant over-the-top multicast solution also provides a hybrid solution that leverages multicast and unicast to customize the quality of content streamed on a per user or per user device basis.
- content is streamed at different quality levels through different multicast groups. Should the optimal quality level encoding of the event for a particular user device be outside the available set of quality level encodings offered through the multicast groups, the intelligent client application switches from multicast to unicast to request and receive the optimal quality level encoding for that particular user device directly from a content source.
- the multi-tenant over-the-top multicast solution uses different multicast groups to provide different secondary content for an event streaming primary content.
- the secondary content can include third party content that is added during breaks in the primary content stream, overlaid onto the primary content stream, or otherwise presented with the primary content stream.
- the secondary content can include advertisements, informational content (e.g., a stock or sports score ticker), interactive applications, or any other content that is not encoded as part of the primary content stream.
- the intelligent client application of some embodiments dynamically switches between the different multicast groups in order to provide secondary content that is relevant to the user viewing the content using the intelligent client application. For instance, the intelligent client application presents the primary content stream by joining a first multicast group and during a break in the primary content stream, the application switches to one of a second set of multicast groups providing an advertisement that is relevant to the user or user device.
- the multi-tenant over-the-top multicast solution provides such secondary content customization by configuring the intelligent client application to join a multicast group for presentation of the primary content stream and to switch to a unicast address to retrieve a relevant advertisement from a third party before rejoining the multicast group to resume the primary content stream. In this manner, the majority of the content is streamed using multicast with intermittent periods of unicast usage.
- different multicast groups are used to provide a combination of the above described customizations.
- a first multicast group is configured to provide a live stream of particular content at a first quality encoding
- a second multicast group is configured to provide the live stream at a different second quality encoding
- a third multicast group is configured to provide the particular content with a one minute delay at a different third quality encoding.
- the multi-tenant over-the-top multicast solution can also provide a hybrid implementation that leverages multicast and unicast for failover purposes. Specifically, a particular network may not join the multicast groups streaming the event content provided by a content source. Accordingly, users of that particular network may be unable to receive the stream using the multicast and, in these circumstances, the intelligent client application fails over to unicast such that all users can receive the event content.
- the benefit of this hybrid solution is that all users will be able to receive the event content with a majority of those users receiving the event content via multicast, thereby reducing the burden on the content source.
- any of a manifest file and metadata may be used to configure the intelligent client application to provide any one or more of the above described functionality over multicast.
- FIG. 1 conceptually illustrates a manifest file 100 in accordance with some embodiments.
- the manifest file 100 identifies for any instance of the intelligent client application, the different multicast groups 110 that are configured for a given event and that provide different variants of the event content.
- Column 120 of the manifest file 100 identifies the different time shifts, quality, or secondary content associated with each of the multicast groups 110 .
- Column 130 of the manifest file 100 identifies the addressing for switching between the multicast groups 110 configured for the event.
- the manifest file also identifies one or more unicast addresses 140 that supplement the customizations offered by the multicast groups 110 .
- the unicast addresses 140 can identify a content source or other servers that host the event content.
- the unicast addresses 140 can point to IP addressing of the content source or a content delivery network (CDN) that hosts and distributes the content source content on behalf of the content source.
- CDN content delivery network
- different unicast addressing is configured to allow the intelligent client application to receive the event content with a custom time shift with each unicast address providing the event content at a different quality level encoding.
- the configuration information of the manifest file identifies one multicast address for a multicast group providing a primary stream for particular content and a unicast address with which the intelligent client application can receive the particular content directly from the content source with a custom time shift, a non-default quality encoding, or custom secondary content.
- the intelligent client application joins the multicast group to initially receive the primary stream, then the application switches from multicast to unicast to provide a custom time-shift, non-default quality encoding, or secondary content.
- FIG. 2 illustrates initializing the intelligent client application with a manifest file in accordance with some embodiments.
- the figure depicts a user device 210 , routers 220 , and a content source 230 .
- the content source 230 can be one or more machines tasked with streaming particular content with any of the above described customizations or optimizations through different multicast groups, and the routers 220 are devices within the network that have joined the different multicast groups and support the multicast distribution of the particular content with the different customizations or optimizations.
- the content source 230 begins streaming different customizations of a particular event across four multicast groups that the routers 220 have joined.
- the intelligent client application loads (at 240 ) on the user device.
- the intelligent client application loading can be in response to user input to begin streaming the particular event.
- the user input can include any of invocation of a link, entering an address, or otherwise loading a website or configuration to request the particular event stream. If the application is present on the user device, it is executed. Otherwise, the application is downloaded from the content source or other third party site and is executed on the user device thereafter.
- the intelligent client application sends (at 250 ) a request for the particular event stream to a unicast address associated with the content source 230 .
- the unicast address may be identified from the user input.
- the user may invoke a link or specify an address using a web browser or other application that sends the request for the particular event stream to the content source 230 and the response from the content source 230 causes the intelligent client application to load on the user device 210 .
- the content source 230 sends (at 260 ) a manifest file in response to the request.
- the manifest file is received by the user device 210 .
- the manifest file contains the configuration information for the particular event.
- the configuration information identifies the different multicast groups that have been configured for the particular event, the customizations or optimizations provided by each multicast group, and the addressing for accessing each multicast group.
- the manifest file optionally specifies one or more unicast addresses that can be used to supplement the multicast groups and provide additional customizations and optimizations for the particular event stream.
- the intelligent client application selects (at 270 ) a first multicast group from which to receive the particular event stream.
- the intelligent client application may be configured to initially select the multicast group that presents a primary stream of the particular event at a default quality encoding, wherein the primary stream can be a live stream.
- the intelligent client application then causes the user device 210 to join (at 280 ) the first multicast group.
- the primary stream for the particular event is streamed (at 285 ) to the user device 210 from the routers 220 .
- the user device 210 then processes and presents (at 290 ) the primary stream. If any customizing functionality is invoked on the intelligent client application, the application references the manifest file to identify which multicast group or unicast address to switch to in order to provide the particular content with the requested customization.
- the configuration information from the manifest file can also or alternatively be passed as metadata that is periodically included in the header or body of the packets used to stream the event content.
- the metadata containing the configuration information can be included in control packets that are periodically intermixed with the packets used to stream the event content.
- the metadata can be replicated or provided in any of the multicast groups configured for an event as well as in any direct unicast stream established between a user and a content source.
- the metadata is used to update information originally obtained from the manifest file.
- FIG. 3 illustrates initializing the intelligent client application with metadata in accordance with some embodiments.
- the initialization of the intelligent client application begins with the user device 310 joining (at 340 ) a first multicast group. This can be in response to invocation of a link, entry of an address, or otherwise loading a website or configuration.
- the intelligent client application loads (at 350 ) on the user device.
- the intelligent client application then begins to receive (at 360 ) packets for the stream provided over the joined multicast group. Intermixed with the packets is the metadata specifying additional multicast groups and optionally, one or more unicast addresses, at which different customizations of the stream are available. Accordingly, the intelligent client application receives (at 370 ) the metadata and processes the metadata to identify the different customizations that are available through the different multicast groups. Thereafter, should any customization functionality be invoked, the intelligent client application can provide the customization by switching to the appropriate multicast group or unicast address.
- FIG. 4 illustrates providing DVR like functionality to a user device using different multicast groups in accordance with some embodiments.
- the figure illustrates a user device 410 , routers 420 , and a content source 430 .
- the content source 430 configures and simultaneously streams different time shifted streams for a given event across different multicast groups 435 that are configured for that event. Specifically, the content source 430 provides a live stream of the event using a first multicast group identified by a first multicast address, provides a thirty second delay of the event using a second multicast group identified by a second multicast address, provides a one minute delay of the event using a third multicast group identified by a third multicast address, and provide a two minute delay of the event using a fourth multicast group. Any number of multicast groups with any time shift can be provided, however the discussion of FIG. 1 will be restricted to the four identified groups for purposes of simplicity. Even though the multicast groups 435 are identified by unique IP addresses in this figure, some embodiments can provide the same IP address to each group and uniquely identify the groups using a different port number.
- the routers 420 join each of the multicast groups 435 .
- advertisement or control messaging is passed by the content source 430 to notify the routers 420 of the groups to join.
- the multicast addresses used for streaming the event are reserved in advance of the event such that the when the stream begins, the routers 420 have already joined the groups.
- the routers 420 operate to fan-out the streams as per standard multicast operation.
- the user device 210 loads the intelligent client application (at 440 ) of some embodiments.
- the intelligent client application receives (at 445 ) a manifest file from the content source 430 identifying addressing for the different multicast groups 435 of the event and the time shift provided by each multicast group.
- the intelligent client application initializes presentation of the event on the user device by joining (at 450 ) the first multicast group.
- the manifest file can identify the first multicast group as a default group that the application is to first join. Alternatively, a link that is used to access the event can direct the application to the first multicast group. This can be the case when the event is a live streaming event.
- the application then processes and presents the content streamed over the first multicast group.
- the user invokes a rewind or replay operation on the intelligent client application to go back up to thirty seconds in the stream.
- the application can provide either fixed increment time shifting operations that match the time shifting that is available from the different multicast groups or provide for custom incremental time shifting with the application adjusting the custom time shift to match time shifting provided by one of the available time shifted multicast groups. For example, if the user requests a twenty five second rewind from the live stream, the application would switch from the first multicast group to the second multicast group providing a thirty second delay. Similarly, if the user requests a thirty one second rewind from the live stream, the application could switch from the first multicast group to either the third multicast group providing a one minute delay or the second multicast group providing a thirty second delay.
- the application switches from the first multicast group to the second multicast group to go back thirty seconds in the content stream.
- the switch occurs by leaving (at 460 ) the first multicast group and joining (at 465 ) the second multicast group.
- the application then resumes playback of the event based on the thirty second delayed stream of the second multicast group.
- the switch from the first multicast group to the second multicast group occurs seamlessly with little to no buffering or blackout experienced on the user device 410 .
- the user invokes a custom time shift rewind or replay operation to time shift the playback position four minutes and ten seconds back from the live stream. Since this time shift is beyond the time shifting provided by any of the available multicast groups, the intelligent client application leaves (at 475 ) any joined multicast groups, establishes a direct connection with the content source 430 using unicast, and requests (at 480 ) the content at the specified position from the content source 430 over the established connection. The application then resumes (at 485 ) playback of the event over unicast at the designated time.
- the user invokes an operation on the intelligent client application to advance the content back to the live stream.
- the intelligent client application closes (at 493 ) the unicast connection and joins (at 496 ) the first multicast group, thereby once again receiving (at 499 ) the live stream over multicast.
- the different multicast groups can support any number of user devices without any additional overhead on the content source. Accordingly, the intelligent client application along with the various multiple multicast groups allow the content source to provide the identified DVR like functionality while still being able to support a large viewing audience with no additional impact for any users receiving the content through one of the available multicast groups. Providing such functionality while streaming a large scale event would require exponentially more resources if the streaming was done using unicast exclusively.
- FIG. 5 presents a hybrid solution leveraging multicast and unicast to facilitate streaming of an event with DVR like functionality.
- multicast is used to stream default content to a majority of users, while unicast is used to stream the content with a requested time shift customization. This greatly reduces the load on the content source and intermediary networks while still allowing the event to be streamed to a large audience with DVR like functionality.
- This figure depicts a content source 510 , routers 515 , and several different user devices 520 , 525 , 530 , 535 , and 540 .
- the content source 510 distributes a live stream of an event over a particular multicast group.
- the routers 515 join the particular multicast group to fan-out the event.
- a manifest file or metadata is passed (not shown) to each of the user devices 520 - 540 . This provides the intelligent client application running on each user device with the configuration information identifying the availability of the event and the different offered customizations.
- All user devices including user devices 520 , 530 , and 535 , that watch the live stream also join the particular multicast group. In so doing, user devices 520 , 530 , and 535 receive the content from a participating router 520 over multicast. However, those user devices, including user devices 525 and 540 , that have time shifted away from the live stream establish a unicast connection with the content source 510 in order to receive the event with the proper time shift.
- Some embodiments of the multi-tenant over-the-top multicast solution leverage the different multicast groups to support optimizing content quality level on per user basis while streaming the content over multicast.
- the content source transmits the same content at different quality encodings over different multicast groups.
- each multicast group is identified and accessed using a different multicast address.
- the intelligent client application optimizes the viewing experience on the user device by switching between the different multicast groups in to select a quality encoding of the content that is optimal for the user device. The selection is based on the user device's capabilities, user device's resource usage, and network connectivity in some embodiments.
- FIG. 6 presents a process 600 performed by the intelligent client application running on a user device to optimize presentation of an event stream for the user device by dynamically changing quality of the event by switching between different multicast groups in accordance with some embodiments.
- the process 600 commences by receiving (at 610 ) a request for a content stream that is accessible at a first multicast address.
- the request may originate in response to a user invoking a link, entering an address, or selecting a file, service, or sub-application to load the content stream.
- the process obtains (at 615 ) a manifest file or metadata that identifies addressing for the multicast groups that stream the same content and the differing content quality levels at which each multicast group provides the content.
- the manifest file or metadata can be obtained prior to the request or in response to the request.
- the process joins (at 620 ) the multicast group identified by a first multicast address.
- the first multicast address may identify an initial or default quality level for the content.
- the content quality level can vary based on general classifications such as low definition, standard definition, high definition, and ultra high definition, wherein the initial quality level is one of the general classifications.
- the content quality level can be quantified in terms of a bit rate encoding for the content (e.g., 3 megabits per second (Mbps), 1 Mbps, etc.), a resolution (e.g., 1920 ⁇ 1080, 4K, etc.), a level of compression (e.g., lossless, minimum lossy compression, maximum lossy compression, etc.), file size, or encoding (e.g., MPEG-2, H.264, H.265, etc.) as some examples.
- a bit rate encoding for the content e.g., 3 megabits per second (Mbps), 1 Mbps, etc.
- a resolution e.g., 1920 ⁇ 1080, 4K, etc.
- a level of compression e.g., lossless, minimum lossy compression, maximum lossy compression, etc.
- file size e.g., MPEG-2, H.264, H.265, etc.
- the process receives (at 630 ) packets encoding the content at the initial quality level.
- the process may also periodically receive metadata.
- the metadata may serve to update the data in the manifest file or may serve as a substitute for the manifest file if the manifest file is not provided when the streaming is initialized.
- the process monitors (at 640 ) the user device's capabilities and ability to process and render the packets at the current initial quality level.
- the process monitors user device capabilities such as screen resolution, screen size, operating system, battery life, and supported codecs as some examples.
- the process monitors the user device's ability to process the content and resource usage based on any of processor speed, processor load, available memory, memory usage, and frame rendering speed of the user device as some example.
- the process monitors the network connectivity by measuring network bandwidth, network throughput, network latency, packet loss, amount or time for buffering, and jitter as some examples.
- the process determines (at 650 ) if the current initial quality level is optimal for the user device.
- the process ends or can revert to step 640 until the content stream terminates or completes.
- the process switches (at 660 ) from the multicast group providing the current quality level to a different multicast group that is identified in the manifest file to be optimal for the current state of the user device. For instance, if the initial quality level requires too much bandwidth or too much processing power from the user device, the process will switch from the multicast group providing the initial quality level to a different multicast group providing a lower quality level that is less taxing of the user device and network connection.
- the process will switch from the multicast group providing the initial quality level to a different multicast group providing a higher quality level.
- the switch is made by changing from the first multicast address to a different second multicast address identifying the optimal multicast group.
- the intelligent client application leaves the multicast group providing the initial quality level and joins the multicast group providing the optimal quality level.
- the process then continues monitoring (at 640 ) performance of the user device in order to further optimize the quality of the event stream for the user device based on changing loads on the user device or network connectivity. The process continues until the content stream is terminated or completed.
- the content source can stream content at different quality levels to thousands of user devices and only incur the burden associated with streaming a different multicast group for each supported quality level.
- the burden on the content source would be significantly greater when providing the different quality levels to thousands of users through unicast as unicast streaming would require the content source to establish a separate connection and provide a separate stream to each of the user devices.
- the content source can create ten multicast groups and stream ten different quality level encodings for event content over the ten multicast groups to thousands of user devices with the content source incurring only the overhead for the ten streams.
- streaming the same event content with the same quality level encodings with unicast would impose additional linear overhead for each user device receiving the event content.
- Some embodiments also support streaming content at different quality levels using a combination of different multicast groups and unicast, with unicast being used to support additional quality levels not available through the different multicast groups.
- the multicast groups support the common quality levels at which content is consumed. For example, a first multicast group may optimize content for viewing on a Microsoft Windows user device, a second multicast group may optimize content for viewing on an iOS user device, a third multicast group may optimize content for viewing on an Android user device, and unicast is used to provide customized optimization for other user devices.
- multicast is used to provide different quality levels to the majority of user devices with unicast being used to support a minority of user devices.
- the manifest file or metadata identifies the quality level encodings for the intelligent client application allowing the application to select the quality level encoding that is best for the user or user device on which the application executes.
- FIG. 7 presents a process 700 performed by a content source to stream an event at different quality levels over multicast.
- the process 700 commences when the content source obtains (at 710 ) content for streaming.
- the process transcodes (at 720 ) the content at multiple quality levels.
- the transcoding creates the different quality level encodings for the event content.
- the process then assigns each quality level encoding to a different multicast group. Specifically, for each quality level encoding of the even content, the process configures (at 730 ) a different multicast group with a unique multicast address, wherein the unique multicast address for each group can be a unique IP address or the same IP address with a unique port number.
- the process then streams (at 740 ) the corresponding quality level encoding through each of the configured groups.
- the process may perform a multicast advertisement routine to notify downstream routers of the new groups that are available.
- the process also generates (at 750 ) a manifest file or metadata to periodically include within the streams to notify the intelligent client application running on the user devices of the different quality level encodings that are available and the addressing for each.
- the multi-tenant over-the-top multicast solution leverage the different multicast groups to deliver customized or targeted secondary content to different users receiving the same primary content stream.
- the primary content stream is a streaming event and the secondary content is advertising, informational, or other content that is presented during breaks throughout the primary content stream, overlaid onto the primary content stream, or otherwise presented with the primary content stream.
- the secondary content can itself be a stream.
- Different multicast groups are configured to provide different secondary content to different user devices based on any of several factors including, for example, geographic region, user interests, user demographic information (e.g., age, sex, income level), user browsing behavior, and user device type.
- Monitoring performed by the intelligent client application is used to select the secondary content that is most relevant to the user or user device on which the intelligent client application executes. For example, a sporting event is streamed using a first multicast group. During a break or pause in the sporting event, the intelligent client application switches from the first multicast group to one of several other multicast groups that provides an advertisement or other embedded content that is relevant to the user device on which the intelligent client application runs. The application switches back to the first multicast group when the sporting event resumes and the presentation of the advertisement or other embedded content is complete.
- FIG. 8 presents different timelines conceptually illustrating the use of multicast to deliver customized or targeted secondary content to different user devices in accordance with some embodiments.
- Each timeline illustrates operation of an intelligent client application running on a different user device 810 , 815 , 820 , 825 , and 830 over a period of time.
- each timeline identifies a multicast group that an intelligent client application joins and corresponding content that it receives over the period of time.
- all user devices 810 - 830 receive the same primary content as a result of the intelligent client application running on each device joining a first multicast group.
- the primary content can be a movie, sporting event, television program, or other streaming event.
- a manifest file or metadata is passed to each of the user devices 810 - 830 receiving the primary content through the first multicast group.
- the manifest file or metadata identifies an upcoming break in the primary content at time 850 for an interval 855 , wherein interval 855 is to be used to present different targeted secondary content to the user devices 810 - 830 .
- the time of the break is not identified in the manifest file or metadata. Instead, the break is identified by a blackout period or period of no content or empty packets in the primary content stream.
- the manifest file or metadata does however identify addressing for second, third, and fourth multicast groups that provide different secondary content, such as advertisements, during interval 855 and parameters qualifying the secondary content.
- the parameters can include geographic qualifiers that identify which secondary content from the second, third, and fourth multicast groups is relevant for user devices operating in different geographic regions. This facilitates regional advertising, whereby users in Los Angeles receiving the primary content stream, receive different secondary content than users in New York receiving the primary content stream.
- the parameters can alternatively or additionally include age qualifiers that identify which secondary content from the second, third, and fourth multicast groups is relevant for users of different age groups (e.g., children, adult, and elderly). It should be apparent that the parameters can include many other qualifiers including sex, race, income level, browsing history, and user device as some examples, in combination with or independent of the geographic and age qualifiers described above.
- the intelligent client application running on the user device is tasked with obtaining the relevant qualifying parameters about the user device or user of that user device in order to determine, based on the parameters specified in the manifest file or metadata, which secondary content from the second, third, and fourth multicast groups is most relevant.
- the intelligent client application can obtain this information from registration information that the user provides when first initializing the application, from user agent parameters or other system identifiers identifying the user device, from a user profile, or from information that the application compiles as a result of monitoring user behavior and usage of the corresponding user device.
- the intelligent client applications running on the first and third user devices 810 and 820 switch from the first multicast group to the third multicast group to present a first advertisement that is streamed over the third multicast group during interval 855
- the intelligent client application running on the second user device 815 switches from the first multicast group to the second multicast group to present a second advertisement that is streamed over the second multicast group during interval 855
- the intelligent client applications running on the fourth and fifth user devices 825 and 830 switch from the first multicast group to the fourth multicast group to present a third advertisement that is streamed over the fourth multicast group during interval 855 .
- the advertisements presented through the second, third, and fourth multicast groups can be originated by the same content source that originates the primary content of the first multicast group.
- the advertisements presented through the second, third, and fourth multicast groups can be originated by different advertisement servers that operate in concert but independent of the content source that originates the primary content stream using the first multicast group.
- each of the second, third, and fourth multicast groups delivers a manifest file or metadata to revert the user devices 810 - 830 back to the first multicast group for resumption of the primary content stream at the end of interval 855 .
- the configuration information from this manifest file or metadata may identify a time to perform the multicast group switch and an address of the first multicast address to switch to at the designated time. As before, the time when the switch is to be performed can be omitted from the configuration information and can occur when there is a blackout period in the corresponding multicast group.
- each of the user devices 810 - 830 switch back to the first multicast group and receive the second segment of the primary content stream during interval 865 .
- Another manifest file or metadata is delivered at time 870 during interval 865 through the first multicast group. This manifest file or metadata identifies a new set of parameters qualifying users for advertisements to be presented during interval 875 at the conclusion of interval 865 .
- the first and fifth user devices 810 and 830 switch to the second multicast group for receipt of a first advertisement during interval 875
- the second and fourth user devices 815 and 825 switch to the third multicast group for receipt of a second advertisement during interval 875
- the third user device 830 switches to the fourth multicast group for receipt of a third advertisement during interval 875
- a manifest file or metadata is also passed at time 880 during interval 875 over the second, third, and fourth multicast groups to revert the intelligent client applications and user devices 810 - 830 back to the first multicast group to resume receipt of the last segment of the primary content stream during interval 885 .
- FIG. 8 is described with multiple manifest files or metadata being passed at different intervals over the timeline.
- a single manifest file provided upon initializing the primary content stream is used control the intelligent client application operation throughout the duration of the primary content stream by indicating when the breaks in the programming occur, the different secondary content multicast groups available for each break, and any qualifying parameters for the secondary content at each break.
- the primary content originator can control which multicast group is selected during interval 855 for presentation of a custom advertisement during the first break and which multicast group is selected during interval 875 for presentation of a custom advertisement during the second break, and to revert the client application back to the first multicast group after presentation of each custom advertisement is complete.
- the operation of the intelligent client application in switching between primary content and different available secondary content is controlled by metadata.
- the metadata can arrive some time prior to a transition taking place. As packet loss may occur during transmission, the metadata can be sent multiple times prior to the transition taking place.
- the solution can be tuned to provide the primary content stream via multicast while identifying a mix of multicast and unicast for delivery of the targeted secondary content. This solution may be preferred to increase the different secondary content choices.
- FIG. 9 provides 900 a process implementing a hybrid solution whereby primary content is delivered using multicast and secondary content is delivered using unicast. The process 900 is performed by the intelligent client application running on a user device.
- the process commences when the user device joins (at 910 ) a multicast group to receive the primary content stream. The process then begins to receive (at 920 ) packets encoding a first segment of the primary content which are rendered to present the primary content on the user device. The process also receives (at 930 ) metadata while receiving the packets encoding the first segment.
- the process identifies (at 940 ) an upcoming break in the primary content, different qualifying parameters for different secondary content available during the break, and different unicast addresses for accessing the different secondary content.
- the upcoming break may be identified with a specific time or by a certain amount of black space occurring during presentation of the primary content stream.
- the process retrieves (at 950 ) any of user parameters qualifying the user and user device parameters qualifying the user device.
- the intelligent client application may continually monitor and update the user parameters and user device parameters or may retrieve these parameters from a database.
- the process compares (at 960 ) the user parameters and/or user device parameters to the qualifying parameters for the different secondary content. Based on the comparison, the process selects (at 970 ) one of the unicast addresses and switches (at 975 ) from the multicast group to the selected unicast address. The process then retrieves (at 980 ) and presents the selected secondary content during the break before receiving additional metadata that causes (at 990 ) the process to switch back to the multicast group.
- one unicast address can be used to provide the targeted secondary content.
- the application transitions to a unicast address and submits the user parameters and/or user device parameters to the host machine at the unicast address.
- the host machine then provides secondary content that is relevant to at least one of the user and user device in response.
- FIG. 10 presents a process 1000 describing the hybrid multicast and unicast failover implementation.
- the process 1000 commences with a user device establishing (at 1010 ) a unicast connection with a source and requesting (at 1020 ) an event stream from the source over the unicast connection.
- the process receives (at 1030 ) a manifest file identifying at least multicast group at which the event stream is available and at least one unicast address to which the user device can failover should the multicast stream be unavailable to the user device.
- the process submits (at 1040 ) a request to join the multicast group identified in the manifest file in order to receive a default multicast stream of the event content.
- the process determines (at 1050 ) if the join was successful. If user device successfully joins the multicast group it will begin receiving (at 1060 ) packets from the multicast address identifying the multicast group. If any failure occurs (at 1070 ) during the stream, the process can perform the failover at step 1080 .
- the user device will not receive any packets and the process fails over to the unicast address identified in the manifest file.
- the failover occurs by establishing (at 1080 ) a connection with the destination identified at the unicast address and submitting (at 1085 ) a request for a stream of the event content from the destination.
- the process will begin receiving (at 1090 ) the event stream directly from the destination over the unicast connection.
- the destination may be the content source or another machine hosting and serving the content source event content.
- the failover implementation allows the multicast solutions to be used even when some users rely on unicast to receive various content streams. Nevertheless, the content source still benefits from being able to offload some users to multicast.
- the failover scenario may arise when the content source distributes a multicast configuration specifying the different multicast groups that it has created and will stream.
- the content source may not have partnerships with various networks and those networks may not receive or accept the configuration. Other networks may simply not support multicast routing.
- networks will reserve several multicast addresses to support multicast streaming. As part of the reservation, the networks automatically accept and route packets sent to those multicast addresses from a content source, such that the various multi-tenant over-the-top multicast solutions implemented by the content source are supported without any additional network configuration.
- Non-transitory computer-readable storage medium also referred to as computer-readable medium.
- these instructions are executed by one or more computational element(s) (such as processors or other computational elements like ASICs and FPGAs), they cause the computational element(s) to perform the actions indicated in the instructions.
- Server, computer, and computing machine are meant in their broadest sense, and can include any electronic device with a processor including cellular telephones, smartphones, portable digital assistants, tablet devices, laptops, notebooks, and desktop computers.
- Examples of computer-readable media include, but are not limited to, CD-ROMs, flash drives, RAM chips, hard drives, EPROMs, etc.
- FIG. 11 illustrates a computer system or server with which some embodiments are implemented.
- a computer system includes various types of computer-readable mediums and interfaces for various other types of computer-readable mediums that implement the various methods and machines described above (e.g., caching servers, replay servers, test servers, etc.).
- Computer system 1100 includes a bus 1105 , a processor 1110 , a system memory 1115 , a read-only memory 1120 , a permanent storage device 1125 , input devices 1130 , and output devices 1135 .
- the bus 1105 collectively represents all system, peripheral, and chipset buses that communicatively connect the numerous internal devices of the computer system 1100 .
- the bus 1105 communicatively connects the processor 1110 with the read-only memory 1120 , the system memory 1115 , and the permanent storage device 1125 . From these various memory units, the processor 1110 retrieves instructions to execute and data to process in order to execute the processes of the embodiments described above.
- the processor 1110 is a processing device such as a central processing unit, integrated circuit, graphical processing unit, etc.
- the read-only-memory (ROM) 1120 stores static data and instructions that are needed by the processor 1110 and other modules of the computer system.
- the permanent storage device 1125 is a read-and-write memory device. This device is a non-volatile memory unit that stores instructions and data even when the computer system 1100 is off. Some embodiments use a mass-storage device (such as a magnetic, solid-state disk, or optical disk and its corresponding disk drive) as the permanent storage device 1125 .
- the system memory 1115 is a read-and-write memory device.
- the system memory is a volatile read-and-write memory, such as random access memory (RAM).
- RAM random access memory
- the system memory stores some of the instructions and data that the processor needs at runtime. In some embodiments, the processes are stored in the system memory 1115 , the permanent storage device 1125 , and/or the read-only memory 1120 .
- the bus 1105 also connects to the input and output devices 1130 and 1135 .
- the input devices enable the user to communicate information and select commands to the computer system.
- the input devices 1130 include alphanumeric keypads (including physical keyboards and touchscreen keyboards), pointing devices (also called “cursor control devices”).
- the input devices 1130 also include audio input devices (e.g., microphones, MIDI musical instruments, etc.).
- the output devices 1135 display images generated by the computer system.
- the output devices include printers and display devices, such as liquid crystal displays (LCD).
- bus 1105 also couples computer 1100 to a network 1165 through a network adapter (not shown).
- the computer can be a part of a network of computers (such as a local area network (“LAN”), a wide area network (“WAN”), or an Intranet, or a network of networks, such as the Internet.
- LAN local area network
- WAN wide area network
- Intranet an Intranet
- the computer system 1100 may include one or more of a variety of different computer-readable media.
- Some examples of such computer-readable media include RAM, ROM, compact discs (CD-ROM), digital versatile discs (e.g., DVD-ROM, dual-layer DVD-ROM), a variety of recordable/rewritable DVDs (e.g., DVD-RAM, DVD-RW, DVD+RW, etc.), flash memory (e.g., SD cards, mini-SD cards, micro-SD cards, etc.), magnetic and/or solid state hard drives, read-only and recordable blu-ray discs, and any other optical or magnetic media.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Business, Economics & Management (AREA)
- General Business, Economics & Management (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
- Information Transfer Between Computers (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
Description
Claims (19)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/693,696 US10791157B2 (en) | 2014-09-15 | 2017-09-01 | Multi-tenant over-the-top multicast |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/486,093 US9756098B2 (en) | 2014-09-15 | 2014-09-15 | Multi-tenant over-the-top multicast |
US15/693,696 US10791157B2 (en) | 2014-09-15 | 2017-09-01 | Multi-tenant over-the-top multicast |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/486,093 Continuation US9756098B2 (en) | 2014-09-15 | 2014-09-15 | Multi-tenant over-the-top multicast |
Publications (2)
Publication Number | Publication Date |
---|---|
US20170366590A1 US20170366590A1 (en) | 2017-12-21 |
US10791157B2 true US10791157B2 (en) | 2020-09-29 |
Family
ID=55456002
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/486,093 Active 2034-12-02 US9756098B2 (en) | 2014-09-15 | 2014-09-15 | Multi-tenant over-the-top multicast |
US15/693,696 Active 2034-10-01 US10791157B2 (en) | 2014-09-15 | 2017-09-01 | Multi-tenant over-the-top multicast |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/486,093 Active 2034-12-02 US9756098B2 (en) | 2014-09-15 | 2014-09-15 | Multi-tenant over-the-top multicast |
Country Status (1)
Country | Link |
---|---|
US (2) | US9756098B2 (en) |
Families Citing this family (37)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10430894B2 (en) | 2013-03-21 | 2019-10-01 | Khoros, Llc | Gamification for online social communities |
KR101607092B1 (en) * | 2014-11-18 | 2016-03-29 | 에스케이텔레콤 주식회사 | Method for providing of streaming contents and recording medium recording program therfor |
US11637873B2 (en) * | 2015-02-13 | 2023-04-25 | At&T Intellectual Property I, L.P. | Method and apparatus for managing communication resources |
US10097608B2 (en) * | 2015-12-26 | 2018-10-09 | Intel Corporation | Technologies for wireless transmission of digital media |
GB2549997B (en) * | 2016-04-19 | 2019-07-03 | Cisco Tech Inc | Management of content delivery in an IP network |
JP2018064171A (en) * | 2016-10-12 | 2018-04-19 | 富士通株式会社 | Communication method, communication apparatus and communication program |
US10362346B2 (en) | 2017-04-20 | 2019-07-23 | Apple Inc. | Simultaneous playback for multiple audience members with different visual and audio needs |
US10902462B2 (en) | 2017-04-28 | 2021-01-26 | Khoros, Llc | System and method of providing a platform for managing data content campaign on social networks |
US10977699B2 (en) * | 2017-07-28 | 2021-04-13 | Verizon Patent And Licensing Inc. | Digital signage shim layer |
US10999278B2 (en) | 2018-10-11 | 2021-05-04 | Spredfast, Inc. | Proxied multi-factor authentication using credential and authentication management in scalable data networks |
US10346449B2 (en) | 2017-10-12 | 2019-07-09 | Spredfast, Inc. | Predicting performance of content and electronic messages among a system of networked computing devices |
US11050704B2 (en) | 2017-10-12 | 2021-06-29 | Spredfast, Inc. | Computerized tools to enhance speed and propagation of content in electronic messages among a system of networked computing devices |
US10785222B2 (en) | 2018-10-11 | 2020-09-22 | Spredfast, Inc. | Credential and authentication management in scalable data networks |
US11570128B2 (en) | 2017-10-12 | 2023-01-31 | Spredfast, Inc. | Optimizing effectiveness of content in electronic messages among a system of networked computing device |
US11470161B2 (en) | 2018-10-11 | 2022-10-11 | Spredfast, Inc. | Native activity tracking using credential and authentication management in scalable data networks |
US10601937B2 (en) | 2017-11-22 | 2020-03-24 | Spredfast, Inc. | Responsive action prediction based on electronic messages among a system of networked computing devices |
US10594773B2 (en) | 2018-01-22 | 2020-03-17 | Spredfast, Inc. | Temporal optimization of data operations using distributed search and server management |
AU2019209542B2 (en) * | 2018-01-22 | 2021-10-21 | Eric Manuel FALCAO | Temporal optimization of data operations using distributed search and server management |
US11061900B2 (en) | 2018-01-22 | 2021-07-13 | Spredfast, Inc. | Temporal optimization of data operations using distributed search and server management |
US10855657B2 (en) | 2018-10-11 | 2020-12-01 | Spredfast, Inc. | Multiplexed data exchange portal interface in scalable data networks |
US11234027B2 (en) * | 2019-01-10 | 2022-01-25 | Disney Enterprises, Inc. | Automated content compilation |
CN113475084B (en) * | 2019-02-27 | 2024-02-02 | 英国电讯有限公司 | Multicast assisted delivery |
US10931540B2 (en) | 2019-05-15 | 2021-02-23 | Khoros, Llc | Continuous data sensing of functional states of networked computing devices to determine efficiency metrics for servicing electronic messages asynchronously |
US11567335B1 (en) * | 2019-06-28 | 2023-01-31 | Snap Inc. | Selector input device to target recipients of media content items |
US11509972B2 (en) | 2019-07-09 | 2022-11-22 | Dolby International Ab | Method and device for personalization of media data for playback |
GB2595251A (en) * | 2020-05-19 | 2021-11-24 | British Telecomm | Delivery of media content |
US12120078B2 (en) | 2020-09-18 | 2024-10-15 | Khoros, Llc | Automated disposition of a community of electronic messages under moderation using a gesture-based computerized tool |
US11438289B2 (en) | 2020-09-18 | 2022-09-06 | Khoros, Llc | Gesture-based community moderation |
US11128589B1 (en) | 2020-09-18 | 2021-09-21 | Khoros, Llc | Gesture-based community moderation |
US11924375B2 (en) | 2021-10-27 | 2024-03-05 | Khoros, Llc | Automated response engine and flow configured to exchange responsive communication data via an omnichannel electronic communication channel independent of data source |
US11627100B1 (en) | 2021-10-27 | 2023-04-11 | Khoros, Llc | Automated response engine implementing a universal data space based on communication interactions via an omnichannel electronic data channel |
US11438282B2 (en) | 2020-11-06 | 2022-09-06 | Khoros, Llc | Synchronicity of electronic messages via a transferred secure messaging channel among a system of various networked computing devices |
EP4002857A1 (en) * | 2020-11-13 | 2022-05-25 | Broadpeak | Method and system for customized audio and/or video content delivery |
US11714629B2 (en) | 2020-11-19 | 2023-08-01 | Khoros, Llc | Software dependency management |
US20220400297A1 (en) * | 2021-06-04 | 2022-12-15 | Netskrt Systems, Inc. | Method and apparatus for multicast control of a live video stream |
US11631252B1 (en) * | 2022-01-03 | 2023-04-18 | Brian Lawrence Repper | Visual media management for mobile devices |
US20240333545A1 (en) * | 2023-03-31 | 2024-10-03 | Adeia Guides Inc. | System and method for retrieving missing multicast or broadcast media segments using d2d communication |
Citations (16)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5511168A (en) * | 1993-07-01 | 1996-04-23 | Digital Equipment Corporation | Virtual circuit manager for multicast messaging |
US5612959A (en) * | 1992-07-08 | 1997-03-18 | Hitachi, Ltd. | Multicast communications method |
US5959989A (en) * | 1997-06-25 | 1999-09-28 | Cisco Technology, Inc. | System for efficient multicast distribution in a virtual local area network environment |
DE10104961A1 (en) * | 2001-02-03 | 2002-08-08 | Deutsche Telekom Ag | Bandwidth-efficient transmission of data streams in IP network involves forming IP multi-cast groups on server by allocating multi-cast addresses according to time sequence of requests |
US20060039314A1 (en) * | 2004-08-17 | 2006-02-23 | Sathya Narayanan | Router reachability verification in IPv6 networks |
US20070008969A1 (en) | 2005-07-05 | 2007-01-11 | Elstermann Erik J | Apparatuses and methods for delivering data stream content to consumer devices |
US20070101012A1 (en) | 2005-10-31 | 2007-05-03 | Utstarcom, Inc. | Method and apparatus for automatic switching of multicast/unicast live tv streaming in a tv-over-ip environment |
US20080102749A1 (en) | 2005-02-16 | 2008-05-01 | Matsushita Electric Industrial Co., Ltd. | Providing Information On The Individual Bearers' Relationships To Mobile Terminals Receiving A Multicast Or Broadcast Service |
US20080184087A1 (en) | 2007-01-26 | 2008-07-31 | Morihiko Hayashi | Transmitting Device, Receiving Device, Packet Transmission Method, Packet Reception Method, and Programs for Same |
US20090049469A1 (en) | 2007-08-17 | 2009-02-19 | Att Knowledge Ventures L.P. | Targeted online, telephone and television advertisements based on cross-service subscriber profiling |
US20100020690A1 (en) * | 2008-07-25 | 2010-01-28 | Kenta Komiya | Communication System, Optical Line Terminal, and Congestion Control Method |
US20100254383A1 (en) * | 2007-10-30 | 2010-10-07 | Media Patents, S.L. | Method for managing multicast traffic between equipment in a multicast data network |
US20100260180A1 (en) | 2007-10-23 | 2010-10-14 | THOMSON LICENSING a, corporation | Method and apparatus for adaptive forward error correction with merged automatic repeat request for reliable multicast in wireless local area networks |
US20110082946A1 (en) | 2009-10-06 | 2011-04-07 | Openwave Systems Inc. | Managing network traffic using intermediate flow control |
US20120303760A1 (en) * | 2011-05-25 | 2012-11-29 | Cisco Technology, Inc. | Fine-tuning the time for leaving/joining a multicast session during channel changes |
US20140189052A1 (en) * | 2012-12-28 | 2014-07-03 | Qualcomm Incorporated | Device timing adjustments and methods for supporting dash over broadcast |
-
2014
- 2014-09-15 US US14/486,093 patent/US9756098B2/en active Active
-
2017
- 2017-09-01 US US15/693,696 patent/US10791157B2/en active Active
Patent Citations (16)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5612959A (en) * | 1992-07-08 | 1997-03-18 | Hitachi, Ltd. | Multicast communications method |
US5511168A (en) * | 1993-07-01 | 1996-04-23 | Digital Equipment Corporation | Virtual circuit manager for multicast messaging |
US5959989A (en) * | 1997-06-25 | 1999-09-28 | Cisco Technology, Inc. | System for efficient multicast distribution in a virtual local area network environment |
DE10104961A1 (en) * | 2001-02-03 | 2002-08-08 | Deutsche Telekom Ag | Bandwidth-efficient transmission of data streams in IP network involves forming IP multi-cast groups on server by allocating multi-cast addresses according to time sequence of requests |
US20060039314A1 (en) * | 2004-08-17 | 2006-02-23 | Sathya Narayanan | Router reachability verification in IPv6 networks |
US20080102749A1 (en) | 2005-02-16 | 2008-05-01 | Matsushita Electric Industrial Co., Ltd. | Providing Information On The Individual Bearers' Relationships To Mobile Terminals Receiving A Multicast Or Broadcast Service |
US20070008969A1 (en) | 2005-07-05 | 2007-01-11 | Elstermann Erik J | Apparatuses and methods for delivering data stream content to consumer devices |
US20070101012A1 (en) | 2005-10-31 | 2007-05-03 | Utstarcom, Inc. | Method and apparatus for automatic switching of multicast/unicast live tv streaming in a tv-over-ip environment |
US20080184087A1 (en) | 2007-01-26 | 2008-07-31 | Morihiko Hayashi | Transmitting Device, Receiving Device, Packet Transmission Method, Packet Reception Method, and Programs for Same |
US20090049469A1 (en) | 2007-08-17 | 2009-02-19 | Att Knowledge Ventures L.P. | Targeted online, telephone and television advertisements based on cross-service subscriber profiling |
US20100260180A1 (en) | 2007-10-23 | 2010-10-14 | THOMSON LICENSING a, corporation | Method and apparatus for adaptive forward error correction with merged automatic repeat request for reliable multicast in wireless local area networks |
US20100254383A1 (en) * | 2007-10-30 | 2010-10-07 | Media Patents, S.L. | Method for managing multicast traffic between equipment in a multicast data network |
US20100020690A1 (en) * | 2008-07-25 | 2010-01-28 | Kenta Komiya | Communication System, Optical Line Terminal, and Congestion Control Method |
US20110082946A1 (en) | 2009-10-06 | 2011-04-07 | Openwave Systems Inc. | Managing network traffic using intermediate flow control |
US20120303760A1 (en) * | 2011-05-25 | 2012-11-29 | Cisco Technology, Inc. | Fine-tuning the time for leaving/joining a multicast session during channel changes |
US20140189052A1 (en) * | 2012-12-28 | 2014-07-03 | Qualcomm Incorporated | Device timing adjustments and methods for supporting dash over broadcast |
Also Published As
Publication number | Publication date |
---|---|
US20160080445A1 (en) | 2016-03-17 |
US20170366590A1 (en) | 2017-12-21 |
US9756098B2 (en) | 2017-09-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10791157B2 (en) | Multi-tenant over-the-top multicast | |
US11770426B2 (en) | Software-defined media platform | |
JP6279512B2 (en) | System and method for adaptive video communication | |
US10063656B2 (en) | Server-side scheduling for media transmissions | |
US10250949B2 (en) | Broadcast content to HTTP client conversion | |
JP6346899B2 (en) | Method and apparatus for streaming media content to client devices | |
JP6337350B2 (en) | Improved video quality | |
US10015437B2 (en) | Supporting transport diversity and time-shifted buffers for media streaming over a network | |
US9413806B2 (en) | Adaptive bit rate proxy | |
US9680685B2 (en) | System and method for managing video content feeds | |
TW201618517A (en) | Server-side session control in media streaming by media player devices | |
US9866602B2 (en) | Adaptive bit rates during broadcast transmission in distributed content delivery networks | |
US10362080B2 (en) | Methods, systems, and devices for video streaming adaptation using control theoretic approach | |
US20160029050A1 (en) | Hybrid Stream Delivery | |
US20220086519A1 (en) | Dynamic playlist customization by adaptive streaming client | |
US10015219B2 (en) | Multicasting adaptive bitrate streams | |
US11777871B2 (en) | Delivery of multimedia components according to user activity | |
US10771831B2 (en) | System and method for preemptive advertisement caching to optimize network traffic | |
KR20180024841A (en) | Streaming service server and control method thereof |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: EDGECAST NETWORKS, INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:KAZERANI, ALEXANDER A.;SAKATA, JAYSON G.;PETERS, ROBERT J.;AND OTHERS;SIGNING DATES FROM 20140908 TO 20140915;REEL/FRAME:043470/0309 Owner name: VERIZON DIGITAL MEDIA SERVICES INC., CALIFORNIA Free format text: CHANGE OF NAME;ASSIGNOR:EDGECAST NETWORKS, INC.;REEL/FRAME:043749/0375 Effective date: 20160318 |
|
FEPP | Fee payment procedure |
Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: AWAITING TC RESP., ISSUE FEE NOT PAID |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NOTICE OF ALLOWANCE MAILED -- APPLICATION RECEIVED IN OFFICE OF PUBLICATIONS |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: PUBLICATIONS -- ISSUE FEE PAYMENT VERIFIED |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
AS | Assignment |
Owner name: EDGECAST INC., VIRGINIA Free format text: CHANGE OF NAME;ASSIGNOR:VERIZON DIGITAL MEDIA SERVICES INC.;REEL/FRAME:059367/0990 Effective date: 20211101 |
|
AS | Assignment |
Owner name: EDGIO, INC., ARIZONA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:EDGECAST INC.;REEL/FRAME:061738/0972 Effective date: 20221021 |
|
AS | Assignment |
Owner name: LYNROCK LAKE MASTER FUND LP (LYNROCK LAKE PARTNERS LLC, ITS GENERAL PARTNER), NEW YORK Free format text: PATENT SECURITY AGREEMENT;ASSIGNORS:EDGIO, INC.;MOJO MERGER SUB, LLC;REEL/FRAME:065597/0212 Effective date: 20231114 Owner name: U.S. BANK TRUST COMPANY, NATIONAL ASSOCIATION, ARIZONA Free format text: PATENT SECURITY AGREEMENT;ASSIGNORS:EDGIO, INC.;MOJO MERGER SUB, LLC;REEL/FRAME:065597/0406 Effective date: 20231114 |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
AS | Assignment |
Owner name: LYNROCK LAKE MASTER FUND LP (LYNROCK LAKE PARTNERS LLC, ITS GENERAL PARTNER), NEW YORK Free format text: PATENT SECURITY AGREEMENT;ASSIGNORS:EDGIO, INC.;MOJO MERGER SUB, LLC;REEL/FRAME:068763/0276 Effective date: 20240823 |
|
FEPP | Fee payment procedure |
Free format text: SURCHARGE FOR LATE PAYMENT, LARGE ENTITY (ORIGINAL EVENT CODE: M1554); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 4 |