All of the material in this patent document is subject to copyright protection under the copyright laws of the United States and of other countries. The owner of the copyright has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the United States Patent and Trademark Office file or records, but otherwise reserves all copyrights whatsoever.
The present invention relates generally to search engines, and more particularly to a search engine for a video recorder system that has enhanced presentation and searching capabilities.
Video recorders are devices that are used in conjunction with a television set to enhance the user's entertainment experience. A user watches an output device, such as a television set, while the video recorder, which is either attached to or incorporated within the output device, is used for such things, for example, as tuning to particular stations, recording the shows, playing back previously recorded shows, and searching for shows to watch now or schedule for recording later.
In the past, a user searched for shows using a magazine such as “TV Guide”. The user would scan through the pages of the magazine until the appropriate show was located and then would manually tune their television to that channel. More recently, a program guide was provided with analog cable. Instead of a magazine, a specific channel was dedicated to the program guide and similar to a magazine, pages of the program guide were displayed on the screen and the user watched the pages on the screen to find a show that the user could then tune to or schedule to record.
As digital cable became more common, a more interactive program guide (IPG) was provided. While not only displaying pages similar to a magazine, the user was able to provide input and actively search for shows, rather than passively wait for the appropriate page to appear on the screen. For instance, the user could move forward in time to see shows in the future and the user could move between channels as well. IPGs also gave the user the ability to select shows automatically for tuning or recording by providing input to the IPG.
Magazine and IPG searches are “timeslot based” meaning one can find shows based on the show's timeslot. If the show airs at 9:00 AM every Sunday, then the show is found in the magazine under the 9:00 AM timeslot on Sunday and likewise in the IPG. This creates a problem because oftentimes two or more entries of interest to a user are located a great distance apart spatially in a timeslot based grid. Take for example a user who wants to consider all shows where one of the characters is “Big Bird”. Such entries might be located, for instance, Monday through Friday at 10:00 AM on channel 5 when the show “Sesame Street” is aired, as well as on Sunday at 5:00 PM on channel 33, when “Sesame Street the Movie” is aired. In such a case, the only way the user could discover all of these entries is to scan through the entire timeslot based program guide for the entire week examining every entry. From the user's perspective, this is a problematic and overly time-consuming method of searching for shows.
The present invention is directed to a search engine for a video recorder having enhanced search and presentation capabilities. One embodiment of the present invention operates in an environment that includes one or more set-top boxes connected to or integrated within one or more output devices. The set-top boxes are used to transfer shows from a broadcast input source to one or more types of storage devices (e.g., hard drives) and to play back the shows from the storage devices to the output devices, either in a delayed-live fashion or at a later time of the user's choosing. The set-top box displays a graphical user interface (GUI), which gives the user the ability to watch and/or record timeslot based programming, to order on-demand programming, and to playback previously recorded shows that reside on a local or remote storage device.
A search engine is included in the GUI. In one embodiment, the search engine comprises an on-screen, alpha-numeric interface area that lets the user select letters or numbers using an input device such as a remote control. As the user selects letters or numbers, the system interfaces with one or more databases to locate entries that have a possibility of being matches with the user's initial selection from the alpha-numeric interface area. As the user proceeds to select more letters or numbers, the system continues using the database to narrow the potential results to output to the screen. In one embodiment, the alpha-numeric interface area is modified after each selection by making invalid letters and numbers inaccessible to the user, for instance by making it unselectable.
In another embodiment, the search engine comprises a keyword search engine. First, the user types in a keyword in an input field area. The system examines the first letter of the keyword and uses the database to find possible matches. The system then continues by examining the second and subsequent letters entered into the input field area until appropriate results are obtained.
In one embodiment, the results are organized using categories. For instance, results may be obtained by creating folders of all shows where a certain actor or actress appears, where their name matches the selections by the user. Alternatively, matching shows may be listed by show title, show type, or other appropriate category. Identical instances of the same show that are aired at different times or on different channels may be displayed as a single folder on-screen which allows the user to open the folder to find the instance of the show most appropriate to them. Once a result is found by the user, they may view the show, find out more information about the show, record the show, or schedule the show to be recorded later.
In one embodiment, the search engine utilizes a common key that is used as the basis for a search of three separate types of databases. The first type of database comprises data relating to timeslot based programming, the second type of database comprises data related to on-demand programming, the third type of database comprises data related to previously recorded shows that are available to the set-top box in use. The common key is used to query each database to find database entries that match the key. Such keys are then used to output a list of results that match the search from all three databases. In one embodiment, the search engine utilizes such factors, for instance, as title, category (e.g., horror or comedy), time, actors, etc.
The invention will be more fully understood by reference to the following drawings, which are for illustrative purposes only:
The present invention is directed to a search engine for a video recorder that has enhanced output and search capabilities. A video recorder as used herein refers to a device capable of transferring broadcast signals and stored content to an output device, transferring broadcast signals to a storage device (e.g., hard drive), and retrieving the broadcast signals from the storage device. The terms video recorder, personal video recorder (PVR), and digital video recorder (DVR) are used herein interchangeably. Referring more specifically to the drawings, for illustrative purposes an embodiment of a video recorder is shown in the functional block diagram of
A video recorder 5 is an internal or external component of a set-top box 10. The video recorder 5 includes some or all of a combination of software, hardware, and firmware. In one embodiment, the video recorder 5 uses a storage device 6, such as a hard drive that is internal or external to the set-top box 10 where shows are saved. The set-top box 10 connects to an output device 20, which facilitates the use of broadcast signals, such as live television signals, video on demand broadcasts, downloads of Internet content, viewing of web pages, and viewing of content previously transferred to the storage device 6. In the example of
A GUI 7 that includes an IPG 8 is provided, which is displayed on the output device 20. GUI 7 in conjunction with IPG 8 allows the user to control the video recorder 5, typically using a remote control 60. For instance, the user may search the IPG 8 and select shows which are then scheduled to be transferred to storage device 6. The software or firmware that controls set-top box 10 may be installed locally or it may be downloaded from the Internet as needed when configuring new set-top boxes or when updating existing ones.
Set-top box 10 is connected to output device 20 via a transmission line 30. Broadcast signals are received by the set-top box 10 via broadcast input source 40, which may be connected to either an antenna, cable television outlet, or other suitable input source. One or more tuner systems 45 are configured to allow the system to utilize broadcast signals from multiple channels. The video recorder component 5 includes a storage device 6 in conjunction with a volatile memory 46, such as a Random Access Memory (RAM). Typically, the broadcast input received along line 40 is handled by the tuner 45. The signal is temporarily resident in memory 46 using a circular buffer or other cache before being transferred more or less permanently to storage device 6. The tuner system 45 works in conjunction with the storage device 6 so that for each tuner in the system, each can simultaneously transfer broadcast signals to the storage device 6, or display channels up to the given number of tuners on output device 20.
Set-top box 10 receives power through a line 50. Set-top box 10 receives user input entered from a handheld remote control 60 over a wireless link 70. Wireless link 70 may be an infrared (IR) link, a radio frequency (RF) link, or any other suitable type of link. A bi-directional data path 80 is provided to set-top box 10, through which set-top box 10 can access a network 90, either local, global, or both. Transmission line 40 may provide data from a variety of input sources including cable, satellite, or electro-magnetic waves.
In one embodiment of the present invention, the PVR uses multiple tuners. Each of the tuners is normally associated with one encoder and one cache, which may be a fixed or variable size cache (for a live signal) or a fixed file in the case where the incoming signal is merely transferred to the storage device 6.
An alternate configuration includes a video stream 240, which is then provided to tuner 245, which is then passed to encoder 250 and then to fixed file block 260. This configuration is useful for the analog transfer of a signal. For digital channels, encoder blocks 220 and 250 are removed, since the signal has already been digitized.
Each decoder shown in
If the user is watching a show that has already been transferred to the storage device, the decoder is decoupled from the encoder (i.e., it reads from a different cache than the encoder), which continues to encode and cache the live video signal. This embodiment is shown in
Finally, if a user is watching a show that resides already on the storage device while another show is currently being transferred to the storage device, two different fixed buffers are implemented. This embodiment of the present invention is shown in
According to one embodiment of the present invention, the set-top box displays a graphical user interface (GUI), which gives the user the ability to watch and/or record timeslot based programming, to order on-demand programming, and to playback previously recorded shows that reside on a local or remote storage device (including a connected set-top box in another room of the user's house, for instance). The search engine is typically implemented as software resident on memory internal to the set-top box, such as a hard drive or Random Access Memory. But the search engine may also be implemented in part as firmware or hardware. The search engine code may also reside on a remote memory, either in another set-top box connected in a network, a shared hard drive, or as an Internet download.
In one embodiment, the search engine is integrated into three separate types of databases. The first type of database comprises data relating to timeslot based programming, the second type of database comprises data related to on-demand programming, the third type of database comprises data related to previously recorded shows that are available to the set-top box in use. Each type of database may be a single database or multiple databases of the same type. Moreover, if several separate databases of the same type are used, they may reside on a single storage location or they may be networked across multiple storage locations. For simplicity, each type of database is referred to as a “database”, but it should be understood that, for instance, a timeslot based database includes typical timeslot based guide data, that is available to the user for free, and also timeslot based pay per view programming that incurs additional fees to the user which might reside in a different database physically.
In another embodiment, the search engine utilizes a common key that is used as the basis for a search of each of the three separate databases. The common key is used to query each database to find database entries that match the key. Such keys are then used to output a list of results that match the search from all three databases.
Search engine 910 is a component of application 900 includes common key field 920 where a search 930 is entered. Search 930 is used as data to search for entries in an appropriate field 940, 950, and 960 in databases 970, 980, and 990 that match common key field 920. Once the appropriate fields 940-960 are located in the databases, each row in the column relating to the appropriate fields 940-960 is searched to match an entry 995 and 996, for instance, with search 930. The search of
In one embodiment, the search engine utilizes such factors, for instance, as title, category (e.g., horror), time, actors, etc. In this embodiment, shown in
Each database includes, at least fields for title 1050-1052, category 1060-1062, time 1070-1072, and actor or actress 1080-1082. Each database 1040, 1042, and 1044 may have other fields as well, which are not shown for the purpose of simplicity. Entries 1090 and 1091 are used to query databases 1040, 1042, and 1044 in the appropriate database querying programming language. For instance, entries 1090 and 1091 might be “Hollywood Squares” and “10:00 AM”. In such a case, entries 1090 and 1091 are compared to the entries in each row of databases 1040, 1042, and 1044 along columns 1060-1062 and 1070-1072. Once entries matching the query in both rows 1098 and 1099 are obtained, the results 1095 can be output to the user for further selection.
The present invention can be used in a “linking” model or an “acting on” model. In the linking model, results that are chosen that are “on demand” or “pay-per-view” (i.e., timeslot based) cause a link to be invoked that send the user to a separate application that allows the user to get more information and/or begin a process of ordering and paying for the show.
At block 1230, it is determined if a timeslot based broadcast is found. If so, a link is provided that allows the user to tune to that broadcast at block 1240. After block 1240 or if no a timeslot based broadcast is found, it is determined if a timeslot based pay-per-view entry was found at block 1250. If so, the user is provided with a link to a page where the user can order the pay-per view program at block 1260. After block 1260 or if no timeslot based pay-per-view entry was found, then at block 1270, it is determined if an on-demand entry was found. If so, then at block 1280, a link is provided to a page where the user can purchase the on-demand programming. After block 1280 or if no on-demand entry was found, then at block 1290, it is determined if a show that has been saved on the local set-top box's hard drive or a connected hard drive is found. If so, a link is provided at block 1295 that allows the user to retrieve the saved show from the appropriate storage device. Otherwise the search was unsuccessful for saved shows at block 1299.
In the “acting on” model a single application controls the entire process of searching, purchasing, and watching, without linking to a separate application. The “acting on” model is illustrated in
The operation of one embodiment of a set-top box is shown in
As new signals are received, they eventually move to the head 1490 of the cache 1440. At that time, they are decoded at block 1460 and transferred as an output signal 1470 to an output device such as a television, for instance. The delay between the head 1490 and the tail 1480 is adjustable or can be completely eliminated to have a true “live television” experience. Variable delay cache 1440 is shown being a circular buffer, however, the actual locations in the storage device 1430 need not be contiguous or even reside on the same storage device. Instead, they can be in disparate locations on storage device 1430 and connected, for instance using pointers or other memory reference techniques, so that there is an ability to produce the data in a logical manner, but an actual contiguous space in storage device 1430 need not be reserved for the variable delay cache 1440. Moreover storage device 1430 can be used to represent the storage devices of multiple video recorder connected in a computer network arrangement.
As new signals are received, they eventually move to the head 1590 of the cache 1540. At that time, they are decoded at block 1560 and transferred as an output signal 1570 to an output device such as a television, for instance. The delay between the head 1590 and the tail 1580 is adjustable or can be completely eliminated to have a true “live television” experience. Variable delay cache 1540 in linked list form connects each frame by a pointer structure, wherein a first frame 1595 and a second frame 1596 in storage device 1530 appear to be logically located near each other, or contiguous in storage device 1530, but actually first frame 1595 and second frame 1596 may be located far apart on storage device 1530 and are logically linked by pointer reference 1597.
It should be noted that the search engine of the present invention can be configured to be utilized with any one or all three of the above database types. The search engine may be of multiple types according to the present invention. One type comprises a keyword type search, which has been used by way of example in
In one embodiment, the alpha-numeric interface area is modified after each selection by making invalid letters and numbers inaccessible to the user, for instance by making it appear opaque and un-selectable. This embodiment is shown in
When the user selects a letter or number, the system uses that letter or number to search one or more databases 1620. The one or more databases 1620 may be accessed, for instance, in the manner shown with respect to
The steps taken by a search engine according to an embodiment of the present invention are shown in
In one embodiment, the results of a successful search query are organized using categories. For instance, results may be obtained by creating folders of all shows where a certain actor or actress appears, where their name matches the selections by the user. Alternatively, matching shows may be listed by show title, show type, or other appropriate category. Identical instances of the same show that are aired at different times or on different channels may be displayed as a single folder on-screen which allows the user to open the folder to find the instance of the show most appropriate to them. Once a result is found by the user, they may view the show, find out more information about the show, record the show, or schedule the show to be recorded later.
The steps taken by a search engine according to one embodiment of the present invention is shown in
At block 1860, it is determined if the user has selected one of the results that are output to the screen using their input device. If so, a match is found, and a further action is performed by the user with respect to the show at block 1870. Such a further action includes, for instance, recording the show, scheduling the show to be recorded in the future, watching the show, or receiving additional information about the show. Otherwise, no match has been found yet, so at block 1880 the system waits for the user to input an additional character and the process repeats at block 1810.
The steps taken by a search engine according to another embodiment of the present invention are shown in
At block 1900 a character is received for searching. At block 1910 the database is searched for matching entries. At block 1920 it is determined if multiple instances of the same show are found. If so, a new category is created under the name of the show that has multiple instances at block 1930 and any subsequent shows to be output by the search engine are organized in the new category. After the category is created, or if no shows having multiple instances are found, the matching entries are displayed on the screen at block 1940.
At block 1950, it is determined if the user has selected one of the results that are output to the screen using their input device. If so, a match is found, and a further action is performed by the user with respect to the show at block 1960. Such a further action includes, for instance, recording the show, scheduling the show to be recorded in the future, watching the show, or receiving additional information about the show. Otherwise, no match has been found yet, so at block 1970 it is determined if the user selected one of the categories, if any, that are displayed on the screen. If so, the matching entries within the category are displayed at block 1980 and block 1950 repeats. Otherwise, no match has been found yet, so the system waits for the user to input an additional character at block 1990 and the process repeats at block 1910.
When the user selects a letter or number, the system uses that letter or number to search one or more databases 2020. The single letter or number search typically will elicit many results which are displayed in search results area 2008, if the number of results are below a certain threshold. For instance, results exceeding 100 might not be displayed and the system might wait until it has received a narrow enough search to display less than 100 results on the screen. In this example the character “S” was first input into keyword search field 2060. “S” retrieved too many results and nothing was displayed until the user input a second character “E” into field 2060, so that cursor 2080 was waiting for a third character to be input.
The search of databases 2020 with the character string “SE” brought up several different types of results. First, Categories 2030 and 2040 were created after matching the actor's name field in database 2020 to the “SE” character string representing Sean Connery and Sean Penn. Within categories 2030 and 2040 would be individual instances of movies where these actors appeared. Secondly, A category 2050 was created to hold several instances of the same show called “Sesame Street”. Within category 2050 would be a plurality of either times, days, or channels where the same show having the title “Sesame Street” occurs. Third, an entry 2070 was created for the pay-per-view movie “Seabiscuit”, which was obtained by searching a separate or integrated database shown as databases 2020. Output area 2008 could also include media-on-demand matches and matches to shows that are already saved in a storage medium, such as a hard disk of the current or an attached set-top box.
Tuners 2110 receive broadcast signals on transmission line 2160, which may originate from an antenna, a cable television outlet, a satellite connection, or another suitable broadcast input source. Processing and control circuitry 2100 provides audio and video output to device 2198 via a line 2170. Remote interface 2140 receives signals from remote control 60 via wireless connection 70. Communication device 2130 is used to transfer data between set-top box 10 and one or more remote processing systems, such as a server 2180, via a data path 2190. Server 2180 includes, for instance, a web server, or other set-top boxes connected in a network arrangement, where data from the web or resources from connected set-top boxes are available via data path 2190.
Processing and control circuitry 2100 may include one or more of devices such as general-purpose microprocessors, digital signal processors, application specific integrated circuits, various types of signal conditioning circuitry, including analog-to-digital converters, digital-to-analog converters, input/output buffers, etc. Storage device 2120 may include one or more physical memory devices, which may include volatile storage devices, non-volatile storage devices, or both. For example, storage device 2120 may include both random access memory (RAM), read-only memory (ROM), hard disk drives, various forms of programmable and/or erasable ROM, flash memory, or any combination of these devices.
Communication device 2130 may be a conventional telephone modem, an Integrated Services Digital Network adapter, a Digital Subscriber Line adapter, a cable television modem, or any other suitable data communication device. Instructions 2195 typically are resident in storage device 2120. Instructions 2195 control the overall functionality of the system, including the GUI, IPG, and the presentation of search engines. For instance, a search engine may be presented to a user and based on the search, instructions 2195 might tell set-top box 10 to use processing and control circuitry to search one or more databases in both storage device 2120 and along data path 2190. The results might, for instance, per instructions 2195, be retrieved, sorted, and presented to the user on output device 2198 as links, or they could be invoked directly, for instance, to cause output device 2198 to use tuners 2110 to tune to a specific channel.
It should be noted that for simplicity of use, the search engine of the present invention need not be presented to the user on an output device. Instead, the search engine may be in the background, and hence invisible to the user, yet still used to access results that the user selects. In this embodiment, a “theme view” is used to guide the background search engine in its task of obtaining results. The theme view presents a series of lists to the user that allows the user to narrow down the potential set of results, without inputting characters into a search engine prompt.
The theme view operates, for instance, by presenting a first broad list of themes (i.e., family, news, and sports). By selecting one of the choices, a sub-category list is presented (i.e., family 4 cartoons, sports 4 football, sports, 4 basketball). By narrowing down the potential results in this manner, the user avoids typing in keywords and narrows the pool of potential results for the search engine. Once the pre-defined lists have become as narrow as possible, the search engine still searches as shown in accordance with one or more embodiments of the invention and presents the results. This step of searching, however, is transparent to the user and occurs in the background instead of as a result of an affirmative action by the user.
Once the narrowest list is found, a background search engine is invoked at block 2250. At block 2260, the search engine searches a database of timeslot based programming for members of the narrowed list. At block 2270, the search engine searches a database of non-timeslot based programming for members of the narrowed list. At block 2280, the search engine searches a database relating to shows saved in the storage device (hard drive) of the current and any connected set-top boxes for members of the narrowed list. At block 2290, the user is presented with the results.
As discussed with other embodiments of the present invention, members of each list are determined by keywords that are stored in the databases associated with each entry that the user can search for. Hence, if the user had narrowed the list down to sports, football and this is the narrowest invocation of the list, then keywords of sports and football, which are potentially associated with each entry in all of the databases are searched for. When a show in any of the databases is found that has these associated characteristics, it becomes a member of the narrowed list and it is added to the list of results that the search engine will output to the user.
Although the description above contains many specificities, these should not be construed as limiting the scope of the invention but as merely providing illustrations of some of the presently preferred embodiments of this invention. Thus the scope of this invention should be determined by the appended claims and their legal equivalents.
This application is a continuation of prior U.S. patent application Ser. No. 15/810,579, filed Nov. 13, 2017, now pending, which is a continuation of prior U.S. patent application Ser. No. 15/274,390, filed Sep. 23, 2016, now U.S. Pat. No. 9,836,537, which is a continuation of prior U.S. patent application Ser. No. 14/925,513, filed Oct. 28, 2015, now U.S. Pat. No. 9,471,678, which is a continuation of prior U.S. patent application Ser. No. 14/857,384, filed Sep. 17, 2015, now abandoned, which is a continuation of U.S. patent application Ser. No. 14/244,268, filed on Apr. 3, 2014, now U.S. Pat. No. 9,152,720, which is a continuation of prior U.S. patent application Ser. No. 13/159,089, filed on Jun. 13, 2011, now U.S. Pat. No. 8,732,152, which is a continuation of prior U.S. patent application Ser. No. 10/905,489, filed on Jan. 6, 2005, now U.S. Pat. No. 7,974,962, all of which are hereby incorporated by reference herein in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
6005565 | Legall | Dec 1999 | A |
6711565 | Subramaniam | Mar 2004 | B1 |
7228556 | Beach | Jun 2007 | B2 |
7707245 | Lunenfeld | Apr 2010 | B2 |
7711813 | Yehuda | May 2010 | B1 |
20020042921 | Ellis | Apr 2002 | A1 |
20020091700 | Steele | Jul 2002 | A1 |
20020169656 | Al-Azzawe | Nov 2002 | A1 |
20030014758 | Kim | Jan 2003 | A1 |
20040002384 | Multerer | Jan 2004 | A1 |
20040068538 | Lunenfeld | Apr 2004 | A1 |
20040153456 | Charnock | Aug 2004 | A1 |
20040268250 | Danker | Dec 2004 | A1 |
20050050022 | Dukes | Mar 2005 | A1 |
20050076012 | Manber | Apr 2005 | A1 |
20050172007 | Avrahami | Aug 2005 | A1 |
20060026641 | Jule | Feb 2006 | A1 |
20060026647 | Potrebic | Feb 2006 | A1 |
20070240187 | Beach | Oct 2007 | A1 |
20090171950 | Lunenfeld | Jul 2009 | A1 |
Number | Date | Country | |
---|---|---|---|
20200151215 A1 | May 2020 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15810579 | Nov 2017 | US |
Child | 16577041 | US | |
Parent | 15274390 | Sep 2016 | US |
Child | 15810579 | US | |
Parent | 14925513 | Oct 2015 | US |
Child | 15274390 | US | |
Parent | 14857384 | Sep 2015 | US |
Child | 14925513 | US | |
Parent | 14244268 | Apr 2014 | US |
Child | 14857384 | US | |
Parent | 13159089 | Jun 2011 | US |
Child | 14244268 | US | |
Parent | 10905489 | Jan 2005 | US |
Child | 13159089 | US |