Live video broadcasting on distributed networks
First Claim
1. A method for distributing a live program over a distributed network, the method being performed by a server and comprising:
- processing a data stream representing the live program into a plurality of substreams, a number of substreams being based, at least in part, on an availability of bandwidth across devices in the network, each of the substreams comprising decimated samples of the data stream, wherein the processing of the data stream is continuously performed until the live program ends;
identifying a plurality of devices in the network that are idle;
selecting a set of seeding devices from the plurality of devices to receive at least one substream of the plurality of substreams;
transmitting the plurality of substreams to the set of seeding devices with a sourcing instruction, wherein the sourcing instruction instructs the set of seeding devices to transmit specific substreams of the plurality of substreams to specific devices of others of the plurality of devices as the plurality of substreams are received, the seeding devices further transmitting the sourcing instruction to the others of the plurality of devices, the sourcing instruction instructing the others of the plurality of devices to transmit one or more substreams of the plurality of substreams to still other devices of the plurality of devices; and
configuring a plurality of suppliers from the plurality of devices to provide the plurality of substreams to one or more ordering devices in response to the one or more ordering devices requesting to the server to view or listen to the live program so that the live program can be played back on the one or more ordering devices.
5 Assignments
0 Petitions
Accused Products
Abstract
The techniques related to providing a live program over the Internet are described. According to one aspect of the techniques, a data stream representing a live program is preprocessed to produce a plurality of substreams, each of the substreams comprising decimated samples of the data stream. The number of substreams is relatively large so that the bandwidth requirement for delivering one of the substreams is relatively low. With a group of seeding boxes receiving the substreams, a group of boxes in services are designated to receive the substreams from the seeding boxes, each of these boxes including the seeding boxes is able to support multiple outbound streams (e.g., greater than 2) so that there are enough data suppliers to service the ordering boxes or colonize more boxes to become the data suppliers. As a result, a live program can be timely serviced by peer boxes, significantly reducing the computation and bandwidth burdens on a server(s).
188 Citations
18 Claims
-
1. A method for distributing a live program over a distributed network, the method being performed by a server and comprising:
-
processing a data stream representing the live program into a plurality of substreams, a number of substreams being based, at least in part, on an availability of bandwidth across devices in the network, each of the substreams comprising decimated samples of the data stream, wherein the processing of the data stream is continuously performed until the live program ends; identifying a plurality of devices in the network that are idle; selecting a set of seeding devices from the plurality of devices to receive at least one substream of the plurality of substreams; transmitting the plurality of substreams to the set of seeding devices with a sourcing instruction, wherein the sourcing instruction instructs the set of seeding devices to transmit specific substreams of the plurality of substreams to specific devices of others of the plurality of devices as the plurality of substreams are received, the seeding devices further transmitting the sourcing instruction to the others of the plurality of devices, the sourcing instruction instructing the others of the plurality of devices to transmit one or more substreams of the plurality of substreams to still other devices of the plurality of devices; and configuring a plurality of suppliers from the plurality of devices to provide the plurality of substreams to one or more ordering devices in response to the one or more ordering devices requesting to the server to view or listen to the live program so that the live program can be played back on the one or more ordering devices. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9)
-
-
10. A system for distributing a live program over a distributed network, the system comprising:
-
a server configured to generate N substreams that are created from a data stream representing the live program, N being a finite integer and each of the N substreams including decimated samples of the live program, wherein generates number of the N substreams are based, at least in part, on an availability of bandwidth across devices in the network; a plurality of devices in the network that are idle, wherein a set of seeding devices from among the plurality of devices (i) is selected to receive at least one substream of the N substreams from the server, and (ii) propagate the N substreams to others of the plurality of devices as the N substreams are received from the server, the server further configured to transmit a sourcing instruction to the set of seeding devices, the sourcing instruction instructing the set of seeding devices to transmit the sourcing instruction and specific substreams of the plurality of substreams to specific other devises of the plurality of devices, the sourcing instruction further instructing the other devices of the plurality of devices to transmit one or more substreams of the plurality of substreams to still other devices of the plurality of devices; and a plurality of ordering devices to request to the server to view or listen to the live program, each of the plurality of ordering devices receiving the N substreams from N of the plurality of devices, wherein each of the N devices is capable of providing a corresponding substream to one or more of the plurality of ordering devices. - View Dependent Claims (11, 12, 13, 14, 15, 16, 17)
-
-
18. A method for distributing media content over a network, the method being performed by a server and comprising:
-
processing a data stream into a plurality of substreams, a number of substreams being based, at least in part, on an availability of bandwidth across devices in the network, wherein the data stream corresponds to a presentation that includes a live event, wherein the processing of the data stream is continuously performed until the live event ends; transmitting the substreams with a sourcing instruction to a set of seeding devices in a plurality of devices in the network, wherein the sourcing instruction instructs the set of seeding devices to transmit specific substreams of the plurality of substreams to specific devices of others of the plurality of devices as the plurality of substreams are being received, the seeding devices further transmitting the sourcing instruction to others of the plurality of devices, the sourcing instruction instructing the others of the plurality of devices to transmit one or more substreams of the plurality of substreams to still other devices of the plurality of devices; configuring a plurality of suppliers from the plurality of devices to transmit the plurality of substreams to a requesting device in response to the requesting device requesting to the server to view or listen to the presentation that includes the live event; and dynamically varying one or more of the plurality of suppliers to transmit the plurality of substreams to the requesting device based on an availability of one or more of the plurality of suppliers.
-
Specification