The systems and methods described herein relate to managing metadata associated with content, such as program content.
A client device in a television-based system can receive data, such as video data and audio data from a program distributor in the form of broadcast programs, such as news programs, sitcoms, movies, sporting events, commercials, and any other type of television-based information. Video data and audio data may also be referred to as video content and audio content, respectively. A client device includes, for example, a set-top box, a digital satellite receiver, a cable box, a digital video recorder (DVR), and a television with a built-in receiver.
Various program data is available to identify programs scheduled to be broadcast to viewers. This program data can be referred to as “metadata”. The metadata associated with one or more programs may include information displayed in a program guide such as program title, channel, and time of broadcast. Metadata is typically associated with programs that will be broadcast at a future time, such as programs scheduled to be broadcast during an upcoming week. Programs that have already been broadcast may be recorded on a DVR or other device. Metadata associated with these recorded programs may also be recorded on the same DVR or other device. This recorded metadata is accurate as of the time the broadcast of the associated program began. Often, this metadata is incorrect or incomplete. For example, the duration of a program may be different than the scheduled information due to the program being preempted or running longer than expected.
When a user searches through numerous stored programs, metadata is useful in locating programs of interest to the user. Using metadata that is not accurate or complete may prevent the user from finding a desired program or may identify programs that are not of interest to the user due to the inaccurate or incomplete metadata used in the search. Thus, the use of inaccurate or incomplete metadata can result in a frustrating and undesirable user experience.
The systems and methods described herein manage metadata associated with various content. In a particular embodiment, a video program is recorded along with metadata associated with the video program. Upon receiving updated metadata associated with the video program, the previously recorded metadata is replaced with the updated metadata.
Similar reference numbers are used throughout the figures to reference like components and/or features.
The systems and methods described herein manage metadata associated with various content, such as television programs, video-on-demand (VOD), and advertisements. These systems and methods maintain timestamps associated with various metadata to enable metadata to be updated or refreshed after it has been delivered. A version number or other identifier may be used in place of a timestamp to differentiate different between metadata. For example, when a client device accesses a content server or other device, the content server delivers updated metadata to the client device. Similarly, a data provider can provide updated metadata to a server—the metadata being associated with content stored by the server or accessible to the server. This updated metadata can correct inaccuracies or incomplete data in previous versions of the metadata, thereby improving the results of a user's search for programs of interest.
Television broadcasting systems (such as cable TV broadcasters or satellite broadcasters) originate and communicate signals to customers from a headend (or “head-end”). The headend contains equipment to broadcast signals and provide other services to multiple customers. A headend interacts with the client devices to provide content that is appropriate for the client device based on the settings, preferences and account information associated with the client device. The content may be provided to the client devices using any communication method, any communication protocol, and any communication medium.
The systems and methods discussed herein are described with reference to an environment in which content (and metadata associated with the content) is distributed to client devices via a data communication network, such as the Internet. These examples represent one possible environment in which the systems and methods can be implemented. In other embodiments, any type of system or architecture can be used to provide content to one or more client devices. The content distributed to client devices can be any type of data, such as television programs, video-on-demand, advertisements, program data, metadata, and the like. Metadata may be any data related to any type of content. Metadata examples include a program title, broadcast date and time, program rating, program duration, program description, program commentary, program awards, and the like.
Client devices of the type discussed herein range from clients with substantial memory and processing resources, such as television-enabled personal computers and television recorders equipped with hard-disks, to clients with little or no memory and/or limited processing resources. Although particular examples of client devices are discussed herein, any client device can be used with the systems and methods described. Example client devices include personal computers, DVD players, digital video recorders (DVRs), set top boxes, cable boxes, satellite receivers, televisions, game consoles, and the like. As used herein, the term “user” may also be referred to as “viewer”.
Although particular examples discussed herein are related to the broadcast of video content such as television programs, the systems and methods described herein can be applied to any type of content. Other types of content include radio broadcasts, streamed audio and/or video data, an XML stream of stock price data that can be converted to an on-screen ticker, and the like. Additionally, an application that runs on a server and displays information on a client device coupled to the server may use metadata to describe services offered by the application. For example, initial metadata associated with audio data may identify the audio data as a three hour block of “classical music”. Subsequent metadata information may enhance the description to include, for example, the composer, the symphony performing the music, and the historical significance of the music.
In a particular embodiment, client devices 102 communicate with one or more servers via network 104 using simple object access protocol (SOAP) messages transported using hypertext transfer protocol (http), a protocol commonly used by the World Wide Web. In other embodiments, any type of protocol and/or messaging format can be used to exchange data between client devices 102 and one or more servers.
Although not shown in
In the example of
A receiver 110 is coupled to content server 112 and storage device 114. Receiver 110 receives broadcast content, program guide content, and other data from a variety of sources. For example, receiver 110 can receive broadcast content from a content broadcaster 106 via a cable network, radio frequency signals, over-the-air broadcast, satellite communication systems, or any other communication medium. Although one content broadcaster 106 is shown in
A data provider 116 is coupled to content server 112 and to network 104. Data provider 116 provides metadata associated with any number of previously broadcast programs. Data provider 116 may also provide program guide information regarding upcoming programs scheduled to be broadcast (similar to program guide data provider 108). Any number of different data providers 116 may be coupled to content server 112. Various other servers (not shown) may be coupled to content server 112 and/or network 104 to communicate with content server 112 and/or client devices 102.
Traditional television broadcasting systems (such as cable TV broadcasters, over the air broadcasters, or satellite broadcasters) originate and communicate signals to customers from a headend. In the architecture of
Program guide application 208 executes on processor(s) 206 and can be stored as computer-executable instructions in non-volatile memory (not shown) or client device 202. Program guide application 208 generates a recorded program guide 212 that can be displayed on display device 204. For example, recorded program guide 212 may be displayed in the on-screen display (OSD) layer generated by client device 202. Alternatively, recorded program guide 212 can be displayed in another layer generated by client device 202, such as the video layer. Although program guide application 208 is illustrated and described herein as a single application configured to generate recorded program guide 212, program guide application 208 can be implemented as multiple component applications distributed such that each performs one or more functions.
Recorded program guide 212 allows a viewer to see what programs have been recorded by client device 202 and/or other devices, and are available for viewing. In one embodiment, recorded program guide 212 operates in an interactive mode in which the information displayed in recorded program guide 212 is manipulated by pressing control buttons (e.g., arrow buttons) on a remote control device or other input device. Alternatively, program guide application 208 may generate a program guide that identifies programs that are scheduled to be broadcast on particular channels at particular times.
In the example of
The requested program is recorded at the appropriate time (block 304). If the record time is in the future, the device automatically tunes to the appropriate channel and begin recording at the designated time. The program may be recorded by the client device, such as a DVR or a VCR. Metadata associated with the recorded program is also recorded (block 306) by the client device or other recording device. Alternatively, the program and/or the metadata associated with the program may be recorded on a separate device coupled to the client device via a communication link, such as a network communication link.
After recording of the program is complete, procedure 300 identifies program details associated with the recorded program (block 308). For example, the procedure may retrieve metadata associated with the recorded program from a content server, a data provider, or other data source. Alternatively, the procedure may identify program details (such as the actual duration of the recorded program) based on the recorded program itself or based on information received along with the program content. At block 310, the procedure determines whether the program details identified after the program is complete differ from the metadata previously recorded in block 306. If so, procedure 300 updates the previously recorded metadata with the new metadata identified after recording of the program is complete (block 312).
In a particular embodiment, the metadata associated with the recorded program is stored on the same device as the recorded program. In other embodiments, the metadata associated with the recorded program is stored on a separate device, such as a separate storage device or a separate client device.
In one embodiment, program content and associated metadata is stored on a DVR. When recording certain programs, such as sporting events, that may have a variable program length, the DVR typically records for a period of time that exceeds the scheduled program length. For example, if a football game is scheduled for three hours, the DVR may record an additional hour (four hours total) to be sure the entire game is recorded if the length of the game exceeds three hours. However, if the game duration is less than four hours, unwanted content is stored on the DVR, which uses valuable storage space. In this situation, the updated metadata may indicate the exact length (e.g., duration in hours, minutes, and/or seconds) of the game. The DVR can then delete any content recorded after the game ended, thereby releasing storage space for other program content.
If updated metadata is available for one or more of the recorded programs (block 408), the client device retrieves the updated metadata associated with the I recorded programs (block 410). The client device then displays the recorded programs using the metadata associated with the recorded programs (block 412). Updated metadata may include revised information regarding a program, such as a revised program length (shorter or longer than originally scheduled) or an updated is program rating (e.g., from TV-14 to TV-M, or from previously unrated to TV-Y). Updated metadata may also include additional data regarding a program, such as the results of a sporting event, awards received after the program is broadcast, and the like. The display of recorded programs may be similar to the listing of recorded programs shown in
A client device and/or a content server may purchase updated metadata related to one or more programs (or categories of programs), or may subscribe to a metadata update service that provides updated metadata on a regular basis. In one embodiment, a client device accesses a content server periodically (e.g., daily) to receive updated metadata. Similarly, the content server can periodically access a data provider to receive updated metadata. In other embodiments, a client device automatically receives metadata updates from the content server. Similarly the content server can automatically receive metadata updates from the data provider.
In the example of
The procedure continues by generating a listing of programs available for viewing using the metadata associated with the programs (block 908). Finally, the generated listing of programs available for viewing is provided to the requesting device (block 910). This listing of programs may include some or all of the metadata associated with the programs. For example, a summary of the program may be displayed, but there may be insufficient space to display an entire commentary. In this example, a viewer could activate a “Full Commentary” button included in the available program guide to display the entire commentary associated with a particular program.
In the example of
Metadata 1204 includes additional information and updated information as compared to metadata 1202. For example, the program was a basketball game that had two overtime sessions, which caused the program to run longer than scheduled. Metadata 1204 correctly identifies the length of the program as 2 hours 35 minutes whereas metadata 1202 identifies the scheduled length of 2 hours. Additional information regarding the game is included in metadata 1204, such as the game being a double overtime game, the winner of the game, a player setting a new scoring record, as well as other highlights and comments that are available after the game is finished. Metadata 1204 may be further updated at a future time to include additional information regarding the program, such as having the program added to a “100 best games of 2004” list or adding further comments or reviews of the program that are released at a later time.
Metadata 1202 and 1204 represent examples of the types of metadata that may be associated with a program. In other embodiments, any type of data can be associated with a particular program. Further, metadata can be updated and/or revised at any time prior to the broadcast of the program, during the broadcast of the program, or after the broadcast of the program.
Client device 1302 includes one or more tuners 1306 which are representative of one or more in-band tuners that tune to various frequencies or channels to receive television signals, as well as an out-of-band tuner that tunes to the broadcast channel over which program data is broadcast to client device 1302. Tuners 1306 may include hardware-based tuners and/or digital tuners capable of “tuning” or identifying IP-based digital streams of data. IP-based digital streams serve a similar function as tuners, but are used in an IP environment for the delivery of content (e.g., the unicast delivery of content). Client device 1302 also includes one or more processors 1308 (e.g., any of microprocessors, controllers, and the like) which process various instructions to control the operation of client device 1302 and to communicate with other electronic and computing devices.
Client device 1302 can be implemented with one or more memory components, examples of which include a random access memory (RAM) 1310, mass storage media 1312, a disk drive 1314, and a non-volatile memory 1316 (e.g., ROM, Flash, EPROM, EEPROM, etc.). Disk drive 1314 can include any type of magnetic or optical storage device, such as a hard disk drive, a magnetic tape, a rewriteable compact disc, a DVD, and the like. The one or more memory components store various information and/or data such as received content, program metadata 1318, recorded programs 1320, configuration information for client device 1302, and/or graphical user interface information. Alternative implementations of client device 1302 can include a range of processing and memory capabilities, and may include any number of differing memory components than those illustrated in
An operating system 1322 and one or more application programs 1324 can be stored in non-volatile memory 1316 and executed on processor(s) 1308 to provide a runtime environment. A runtime environment facilitates extensibility of client device 1302 by allowing various interfaces to be defined that, in turn, allow application programs 1324 to interact with client device 1302. The application programs 1324 can include a browser to browse the Web (e.g., “World Wide Web”), an email program to facilitate electronic mail, a program to display and search for available programs and video-on-demand content, and any number of other application programs.
A program guide application 1326 that executes on processor(s) 1308 is also stored in non-volatile memory 1316 and is implemented to generate a program guide for display. Using program guide application 1326, the viewer can look at schedules of current and future programming, set reminders for upcoming programs, and/or enter instructions to record one or more programs.
Client device 1302 further includes one or more communication interfaces 1328 and a PSTN, DSL, cable, or other type of modem 1330. A communication interface 1328 can be implemented as a serial and/or parallel interface, as a wireless interface, and/or as any other type of network interface. A wireless interface enables client device 1302 to receive control input commands 1332 and other information from a user-operated input device, such as from a remote control device 1334 or from another infrared (IR), 802.11, Bluetooth, or similar RF input device. Input devices can include a wireless keyboard or another handheld input device 1336 such as a personal digital assistant (PDA), handheld computer, wireless phone, or the like. A network interface and a serial and/or parallel interface enables client device 1302 to interact and communicate with other electronic and computing devices via various communication links. Modem 1330 facilitates client device 1302 communication with other electronic and computing devices via a conventional telephone line, a DSL connection, cable, and/or other type of connection.
Client device 1302 also includes a content processor 1338 which can include a video decoder and/or additional processors to receive, process, and decode broadcast video signals and program data, such as NTSC, PAL, SECAM, or other television system analog video signals, as well as DVB, ATSC, or other television system digital video signals. For example, content processor 1338 can include an MPEG-2 or MPEG-4 (Moving Pictures Experts Group) decoder that decodes MPEG-encoded video content and/or image data. The systems described herein can be implemented for any type of video encoding format as well as for data and/or content streams that are not encoded.
Typically, video content and program data includes video data and corresponding audio data. Content processor 1338 generates video and/or display content that is formatted for display on display device 1304, and generates decoded audio data that is formatted for presentation by a presentation device, such as one or more speakers (not shown) in display device 1304. Content processor 1338 can include a display controller (not shown) that processes the video and/or display content to display corresponding images on display device 1304. A display controller can include a graphics processor, microcontroller, integrated circuit, and/or similar video processing component to process the images.
Client device 1302 also includes an audio and/or video output 1340 that provides the audio, video, and/or display signals to television 1304 or to other devices that process and/or display, or otherwise render, the audio and video data. Video signals and audio signals can be communicated from client device 1302 to television 1304 via an RF (radio frequency) link, S-video link, composite video link, component video link, or other similar communication link.
Although shown separately, some of the components of client device 1302 may be implemented in an application specific integrated circuit (ASIC). Additionally, a system bus (not shown) typically connects the various components within client device 1302. A system bus can be implemented as one or more of any of several types of bus structures, including a memory bus or memory controller, a peripheral bus, an accelerated graphics port, or a local bus using any of a variety of bus architectures. By way of example, such architectures can include an Industry Standard Architecture (ISA) bus, a Micro Channel Architecture (MCA) bus, an Enhanced ISA (EISA) bus, a Video Electronics Standards Association (VESA) local bus, and a Peripheral Component Interconnects (PCI) bus also known as a Mezzanine bus.
Although the description above uses language that is specific to structural features and/or methodological acts, it is to be understood that the invention defined in the appended claims is not limited to the specific features or acts described. Rather, the specific features and acts are disclosed as exemplary forms of implementing the invention.