The media industry has many avenues for providing users with entertainment sources, through television, film, gaming, etc. As the number of available broadcast channels, IPTV (Internet Protocol television) sources, recorded programs, on-demand videos, and on-demand games grow in number, users face the daunting task of trying to find programs of interest. Locating an item of interest among the thousands of items of content, in a television environment, poses a major challenge in that time spent searching undercuts the objective of providing the user with more variety. Reduction or streamlining of content is unacceptable, particularly in light of the competitive landscape of media delivery. However, the user's task of selecting desired content becomes more onerous as the number and variety of content continues to increase. For instance, content from IP sources can be made available to television (TV) systems; the global Internet is replete with user generated video streams, web casts, etc. Undoubtedly, the user interface must keep pace with the explosion of content.
Common methods of locating content include text search and category browsing. Text search can accurately find content, but is slow and cumbersome with the current generation of remote control technologies. Category hierarchies, such as those employed in many current video-on-demand (VOD) systems, are slow and often result in empty or non-interesting sets of results. This causes users to “bob” through the groupings: traversing deep into one area of the hierarchy, coming back up, traversing down yet another area. It is noted that users often trying to find a branch they had viewed previously before finally choosing a program. This laborious process can easily discourage a user from selecting content all together; in a pay-per-view scenario, this results in loss of revenue for the service providers.
Therefore, there is a need for efficiently browsing through content listings.
Various exemplary embodiments are illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings in which like reference numerals refer to similar elements and in which:
In apparatus, method, and software for attribute browsing of video assets are described. In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the various exemplary embodiments. It is apparent, however, to one skilled in the art that the various exemplary embodiments may be practiced without these specific details or with an equivalent arrangement. In other instances, well-known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the exemplary embodiments.
Although the various embodiments of the present invention are described with respect to video assets, it is contemplated that these embodiments have applicability to other media.
The service provider system 101, in an exemplary embodiment, utilizes an asset parser 113 to parse the metadata files of the assets. The metadata can be in form of an extensible Markup Language (XML) file, for example. The parser 113 categorizes attributes of the assets for storage in an asset database 115. This database 115 is accessible via an asset attribute server 117. Additionally, the asset database 115 is administered by an asset administrator 119.
At the subscriber site 103, a user 121 can utilize a remote controller 123 to interface a set-top box 125 to select the asset (e.g., programming) for viewing by a display 127. The remote controller 123 can employ infrared, radio frequency (RE) signals, or other wireless links (e.g., BLUETOOTH) to communicate with the set-top box 125. Additionally, it is contemplated any type of input interface can be used; e.g., a keypad on the set-top box 125, a game controller, a keyboard that is separate from the set-top box 125, mouse, etc. The user can navigate a large amount of content through an “attribute browsing” capability to find a specific asset. The system 100, in an exemplary embodiment, applies “faceted browsing” techniques to the meta-data provided with the types of assets. This browsing capability, in certain embodiments, can be implemented as part of an interactive program guide (IPG), or other applications.
“Faceted browsing” addresses the shortcomings of the conventional text search and category browse methods. Faceted browsing refers to a method of searching through a set of objects based on attributes of those objects (e.g., name, color, weight, size, etc.), and using those attributes to refine the scope of the objects that are shown. As an illustration of this concept, the selection of fruits and vegetables is described. One could first select only items that are green, and further from the resulting set, select only items weighing more than a certain weight, e.g., 7 pounds. Accordingly, finding a watermelon in the remaining set would be much simpler than finding watermelon from all fruits and vegetables.
It is recognized that in the environment of the subscriber site 103, simplicity of the interface for the “television with remote control” environment is important in consumers' willingness to subscribe to more and more content. Accordingly, the system 100 uses, in an exemplary embodiment, the attributes describing the available assets to enable the viewer to compose complex searches in a step-wise fashion, with a presentation of possible attributes and matching video assets at each step of the process. This type of search process would not frustrate the viewer in that return of null set of matches is avoided. This search process has the added advantage of being well-suited to the television user-interface with its “highlight and click” paradigm. This browsing technique is supported through manipulation of the metadata (or attributes), as explained in
As seen in
The above arrangement enables users to quickly browse large sets of assets, and to narrow the collection of assets based on metadata types of interest to the user.
As mentioned, the metadata 109 can be in form of an XML file, according to an exemplary embodiment. For instance, Tables 1 and 2 show exemplary XML files, which the asset parser 113 can process.
The above XML files can be formulated in a download video asset file, as shown in
The asset parser 119 parses the XML files to obtain a database of video assets and the attributes associated with each one. For example, attributes such as “Content_Filesize” are ignored; and synonyms are substituted where appropriate, such as “Free” in place of “Suggested_Price 0.00.” Also, differences in naming conventions are properly handled, such as “Action,Tom” in the video-on-demand files and FirstName=“Tom” MiddleName=“ ” LastName=“Action” in the broadcast television file.
In turn, the set-top box 107, per step 507, retrieves content information (e.g., list of titles) from the asset database 115 corresponding to the selected attribute and displays the retrieved list of titles. From this new list of titles, a new list of attributes is generated—e.g., the attributes of all the titles in the new list, sorted by frequency. At this point, the user 121 can further narrow the listings by selection of other attributes. The user can further refine the list of titles by clicking another item in the list of attributes, or expand the list of titles by removing one of the attributes in the current filter set. Each chosen attribute becomes a filter term, logically “AND-ed” together to refine the list of titles (and the associated list of attributes of those titles). A “back” function can be added to “undo” an added search term (attribute). In this way a user can quickly narrow a long list of titles using any attributes of interest. Further, because each successive list of attributes is derived from the just-narrowed list of titles, clicking any attribute at any step along the navigation path will return at least one title.
To further illustrate faceted browsing, if in the initial list the user 121 clicked on the attribute “PG,” the list of all titles would be replaced by only those titles having as one of their attributes an MPAA rating of “PG.” Additionally, the list of attributes would be replaced by a list of all the attributes of this reduced set of PG titles (e.g., ordered by frequency). The selection of an attribute, for example, could specify a maximum or minimum value. Using this example, selecting PG may result in a result set that contains everything PG or less, including G and TV-Y, etc.
Moreover, some of these “PG” titles can be tagged as a “Comedy” in their XML files, such that “Comedy” would appear in this new attribute list. If the user clicks “Comedy” in this attribute list, then the list of all titles would be replaced by only those titles having both attributes “PG” and “Comedy.” The attribute list would be replaced by a list of all the remaining attributes of this new set of titles.
It is noted that these “PG comedies” can be tagged as High-Definition (HD) in their XML files, so “High-Definition” would appear in the new attribute list. By clicking “High-Definition” the user will receive a list of “PG comedies in High-Definition”, etc.
At some point during the browsing process, the list of titles will be narrowed to a usable or workable number of entries. In step 509, the user 121 can highlight a selection using the remote control device 123 and “clicks” on the title. In step 511, the set-top box requests the selected asset. Alternatively, by selecting an item in the title list, the user 121 can be directed to other options, such as watching a preview, paying for viewing rights (for video-on-demand content), setting the DVR to record (for broadcast), etc.
This searching capability (i.e., attribute browsing) permits finding niche content more quickly than the traditional text search method.
The above described processes relating to faceted browsing may be implemented via software, hardware (e.g., general processor, Digital Signal Processing (DSP) chip, an Application Specific Integrated Circuit (ASIC), Field Programmable Gate Arrays (FPGAs), etc.), firmware or a combination thereof. Such exemplary hardware for performing the described functions is detailed below.
The computer system 600 may be coupled via the bus 601 to a display 611, such as a cathode ray tube (CRT), liquid crystal display, active matrix display, or plasma display, for displaying information to a computer user. A TV interface 612 can optionally be provided to output to a television set. An input device 613, such as a keyboard including alphanumeric and other keys, is coupled to the bus 601 for communicating information and command selections to the processor 603. Another type of user input device is a cursor control 615, such as a mouse, a trackball, or cursor direction keys, for communicating direction information and command selections to the processor 603 and for controlling cursor movement on the display 611.
According to one embodiment of the invention, the processes described herein are performed by the computer system 600, in response to the processor 603 executing an arrangement of instructions contained in main memory 605. Such instructions can be read into main memory 605 from another computer-readable medium, such as the storage device 609. Execution of the arrangement of instructions contained in main memory 605 causes the processor 603 to perform the process steps described herein. One or more processors in a multi-processing arrangement may also be employed to execute the instructions contained in main memory 605. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions to implement the exemplary embodiment. Thus, exemplary embodiments are not limited to any specific combination of hardware circuitry and software.
The computer system 600 also includes a communication interface 617 coupled to bus 601. The communication interface 617 provides a two-way data communication coupling to a network link 619 connected to a local network 621. For example, the communication interface 617 may be a digital subscriber line (DSL) card or modem, an integrated services digital network (ISDN) card, a cable modem, a telephone modem, or any other communication interface to provide a data communication connection to a corresponding type of communication line. As another example, communication interface 617 may be a local area network (LAN) card (e.g. for Ethernet™ or an Asynchronous Transfer Model (ATM) network) to provide a data communication connection to a compatible LAN. Wireless links can also be implemented. In any such implementation, communication interface 617 sends and receives electrical, electromagnetic, or optical signals that carry digital data streams representing various types of information. Further, the communication interface 617 can include peripheral interface devices, such as a Universal Serial Bus (USB) interface, a PCMCIA (Personal Computer Memory Card International Association) interface, etc. Although a single communication interface 617 is depicted in
The network link 619 typically provides data communication through one or more networks to other data devices. For example, the network link 619 may provide a connection through local network 621 to a host computer 623, which has connectivity to a network 625 (e.g. a wide area network (WAN) or the global packet data communication network now commonly referred to as the “Internet”) or to data equipment operated by a service provider. The local network 621 and the network 625 both use electrical, electromagnetic, or optical signals to convey information and instructions. The signals through the various networks and the signals on the network link 619 and through the communication interface 617, which communicate digital data with the computer system 600, are exemplary forms of carrier waves bearing the information and instructions.
The computer system 600 can send messages and receive data, including program code, through the network(s), the network link 619, and the communication interface 617. In the Internet example, a server (not shown) might transmit requested code belonging to an application program for implementing an exemplary embodiment through the network 625, the local network 621 and the communication interface 617. The processor 603 may execute the transmitted code while being received and/or store the code in the storage device 609, or other non-volatile storage for later execution. In this manner, the computer system 600 may obtain application code in the form of a carrier wave.
The term “computer-readable medium” as used herein refers to any medium that participates in providing instructions to the processor 603 for execution. Such a medium may take many forms, including but not limited to non-volatile media, volatile media, and transmission media. Non-volatile media include, for example, optical or magnetic disks, such as the storage device 609. Volatile media include dynamic memory, such as main memory 605. Transmission media include coaxial cables, copper wire and fiber optics, including the wires that comprise the bus 601. Transmission media can also take the form of acoustic, optical, or electromagnetic waves, such as those generated during radio frequency (RF) and infrared (IR) data communications. Common forms of computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, any other magnetic medium, a CD-ROM, CDRW, DVD, any other optical medium, punch cards, paper tape, optical mark sheets, any other physical medium with patterns of holes or other optically recognizable indicia, a RAM, a PROM, and EPROM, a FLASH-EPROM, any other memory chip or cartridge, a carrier wave, or any other medium from which a computer can read.
Various forms of computer-readable media may be involved in providing instructions to a processor for execution. For example, the instructions for carrying out at least part of the various exemplary embodiments may initially be borne on a magnetic disk of a remote computer. In such a scenario, the remote computer loads the instructions into main memory and sends the instructions over a telephone line using a modem. A modem of a local computer system receives the data on the telephone line and uses an infrared transmitter to convert the data to an infrared signal and transmit the infrared signal to a portable computing device, such as a personal digital assistant (PDA) or a laptop. An infrared detector on the portable computing device receives the information and instructions borne by the infrared signal and places the data on a bus. The bus conveys the data to main memory, from which a processor retrieves and executes the instructions. The instructions received by main memory can optionally be stored on storage device either before or after execution by processor.
In the preceding specification, various preferred embodiments have been described with reference to the accompanying drawings. It will, however, be evident that various modifications and changes may be made thereto, and additional embodiments may be implemented, without departing from the broader scope of the invention as set forth in the claims that flow. The specification and the drawings are accordingly to be regarded in an illustrative rather than restrictive sense.
Number | Name | Date | Kind |
---|---|---|---|
4977455 | Young | Dec 1990 | A |
5151789 | Young | Sep 1992 | A |
5253066 | Vogel | Oct 1993 | A |
5307173 | Yuen et al. | Apr 1994 | A |
5335079 | Yuen et al. | Aug 1994 | A |
5353121 | Young et al. | Oct 1994 | A |
5382983 | Kwoh et al. | Jan 1995 | A |
5479266 | Young et al. | Dec 1995 | A |
5479268 | Young et al. | Dec 1995 | A |
5499103 | Mankovitz | Mar 1996 | A |
5512963 | Mankovitz | Apr 1996 | A |
5515173 | Mankovitz et al. | May 1996 | A |
5532732 | Yuen et al. | Jul 1996 | A |
5532754 | Young et al. | Jul 1996 | A |
5541738 | Mankovitz | Jul 1996 | A |
5550576 | Klosterman | Aug 1996 | A |
5553123 | Chan et al. | Sep 1996 | A |
5559550 | Mankovitz | Sep 1996 | A |
5600711 | Yuen | Feb 1997 | A |
5619274 | Roop et al. | Apr 1997 | A |
5640484 | Mankovitz | Jun 1997 | A |
5684525 | Klosterman | Nov 1997 | A |
5701383 | Russo et al. | Dec 1997 | A |
5706145 | Hindman et al. | Jan 1998 | A |
5727060 | Young | Mar 1998 | A |
5734786 | Mankovitz | Mar 1998 | A |
5784061 | Moran et al. | Jul 1998 | A |
5790198 | Roop et al. | Aug 1998 | A |
5801787 | Schein et al. | Sep 1998 | A |
5802361 | Wang et al. | Sep 1998 | A |
5808608 | Young et al. | Sep 1998 | A |
5809204 | Young et al. | Sep 1998 | A |
5812123 | Rowe et al. | Sep 1998 | A |
5812205 | Milnes et al. | Sep 1998 | A |
5828945 | Klosterman | Oct 1998 | A |
5870150 | Yuen | Feb 1999 | A |
5886746 | Yuen et al. | Mar 1999 | A |
5915026 | Mankovitz | Jun 1999 | A |
5923362 | Klosterman | Jul 1999 | A |
5940073 | Klosterman et al. | Aug 1999 | A |
5949954 | Young et al. | Sep 1999 | A |
5959688 | Schein et al. | Sep 1999 | A |
5969748 | Casement et al. | Oct 1999 | A |
5970206 | Yuen et al. | Oct 1999 | A |
5974222 | Yuen et al. | Oct 1999 | A |
5987213 | Mankovitz et al. | Nov 1999 | A |
5988078 | Levine | Nov 1999 | A |
5991498 | Young | Nov 1999 | A |
6002394 | Schein et al. | Dec 1999 | A |
6016141 | Knudson et al. | Jan 2000 | A |
6028599 | Yuen et al. | Feb 2000 | A |
6049652 | Yuen et al. | Apr 2000 | A |
6052145 | Macrae et al. | Apr 2000 | A |
6072983 | Klosterman | Jun 2000 | A |
6075551 | Berezowski et al. | Jun 2000 | A |
6075575 | Schein et al. | Jun 2000 | A |
6078348 | Klosterman et al. | Jun 2000 | A |
6091882 | Yuen et al. | Jul 2000 | A |
6118492 | Milnes et al. | Sep 2000 | A |
6133909 | Schein et al. | Oct 2000 | A |
6137950 | Yuen | Oct 2000 | A |
6144401 | Casement et al. | Nov 2000 | A |
6151059 | Schein et al. | Nov 2000 | A |
6167188 | Young et al. | Dec 2000 | A |
6177931 | Alexander et al. | Jan 2001 | B1 |
6216265 | Roop et al. | Apr 2001 | B1 |
6239794 | Yuen et al. | May 2001 | B1 |
6247176 | Schein et al. | Jun 2001 | B1 |
6262722 | Allison et al. | Jul 2001 | B1 |
6263501 | Schein et al. | Jul 2001 | B1 |
6323911 | Schein et al. | Nov 2001 | B1 |
6341195 | Mankovitz et al. | Jan 2002 | B1 |
6341374 | Schein et al. | Jan 2002 | B2 |
6388714 | Schein et al. | May 2002 | B1 |
6396546 | Alten et al. | May 2002 | B1 |
6412110 | Schein et al. | Jun 2002 | B1 |
6430358 | Yuen et al. | Aug 2002 | B1 |
6430359 | Yuen et al. | Aug 2002 | B1 |
6453471 | Klosterman | Sep 2002 | B1 |
6460181 | Donnelly | Oct 2002 | B1 |
6466734 | Yuen et al. | Oct 2002 | B2 |
6469753 | Klosterman et al. | Oct 2002 | B1 |
6477705 | Yuen et al. | Nov 2002 | B1 |
6498895 | Young et al. | Dec 2002 | B2 |
6505348 | Knowles et al. | Jan 2003 | B1 |
6538701 | Yuen | Mar 2003 | B1 |
6549719 | Mankovitz | Apr 2003 | B2 |
6564379 | Knudson et al. | May 2003 | B1 |
6567606 | Milnes et al. | May 2003 | B2 |
6588013 | Lumley et al. | Jul 2003 | B1 |
6668133 | Yuen et al. | Dec 2003 | B2 |
6687906 | Yuen et al. | Feb 2004 | B1 |
6732369 | Schein et al. | May 2004 | B1 |
6742183 | Reynolds et al. | May 2004 | B1 |
6745391 | Macrae et al. | Jun 2004 | B1 |
6756997 | Ward et al. | Jun 2004 | B1 |
6760537 | Mankovitz | Jul 2004 | B2 |
6799326 | Boylan et al. | Sep 2004 | B2 |
6799327 | Reynolds et al. | Sep 2004 | B1 |
6842761 | Diamond et al. | Jan 2005 | B2 |
6850693 | Young et al. | Feb 2005 | B2 |
6859799 | Yuen | Feb 2005 | B1 |
6956573 | Bergen et al. | Oct 2005 | B1 |
7039935 | Knudson et al. | May 2006 | B2 |
7069576 | Knudson et al. | Jun 2006 | B1 |
7487529 | Orlick | Feb 2009 | B1 |
20010029610 | Corvin et al. | Oct 2001 | A1 |
20010047298 | Moore et al. | Nov 2001 | A1 |
20010054181 | Corvin | Dec 2001 | A1 |
20020073424 | Ward et al. | Jun 2002 | A1 |
20020124255 | Reichardt et al. | Sep 2002 | A1 |
20030005445 | Schein et al. | Jan 2003 | A1 |
20030056219 | Reichardt et al. | Mar 2003 | A1 |
20030110495 | Bennington et al. | Jun 2003 | A1 |
20030110499 | Knudson et al. | Jun 2003 | A1 |
20030115599 | Bennington et al. | Jun 2003 | A1 |
20030115602 | Knee et al. | Jun 2003 | A1 |
20030163813 | Klosterman et al. | Aug 2003 | A1 |
20030164858 | Klosterman et al. | Sep 2003 | A1 |
20030188310 | Klosterman et al. | Oct 2003 | A1 |
20030188311 | Yuen et al. | Oct 2003 | A1 |
20030196201 | Schein et al. | Oct 2003 | A1 |
20030204847 | Ellis et al. | Oct 2003 | A1 |
20030208756 | Macrae et al. | Nov 2003 | A1 |
20040010806 | Yuen et al. | Jan 2004 | A1 |
20040045025 | Ward et al. | Mar 2004 | A1 |
20040088208 | Runge et al. | May 2004 | A1 |
20040107437 | Reichardt et al. | Jun 2004 | A1 |
20040143604 | Glenner et al. | Jul 2004 | A1 |
20040168189 | Reynolds et al. | Aug 2004 | A1 |
20040194138 | Boylan et al. | Sep 2004 | A1 |
20040194140 | Rao et al. | Sep 2004 | A1 |
20040210936 | Rao et al. | Oct 2004 | A1 |
20040254950 | Musgrove et al. | Dec 2004 | A1 |
20040261098 | Macrae et al. | Dec 2004 | A1 |
20050010949 | Ward et al. | Jan 2005 | A1 |
20050028201 | Klosterman et al. | Feb 2005 | A1 |
20050114794 | Grimes et al. | May 2005 | A1 |
20050125823 | McCoy et al. | Jun 2005 | A1 |
20050149964 | Thomas et al. | Jul 2005 | A1 |
20050155056 | Knee et al. | Jul 2005 | A1 |
20050160458 | Baumgartner | Jul 2005 | A1 |
20050216936 | Knudson et al. | Sep 2005 | A1 |
20050228806 | Haberman | Oct 2005 | A1 |
20050251824 | Thomas et al. | Nov 2005 | A1 |
20050289593 | Spilo | Dec 2005 | A1 |
20060031916 | Colter et al. | Feb 2006 | A1 |
20060156336 | Knudson et al. | Jul 2006 | A1 |
20060212894 | Knudson et al. | Sep 2006 | A1 |
20060277574 | Schein et al. | Dec 2006 | A1 |
20060288366 | Boylan et al. | Dec 2006 | A1 |
20070011702 | Vaysman | Jan 2007 | A1 |
20070016926 | Ward et al. | Jan 2007 | A1 |
20070033613 | Ward et al. | Feb 2007 | A1 |
20070107010 | Jolna et al. | May 2007 | A1 |
Number | Date | Country | |
---|---|---|---|
20080163328 A1 | Jul 2008 | US |