TECHNICAL FIELDThe present disclosure relates generally to a multi-room digital video recording system, and, more specifically, to providing a system for tuner allocation in the multi-room digital video recording system.
BACKGROUNDThe statements in this section merely provide background information related to the present disclosure and may not constitute prior art.
Satellite television has become increasingly popular due to the wide variety of content and the quality of content available. A satellite television system typically includes a set top box that is used to receive the satellite signals and decode the satellite signals for use on a television. The set top box typically has a memory associated therewith. The memory may include a digital video recorder or the like as well as storage for the operating code of the set top box. Because of the numerous components associated with the set top box, the set top box for each individual television is relatively expensive.
Satellite television systems typically broadcast content to a number of users simultaneously in a system. Satellite television systems also offer subscription or pay-per-view access to broadcast content. Access is provided using signals broadcast over the satellite. Once access is provided, the user can access the particular content.
Electronic devices are increasingly accessing the Internet. In the newest flat panel televisions, Internet connections are provided to enhance the customer experience. For example, various Internet sources such as movie sources and data sources such as weather data and stock data may all be obtained directly from the Internet-connected device.
Because each electronic device receives the signals and also processes the signals, the customer experiences at each of the electronic devices may be slightly different. Consistency and the quality that the customer perceives at each device are important for providing a consistent customer experience.
Providing multi-room digital video recording is important to content providers. Many systems, however, have permanent allocation of resources to a particular device or location. In many situations, it may be desirable to provide many resources to one location while allocating relatively few resources to another location.
SUMMARYThe present disclosure provides a method and system for allocating times in a multi-room digital video recording system.
In one aspect of the disclosure, a method includes allocating a first tuner of a plurality of tuners to a first client device, generating a tuner request at the second client device, communicating the tuner request from the second client device to the server, reallocating the first tuner to the second client device in response to the tuner request and communicating a content signal through the first tuner to the second client device.
In another aspect of the disclosure, a method includes allocating a first tuner of a plurality of tuners to a first client device, generating a tuner request at the first device, communicating the tuner request from the first client device to the server device, allocating a second tuner to the first client device and communicating content signals through the first tuner and the second tuner to the first client device.
In yet another aspect of the disclosure, a system includes a server device having a plurality of tuners therein and a first client device in communication with the server device and allocated at least a first tuner from the plurality of tuners. A second client in communication with the server that generates a tuner request. The server device allocates the first tuner to the second user device and communicates a content signal through the first tuner to the second client device.
In a further aspect of the disclosure, a system includes a server device having a plurality of tuners therein and a first client device in communication with the server and allocated at least a first tuner from the plurality of tuners and generating a tuner request. The server device allocates at least a second tuner from the plurality of tuners in response to the tuner request. The server device communicates content signals through the first tuner and the second tuner to the first client device.
Further areas of applicability will become apparent from the description provided herein. It should be understood that the description and specific examples are intended for purposes of illustration only and are not intended to limit the scope of the present disclosure.
DRAWINGSThe drawings described herein are for illustration purposes only and are not intended to limit the scope of the present disclosure in any way.
FIG. 1 is a high level block diagrammatic view of a satellite distribution system according to the present disclosure;
FIG. 2 is a block diagrammatic view of a first network topology;
FIG. 3 is a block diagrammatic view of a second embodiment of the network topology;
FIG. 4 is a block diagrammatic view of a third embodiment of a network topology;
FIG. 5 is a block diagrammatic view of a fourth embodiment of a network topology;
FIG. 6 is a simplified block diagrammatic view of a client device;
FIG. 7 is a block diagrammatic view of a server device;
FIG. 8 is a block diagrammatic view of a tuner conflict situation;
FIG. 9 is a flowchart of a first method for assigning a tuner;
FIG. 10 is a flowchart of a second method for assigning the tuner;
FIG. 11 is a flowchart of a third method for assigning the tuner;
FIG. 12 is a first representational screen view of a conflict screen;
FIG. 13 is a second representational screen view of a conflict screen;
FIG. 14 is a first representational screen view of a tuner activity screen;
FIG. 15 is a second representational screen view of a tuner activity screen;
FIG. 16 is a flowchart of a fourth method for assigning the tuner;
FIG. 17 is a flowchart of a fifth method for assigning the tuner; and
FIG. 18 is a flowchart of a sixth method for assigning the tuner.
DETAILED DESCRIPTIONThe following description is merely exemplary in nature and is not intended to limit the present disclosure, application, or uses. For purposes of clarity, the same reference numbers will be used in the drawings to identify similar elements. As used herein, the term module refers to an Application Specific Integrated Circuit (ASIC), an electronic circuit, a processor (shared, dedicated, or group) and memory that execute one or more software or firmware programs, a combinational logic circuit, and/or other suitable components that provide the described functionality. As used herein, the phrase at least one of A, B, and C should be construed to mean a logical (A or B or C), using a non-exclusive logical OR. It should be understood that steps within a method may be executed in different order without altering the principles of the present disclosure.
The following system is described with respect to a satellite system. The communication system may be implemented in a terrestrial system such as a broadband system, cable system or telephone-type system. Optical fiber and wireless distribution may also be used in the broadband distribution system.
Further, many other types of content delivery systems are readily applicable to the disclosed systems and methods. For example, other wireless distribution systems, wired or cable distribution systems, cable television distribution systems, ultra-high frequency/very high frequency radio frequency systems, or other terrestrial broadcast systems may be used. Local multi-point distribution systems, Internet protocol- (IP) based distribution systems, cellular distribution systems, power-line broadcast systems, and point-to-point or multicast Internet protocol delivery networks may be used.
The following disclosure is made with respect to the delivery of video such as television, movies, music videos, and the like. It should also be understood that the systems and methods disclosed herein could also be used for the delivery of any media type, for example, audio, music, data, files, web pages, games, etc. Additionally, throughout this disclosure reference is made to data, information, program, movies, assets, video data, etc. However, it will be readily apparent that these terms are substantially equivalent in reference to the example systems and methods disclosed herein. Therefore, the present disclosure is applicable to the many types of content described above.
Referring now toFIG. 1, acommunication system10 is illustrated.Communication system10 includes acontent processing system12 that is used as a processing and transmission source. A plurality ofcontent providers14, only one of which illustrated, may provide content to thecontent processing system12. Thecontent processing system12 receives various types of content from acontent provider14 and communicates the content to system users. Thecontent processing system12 may also be associated with acentral distribution server16. Thecentral distribution server16 may be incorporated into thecontent processing system12 or may be a separate item. Thecentral distribution server16 may be used for various types of distribution including resetting a user device, providing a software image or providing an updated software image to a user device. Other uses of thecentral distribution server16 will be described below.
Thecontent processing system12 communicates with various user systems through acontent delivery system19. Thecontent delivery system19 may be one of the various types of systems such as a wired, wireless, Internet Protocols, cable, high frequency system, etc. described above. In this case, a satellite system is illustrated but should not be considered limiting.
Carrying through with the satellite example, thecontent processing system12 includes anantenna18 for communicating processed content through anuplink20 to asatellite22. Thesatellite22 may include a receivingantenna24 and a transmittingantenna26. The receivingantenna24 receives the uplink signals20 from thesatellite antenna18. The transmittingantenna26 generatesdownlinks28 and communicates thedownlinks28 to various user devices.
A fixeduser system30 receives the downlink signals30 through a receivingantenna32. The fixeduser system30 is a fixed user system meaning it is stationary. However, some components may be mobile components. The fixeduser system30 may be deployed within a building such as a single-family household, a multi-dwelling unit, or a business. Details of the fixed user system are provided below.
The present disclosure is also applicable to amobile user system40. Themobile user system40 may include asatellite antenna42. Thesatellite antenna42 may be a tracking antenna to account for the mobility of the mobile user system. This is in contrast to theantenna32 of the fixed user system that may be fixed in a single direction. Themobile user system40 may include systems in airplanes, trains, buses, ships, and the like.
The fixeduser system30 and themobile user system40 may be in communication with anetwork50. Thenetwork50 may be a single network or a combination of different networks or different types of networks. Thenetwork50 may, for example, be a broadband wired network or wireless network. Thenetwork50 may be a one-way network so that data or content may be communicated from the fixeduser system30 or themobile user system40 through thenetwork50 to thecontent processing system12 and thecentral distribution server16. Likewise, thenetwork50 may also be one-way in the other direction so that thecontent distribution server16 may communicate content data or other control signals such as a reset signal through thenetwork50 to the fixeduser system30 and themobile user system40. Thenetwork50 may also be a two-way network so that communications may take place between thecontent processing system12, which includes thedistribution server16, and the fixeduser system30 and themobile user system40. Thenetwork50 may also be in communication with thesoftware image server54. Thesoftware image server54 may include memory for storing software images for the fixeduser system30 or themobile user system40. Thesoftware image server54 may include boot software images or other software images. The software images may be initial software images or revised software images. The software images within thesoftware image server54 may also be different versions of software images. The fixeduser system30 and themobile user system40 use various data versions of software for testing. Thesoftware image server54 may be incorporated into thecontent processing system12 or a separate component or data site that may interconnect to the other parts of thesystem10 through thenetwork50.
Referring now toFIG. 2, an example of a fixeduser system30 is illustrated in further detail. The fixeduser system30 may include alocal network server110. Thelocal network server110 may receive content from anexternal source112. Theexternal source112 may be a satellite distribution system as illustrated inFIG. 1 or the other sources described above. In such a case, theexternal source112 may be thesatellite antenna32 illustrated inFIG. 1. Theexternal source112 may be a variety of television signal sources such as an over-the-air tuner, a cable, a wireless system, or an optical system. Various types of signals such as data, music, video, games, audio, and combinations thereof may be part of the external source.
Theserver device110 may act as a set top box for directly communicating content to adisplay114. The content in a direct connect may not be renderable content but rather directly displayable signals within a frequency band. The signals to display114 may also be renderable. Thedisplay114 may be a television or monitor.
Theserver110 may also be in communication with alocal area network120. Although wired connections are illustrated, wireless or optical signals may be used for communicating through thelocal area network120. Theserver device110 may also communicate with thenetwork50 illustrated inFIG. 1. In that case, thenetwork50 is an external network when compared tolocal area network120. The local area network ofFIG. 2 is formed through theserver110. That is, theserver110 acts to communicate to both clients A and B as well as acts as an intermediary if client A communicates with Client B, or vice versa.
Theserver device110 may communicate with a first client, Client A, using aclient device122. Theserver device110 may stream content signals to theclient device122. Theserver device110 may also control the display of content and screen displays or remote user interfaces at the client device. The remote user interface may be a graphical user interface for controlling various selections or controls. Theclient device122 may perform various functions that will be described below. For example, theclient device122 may render renderable signals from the server for displaying the rendered signals on adisplay124 associated with theclient device122. Theclient device122 may also select the content and controls from the user interface and communicate the control signals to theserver device110.
A second client, Client B, may also be in communication with theserver110 through thelocal area network120. Client B may contain an internal client device, not shown, for displaying rendered signals on thedisplay126. The internal client device may be functionally equivalent to thestandalone client device122. Because both the first client, Client A, and the second client, Client B, are in communication directly with theserver110, the network may be referred to as a closed network. Various numbers of clients may be connected to thelocal area network120.
Referring now toFIG. 3, a fixeduser system30′ which is an open network is illustrated. In this example, the same components described above inFIG. 2 are provided with the same reference numerals. In this example, thelocal area network120 may include a number of home network elements. One home network element may be ahome network server140 or other computing device. Another home network element may include alaptop computer142 that is in communication with thelocal area network120. Another home network element may include anetwork printer144 and arouter146. Therouter146 may communicate with other devices through an external network such as theInternet148.
The fixeduser system30 may also have wireless elements associated therewith. Therouter146 or another network device may generate wireless signals that allow awireless device150 to communicate with at least oneserver110 or140. Thewireless device150 may, for example, be a personal digital assistant, a cellular phone, a personal media device or a Blu-Ray or DVD player. Of course, other wireless devices may be part of the network.
Referring now toFIG. 4, another example of a fixeduser system30″ is illustrated. In this embodiment, the same elements fromFIGS. 2 and 3 are provided with the same reference numerals. Thelocal area network120 may also include twoservers110A and110B. Each server may include anoptional display device114A,114B, respectively. In this embodiment a third client, Client C, is illustrated having adisplay152 and aclient device154.
Referring now toFIG. 5, providing customers with reliable service is important. A fourth example of the fixeduser system30′″ is illustrated. In certain cases, a home network may not be as reliable as a direct connection. InFIG. 5, the local area network is divided into a firstlocal area network120A between the first client, Client A, the second client, Client B, and theserver110. That is, theserver110 communicates through the firstlocal area network120A with both Client A and Client B and any other clients that may be on the system. A secondlocal area network120B may communicate with other devices within the home network such as thecomputer140, thelaptop computer142, theprinter144 and therouter146.
Referring now toFIG. 6, aclient device122 is illustrated in further detail. The client device may include various component modules for use within the local area network and for displaying signals. The display of signals may take place by rendering signals provided from the network. It should be noted that theclient device122 may comprise various different types of devices or may be incorporated into various types of devices. For example, theclient device122 may be a standalone device that is used to intercommunicate between a local area network and theserver110 illustrated inFIGS. 2-5. Theclient device122 may also be incorporated into various types of devices such as a television, a video gaming system, a hand-held device such as a phone or personal media player, a computer, or any other type of device capable of being networked.
Theclient device122 may include various component modules such as those illustrated below. It should be noted that some of the components may be optional components depending on the desired capabilities of the client device and fixed user system. It should also be noted that the client device may equally apply to themobile user system40 ofFIG. 1.
Theclient device122 includes aninterface module310. Theinterface module310 may control communication between the local area network and theclient device122. As mentioned above, theclient device122 may be integrated within various types of devices or may be a standalone device. Theinterface module310 may include arendering module312. Therendering module312 receives formatted signals through the local area network that are to be displayed on the display. Therendering module312 merely places pixels in locations as instructed by the formatted signals. Therendering module312 will allow consistent customer experiences at various client devices. Therendering module312 communicates rendered signals to the display of the device or an external display.
A boot-upacquisition module314 may provide signals through theinterface module310 during boot-up of theclient device122. The boot-upacquisition module314 may provide various data that is stored inmemory316 through theinterface module310. The boot-upacquisition module314 may provide a make identifier, a model identifier, a hardware revision identifier, a major software revision, and a minor software revision identifier. Also, a download location for the server to download a boot image may also be provided. A unique identifier for each device may also be provided. However, the server device is not required to maintain a specific identity of each device. Rather, the non-specific identifiers may be used such as the make, model, etc. described above. The boot-upacquisition module314 may obtain each of the above-mentioned data frommemory316.
A closed-caption decoder module318 may also be included within theclient device122. The closed-caption decoder module318 may be used to decode closed-captioning signals. The closed-captioningdecoder module318 may also be in communication withrendering module312 so that the closed-captioning may be overlayed upon the rendered signals from therendering module312 when displayed upon the display associated with the client device.
Communications may take place usingHTTP client module330. TheHTTP client module330 may provide formatted HTTP signals to and from theinterface module310.
A remoteuser interface module334 allows clients associated with the media server to communicate remote control commands and status to the server. The remoteuser interface module334 may be in communication with the receivingmodule336. The receivingmodule336 may receive the signals from a remote control associated with the display and convert them to a form usable by the remoteuser interface module334. The remoteuser interface module334 allows the server to send graphics and audio and video to provide a full featured user interface within the client. Screen displays may be generated based on the signals from the server. Thus, the remoteuser interface module334 may also receive data through theinterface module310. It should be noted that modules such as therendering module312 and the remoteuser interface module334 may communicate and render both audio and visual signals.
Aclock340 may communicate with various devices within the system so that the signals and the communications between the server and client are synchronized and controlled.
Referring now toFIG. 7, aserver110 is illustrated in further detail. Theserver110 is used for communicating withvarious client devices122. Theserver110, as mentioned above, may also be used for communicating directly with a display. Theserver110 may be a standalone device or may be provided within another device. For example, theserver110 may be provided within or incorporated with a standard set top box. Theserver110 may also be included within a video gaming system, a computer, or other type of workable device. The functional blocks provided below may vary depending on the system and the desired requirements for the system.
Theserver device110 may be several different types of devices. Theserver device110 may act as a set top box for various types of signals such as satellite signals or cable television signals. Theserver device110 may also be part of a video gaming system. Thus, not all of the components are required for the server device set forth below. As mentioned above, theserver device110 may be in communication with various external content sources such as satellite television, cable television, the Internet or other types of data sources. Afront end408 may be provided for processing signals, if required. When in communication with television sources, thefront end408 of the server device may include a plurality oftuners410A-E, a plurality ofdemodulators412A-E, a plurality of forwarderror correction decoders414A-e and any buffers associated therewith. Thefront end408 of theserver device110 may thus be used to tune and demodulate various channels for providing live or recorded television ultimately to theclient device122. Aconditional access module420 may also be provided. Theconditional access module420 may allow the device to properly decode signals and prevent unauthorized reception of the signals.
Aformat module424 may be in communication with anetwork interface module426. The format module may receive the decoded signals from the decoder414 or theconditional access module420, if available, and format the signals so that they may be rendered after transmission through the local area network through thenetwork interface module426 to the client device. Theformat module424 may generate a signal capable of being used as a bitmap or other types of renderable signals. Essentially, theformat module424 may generate commands to control pixels at different locations of the display. Thenetwork interface module426 may also be used for receiving signals from a client device or devices.
Theserver device110 may also be used for other functions including managing the software images for the client. A clientimage manager module430 may be used to keep track of the various devices that are attached to the local area network or attached directly to the server device. The clientimage manager module430 may keep track of the software major and minor revisions. The clientimage manager module430 may be a database of the software images and their status of update.
Amemory434 may also be incorporated into theserver device110. Thememory434 may be various types of memory or a combination of different types of memory. These may include, but are not limited to, a hard drive, flash memory, ROM, RAM, keep-alive memory, and the like.
Thememory434 may contain various data such as the client image manager database described above with respect to the clientimage manager module430. The memory may also contain other data such as a database ofconnected clients436. The database of connected clients may also include the client image manager module data.
Atrick play module440 may also be included within theserver device110. Thetrick play module440 may allow theserver device110 to provide renderable formatted signals from theformat module424 in a format to allow trick play such as rewinding, forwarding, skipping, and the like. AnHTTP server module444 may also be in communication with thenetwork interface module426. TheHTTP server module444 may allow theserver device110 to communicate with the local area network. Also, the HTTP server module may also allow the server device to communicate with external networks such as the Internet.
A remote user interface (RUI)server module446 may control the remote user interfaces that are provided from theserver device110 to theclient device122.
Aclock450 may also be incorporated within theserver device110. Theclock450 may be used to time and control the various communications with thevarious client devices122.
Acontrol point module452 may be used to control and supervise the various functions provided above within the server device.
It should be noted that multiple tuners and associated circuitry may be provided. Theserver device110 may supportmultiple client devices122 within the local area network. Each device is capable of receiving a different channel or data stream. Each client device may be controlled by the server device to receive a different renderable content signal.
Theserver device110 may also include aresource manager module460 that is in communication with aconflict resolver module462. Theresource manager module460 may be in communication with anetwork interface module426. Thenetwork interface module426 may receive signals such as control signals or selection signals from various client devices. Theresource manager module460 may identify when a conflict arises from a conflict-causing request received from one of the client devices.
A conflict may arise when a concurrent view or service activity requires more resources than those available at the server device.
As will be further described below, theresource manager module460 may generate a set of “sufficient sets.” The sufficient sets may be provided to theconflict resolver module462. Theresource manager module460 or theconflict resolver module462 may then determine a course of action to follow for the encountered conflict. Theconflict resolver module462 may consider the type of activity generating the conflict-causing request versus the activities in the set of sufficient sets. Theconflict resolver module462 returns sufficient sets sorted according to the requirements of the system. Theresource manager module460 may thus resolve the conflict according to the sufficient sets and prompt the user of a client device for an input, if required. Theconflict resolver module462 may resolve conflicts between various aspects of the operation of the server, including tuner conflicts as will be described below.
Referring now toFIG. 8, a method for resolving conflicts using the conflict resolver is set forth. It should be noted that a sufficient set is described. A sufficient set consists of one or more activities that conflict with requesting activity over the time frame of the requesting activity. Each sufficient set may consist of a set of activities that, if cancelled, would free sufficient resources to resolve the resource conflict for the requesting activity. As is illustrated inFIG. 8, first program A is programmed to be recorded between 9:00 and 9:30; program B is programmed to be recorded between 9:30 and 10:00 ontuner1.Tuner2 includes program C between 9:00 and 9:30; and program D is programmed to record between 9:30 and 10:00. A requesting activity such as program Z which would record between 9:00 and 10:00 is requested. A set of sufficient sets to resolve the conflict of the requesting activity may include AB, AD, CD, or CB. The cancellation of any one of these sufficient sets will result in the conflict being resolved and a tuner being available for recording content E. The conflicts may be displayed in a conflict user interface such as that illustrated above inFIGS. 12 and 13.
Referring now toFIG. 9, a method for resolving conflicts with tuners within the server device is set forth. A tuner is requested by a client device or a service associated with the server device. It should be noted that the tuners within the server device may be allocated on an as-needed basis. Multiple tuners may be allocated to a client device under various conditions. One example of multiple tuners being allocated to one client device is for picture-in-picture (PIP). PIP allows two different content streams to be displayed at any one time. The picture-in-picture display may have one picture being larger than another picture. The foreground tuner may be responsible for the larger picture, while a background tuner may be responsible for the smaller picture. The picture-in-picture configuration may also provide side-by-side pictures in the display, or the like. One or both of the foreground tuner and background tuner may also be used for recording content within the server device in addition to displaying the signal. The tuner request signal ofstep510 may be a tuner request from a client device that already has an allocated tuner or from a second client device that has no tuner allocated or at least one tuner allocated. The tuner request may comprise many different types of requests, including a channel selection, a record selection, or a live TV selection. Another way in which the tuner request may be generated is by requesting a dual live buffer (DLB). The dual live buffer may provide live content through more than one tuner to a client device in response to a dual live buffer request.
Instep512, it is determined whether or not a tuner is available. If a tuner is available, meaning the tuner has not been pre-assigned, one of the plurality of tuners that is available is assigned instep514. It should be noted that when a tuner is available, an available tuner may be automatically assigned to the client device. It should be noted also that the tuner request may be from a first client device that already has a tuner allocated or from a second client device that may or may not have a tuner allocated. The system may thus automatically assign a tuner from the plurality of tuners available.
Referring back to step512, when a tuner is not available, a conflict mode may be entered. Instep516, a tuner management tool that displays the tuner status for different tuners may be displayed through an on-screen display (OSD) at a client device. The on-screen display may be generated at the server device. The tuner management on-screen display (OSD) will be described further below and may include the location, the title of the recording content and the recording state. When live TV is being used by a tuner associated with another client device, the words “live TV” or something similar may be used as an identifier rather than the actual content. The tuner associated with live TV may thus be made unavailable. Instep518, a tuner may be selected by the user for reallocation. By selecting a tuner for cancelling a recording,step520 may be performed. If a tuner is cancelled for recording instep520,step522 may be performed which generates a cancel request for the tuner. Afterstep522,step524 may generate an on-screen message to the client device associated with the cancelled tuner selection.
Referring back to step520, if a recording is not to be cancelled,step526 may share playback of recorded content. Afterstep526 and afterstep524,step530 may be performed. Instep530, the selected tuner may be reallocated or shared as in the case ofstep526. Afterstep530,step532 may communicate signals that include content or channel broadcasts to the client device through the reallocated tuner. The content signals may then be displayed on the display device associated with the client devices.
Referring now toFIG. 10, a method for resolving conflicts is set forth. Instep610, it is determined whether or not an attempt to tune to a channel from a client device is performed. If tuning is being performed,step626 is performed. Instep626, it is determined whether the currently used foreground tuner allocated to the client device is recording. If the currently used foreground tuner is not recording, step628 tunes the foreground tuner to the desired channel. Instep626, when the currently used tuner is recording,step630 determines whether all tuners are in use. If all tuners are not in use,step632 assigns a tuner that is not being used. The assignment of an unused tuner may take place automatically.
Instep630, when all the tuners are in use, and no other tuners are available, a tuner activity screen is displayed instep634. The tuner activity screen will be described below. The tuner activity screen may provide an opportunity for a user to cancel a recording so that a tuning request and consequently a tuner may be assigned to the tuning request. The tuner activity screen may also provide an opportunity for a user to re-assign a tuner that is assigned to another user, but is not being actively viewed by the other user. An example of a tuner activity screen is provided below.
Referring back to step610, when the tuner is not generating a tuning request, it is determined whether a recording request for a current program is being generated instep620. Instep620, when a record request for a current program is being generated,step622 determines whether the recording request is for a program that is already tuned by any tuner. Instep622, when the program is already tuned by a tuner, step624 starts a recording of that program on that tuner, including any earlier part of the program in the existing buffer of that tuner. Instep622, when the program is not already tuned by any tuner, then a tuner is needed for tuning and recording the desired program. The same steps (626-634) are then followed, as previously described, to assign a tuner for tuning to the channel, and then to start recording the desired program.
Referring now toFIG. 11, the system may also be configured to automatically assign when activity priority rules cannot be performed. Steps510-514 ofFIG. 9 may be first performed to determine whether a tuner is available. When a tuner is not available instep512,step710 determines whether activity prioritization rules are available. If activity prioritization rules are available, the system may automatically assign a tuner instep712. Instep710, when the system is not able to automatically assign a tuner because of existing recordings or active tuner sessions,step714 determines the least active viewer session. Instep716, an on-screen display may generate a user warning so that a user of a client device may determine whether to cancel a recording. Instep718, the user device may determine whether to proceed to perform a tuner reallocation based upon a user selection. When a user selects reallocation instep718,step720 is performed. Instep720, a tuner is reallocated from the least active viewer session.
Referring back to step718, when the user does not desire to reallocate a tuner, the system ends without reallocating a tuner instep722.
Referring now toFIG. 12, agraphical user interface800 for a screen display associated with a client device is set forth. Thegraphical user interface800 illustrates a conflict screen that may be provided when previously scheduled programs are set to record. In this example, five conflicts numbered 1-5 are provided. Multiple titles are provided for each conflict. In this example, “Dancing with the Stars” is the currently selected item ready to be recorded. The five items listed prevent the program “Dancing with the Stars” from being recorded because a tuner is not available. The graphical user interface may have apicture window810 for displaying the currently displayed channel. A cancelrequest selector812 may also be provided on the screen. As is illustrated, the cancelrequest selector812 is a different color than the cancel request boxes cancel 1-cancel5. By using a remote user interface such as a remote control, one of the boxes cancel 1-cancel 5 may be selected or the cancelrequest box812 may also be selected.
Referring now toFIG. 13, when the selector icon is moved to one of the cancel requests, details for the cancel request may be provided. In this example, the title, the channel and network, the date, the day, and the time may all be provided for the first conflict. By moving the selector to different cancel boxes, the different conflicting programs may be displayed.FIGS. 12 and 13 correspond to recording conflicts.
Referring now toFIGS. 14 and 15, agraphical user interface850 is illustrated. The graphical user interface may be used for selecting a tuner and displaying tuner activity. As is illustrated, alocation column852 is provided as well as atitle column854. Next to each title, a record indicator is provided which indicates to the user that the title is currently recording. It should be noted that undercolumn854, when a tuner assigned to a room or client device, only a “live TV” indicator is provided to protect privacy.
Astatus column860 may also be provided which will allow a user to cancel a recording for another tuner. Aselector862 may be scrolled up and down and selected using a user interface such as a remote control. Under certain conditions, a live TV tuner may not be available as is illustrated inFIG. 14. However, inFIG. 15 the live TV tuner is available. By cancelling the recording, another selected recording may be programmed.
Referring now toFIG. 16, a method for performing conflict resolution is illustrated. Instep910, a conflict of a first event and a second event is determined by the resource manager in response to a conflict-causing request by one of the client devices. The resource manage may determine that assistance is required from a conflict resolver instep912. Instep914, a set of sufficient sets is generated. The set of sufficient sets was described above inFIG. 8.
Instep916, the conflict-causing request and the set of sufficient sets is communicated to the conflict resolver.
Instep918, the conflict may be resolved by determining a type value, priority value, and a sub-priority value for each event. Of course, other types of rankings may be provided to provide scores. The server device may automatically resolve a conflict based upon the scores. However, should a conflict not be resolved by the conflict resolver, a list of conflicting events sorted in a priority from high to low may be presented to a viewer. Different types of activities for different systems may have different priority levels. For example, the highest priority level in the present example is a frequency translation module. The frequency translation module performs a mandatory download as well as performs a reset of the flash memory. The client device acquires the frequency translation module image and stores it within the device. Of course, other mandatory downloads may also be or may also receive a higher priority ranking. The type of such recordings may be high and the priority may also be high. The sub-priority value may also be high for these mandatory downloads. Other types of events, such as set top box upgrades, may also be ranked according to future and immediate upgrades. Client terminal booting, signal strength tests, program guide boot requests, mandatory network pushes, playback of live TV, picture-in-picture requests, one-time pay-per-view recording, one-time non-pay-per-view recordings, recurring recordings, optional upgrade recordings and various types of buffers may all be ranked with a type, priority and sub-priority. The type, priority and sub-priority values may be set by the system designers. Various systems may have various priorities and sub-priorities according to customer and engineering needs.
Instep920, the set of sufficient sets is sorted according to the type value, priority value and sub-priority value. Instep922 it is determined whether user input is required. If user input is not required,step924 solves the conflict by reassigning a tuner or not reassigning a tuner based upon the values. Instep922, if user input is required, an on-screen display may be generated instep926. Afterstep926,step928 communicates a selection from the user device to the resource manager from the client device. A selection signal may be generated at the client device in response to the on-screen display generated instep926. Instep930, a tuner may be re-allocated based upon the selection from the client device instep928. Of course, the tuners may not be reallocated based upon a selection.
Referring now toFIG. 17, a method for resolving tuner resource conflicts is set forth. Instep1010, it is determined whether a scheduled recording is beginning. If a scheduled recording is not beginning, this method is not applicable andstep1010 is again performed. When a recording is scheduled to begin instep1010,step1012 is performed. Instep1012, if a foreground or background tuner of any user is tuned to the channel to be recorded in the recording request,step1014 uses the already tuned tuner to perform the recording. Thus, either the foreground tuner or background tuner that is tuned to that channel is used instep1014. Referring back tostep1012, when a foreground tuner or background tuner is not tuned to the channel for recording,step1016 determines whether a tuner is available, and not currently recording or dedicated to any user. If a tuner is available, a tuner may be assigned instep1018 and locked for a predetermined amount of time instep1020. The locking of a tuner for a predetermined amount of time is optional.
Referring back tostep1016, if a tuner is not available,step1022 determines whether any user has at least one tuner that is not recording. If all tuners are recording, then the scheduled recording is cancelled instep1024. Ifstep1022 determines that there are users with at least one tuner that is not recording, then1026 is performed which assigns the scheduled recording to the least active of those users.Step1026 may determine the least active of those users based on the amount of time since a remote control action. Alternately,step1026 may use another suitable criterion of user activity.
Referring back tostep1026, when the least active user is determined, such user having at least one tuner that is not recording,step1028 now determines whether dual live buffers (DLB) or picture-in-picture (PIP) is active at that user. If dual live buffers or picture-in-picture is not active instep1028, then an on-screen display may be generated instep1030 and the user's tuner may be used for recording instep1032. The on-screen display instep1030 notifies the user, and may optionally allow the user to cancel the scheduled recording, in whichcase step1032 is not performed.
Referring back tostep1028, if dual live buffers or picture-in-picture is active,step1034 is performed. Dual live buffers or picture-in-picture being active requires two tuners dedicated to a client device. As determined instep1022, at least one of these two tuners is not currently being used for a recording, and may be used for the scheduled recording.
Step1034 determines whether the foreground tuner is currently and will still be recording and the dual live buffer remains active. If the foreground tuner is currently tuned and will still be recording and the dual live buffer is active,step1036 generates an on-screen display and the background tuner may be used for recording instep1038. The on-screen display instep1036 may optionally allow the user to cancel the scheduled recording, in whichcase step1038 is not performed.
Referring back tostep1034, when the foreground tuner is or will not still be recording and the DLB may not be active,step1040 may be performed. Instep1040, it is determined whether the background tuner is currently and will be recording when an event is to start. If the background tuner is currently and will be recording, an on-screen display may be generated that asks whether the foreground tuner should be used instep1042. Instep1044, the foreground tuner may be selected for recording the event.
Referring back tostep1040, when the background tuner is not currently or will not be currently recording when the event is to start,step1050 is performed. Instep1050, it is determined whether the foreground and the background tuner will be available at the start of the event and only one recording is scheduled. If only one recording is scheduled and the foreground and background tuner will be available at the start of the event,step1052 may generate an on-screen display selection so that the user of the client device may select the foreground tuner or background tuner for an event instep1054. The generation of an on-screen display is optional. The recording is then recorded instep1056 using the selected tuner. The on-screen display instep1052 may optionally also allow the user to cancel the scheduled recording, in which case steps1054 and1056 are not performed.
Referring back tostep1050, if the foreground tuner and background tuner will be available at the start will not be available at the start time and more than one recording is scheduled,step1060 may determine whether two recordings are scheduled to start within five minutes of each other. Instep1062, an on-screen display may be generated that states that the recordings will be started. Instep1060, if two recordings are not scheduled to start within five minutes of each other, the tuners may be assigned as described above. This may entail an on-screen display selection or merely assigning available tuners to the recording events.
Referring now toFIG. 18, a description for a user resolving conflicts between tuner activities is set forth. Instep1110, the display may be used to display a tuner activity screen such as those illustrated inFIGS. 14 and 15. Instep1112, tuner data may be determined for the display. A tuner status may also be generated within the tuner activity screen instep1114. Instep1116, a tuner identifier is generated on the screen. The tuner identifier may have a numerical identifier or a common identifier such as “living room, my location, bedroom one, bedroom two, or the like.” Instep1118, a recording playback indicator may also be provided. If one device is playing back a recording, the recording may be joined. Instep1120, a program or channel number may be prevented from being displayed on a tuner or a conflict display instep1120. This allows privacy between various client devices. A live program can thus not be joined by another client device. Instep1122, a tuner may be selected to cancel the recording upon the tuner conflict screen. If a tuner has been selected for recording or cancelling, the tuner status is changed instep1126. Instep1124, if a tuner has not been selected for recording or cancelling,step1128 maintains the tuner status of the tuners.
Those skilled in the art can now appreciate from the foregoing description that the broad teachings of the disclosure can be implemented in a variety of forms. Therefore, while this disclosure includes particular examples, the true scope of the disclosure should not be so limited since other modifications will become apparent to the skilled practitioner upon a study of the drawings, the specification and the following claims.