As technology has developed, so have the ways in which viewers obtain video content. Not long ago, viewers could either watch video broadcast to their television sets or by traveling to the local cinema to watch a motion picture. VHS tapes and DVDs eventually emerged, both of which allowed viewers to watch the video content whenever they chose.
With the development of Internet protocol television (IPTV), communication companies are establishing networks for subscribers to watch video content. Generally, IPTV describes a system where a digital television service is delivered using Internet protocol (IP) over a network. The network used for IPTV may include the public Internet or a private IP network controlled by an IPTV service provider via a broadband connection known as digital subscriber lines (DSL), where the digital subscriber lines typically include conventional telephone lines with copper wire into households. Alternatively, the digital subscriber line may be fiber to the premises (FTTP). Telecommunication service provider companies that have begun offering DSL have limited bandwidth resources, particularly when delivering video over existing copper wire infrastructures.
In additional to television programming, many communications companies offer their subscribers video on demand (VOD) services.
Today, VOD typically exists as a unicast video stream, as illustrated in
Therefore, service providers have begun to offer video content through a multicast video stream. A multicast video stream is illustrated in
Additionally, electronic devices exist on the market that allow users to receive and/or record video content based on the user's selection criteria.
As shown, the device 300 includes a processing unit 302, which may be formed of one or more processors, that executes software 304. The software 304, depending upon the system functionality, may be configured to store and (i) manage information, such as video content and/or (ii) manage interaction with an end-user to download video programming and images for display on a television or other electronic display.
The processing unit 302 may be in communication with a memory 306. The processing unit 302 may also be in communication with an input/output (I/O) unit 308 that is configured to communicate with a television or other electronic display, remote control, network, or other devices, such as digital video disc (DVD), internal or external DVR, or any other local or network located device. The processing unit 302 may additionally be in communication with a storage unit 310 that is configured to store video data files in data repositories 312a-312n (collectively 312).
However, there is a need for an improved system and method for storing data delivered by a service provider on a STB.
The present invention provides an improved system and method for storing data content from a service provider to an electronic device associated with a network subscriber. The claims, and only the claims, define the invention.
The principles of the present disclosure provide a system and method for pushing a variety of video, audio and/or data files onto the service provider reserved memory of an electronic device associated with a network subscriber. The disclosed system and method allows a service provider to push data to the “edge” of an IP network, where the data can then be accessed by the subscriber. The disclosed system and method reduces valuable core network peak bandwidth and processing resources by increasing the amount of information locally available to the subscriber. Additionally, the local pushed data is readily available to the subscriber for fast and reliable access.
A system and method for utilizing a secured service provider memory are disclosed. In one aspect of the present disclosure, an electronic device is associated with a subscriber and is in communication with a data distribution network configured to deliver data by a service provider to the subscriber. The data distribution network comprises a server in communication with the data distribution network and the server configured to deliver a stream of data over the data distribution network. The electronic device comprises a first memory communicatively connected to the server. The first memory is configured to receive and store data from the server and it is accessible by the subscriber. A second memory is also communicatively connected to the server. The second memory is configured to receive and store data from the server, though the second memory is accessible only by the service provider.
It is an object of certain embodiments of the present disclosure is to provide an improved system and method for storing data content from a service provider to an electronic device associated with a network subscriber.
Further, objectives and advantages of the present invention will appear as the description proceeds.
For the purposes of promoting an understanding of the principles of the invention, reference will now be made to the embodiment illustrated in the drawings and specific language will be used to describe the same. It will nevertheless be understood that no limitation of the scope of the invention is thereby intended, and alterations and modifications in the illustrated device, and further applications of the principles of the invention as illustrated therein are herein contemplated as would normally occur to one skilled in the art to which the invention relates.
The language used in the claims is to only have its plain and ordinary meaning, except as may be explicitly defined herein. Such plain and ordinary meaning is inclusive of all consistent dictionary definitions from the most recently published Webster's dictionaries and Random House dictionaries.
The principles of the present disclosure provide a system and method for pushing a variety of video, audio and/or data files onto the service provider reserved memory of an electronic device associated with a network subscriber. The disclosed system and method allows a service provider to push data to the “edge” of an IP network, where the data can then be accessed by the subscriber. The disclosed system and method reduces valuable core network peak bandwidth and processing resources by increasing the amount of information locally available to the subscriber. Additionally, the local pushed data is readily available to the subscriber for fast and reliable access.
In the illustrated embodiment, electronic device 400 is communicatively connected to the network via virtual circuit 406. Virtual circuit 406 comprises a subscriber virtual LAN (VLAN) 408 and service provider VLAN 410. Subscriber VLAN 408 is communicatively connected to subscriber accessible memory 402. Similarly, service provider VLAN 410 is communicatively connected to service provider reserved memory 404. VLANs 408 and 410 are configured to deliver video, audio and/or data content over the network to subscriber memory 402 and service provider memory 404, respectively. Further, VLANs 408 and 410 are configured to provide upstream and downstream data access between STB 400 and the service provider. The service provider may configure VLAN 410 such that the service provider has access to service provider memory 404 at all times.
In one embodiment, the service provider has complete control over the management of the service provider reserved memory 404. Accordingly, the service provider alone is able to push files, delete files and make any necessary changes to service provider memory 404. Because the subscriber has no control over service provider memory 404 and cannot add any information onto it, the service provider is guaranteed a certain amount of memory is available on STB 400 to the service provider. In some embodiments, the subscriber is not even aware of the existence of service provider memory 404.
A subscriber premise modem 412 is also communicatively connected to virtual circuit 406. Additionally, modem 412 is communicatively connected to subscriber voice-over-IP (VoIP) appliance 414 and personal computer 416. Modem 412 is configured to communicatively connect subscriber memory 402 and service provider memory 404 to VoIP device 414 and computer 416. In other embodiments, the modem may be replaced by a router, switch or any other device capable of relaying information from one electrical component to another.
The memory space management component verifies the amount of used and unused memory space. The memory space management component also reports memory space usage and performance back to the service provider. This functionality allows the service provider to dynamically push video and/or other data content to the subscriber. The memory space management software can constantly monitor file size, age and/or any other gating factors that would allow the software 604 to make decisions, such as how long a file is available or when a file should be purged. For example, a new release video may be made available by the service provide for a certain amount of time. Once this time has expired, the file would be deleted. The same principles can be applied to all file types on the service provider specific memory and can be configured remotely by the service provider by known techniques, including, but not limited to, GUI or CLI-type interfaces.
The processing unit 602 may be in communication with a memory 606. The memory 606 may be a random access memory, flash memory, or any other memory type. The processing unit 602 may also be in communication with an input/output (I/O) unit 608 that is configured to communicate with a television or other electronic display, remote control, network, or other devices, such as a DVD, DVR, or any other local or network located device. The processing unit 602 may additionally be in communication with a storage unit 610 that is configured to store data files in data repositories 612a-612n (collectively 612).
The processing unit 602 may further be in communication with a storage unit 614 that is configured to store data files in data repositories 616a-616n (collectively 616). Storage unit 610 is in communicative connection with storage unit 614 such that data may be transferred between the storage units. In one embodiment, data repositories 616 represent the memory only accessible by the service provider. Therefore, the service provider is ensured a specified amount of storage space to work with remotely. As described herein, the service provider specific data repositories 616 and/or memory may be used by a service provider to push video content and/or other forms of data to system device 600. In one embodiment, the service provider may push software patches to the system device 600. This functionality allows a service provider to ensure that each subscriber device has the most up-to-date software and complete functionality, all without the subscribers needing to perform any updates themselves.
As previously noted, network 700 includes database 707 and processor 709. Database 707 may be configured to maintain subscriber activity data of the STBs 714 connected to network 708. More particularly, database 707 may maintain data related to the VOD viewing habits of the subscriber's associated with network 708. In one embodiment, the subscriber activity data may be directly gathered from VOD requests being transmitted to server 706. In another embodiment, the data may be collected through another means and then transferred or uploaded onto the database 707.
Database 707 may be configured to receive information related to particular video content from server 706. Some aspects of the present disclosure will be explained through the use of an example. For instance, subscriber B. Wayne may wish to watch a particular video, such as “The Dark Knight,” through his provider's VOD service. B. Wayne will use STB A 714a to initiate his request, which will travel through communication line 712a to DSLAM 710. DSLAM 710 then transmits the request to server 706 through network 708. In one embodiment, the server 706 transmits video information related to “The Dark Knight,” such as title, genre, rating, release date, cast, director, producer, etc. The database 707 may be configured to receive the video information from server 706. Associated processor 709 may then process the subscriber activity data with respect to the video information (e.g. determine and record that subscriber B. Wayne has an affinity for video content related to the video information). Processor 709 may be configured to identify additional subscribers within the network 708 determined to likely make a VOD request for the particular video content. Processor 709 may be provided within database 707 (as shown) or maintained separately from database 707. Once the subscriber activity data has been processed, processor 709 may deliver the results back to database 707 or server 706. In one embodiment, processor 709 may generate a list of subscribers likely interested in the video content.
Returning to the example, database 707 will receive information related to “The Dark Knight,” such as genre: action, rating: PG-13, and release date: Dec. 8, 2008. The database 707 may provide this information to processor 709 which may then process this information through known algorithms, processes and/or metrics to determine other viewers that will likely request “The Dark Knight” through VOD. Subscriber H. Dent, for example, may consistently request VOD related to new release, action movies. Another subscriber, A. Pennyworth, may often request comedy films released in the 1980s. In this instance, processor 709 may identify H. Dent as potentially interested in “The Dark Knight.” Accordingly, database 707 or processor 709 may transmit a list identifying H. Dent as potentially interested in “The Dark Knight” to server 706.
As noted above, server 706 is configured to stream video content to STBs 714 associated with network 708. Upon receipt of the list of additional subscribers, server 706 may be configured to both deliver the video content to (1) the initial requester of the video and (2) the additional subscribers indicated by database 707 as being likely interested. In one embodiment, server 706 may “push” the particular video content to the service provider specific memory of the STBs associated with potentially interested subscribers. As used herein, the term “push” means that the data will be stored either on the service provider reserved memory space of the STB or on any other memory device dedicated to the service provider. In one embodiment, the subscriber does not have access to the pushed data or video content.
In the above example, B. Wayne will receive and watch “The Dark Knight” just like any other VOD request. However, server 706 will also send “The Dark Knight” to H. Dent, and more particularly to the service provider specific memory of STB B 714b, via multicast stream. In one embodiment, server 706 instructs video 704 to be stored on the service provider specific memory of STB B 714b. In one version, H. Dent may then be notified that “The Dark Knight” is ready for immediate viewing. Provider 702 may also allow this “pushed” video content to be viewed by the additional subscribers at a reduced rate. Later, if H. Dent elects to view “The Dark Knight,” it will play directly off of the service provider specific memory of STB B 714b, instead of being streamed from server 706. Therefore, an additional subscriber gets to view the video content with no additional traffic on the network.
Due to STB memory constraints, the server 706 may check for available memory capacity on the service provider specific memory of a particular STB. In one form, old video content may be deleted if there is not sufficient memory available for new, pushed video content. It is further contemplated that the service provider specific memory of the STB is dedicated for pushed video content.
At step 812, the STB may notify the subscriber that the VOD content is available for immediate viewing. Optionally, the network may allow the subscriber to view the “pushed” VOD content at a reduced rate.
As previously noted, network 900 includes trickle server 907 and processor 908. Trickle server 907 is capable of delivering video content 909 over the network 910. As shown, trickle server 907 is configured to transmit video content in the form of data packets 909. For the sake of clarity, video content 904 is distinguished from video content 909, though the video content of each may relate to the same video or data. However, as used herein, video content 904 represents the video content delivered from server 906 to STBs 914 via multicast streams. Video content 909 represents the video content trickled or pushed to service provider memory of STBs 914 as described herein. Though the data streamed from the servers in the illustrated embodiment represents video content, the data may represent any information or data the service provider wishes to be pushed or stored on STBs 914.
Like server 906, trickle server 907 delivers the video content 909 via the network 910 to DSLAM 911. The DSLAM 911 further operates as a multiplexer to distribute the video 909 through communication lines 913a-913n to STBs 914. As shown, communication lines 912 and 913 are shown as distinct lines from DSLAM 911 to STBs 914. In another embodiment, communication lines 912 and 913 may comprise a single data communication line. Processor 908 may be provided within trickle server 907 (as shown) or maintained separately from trickle server 907. As illustrated, trickle server 907 exists as a separate unit from server 906. Alternatively, trickle server 907 and server 906 may form or exist in a single unit.
In accordance with one embodiment of the present disclosure, server 906 distributes video content 904 via a multicast stream. For example, server 906 may stagger streams of “Movie A” in 15 minute intervals. In the known systems, such as multicast network 200, a subscriber wishing to view “Movie A” would either have to wait until the next stagger started or begin watching the most recent stream and miss some of the previously streamed content.
In order to provide the subscriber with a true VOD experience, a segment of video content 909 is slowly streamed to STBs 914 where the segment can be stored in memory reserved for the service provider. In one embodiment, the service provider reserved memory is completely inaccessible to the subscriber. As described above, video content 909 represents the video content, trickled or pushed to STBs 914. Server 906 may communicate with trickle server 907 and/or processor 908 to provide information related to the video content. For example, server 906 may communicate the stagger interval of “Movie A” to trickle server 907 and/or processor 908. Processor 908 may then the determine the appropriate parameters of trickle delivery, such as the time required to push the appropriate segment of “Movie A”, the amount of service provider reserved memory on STB 914 required to store the segment of “Movie A”, etc.
In one embodiment of the present invention, the service provider 902 may determine to trickle or push a segment of video content 909 only for high-demand or seasonal content. If more subscribers are simultaneously watching the video content than the number of multicast streams, then bandwidth is saved on the network.
In one embodiment of the present invention, the service provider 902 determines a particular trickle rate or bandwidth to push a segment of video content onto the service provider reserved memory of STBs 914. The service provider 902 may determine a trickle rate applicable to all video content. Alternatively, the trickle rate may be dependent on the particular video content. The trickle rate may be determined by balancing competing interests. First, the service provider 902 may want the trickle bandwidth to be large enough to push the segment of video onto STB 914 in a reasonable amount of time. Second, the service provider 902 may not want the trickle bandwidth to be so large so as to impede the subscriber's viewing ability. In one embodiment, the trickle bandwidth is determined to be 512 Kbps. In the illustrated embodiment, bandwidth is “carved” out between the service provider 902 and STB 914 such that the service provider 902 maintains access to push and/or pull files from a desired STB at all times.
In one embodiment, the service provider, server 906, trickle server 907 and/or processor 908 may periodically determine whether stored segment 909 has been accessed. If the stored segment 909 has gone unused for a specific number of days or weeks, the service provider may determine that the stored segment 909 should be deleted from the service provider reserved memory.
Although the principles of the present disclosure have been described in association with set top boxes, it should be understood that the set top box functionality may be incorporated into a television or network and use the principles of the present disclosure in the same or similar manner.
While the invention has been illustrated and described in detail in the drawings and foregoing description, the same is to be considered as illustrative and not restrictive in character, it being understood that only the preferred embodiments have been shown and described and that all changes and modifications that come within the spirit of the invention are desired to be protected. It is also contemplated that structures and features embodied in the present examples can be altered, rearranged, substituted, deleted, duplicated, combined, or added to each other. The articles “the”, “a” and “an” are not necessarily limited to mean only one, but rather are inclusive and open ended so as to include, optionally, multiple such elements.
This application is a divisional of U.S. patent application Ser. No. 15/056,413, filed Feb. 29, 2016 by Clinton J. Smoyer et al. and titled, “System and Method for Utilizing a Secured Service Provider Memory”, which is a divisional of U.S. patent application Ser. No. 12/487,163, (now U.S. Pat. No. 9,307,205) filed Jun. 18, 2009 by Clinton J. Smoyer et al. and titled, “System and Method for Utilizing a Secured Service Provider Memory”, both of which are herein incorporated by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
5357276 | Banker et al. | Oct 1994 | A |
5453779 | Dan et al. | Sep 1995 | A |
5461415 | Wolf et al. | Oct 1995 | A |
5477263 | O'Callaghan et al. | Dec 1995 | A |
5629732 | Moskowitz et al. | May 1997 | A |
5812934 | Hard et al. | Sep 1998 | A |
5959968 | Chin et al. | Sep 1999 | A |
5995518 | Burns et al. | Nov 1999 | A |
6018359 | Kermode et al. | Jan 2000 | A |
6208799 | Marsh | Mar 2001 | B1 |
6473424 | DeJager et al. | Oct 2002 | B1 |
6543053 | Li et al. | Apr 2003 | B1 |
6658663 | Bruynsteen | Dec 2003 | B1 |
6667975 | DeJager et al. | Dec 2003 | B1 |
6788765 | Beamon | Sep 2004 | B1 |
6832242 | Keskar | Dec 2004 | B2 |
7080400 | Navar | Jul 2006 | B1 |
7107606 | Lee | Sep 2006 | B2 |
7130399 | Jean et al. | Oct 2006 | B1 |
7463730 | Katkam et al. | Dec 2008 | B2 |
7647618 | Hunter et al. | Jan 2010 | B1 |
7680993 | Dougall | Mar 2010 | B2 |
7734771 | Watson et al. | Jun 2010 | B2 |
7809849 | Sie | Oct 2010 | B2 |
7895625 | Bryan et al. | Feb 2011 | B1 |
7919979 | Mason et al. | Apr 2011 | B1 |
8074041 | Clark | Dec 2011 | B2 |
8275095 | Smith | Sep 2012 | B2 |
8495689 | Cook et al. | Jul 2013 | B2 |
8635355 | Harris | Jan 2014 | B2 |
9307205 | Smoyer et al. | Apr 2016 | B2 |
9396195 | Beguelin | Jul 2016 | B1 |
9710225 | Gazdzinski | Jul 2017 | B2 |
20020053090 | Okayama | May 2002 | A1 |
20020095510 | Sie et al. | Jul 2002 | A1 |
20030191908 | Cohn | Oct 2003 | A1 |
20030229681 | Levitan | Dec 2003 | A1 |
20040001512 | Challener et al. | Jan 2004 | A1 |
20040162876 | Kohavi | Aug 2004 | A1 |
20040267971 | Seshadri | Dec 2004 | A1 |
20050010964 | Sano | Jan 2005 | A1 |
20050022242 | Rosetti et al. | Jan 2005 | A1 |
20050050577 | Westbrook | Mar 2005 | A1 |
20050055718 | Stone | Mar 2005 | A1 |
20050210527 | Hisamatsu et al. | Sep 2005 | A1 |
20060072543 | Lloyd et al. | Apr 2006 | A1 |
20070032975 | Mori et al. | Feb 2007 | A1 |
20070067484 | Cheung et al. | Mar 2007 | A1 |
20070074258 | Wood et al. | Mar 2007 | A1 |
20070107026 | Sherer et al. | May 2007 | A1 |
20070162502 | Thomas et al. | Jul 2007 | A1 |
20070277205 | Grannan | Nov 2007 | A1 |
20080046584 | Tucker | Feb 2008 | A1 |
20080059884 | Ellis | Mar 2008 | A1 |
20080114862 | Moghaddam et al. | May 2008 | A1 |
20080209062 | Barrett | Aug 2008 | A1 |
20080250478 | Miller et al. | Oct 2008 | A1 |
20080259841 | Deshpande | Oct 2008 | A1 |
20080028891 | Smoyer et al. | Nov 2008 | A1 |
20080307453 | Haberman | Dec 2008 | A1 |
20090099919 | Schultheiss et al. | Apr 2009 | A1 |
20090150926 | Schlack | Jun 2009 | A1 |
20090193486 | Patel et al. | Jul 2009 | A1 |
20090199283 | Jain | Aug 2009 | A1 |
20110085551 | Sridhar et al. | Apr 2011 | A1 |
20120210341 | Burke et al. | Aug 2012 | A1 |
20140323092 | Jain | Oct 2014 | A1 |
20160182953 | Smoyer et al. | Jun 2016 | A1 |
Entry |
---|
Oz, Ran, “Switched Unicast: It's Not Just About Capacity”, BigBand Networks, pp. 1-11. |
“Video on Demand,” http://enwikipedia.org/wiki/Video_on_demand; Jan. 8, 2009; 5 pages. |
Number | Date | Country | |
---|---|---|---|
20190253759 A1 | Aug 2019 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15056413 | Feb 2016 | US |
Child | 16397874 | US | |
Parent | 12487163 | Jun 2009 | US |
Child | 15056413 | US |