1. Technical Field
The present invention is generally related to multimedia delivery over the Internet. Particularly, the present invention is related to techniques providing media services including movies with multiple audio streams on an open network, such as the Internet.
2. Description of the Related Art
Continuous or on-demand media data such as video and audio programs have been broadcasted over data networks (e.g., the Internet). Broadcast of such media information over data networks by digital broadcasting systems provides many advantages and benefits that cannot be matched by current television cable systems or over-the-air broadcasting.
With the media-over-network systems, service providers are often able to draw viewers into an exciting, interactive and enhanced television or viewing experience. Video-On-Demand (VOD) or Near Video-On-Demand (NVOD) collectively referred to herein as VOD programs are examples of the interactive television programs typically provided by a service provider to its subscribers. VOD programs are video sessions that subscribers can order whenever they want or per NVOD schedules.
To ensure quality of service (QoS), the bandwidth requirement of the network path (e.g., 108-1, 108-2, . . . 108-n) to each of the client machines 106-1, 106-2, . . . 106-n has to be sufficient. However, as the number of the subscribers continues to increase, the demand on the bandwidth of the backbone network path 110 increases linearly, and the overall cost of the system 100 increases considerably at the same time. If the server has a fixed bandwidth limit and system support capability, an increase in the number of subscribers beyond a certain threshold will result in slower transfer of data to clients. In other words, the transmission of the video data over the network 104 to the subscribers via the client machines 106-1, 106-2, . . . 106-n is no longer guaranteed. When the video data is not received in a client machine on time, the display of the video data may fail or at least become jittery.
To alleviate such loading problem to the video server 102, a video delivery system often employs multiple video servers as rendering farms, perhaps in multiple locations. Each of the video servers, similar to the video server 102, is configured to support a limited number of subscribers. Whenever the number of subscribers goes beyond the capacity of a video server or the bandwidth thereof, an additional video server needs to be deployed or additional bandwidth needs to be allocated. Subsequently, overall costs go up considerably when more subscribers sign up with the video delivery system 100.
Although more servers may be added to accommodate more subscribers, the implementation of the video server 102 present many challenges to consider in delivering programs over an open network. In general, movies come with a number of different audio tracks. Typically, a movie may include respective audio tracks in English, Spanish, French, Chinese, or other languages. Streaming multiple audio streams for each video increases the bandwidth requirements of the network. Increasing the bandwidth requirement for multiple audio tracks makes the overall cost of the system 100 too costly and may not be practically possible.
There have been various effort towards providing multiple audio tracks for a movie. One approach is to treat video with different audio tracks as different movies. For example, a video with English audio track is treated as a different movie from the same video with Spanish audio track. However, such an approach wastes storage space and bandwidth by duplicating videos for different audio tracks.
Thus, there is a need for improved techniques for cost effective ways for service providers to deliver programs with multiple audios to subscribers over an open network.
This section is for the purpose of summarizing some aspects of embodiments of the present invention and to briefly introduce some preferred embodiments. Simplifications or omissions in this section as well as the title and the abstract of this disclosure may be made to avoid obscuring the purpose of the section, the title and the abstract. Such simplifications or omissions are not intended to limit the scope of the present invention.
In general, the present invention relates to techniques for providing media services over an open network. To ensure that multiple audio streams are available for a video, the present invention provides techniques for encoding and sending multiple audio streams, and single video stream into a transport—seeding a “fat” transport. Then, streaming a transport with a single audio and a single video with other audios filtered out to a subscriber—streaming a “lean” transport.
According to another embodiment, the embodiment comprises encoding and sending each video and audio stream separately, then streaming a transport with requested single audio and single video in real-time.
According to one aspect of the present invention, data pertaining to a title is divided or organized into several segments that are distributed among boxes in service. General orders of titles being offered in a library are fulfilled by a group of selected client devices (e.g., boxes) delivering respective segments to an ordering box. Special orders of certain programs (e.g., a live event or a rare title not included in the library) are fulfilled directly by a server. In addition, the server is configured to supply some of the segments to an ordering box or back up any one of the selected boxes designated to supply the needed data to an ordering box. Because of its inherent superior computing power and more bandwidth, the server may deliver more than one segment at a time. The architecture contemplated in the present invention offers the flexibilities of being relatively independent from the number of users while, at the same time, offering centralized management or services to the users. The present invention inherently distributes load among client devices in service by using the computing power and bandwidth collectively available at any time in the client devices. Furthermore, much of the traditional server functionality now gets distributed among the client devices in service.
Embodiments of the invention may be implemented in numerous ways, including a method, system, device, or a computer readable medium. Several embodiments of the invention are discussed below. In one embodiment, the invention provides a method of providing media services over a network, the method comprises: receiving a request from one of a plurality of boxes (hereinafter “ordering box”), the request including an order of a title and an audio. The embodiments further comprise identifying one or more of the boxes other than the ordering box to provide distributed segments pertaining to the title to the ordering box, wherein the ordering box proceeds with downloading the distributed segments, and a playback of the title based on the distributed segments together with residing segments, if any, is started or continued.
According to another embodiment, the invention provides a system for providing media services, the system comprises a server coupled to a network and configured to manage the medial services, and a plurality of boxes coupled to the network, wherein one of the boxes (herein after “ordering box”) initiating a request including an order of a title communicates directly with the server configured to proceed with identifying one or more of the boxes other than the ordering box to provide distributed segments pertaining to the title to the ordering box, wherein the ordering box proceeds with downloading the distributed segments, and a playback of the title based on the distributed segments together with residing segments, if any, is started or continued. One of the objects, features, and advantages of the present invention is to provide various techniques related to streaming multiple audio tracks based on a distributed architecture, a client-server architecture, and a hybrid architecture taking the benefits, features, and advantages of both distributed architecture and client-server architecture.
It should be understood that each technique so described herein has its own distinctive features, and all techniques in combination yield an equally independently novel combination as well, even if combined in their broadest sense; i.e., with less than the specific manner in which each of the techniques has been reduced to practice.
Other objects, features, and advantages of the present invention will become apparent upon examining the following detailed description of an embodiment thereof, taken in conjunction with the attached drawings.
The invention will be readily understood by the following detailed description in conjunction with the accompanying drawings, wherein like reference numerals designate like structural elements, and in which:
The present invention is related to techniques of providing multiple audio streams of media services based on a distributed architecture or a hybrid architecture taking the benefits, features, and advantages of both distributed architecture and client-server architecture. Different from a prior art system in which one video with different audio tracks are treated as different movies, multiple audio streams and a single video are encoded together and sent to a number of boxes, a single audio and a single video are streamed to an ordering box with other audio tracks filtered out by boxes acting as a media content provider. Alternatively, each video and audio is encoded and sent separately to a number of boxes, a single audio and a single video are encoded at a number of boxes to be streamed to the ordering box. As a result, multiple audio streams are provided for a single video without using increased bandwidth.
In the following description, numerous specific details are set forth to provide a thorough understanding of the present invention. The present invention may be practiced without these specific details. The description and representation herein are the means used by those experienced or skilled in the art to effectively convey the substance of their work to others skilled in the art. In other instances, well-known methods, procedures, components, and circuitry have not been described in detail since they are already well understood and to avoid unnecessarily obscuring aspects of the present invention.
Reference herein to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment can be included in at least one implementation of the invention. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment, nor are separate or alternative embodiments mutually exclusive of other embodiments. Further, the order of blocks in process, flowcharts or functional diagrams representing one or more embodiments do not inherently indicate any particular order nor imply limitations in the invention.
Embodiments of the present invention are discussed herein with reference to
Shown as FIG. 2 of U.S. patent application Ser. No. 11/075,573,
According to one embodiment, when fulfilling a request from a local machine or a box (e.g., 206-1), communication between the server 202 and the box 206-1 over the network paths 208-1 and 210 may be limited to small-scale requests and responses (e.g., of small size and very infrequent). A server response to a request from a box may include source information (e.g., identifiers), authorization information and security information. Using the response from the server 202, the box may be activated to begin playback of a title (e.g., 207-1). Substantially at the same time, the box may initiate one or more requests to other boxes (e.g., 206-2 and 206-n) in accordance with the source identifiers to request subsequent portions of the title (e.g., 207-2 and 207-n). Assuming proper authorization, the requesting box receives the subsequent portions of the data concurrently from the other boxes. Because of box-to-box communication of content over the path 209, the bandwidth requirement for box-to-server communications over the network paths 208-1 and 210 is kept low and typically short in duration. In the event there are a large number of user boxes issuing playback requests substantially at the same time, the bandwidth of the backbone path 210 should be sufficient to avoid noticeable or burdensome delay.
The contents available in a library being offered in any of the boxes 206-1, 206-2, . . . 206-n are originally provided by one or more content providers. Examples of the content providers include service satellite receivers, television relay stations, analog or digital broadcasting station, movie studios and Internet sites. Depending on implementation, the contents may be initially received or originated in the server 202. Instead of maintaining and managing the content in a large storage device, the server 202 is configured to distribute the content or files to a plurality of local machines registered with the server 202. The boxes 206-1, 206-2, . . . 206-n shown in
For convenience, it is assumed herein that a file pertaining to a title is played back when the title is selected and ordered by a user. When an order for a title is placed, a corresponding file must be available for playback. One of the features in the system 200 is that a file, or at least a portion thereof, regardless of its size, can be accessed instantaneously, thereby realizing instantaneous VOD. According to one embodiment, where a file is 840 Mbytes on average and a box includes a storage capacity of 300 Gbytes, a system may offer a large library of titles (e.g., 5000) for access at any time instantly. In the prior art, if the files for the titles must be stored in advance to offer instantaneous playback, the local storage of a box would have to have a capacity of 4,000 Gbytes, consequently, rendering instantaneous VOD economically impractical.
According to one aspect of the present invention, only a beginning portion (referred to as a “head”) and possibly one or more tail segments of a file are locally cached in a box. Such locally cached segments are referred to as residing objects or segments, while segments not residing locally are referred to as distributed objects or segments. When a title is selected, the head of the corresponding file is instantly played back. During the time the head is being played, the distributed objects corresponding to the title are retrieved simultaneously from other boxes. When the head is finished, the received parts of the distributed segments being streamed in from other boxes is combined with residing segments for the title, if any, to enable a continuous playback. Depending on the popularity and concurrent demand for a particular title, the number of residing objects may be increased or decreased to control the dependency of each box on other boxes for playback. Typically, the more residing objects for a title a box has, the more distributed copies of the title there are in the entire system and thus the less dependency of the ordering box on the other boxes.
In one embodiment, the head is always played first to ensure an instant playback. In another embodiment, the head size is reduced to zero, in which case, a time-fill program is played first to provide a time frame that is sufficient enough to fetch and assembly the beginning data portion of the segments either locally available or from other boxes. Depending on implementation, the time-fill program may include one or more trailers related to the title being ordered, various notifications/updates or commercial programs. The time-fill program may be locally configured. In one embodiment, the time-fill program is provided to give a time frame in which data being fetched from one or more other devices can be stabilized. In another embodiment, the time-fill program provides a platform for sponsors that hope to display their respective programs to audience. Orders or slot positions for these programs in a time-fill program may be auctioned.
Various content streams include IP packets that are directed to appropriate channels for delivery over the data network. The IP packets include IP data representing the content of the programs. Prior to transmission over the data network, the IP packets are encrypted by a conditional access encryption unit 710. Once the IP data is encrypted, the Slicing unit 712 slices the data stream in segments of data stream as described further below.
Referring to
Regardless whether a head is used or not, a file or a majority of a file will be fragmented and the segments are distributed among the boxes in service. According to one embodiment, given a required transmission rate (e.g., 1 megabit per second or 1 Mbps), the minimum uploading and downloading speeds of a network are considered to determine a number that defines the segmentation, and thus the dependency on other boxes and the support for concurrent demands of a particular title.
It is assumed that a minimum uploading speed is U and a required transmission rate is D, and D/U=K<k, where k is the smallest integer greater than K. In one embodiment, a file or a majority of a file is preferably divided into k segments to optimally utilize the uploading speed of U, assuming that the downloading speed is at least k times faster than the uploading speed. For example, in a POTS-based DSL network for residential areas, the required transmission may be about 1.0 Mbps while the uploading speed may be about 300 kbps. Hence, k=4. Assuming that an ordering box has a downloading speed four times the uploading speed of the other boxes, up to four segments in other boxes can be downloaded concurrently across the network as streaming into the ordering box without interruption.
As shown in
Segment 1={b11,b12,b13,b14 . . . };
Segment 2={b21,b22,b23,b24 . . . };
Segment 3={b31,b32,b33,b34 . . . }; and
Segment 4={b41,b42,b43,b44 . . . }.
where b stands for “data block”, numerals after “b” are mere reference numbers. As used above, the data blocks b11, b21, b31, b41, b12, b22, b32, b42, b13, b23, b33, b43, . . . b1n, b2n, b3n, b4n are sequential while, for example, data blocks b11, b12, b13, b14 . . . b1n in Segment 1 are not sequential.
Because multiple audios are encoded, the fragmentation of the file is difficult:
Segmentation is performed to the point where there is cutting into the middle of an audio.
Referring to
It should be noted, however, a head, if used, includes data blocks that are consecutive so that an instantaneous playback of the head is possible. It is evident that the data blocks in the segments are non-consecutive, interlaced or interleaved.
In one embodiment, the data stream 240-2 includes one single video 260 and multiple audios 262 associated with the video. For example, the video 260 may be a movie and multiple audios may be audios in different languages such as English, French, Spanish, Italian, Chinese, and etc. To ease the bandwidth requirement, the data stream may be sliced into smaller segments and distributed to the boxes. When a movie (i.e., a video and a particular audio stream) is requested by an ordering box, the boxes with different segments filter out the requested audio to be sent to the ordering box. For example, if the ordering box requests the video 260 with audio 262-3, then the boxes with segments for the requested video 260 filter out all other audios 262-1, 262-2 . . . 262-n, so that only audio 262-3 is sent with the video 260. Once the filtering is done, the requested data stream 240-8 which only includes the video 260 and audio 262-3 can be sent to the ordering box in real-time without wasting the bandwidth because it only has one video and one audio—hence a lean streaming.
Furthermore, the data stream 240-2 may include multiple audio and multiple closed captioning.
In another embodiment, fat seeding may be achieved by distributing video and audio streams 240-4 and 240-6 separately. For example, at the server 202, a video stream 240-4 is encrypted, sliced, and distributed to a number of boxes. An audio stream 240-6 is encrypted, sliced, and distributed to a number of boxes. This is repeated for the audio stream until all audios associated with the video is distributed to the boxes. At the boxes, the video and audio streams reside until an ordering box requests for the video and audio. The ordering box requests for a program that includes a video ID and an audio ID. Once the request is received by the server, the server instructs the boxes with segments to multiplex the requested video and audio. This is done by looking at the video ID and audio ID, and individual packet presentation and decoding time stamps. Once, segments of requested video and audio are multiplexed at the sending boxes, the segments of the data stream 240-8 which only includes one video and audio are forwarded to the ordering box over the path 209.
In both embodiments, distribution of one single video and multiple audios may be done gradually over the paths 210 and 208 from the server 202 to a number of boxes 206—fat seed. Once an ordering box makes a request, the number of boxes forwards a lean stream over the path 209 to the ordering box.
Referring to
Referring now to
For example, the architecture 300 may be configured to deliver non-prerecorded programs such as live broadcasts by a multicasting protocol. The server 302 receives orders from some of the subscribers (e.g., for boxes 306-1 and 306-n) for a broadcasting event. When the event comes, the server 302 receives a streaming feed from a source (e.g., a televised site). The streaming is then delivered by the server 302 via the network path 310 to 308-1 and 308-n to the ordering boxes 306-1 and 306-n. As the subscriber for the box 306-2 did not order the event, the box 306-2 will not receive the streaming from the server 302. It can be appreciated that the number of recipients for the program does not affect the performance of the server 302 or demands higher bandwidth because the program is being multicast to the ordering boxes.
The architecture 300, at the same time, allows non-interrupted media services among the boxes. Similar to the description for
Referring now back to
In one embodiment, when a server is designed to be one of the suppliers to service an ordering box, the server is not necessarily the one that provides the designation information. A service provider may deploy several servers, each is designated to cover a specific area in accordance with one or more specification (e.g., popularity, geography, demographics, and/or like criteria).
According to one embodiment, the server 302 is configured to provide titles that are not widely distributed among the boxes in service. It is understood that the distributed architecture as described in
Referring now to
To facilitate the continuation of a data stream, each of the pointers 482 and 484 is used to remember where the data block of a segment is being fed or about to be fed to the buffer 470. In the event, the segment being fetched from a box is interrupted and a backup box needs to step in, the ordering box knows exactly where to start fetching the segment from where it was interrupted in accordance with the pointer. Likewise, similar pointers (not shown) may be provided to remember where the data block of the locally cached segment is being fed or about to be fed to the buffer 470. In the event, the ordering box needs to be reset or is suddenly powered off and back on, these pointers can facilitate the continuation of the playback of the ordered movie.
It should be readily understood to those skilled in the art that the above description may be equally applied to cases in which instantaneous VOD services are desired. Instead of playing back the time-fill program, a head of a movie title can be played back first, during which the remaining segments, if not locally available, can be fetched from other designated boxes.
Referring now to
According to one embodiment, any of the boxes 506-1, 506-2, 506-3, . . . 506-n and 508 may receive compressed data from the server 504 that centrally stores all video data and delivers required video data pertaining to an ordered title upon receiving a request. According to another embodiment, the server 504 is configured to identify one or more other boxes to supply pieces of compressed data to a box requesting the data. In other words, all video data is distributed among all boxes in service and the server 504 is not required to deliver all the data in response to a request, and instead is configured to provide source information as to where and how to retrieve some or all of the data from other boxes. As shown in
The operation of distributing segments of a single video and multiple audios—fat seeding—is described in a flow chart or process 750 shown in
At 752, the server is configured to distribute programs to a plurality of boxes for future access depending on popularity. The server also takes into account the programs that are already residing at boxes because either they have been viewed or distributed. Once the server determines that a program needs to be distributed, at 754, the server encodes the program. Typically, the program includes a single video and multiple audios. However, the data stream may included multiple video, audio, and closed captioning. The server may encode the single video and multiple audios as a single data stream or as separate data streams. For example, referring back to
In the case of one data stream that includes a video and multiple audios, at 756, the data stream is sliced into segments and distributed to a number of boxes at 758. The number and location of boxes depend on the popularity of a program, available bandwidth, and other factors.
In the case of separate data stream for a video and each audio, at 756, each data stream is sliced into segments and distributed to a number of boxes at 758. This is repeated until all audios have been distributed to the boxes. Whether the data stream includes single video and multiple audios, or single video or audio, once the process is completed, the selected boxes have for each video, multiple audios associated with each video—fat seed. Typically, data stream is sent from a server to some clients, and then from those clients to other clients.
The operation of fetching segments of requested single video and single audio—lean streaming is described in a flow chart or process 780 shown in
At 786, depending on how the audio streams are residing at the box—either as separate streams or in a single data stream along with the video—the requested audio is selected. In the case where multiple audios are in separate audio streams, the requested audio is identified by its audio ID number. Then, the selected audio is multiplex with the requested video. In the case where multiple audios are in a single data stream together, all audios are filtered out except for the requested audio. Thus, after the filtering, the data stream only includes the requested video and audio. In either case, a lean stream including one video and one audio is constructed. MPEG2 TS has about 188 byte packets, and individual stream IDs, knows as Program Ids (PID). Video, and each audio stream have their own PID.
At 788, segments of the lean stream of the requested video and audio are sent to the ordering box. At 789, the ordering box receives, multiplexes segments received from different boxes to a buffer. At 790, the ordering box plays assembled data in the buffer.
As described above, the architecture of
Similarly, in the event where a video is associated with multiple subtitle tracks, responsive boxes can filter out the irrelevant subtitles before streaming. If the user does not choose any subtitles, then all subtitle packets are filtered out. In cases where there are multiple video tracks, e.g., at different bit rates, and one video track may be streamed depending on the bandwidth available on the receiver.
In addition, one embodiment of the present invention dynamically determines what fragments to stream and what to filter out. For example, the receiver may tell the sender exactly what to send and what to filter out. Such dynamic switching is useful to enable the following features:
In another embodiment, the above described architecture can be use to deal with associated closed caption streams. Each closed caption stream of data is multiplexed into the media stream with its own ID and its own presentation time information. There can be none, one or more closed caption streams in the media stream. Each closed caption stream could correspond to one language or there could be multiple closed caption streams in single language with different content (e.g. Actual dialog, or commentary, etc). Segments of the complete media stream with multiple close caption streams gets distributed to client boxes during seeding (fat seed). During playback, user of the requesting box selects which closed caption stream, if any, s/he wants to see. The serving boxes filter out all closed caption streams other than the requested stream based on the ID of the requested stream.
The foregoing description of embodiments is illustrative of various aspects/embodiments of the present invention. Various modifications to the present invention can be made to the preferred embodiments by those skilled in the art without departing from the true spirit and scope of the invention as defined by the appended claims. Accordingly, the scope of the present invention is defined by the appended claims rather than the foregoing description of embodiments.
This application is a continuation of co-pending U.S. application Ser. No. 11/492,673, filed Jul. 24, 2006, entitled “Multiple Audio Streams;” This application is also a continuation-in-part of U.S. application Ser. No. 11/388,613, filed Mar. 23, 2006, now U.S. Pat. No. 8,018,995 entitled “System and Method for Trick Play of Highly Compressed Video Data;” This application is also a continuation-in-part of U.S. application Ser. No. 11/331,113, filed Jan. 10, 2006, now abandoned entitled “Access Control of Media Services Over an Open Network;” This application is also a continuation-in-part of U.S. application Ser. No. 11/075,573, filed Mar. 9, 2005, now U.S. Pat. No. 8,219,635 entitled “Continuous Data Feeding in a Distributed Environment;” All of the aforementioned applications are incorporated herein by reference in their entirety for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
5132992 | Yurt et al. | Jul 1992 | A |
5414455 | Hooper et al. | May 1995 | A |
5530754 | Garfinkle | Jun 1996 | A |
5602918 | Chen et al. | Feb 1997 | A |
RE35651 | Bradley et al. | Nov 1997 | E |
5694559 | Hobson et al. | Dec 1997 | A |
5701582 | DeBey | Dec 1997 | A |
5721878 | Ottesen et al. | Feb 1998 | A |
5729280 | Inoue et al. | Mar 1998 | A |
5761417 | Henley et al. | Jun 1998 | A |
5765164 | Prasad et al. | Jun 1998 | A |
5798785 | Hendricks et al. | Aug 1998 | A |
5802283 | Grady et al. | Sep 1998 | A |
5812123 | Rowe et al. | Sep 1998 | A |
5815146 | Youden et al. | Sep 1998 | A |
5815662 | Ong | Sep 1998 | A |
5826168 | Inoue et al. | Oct 1998 | A |
5831662 | Payton | Nov 1998 | A |
5838314 | Neel et al. | Nov 1998 | A |
5877812 | Krause et al. | Mar 1999 | A |
5884031 | Ice | Mar 1999 | A |
5886730 | Tsosie | Mar 1999 | A |
5903563 | Rashid et al. | May 1999 | A |
5926205 | Krause et al. | Jul 1999 | A |
5928331 | Bushmitch | Jul 1999 | A |
5933603 | Vahalia et al. | Aug 1999 | A |
5948070 | Fujita | Sep 1999 | A |
6005565 | Legall et al. | Dec 1999 | A |
6014694 | Aharoni et al. | Jan 2000 | A |
6018359 | Kermode et al. | Jan 2000 | A |
6037983 | Au et al. | Mar 2000 | A |
6038560 | Wical | Mar 2000 | A |
6055314 | Spies et al. | Apr 2000 | A |
6124854 | Sartain et al. | Sep 2000 | A |
6138221 | Korst et al. | Oct 2000 | A |
6170006 | Namba | Jan 2001 | B1 |
6177931 | Alexander et al. | Jan 2001 | B1 |
6184878 | Alonso et al. | Feb 2001 | B1 |
6212549 | Page et al. | Apr 2001 | B1 |
6236504 | Kao et al. | May 2001 | B1 |
6263504 | Ebisawa | Jul 2001 | B1 |
6285987 | Roth et al. | Sep 2001 | B1 |
6324519 | Eldering | Nov 2001 | B1 |
6334124 | Bouchard et al. | Dec 2001 | B1 |
6397251 | Graf | May 2002 | B1 |
6463508 | Wolf et al. | Oct 2002 | B1 |
6502139 | Birk et al. | Dec 2002 | B1 |
6515680 | Hendricks et al. | Feb 2003 | B1 |
6519693 | Debey | Feb 2003 | B1 |
6614366 | Luby | Sep 2003 | B2 |
6622305 | Willard | Sep 2003 | B1 |
6630963 | Billmaier | Oct 2003 | B1 |
6640241 | Ozzie et al. | Oct 2003 | B1 |
6701528 | Arsenault et al. | Mar 2004 | B1 |
6704813 | Smirnov et al. | Mar 2004 | B2 |
6728763 | Chen | Apr 2004 | B1 |
6731605 | Deshpande | May 2004 | B1 |
6763392 | del Val et al. | Jul 2004 | B1 |
6789106 | Eyer et al. | Sep 2004 | B2 |
6801947 | Li | Oct 2004 | B1 |
6804719 | Cabrera | Oct 2004 | B1 |
6857012 | Sim et al. | Feb 2005 | B2 |
6934965 | Gordon et al. | Aug 2005 | B2 |
6938258 | Weinberger et al. | Aug 2005 | B1 |
6944585 | Pawson | Sep 2005 | B1 |
6970937 | Huntington | Nov 2005 | B1 |
6973667 | Fritsch | Dec 2005 | B2 |
7024679 | Sie et al. | Apr 2006 | B1 |
7051360 | Ellis et al. | May 2006 | B1 |
7080400 | Navar | Jul 2006 | B1 |
7110006 | MacInnis et al. | Sep 2006 | B2 |
7174385 | Li | Feb 2007 | B2 |
7188357 | Rieschl et al. | Mar 2007 | B1 |
7191215 | Ganesan et al. | Mar 2007 | B2 |
7228556 | Beach et al. | Jun 2007 | B2 |
7240359 | Sie et al. | Jul 2007 | B1 |
7246369 | Duan et al. | Jul 2007 | B1 |
7260829 | Hendricks et al. | Aug 2007 | B1 |
7281261 | Jaff et al. | Oct 2007 | B2 |
7293275 | Krieger et al. | Nov 2007 | B1 |
7324555 | Chen et al. | Jan 2008 | B1 |
7360235 | Davies et al. | Apr 2008 | B2 |
7379963 | Khare et al. | May 2008 | B1 |
7386874 | White et al. | Jun 2008 | B2 |
7577750 | Shen et al. | Aug 2009 | B2 |
7633887 | Panwar et al. | Dec 2009 | B2 |
7698451 | Ganesan | Apr 2010 | B2 |
7810647 | Ganesan et al. | Oct 2010 | B2 |
20010019630 | Johnson | Sep 2001 | A1 |
20010024239 | Feder et al. | Sep 2001 | A1 |
20010042249 | Knepper et al. | Nov 2001 | A1 |
20010051998 | Henderson | Dec 2001 | A1 |
20020022956 | Ukrainczyk | Feb 2002 | A1 |
20020029282 | Buddhikot et al. | Mar 2002 | A1 |
20020031331 | Kwoh et al. | Mar 2002 | A1 |
20020053078 | Holtz et al. | May 2002 | A1 |
20020083147 | Ripperger | Jun 2002 | A1 |
20020091825 | Shuster | Jul 2002 | A1 |
20020129375 | Kim et al. | Sep 2002 | A1 |
20020131423 | Chan et al. | Sep 2002 | A1 |
20020133491 | Sim et al. | Sep 2002 | A1 |
20020143959 | El-Baze et al. | Oct 2002 | A1 |
20020154892 | Hoshen et al. | Oct 2002 | A1 |
20020162109 | Shteyn | Oct 2002 | A1 |
20020163882 | Bornstein et al. | Nov 2002 | A1 |
20030026254 | Sim | Feb 2003 | A1 |
20030028490 | Miura et al. | Feb 2003 | A1 |
20030040962 | Lewis | Feb 2003 | A1 |
20030046698 | Kamen et al. | Mar 2003 | A1 |
20030055893 | Sato et al. | Mar 2003 | A1 |
20030078964 | Parrella et al. | Apr 2003 | A1 |
20030084461 | Hoang | May 2003 | A1 |
20030097661 | Li et al. | May 2003 | A1 |
20030115597 | Yassin et al. | Jun 2003 | A1 |
20030126277 | Son et al. | Jul 2003 | A1 |
20030135867 | Guedalia | Jul 2003 | A1 |
20030163646 | O'Neil | Aug 2003 | A1 |
20030188316 | DePrez | Oct 2003 | A1 |
20030188317 | Liew et al. | Oct 2003 | A1 |
20030204613 | Hudson et al. | Oct 2003 | A1 |
20030204856 | Buxton | Oct 2003 | A1 |
20030208612 | Harris et al. | Nov 2003 | A1 |
20040016000 | Zhang et al. | Jan 2004 | A1 |
20040078460 | Valavi et al. | Apr 2004 | A1 |
20040107242 | Vert et al. | Jun 2004 | A1 |
20040117831 | Ellis et al. | Jun 2004 | A1 |
20040122741 | Sidman | Jun 2004 | A1 |
20040123324 | Sazzad et al. | Jun 2004 | A1 |
20040128343 | Mayer | Jul 2004 | A1 |
20040133923 | Watson et al. | Jul 2004 | A1 |
20040143672 | Padmanabham et al. | Jul 2004 | A1 |
20040143850 | Costa | Jul 2004 | A1 |
20040148634 | Arsenault et al. | Jul 2004 | A1 |
20040148636 | Weinstein et al. | Jul 2004 | A1 |
20040158867 | Mack et al. | Aug 2004 | A1 |
20040202073 | Lai et al. | Oct 2004 | A1 |
20040216164 | Hayhurst | Oct 2004 | A1 |
20040250286 | Fraser et al. | Dec 2004 | A1 |
20040255323 | Varadarajan et al. | Dec 2004 | A1 |
20040267822 | Curran et al. | Dec 2004 | A1 |
20050005241 | Hunleth et al. | Jan 2005 | A1 |
20050010653 | McCanne | Jan 2005 | A1 |
20050015511 | Izmailov et al. | Jan 2005 | A1 |
20050033856 | Li | Feb 2005 | A1 |
20050038724 | Roever et al. | Feb 2005 | A1 |
20050041679 | Weinstein et al. | Feb 2005 | A1 |
20050055425 | Lango et al. | Mar 2005 | A1 |
20050055718 | Stone | Mar 2005 | A1 |
20050066063 | Grigorovitch et al. | Mar 2005 | A1 |
20050076363 | Dukes et al. | Apr 2005 | A1 |
20050086696 | Daniels | Apr 2005 | A1 |
20050108414 | Taylor et al. | May 2005 | A1 |
20050177853 | Williams et al. | Aug 2005 | A1 |
20050216941 | Flanagan et al. | Sep 2005 | A1 |
20050259682 | Yosef et al. | Nov 2005 | A1 |
20050267948 | McKinley et al. | Dec 2005 | A1 |
20050289593 | Spilo | Dec 2005 | A1 |
20060008256 | Khedouri et al. | Jan 2006 | A1 |
20060026639 | Potrebic et al. | Feb 2006 | A1 |
20060026663 | Kortum et al. | Feb 2006 | A1 |
20060031537 | Boutboul et al. | Feb 2006 | A1 |
20060034537 | Masaki | Feb 2006 | A1 |
20060037037 | Miranz | Feb 2006 | A1 |
20060075453 | Choi | Apr 2006 | A1 |
20060106807 | DeVitis et al. | May 2006 | A1 |
20060136597 | Shabtai et al. | Jun 2006 | A1 |
20060174160 | Kim | Aug 2006 | A1 |
20060184688 | Ganguly et al. | Aug 2006 | A1 |
20060190615 | Panwar et al. | Aug 2006 | A1 |
20060190975 | Gonzalez | Aug 2006 | A1 |
20060206889 | Ganesan et al. | Sep 2006 | A1 |
20060218088 | Flora et al. | Sep 2006 | A1 |
20060218217 | Ganesan et al. | Sep 2006 | A1 |
20060242153 | Newberry et al. | Oct 2006 | A1 |
20060248078 | Gross et al. | Nov 2006 | A1 |
20070089146 | Ikeda et al. | Apr 2007 | A1 |
20070143804 | Wang | Jun 2007 | A1 |
20080022343 | Hodzic et al. | Jan 2008 | A1 |
20080091840 | Guo et al. | Apr 2008 | A1 |
20080134258 | Goose et al. | Jun 2008 | A1 |
20080148323 | White et al. | Jun 2008 | A1 |
20080212945 | Khedouri et al. | Sep 2008 | A1 |
20080256272 | Kampmann et al. | Oct 2008 | A1 |
20080281913 | Shankar et al. | Nov 2008 | A1 |
20080282036 | Ganesan | Nov 2008 | A1 |
20080301738 | Davies et al. | Dec 2008 | A1 |
20090007196 | Ganesan | Jan 2009 | A1 |
20090019174 | Ehn et al. | Jan 2009 | A1 |
20090019468 | Ganesan et al. | Jan 2009 | A1 |
20090019489 | Ohlfs et al. | Jan 2009 | A1 |
20090024573 | Zink | Jan 2009 | A1 |
20090025046 | Ganesan et al. | Jan 2009 | A1 |
20090025048 | Ganesan | Jan 2009 | A1 |
20100049867 | Panwar et al. | Feb 2010 | A1 |
20100223362 | Price | Sep 2010 | A1 |
20100254675 | Ganesan | Oct 2010 | A1 |
Number | Date | Country |
---|---|---|
WO 9716023 | May 1997 | WO |
WO 0124526 | Apr 2001 | WO |
WO 03041383 | May 2003 | WO |
Entry |
---|
Communication of Dec. 16, 2010 in European Application No. 08796939.0-1244. |
Final Office Action dated Feb. 10, 2011 in U.S. Appl. No. 11/515,267, 12 pages. |
Ma et al., “Reducing bandwidth requirement for delivering video over wide area networks with proxy server”, IEEE, 2002, vol. 4, Iss. 4, p. 539-550. |
Non-Final Office Action dated Apr. 21, 2011 in U.S. Appl. No. 11/278,416. |
Non-Final Office Action dated Mar. 14, 2011 in U.S. Appl. No. 11/492,673, 15 pages. |
Non-Final Office Action dated Mar. 14, 2011 in U.S. Appl. No. 11/150,653, 34 pages. |
Non-Final Office Action dated Feb. 25, 2011 in U.S. Appl. No. 11/075,573, 27 pages. |
Ramesh et al., “Multicast with cache (Mcache): an adaptive zero-delay video-on-demand service”, IEEE, 2001. vol. 11, Iss. 3; p. 440-456. |
U.S. Appl. No. 11/150,653, filed Jun. 11, 2005, Ganesan et al. |
U.S. Appl. No. 11/404,972, filed Apr. 13, 2006, Ganesan. |
U.S. Appl. No. 11/515,267, filed Sep. 1, 2006, Ganesan. |
U.S. Appl. No. 11/927,690, filed Oct. 30, 2007, Ganesan et al. |
Video-on-Demand Research, from http://www.cs.ndsu.nodak.edu/-rvetter|ATM/html/video.html, dated Oct. 31, 2005, North Dakota State University, Computer Science Department, 2 pgs., Oct. 31, 2005. |
C. Siva Ram Murthy “A Primary-Segmented Backup Scheme for Fast Restoration of Real-Time Channels from Network Component Failures”, from http://www.prl.ernet.in/-librarv/Hari%200m/Hari%200m%20Lecture/Siva/%20Ram%20Murthy final.html, dated Oct. 31, 2005, Indian Institute of Technology, Department ofComputer Science and Engineering, 8 pgs, Oct. 31, 2005. |
Clifford A. Shaffer, A Practical Introduction to Data Structures and Algorithm Analysis Java Edition, 1998, Alan Apt, Prentice-Hall, Inc., 11 pgs. |
Decision on Petition to Make Special dated Nov. 29, 2005 in U.S. Appl. No. 11/075,573, 1 pg. |
Decision on Petition to Make Special dated Apr. 16, 2005 in U.S. Appl. No. 11/077,411, 1 pg. |
Election/Restriction Requirement dated Oct. 28, 2009 in U.S. Appl. No. 11/404,972, 6 pgs. |
Final Office Action dated Dec. 29, 2008 in U.S. Appl. No. 11/210,272, 19 pgs. |
Final Office Action dated Dec. 3, 2008 in U.S. Appl. No. 11/458,384, 24 pgs. |
Final Office Action dated Mar. 18, 2008 in U.S. Appl. No. 11/075,573, 18 pgs. |
Final Office Action dated Apr. 24, 2006 in U.S. Appl. No. 11/077,411, 7 pgs. |
Final Office Action dated Oct. 14, 2010 in U.S. Appl. No. 11/076,214, 12 pages. |
Final Office Action dated Sep. 17, 2010 in U.S. Appl. No. 11/150,653; 31 pages. |
Final Office Action date Aug. 31, 2010 in U.S. Appl. No. 11/831,938; 29 pages. |
Final Office Action dated Aug. 14, 2009 in U.S. Appl. No. 11/150,653, 27 pgs. |
Final Office Action dated Sep. 30, 2009 in U.S. Appl. No. 11/269,462, 27 pgs. |
Final Office Action dated Aug. 31, 2009 in U.S. Appl. No. 11/278,416, 15 pgs. |
Final Office Action dated Aug. 31, 2009 in U.S. Appl. No. 11/492,673, 16 pgs. |
Final Office Action dated Sep. 28, 2010 in U.S. Appl. No. 11/492,673, 12 pages. |
Final Office Action date May 5, 2010 in U.S. Appl. No. 11/269,462, 10 pages. |
Final Office Action dated Jan. 21, 2010 in U.S. Appl. No. 11/515,267, 11 pgs. |
Final Office Action date Mar. 26, 2010 in U.S. Appl. No. 11/930,147, 13 pages. |
Final Office Action date Aug. 4, 2009 in U.S. Appl. No. 11/076,214, 16 pages. |
Final Office Action date Jan. 21, 2010 in U.S. Appl. No. 11/075,573,24pages. |
Final Office Action Mar. 18, 2010 in U.S. Appl. No. 11/331,113 15pages. |
Francois, Alexandre R.J., “A Hybrid Architectural Style for Distributed Parallel Processing of Generic Data Streams” May 2004, IEEE Computer Society, ICSE '04: Proceedings of the 26th International Conference on Software Engineering, pp. 1-10. |
Guo, Yang et al., “P2Cast: Peer-to-peer Patching Scheme for VoD Service” May 2003, ACM, WWW '03: Proceedings of the 12th international conference on World Wide Web, pp. 301-309. |
International Preliminary Report on Patentability and Written Opinion in the International Application PCT/US2005/020051, World Intellectual Property Organization, European Patent Office, Apr. 3, 2007, 4 pages. |
International Preliminary Report on Patentability and Searching Authority in the International Application PCT/US2006/007070, World IntellectualProperty Organization, European Patent Office, Sep. 12, 2007,7 pages, Written Opinion of the International. |
International Preliminary Report on Patentability and Written Opinion of the International Searching Authority in International Application PCT/US2008/071735, European Patent Office, Feb. 11, 2010, 7 pages. |
International Search Report and Written Opinion of the International Searching Authority inInternational Application PCT/US2006/007070, European Patent Office, Apr. 19, 2007, 9 pages. |
International Search Report International Searching Authority inInternational Application PCT/US2005/020051, European Patent Office, Mar. 9, 2007, 3 pages. |
International Search Report and Written Opinion of the International Searching Authority inInternational Application PCT/US2006/007070, European Patent Office, Feb. 27, 2006, 12 pages. |
Jim Ferrara, “Creating and Maintaining a Hierarchical Directory”, from http://devzone.zend.com/article/1259-Creating-and%20 Maintaining-a-Hierarchical-Directory, dated Jan. 15, 2008, Zend Developer Zone, Nov. 2002, 14 pgs. |
Lisa Payne, “Web Authoring Inline Images”, from http://www.coventry.ac.uk/swift/˜csx067/web—auth/images.htm, dated Apr. 16, 2008, Coventry University, Jan. 2002, 4 pgs. |
Non-Final Office Action dated Dec. 26, 2008 in U.S. Appl. No. 11/150,653, 26 pgs. |
Non-Final Office Action dated Aug. 28, 2006 in U.S. Appl. No. 11/077,411, 10 pgs. |
Non-Final Office Action date Mar. 24, 2010 in U.S. Appl. No. 11/404,972, 10 pages. |
Non-Final Office Action dated Mar. 11, 2009 in U.S. Appl. No. 11/492,673, 12 pgs. |
Non-Final Office Action dated Jan. 30, 2006 in U.S. Appl. No. 11/077,411, 6 pgs. |
Non-Final Office Action dated Oct. 17, 2007 in U.S. Appl. No. 11/075,573, 13 pgs. |
Non-Final Office Action dated Oct. 28, 2008 in U.S. Appl. No. 10/867,155, 12 pgs. |
Non-Final Office Action date Apr. 12, 2010 in U.S. Appl. No. 11/492,673, 11 pages. |
Non-Final Office Action dated Nov. 25, 2008 in U.S. Appl. No. 11/075,573, 18 pgs. |
Non-Final Office Action date Aug. 2, 2010 in U.S. Appl. No. 11/515,267; 14 pages. |
Non-Final Office Action dated Dec. 16, 2009 in U.S. Appl. No. 11/684,637, 5 pgs. |
Non-Final Office Action dated Jun. 11, 2009 in U.S. Appl. No. 11/210,272, 23 pgs. |
Non-Final Office Action dated Jul. 20, 2009 in U.S. Appl. No. 11/930,147, 14 pgs. |
Non-Final Office Action dated Jul. 2, 2009 in U.S. Appl. No. 11/331,113, 14 pgs. |
Non-Final Office Action dated Jun. 20, 2008 in U.S. Appl. No. 11/210,272, 16 pgs. |
Non-Final Office Action dated Dec. 1, 2009 in U.S. Appl. No. 11/831,938, 16 pgs. |
Non-Final Office Action dated Mar. 13, 2009 in U.S. Appl. No. 11/278,416, 9 pgs. |
Non-Final Office Action date Dec. 23, 2008 in U.S. Appl. No. 11/076,214,19pages. |
Non-Final Office Action date Mar. 4, 2010 in U.S. Appl. No. 11/076,214, 13 pages. |
Non-Final Office Action Mar. 12, 2010 in U.S. Appl. No. 11/150,653 29pages. |
Non-Final Office Action dated May 13, 2009 in U.S. Appl. No. 11/685,101, 10 pgs. |
Non-Final Office Action dated Sep. 23, 2008 in U.S. Appl. No. 11/684,637, 5 pgs. |
Non-Final Office Action dated Apr. 28, 2009 in U.S. Appl. No. 11/515,267, 9 pgs. |
Non-Final Office Action dated Sep. 10, 2008 in U.S. Appl. No. 11/515,267, 9 pgs. |
Non-Final Office Action dated Jun. 30, 2008 in U.S. Appl. No. 11/075,573, 19 pgs. |
Non-Final Office Action dated Apr. 29, 2008 in U.S. Appl. No. 11/458,384, 24 pgs. |
Notice of Allowance dated Jun. 10, 2010 in U.S. Appl. No. 11/684,637; 8 pages. |
Notice of Allowance dated Nov. 2, 2009 in U.S. Appl. No. 11/685,101, 6 pgs. |
Notice of Allowance dated Aug. 27, 2009 in U.S. Appl. No. 11/684,637, 4 pgs. |
Notice of Allowance dated Jan. 16, 2007 in U.S. Appl. No. 11/077,411, 4 pgs. |
Paris et al., “Zero-delay broadcasting protocols for video-on-demand”, International Multimedia Conference Proceedings of the seventh ACM international conference on Multimedia, Florida, 1999, pp. 189-197. Download: http://portal.acm.org/citation.cfm?id=319600. |
Paris et al.: “Zero-delay broadcasting protocols for video-on-demand”, ACM Multimedia, Proceedings of the International Conference, New York, NY, US, Oct. 30, 1999, 9 pages. |
Petition to Make Special dated Oct. 31, 2005 in U.S. Appl. No. 11/075,573, 16 pgs. |
Petition to Make Special dated Mar. 9, 2005 in U.S. Appl. No. 11/077,411, 52 pgs. |
U.S. Appl. No. 11/974,138, filed Oct. 11, 2007, Ganesan et al. |
“Video-on-Demand Research”, printable at http:||www.cs. ndsu.nodak.edu/-rvetter|ATM/html/video. html. |
Final Office Action mailed Jan. 2, 2009 in U.S. Appl. No. 11/226,625, 23 pgs. |
Jehan-Francois Paris et al., “Zero-Delay Broadcasting Protocols for Video-on-Demand,” Proceedings of the 7th ACM International Conference on Multimedia '99, Oct. 30-Nov. 5, 1999, Orlando, FL, USA. ACM ,1999, vol. 1. |
Non-Final Office Action mailed Jul. 9, 2008 in U.S. Appl. No. 11/226,625, 20 pgs. |
Rush—Hour—2—Movie—Poster.pdf, www.imdb,com KEY WORD: “Rush Hour 2”. |
“Google-2005-ScreenShot (Google Inc., Copyright 2005; http://web.archive.org/web/200601 01175628/www.google.com/, 3 pages).” |
Decision on Petition to Make Special dated Dec. 18, 2007 in U.S. Appl. No. 11/974,138, 2 pgs. |
International Search Report and Written Opinion of the International Searching Authority inInternational Application PCT/US2008/071735, European Patent Office, Feb. 19, 2009, 11 pages. |
Non-Final Office Action dated Jul. 17, 2009 in U.S. Appl. No. 11/226,625, 21 pgs. |
Non-Final Office Action dated Jun. 26, 2008 in U.S. Appl. No. 11/203,021, 15 pgs. |
Non-Final Office Action dated Jun. 25, 2008 in U.S. Appl. No. 11/458,385, 9 pgs. |
Non-Final Office Action dated Oct. 7, 2008 in U.S. Appl. No. 11/383,751, 8 pgs. |
Petition to Make Special dated Oct. 10, 2007 in U.S. Appl. No. 11/974,138, 9 pgs. |
Final Office Action dated Nov. 19, 2010 in U.S. Appl. No. 11/226,625; 26 pages. |
Final Office Action dated Nov. 9, 2010 in U.S. Appl. No. 11/974,138; 17 pages. |
Non-Final Office Action dated Dec. 14, 2011 in U.S. Appl. No. 11/974,138. |
Non-Final Office Action dated Jul. 19, 2010 in U.S. Appl. No. 11/226,625. |
Refernces Cited in Non-Final Office Action Dated Jun. 20, 2008 for U.S. Appl. No. 11/210,272. |
Refernces Cited in Non-Final Office Action Dated Jun. 11, 2009 for U.S. Appl. No. 11/210,272. |
Refernces Cited in Final Office Action Dated Mar. 16, 2010 for U.S. Appl. No. 11/210,272. |
Refernces Cited in Non-Final Office Action Dated Aug. 3, 2011 for U.S. Appl. No. 11/210,272. |
Refernces Cited in Non-Final Office Action Dated Sep. 25, 2013 for U.S. Appl. No. 11/210,272. |
Refernces Cited in Final Office Action Dated Apr. 16, 2012 for U.S. Appl. No. 11/210,272. |
Refernces Cited in Notice of Allowance Dated Jan. 7, 2014 for U.S. Appl. No. 11/210,272. |
Number | Date | Country | |
---|---|---|---|
20110023072 A1 | Jan 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11492673 | Jul 2006 | US |
Child | 12896701 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11388613 | Mar 2006 | US |
Child | 11492673 | US | |
Parent | 11331113 | Jan 2006 | US |
Child | 11388613 | US | |
Parent | 11075573 | Mar 2005 | US |
Child | 11331113 | US |