The invention relates to the field of data processing. More specifically, the invention relates to processing data concerning television viewing preferences.
Due to the enormous amount of TV channels available on digital cable, satellite TVs, etc., it has become a frustrating exercise for a viewer to try to scroll through all the channels at one time, because by the time a typical viewer may scroll through all the channels, a typical TV program may already be well under way, if not nearly over! Thus the viewer may be stuck in a continuous loop of flipping through channels, without being able to locate his preferred shows in time to view them.
To assist the viewer, some TV service providers (e.g., cable, satellite, etc.) offer a “favorites” function that allows the user to create his own short list of preferred channels and scroll only through those channels, instead of scrolling through all the channels. However, the given names of channels are usually replaced by numbers or a four-letter standard abbreviation, so the user simply does not recognize many channels and does not know whether he would prefer them or not. Any time the user wants to add or delete a channel, he manually updates the list.
Additionally, some users watch TV only during certain preferred time periods, and find it inconvenient to scroll through broadcast program listings for time periods when they do not watch TV.
As a result, preferred broadcast programs lists require programming, maintenance, updating, and so forth, which can be inconvenient. Due to this potential inconvenience, users may give up on the effort to create their own preferred broadcast programs list.
A second set of broadcasted programs is added to a first set of broadcasted programs. The second set of broadcasted programs includes broadcasted programs viewed by a viewer for a period of time at least equal to a first threshold. A third set of broadcasted programs is removed from the first set of broadcasted programs. The third set of broadcasted programs includes broadcasted programs not viewed by a viewer for a period of time at least equal to a second threshold. In one embodiment, a fourth set of broadcasted programs selected by the viewer is added to the first set of broadcasted programs. In one embodiment, the first threshold and the second threshold are updated upon the viewer indicating dissatisfaction. In one embodiment, the first threshold and the second threshold are updated upon the viewer returning to a schedule list more than a predetermined number of times. In one embodiment, the first threshold is set to be a first percentage of a period of time that a channel was viewed, and the second threshold is set to be a second percentage of the period of time that the channel was viewed.
The present invention will be understood more fully from the detailed description given below and from the accompanying drawings of various embodiments of the invention, which, however, should not be taken to limit the invention to the specific embodiments, but are for explanation and understanding only.
In one embodiment, creating and dynamically updating a list of a viewer's preferred broadcasted programs, with associated channels and viewing times, is accomplished through statistical analysis of the viewer's behavior to learn the viewer's preferences from accumulated statistics. The viewer is thus not required to program each broadcasted program into the list. Channels include, in one embodiment, channels selectable on a television set. On each channel a set of broadcasted programs may be viewed. A broadcasted program is associated with a viewing time; the time during which the program is broadcast. In one embodiment, creating and dynamically updating a list of preferred broadcasted programs for the viewer without requiring the viewer to program the list is accomplished by using adaptive heuristic algorithms, commonly known as “fuzzy logic,” to learn the viewer's preferences from accumulated statistics.
Generating a preferred broadcasted programs list according to one embodiment proceeds, for example, as follows.
The advantage of such a preferred broadcasted programs list generated dynamically by a fuzzy logic software engine is that if the user changes his viewing practices and starts viewing new channels or new broadcasted programs for any substantial duration, the fuzzy logic engine will accordingly adapt very quickly. The reasons for this are well known in the art of fuzzy logic programming.
In one embodiment, threshold parameters can be updated according to a user's indication of satisfaction or dissatisfaction with the list of preferred broadcast programs. In one embodiment, the indication of satisfaction or dissatisfaction is expressed as a rating on a scale (e.g., 7 out of 10 being an indication of moderate satisfaction and 3 out of 10 being an indication of moderate dissatisfaction). In one embodiment, the indication of satisfaction or dissatisfaction is expressed as a boolean true or false value, where a user expresses either entire satisfaction (e.g., as by a “thumbs up” or “true” selection) or entire dissatisfaction (e.g., as by a “thumbs down” or “false” selection). Where a user expresses satisfaction with the list of preferred broadcast programs, the threshold parameters remain unchanged. Where a user expresses dissatisfaction, the threshold parameters are modified so that either a greater or lesser number of broadcast programs are included in the preferred list. If the number of broadcast programs in the list is already large, the threshold parameters L1 and L2 may be raised so that the number of broadcast programs in the preferred list is reduced. If the number of broadcast programs in the list is small, the threshold parameters L1 and L2 may be lowered so that the number of broadcast programs in the preferred list is increased. In one embodiment, an indication of dissatisfaction is sent to a media provider, who may then manually modify the threshold parameters. In one embodiment, threshold parameters can be updated depending a number of times the user returns to the complete schedule list for more information during the control period. If the user returns to the complete list more than a predetermined number of times then L1 or L2 may be too high. In an opposite case, the threshold levels may be set too low and the user-generated preferred list may be too long. In one embodiment, if a threshold (L1 or L2) is set too high, as evidenced by a viewer returning to a schedule list more than a predetermined number of times (where the predetermined number may be selected by a viewer in one embodiment, or by a media provider in one embodiment), then that threshold is automatically lowered. Similarly, in one embodiment, if a threshold is set too low, then that threshold is automatically raised. Thus, the viewer is not required to select each broadcasted program, channel, or viewing time to include or exclude from the list, as these are included or excluded by the thresholds, and the thresholds are automatically adjusted.
In addition to generating a list of most preferred broadcast programs, one embodiment also removes broadcasted programs having viewing times during time intervals that are not of interest to the viewer from the list of preferred broadcasted programs. A time interval is determined to not be of interest to a viewer if the user does not select programs which are broadcast on any channels during the time interval. For example, if the user does not select the time interval between 10 a.m. and noon during working days (which could simply mean that he is working at this time) and the user is not doing a recording from the guide, it may be more convenient for the user to scroll through only the time intervals of interest. Therefore, in one embodiment, the time frame for the whole day is divided by contiguous intervals. An interval may vary in duration, but in a preferred embodiment typically lasts 2-3 hours. A histogram of activity is then generated, and based on threshold numbers T1 and T2, the system automatically creates a most preferred time frames list and least preferred time frames list. The threshold numbers T1 and T2 may be chosen in the same manner as the threshold numbers L1 and L2. However, the threshold numbers T1 and T2 are in one embodiment chosen for each time interval. Therefore, selection criteria for one time of day may differ from selection criteria for another time of day as the corresponding threshold numbers for these times differ. These may also differ depending on the day of the week.
In one embodiment, the above processes may be performed by a system. In one embodiment, the system includes a first unit to add to a first set of broadcasted programs a second set of broadcasted programs. The second set of broadcasted programs includes broadcasted programs viewed by a viewer for a period of time at least equal to a first threshold. In one embodiment, the system also includes a second unit coupled with the first unit to remove from the first set of broadcasted programs a third set of broadcasted programs. The third set of broadcasted programs includes broadcasted programs not viewed by a viewer for a period of time at least equal to a second threshold. In one embodiment, the first unit is further to add to the first set of broadcasted programs a fourth set of broadcasted programs selected by the viewer. In one embodiment, the first unit is further to update the first threshold and the second threshold upon the viewer indicating dissatisfaction. In one embodiment, the first unit is further to update the first threshold and the second threshold upon the viewer returning to a schedule list more than a predetermined number of times. In one embodiment, the first unit is further to set the first threshold to be a first percentage of a period of time that a channel was viewed, and to set the second threshold to be a second percentage of the period of time that the channel was viewed. In one embodiment, the first unit is further to add to the first set of broadcasted programs a fifth set of broadcasted programs, the fifth set of broadcasted programs including broadcasted programs selected by a viewer a number of times at least equal to a third threshold, and wherein the second unit is further to remove from the first set of broadcasted programs a sixth set of broadcasted programs, the sixth set of broadcasted programs including broadcasted programs not selected by a viewer a number of times at least equal to a fourth threshold. In one embodiment, all of the above units are included within a processor. In one embodiment, all of the above units are included within a television set-top box. In one embodiment, all of the above units are included within a television.
The embodiments described above can be implemented using software in a TV viewing system. Such a TV viewing system can be implemented in many ways. A typical approach to implementation uses a set-top box that contains, among other things, a CPU, storage (e.g., RAM, ROM, etc.), a receiving network adapter, and circuitry to drive a viewing system such as a TV, monitor, projector, etc. All of these elements are not necessarily shown, but are well know in the art. For purposes of the embodiments described above, any other grouping, such as a TV with a built-in CPU, or a personal computer with TV capabilities are considered to be equivalent.
The method and apparatus disclosed herein may be integrated into advanced Internet- or network-based knowledge systems as related to information retrieval, information extraction, and question and answer systems. The system has a processor coupled to a bus. Also coupled to the bus are a memory which may contain instructions. Additional components coupled to the bus are a storage device (such as a hard drive, floppy drive, CD-ROM, DVD-ROM, etc.), an input device (such as a keyboard, mouse, light pen, bar code reader, scanner, microphone, joystick, etc.), and an output device (such as a printer, monitor, speakers, etc.). Of course, an exemplary computer system could have more components than these or a subset of the components listed.
The method described above can be stored in the memory of a computer system (e.g., set top box, video recorders, etc.) as a set of instructions to be executed. In addition, the instructions to perform the method described above could alternatively be stored on other forms of machine-readable media, including magnetic and optical disks. For example, the method of the present invention could be stored on machine-readable media, such as magnetic disks or optical disks, which are accessible via a disk drive (or computer-readable medium drive). Further, the instructions can be downloaded into a computing device over a data network in a form of compiled and linked version.
Alternatively, the logic to perform the methods as discussed above, could be implemented in additional computer and/or machine readable media, such as discrete hardware components as large-scale integrated circuits (LSI's), application-specific integrated circuits (ASIC's), firmware such as electrically erasable programmable read-only memory (EEPROM's); and electrical, optical, acoustical and other forms of propagated signals (e.g., carrier waves, infrared signals, digital signals, etc.); etc.
Although the present invention has been described with reference to specific exemplary embodiments, it will be evident that various modifications and changes may be made to these embodiments without departing from the broader spirit and scope of the invention. Accordingly, the specification and drawings are to be regarded in an illustrative rather than a restrictive sense.
The present application is a continuation of U.S. patent application Ser. No. 10/029,784, filed Oct. 19, 2001, entitled “METHOD AND APPARATUS FOR GENERATION OF A PREFERRED BROADCASTED PROGRAMS LIST,” which claims priority to U.S. provisional patent application Ser. No. 60/241,880, filed on Oct. 19, 2000, entitled “DYNAMIC, AUTOMATIC, GENERATION OF FAVORITE TIMES AND CHANNELS LIST,” both of which are incorporated herein by reference in their entirety for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
5414773 | Handelman | May 1995 | A |
5479268 | Young | Dec 1995 | A |
5526034 | Hoarty | Jun 1996 | A |
5532754 | Young | Jul 1996 | A |
5550578 | Hoarty | Aug 1996 | A |
5737028 | Bertram | Apr 1998 | A |
5751282 | Girard | May 1998 | A |
5801747 | Bedard | Sep 1998 | A |
5818441 | Throckmorton et al. | Oct 1998 | A |
5841563 | Effenberger | Nov 1998 | A |
5900915 | Morrison | May 1999 | A |
5926168 | Fan | Jul 1999 | A |
5956456 | Bang | Sep 1999 | A |
5999167 | Marsh | Dec 1999 | A |
6029195 | Herz | Feb 2000 | A |
6034678 | Hoarty | Mar 2000 | A |
6075575 | Schein | Jun 2000 | A |
6100883 | Hoarty | Aug 2000 | A |
6128009 | Ohkura et al. | Oct 2000 | A |
6167188 | Young | Dec 2000 | A |
6177931 | Alexander et al. | Jan 2001 | B1 |
6205485 | Kikinis | Mar 2001 | B1 |
6205582 | Hoarty | Mar 2001 | B1 |
6233389 | Barton | May 2001 | B1 |
6271831 | Escobosa | Aug 2001 | B1 |
6298482 | Seidman et al. | Oct 2001 | B1 |
6614987 | Ismail | Sep 2003 | B1 |
6721953 | Bates et al. | Apr 2004 | B1 |
7082613 | Mineyama | Jul 2006 | B1 |
20020199193 | Gogoi et al. | Dec 2002 | A1 |
20040049787 | Maissel et al. | Mar 2004 | A1 |
20060271958 | Ukai et al. | Nov 2006 | A1 |
20090106787 | Maissel et al. | Apr 2009 | A1 |
20100138790 | Rashkovskiy et al. | Jun 2010 | A1 |
20110061076 | Ali et al. | Mar 2011 | A1 |
Number | Date | Country |
---|---|---|
0001149 | Jun 2000 | WO |
Number | Date | Country | |
---|---|---|---|
20090138902 A1 | May 2009 | US |
Number | Date | Country | |
---|---|---|---|
60241880 | Oct 2000 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10029784 | Oct 2001 | US |
Child | 12363910 | US |