CROSS-REFERENCE TO RELATED APPLICATIONS; PRIORITY CLAIMThis application claims benefit as a Continuation of application Ser. No. 12/861,124, filed 23 Aug. 2010, which claims benefit of application Ser. No. 11/105,011, filed Apr. 12, 2005, which claims benefit of Provisional Appln. Ser. No. 60/561,558, filed Apr. 12, 2004; the entire contents of the foregoing are hereby incorporated by reference as if fully set forth herein. Application Ser. No. 11/105,011 also claims benefit as a Continuation-in-part of application Ser. No. 10/843,550, filed May 10, 2004, which is a continuation of Issued U.S. Pat. No. 6,757,906 B1, issued on Jun. 29, 2004, and claims benefit of Provisional Appln. Ser. No. 60/127,178, filed Mar. 30, 1999; the entire contents of the foregoing are hereby incorporated by reference as if fully set forth herein. The applicants hereby rescind any disclaimer of claim scope in the parent applications or the prosecution history thereof and advise the USPTO that the claims in this application may be broader than any claim in the parent applications.
TECHNICAL FIELDThe invention relates to the automatic configuration of a multimedia device's operating environment according a mobile user's profile.
BACKGROUNDMultimedia devices such as VCRs, DVD players, MP3 players, cassette players, CD players, video tape editors, and the new class of Digital Video Recorders (DVR) are extremely popular with consumers. Almost every household in the United States has at least one of these devices.
Multimedia devices must have some way of jumping through the program material to allow the user to select his desired position in the program material. This has commonly been achieved using a fast forward and reverse mode. The fast forward mode moves through the program material in a forward progression and the reverse mode moves backwards in program material.
The user simply presses a button (typically on a remote control) to initiate a fast forward or reverse mode and then presses a button to terminate the fast forward or reverse mode. A remote control is used on a majority of devices to control the playback of material as well as menu display and item selection. A DVR, for example, presents the user with a graphical user interface that allows the user to select television shows being broadcast or programs that have been stored on the DVR. A user uses a remote control to navigate through the DVR's menus and to select menu items and playback recorded programs.
A drawback to a typical DVR's operation, for example, is that the DVR does not distinguish between a single user and a family of users. The DVR recognizes that a remote control is being used, but does not distinguish which member of a family is using the remote control. The DVR records programs for an entire family and displays information and recordings as if a single user has configured the DVR. The DVR does not distinguish whether a program recorded for an adult family member is being viewed by an underage family member.
Further, the DVR retains a user's viewing preferences within the DVR itself. A user that travels frequently is unable to view programs that his DVR is recording while the user is away from home. The user cannot view those programs until he returns to his home.
It would be advantageous to provide a mobile personalization system that is able to identify the current user. It would further be advantageous to provide a system that allows a user to transfer his viewing and/or operational preferences to other devices.
BRIEF DESCRIPTION OF THE DRAWINGSFIG. 1 is a block schematic diagram of a high level view of an embodiment of the invention according to the invention;
FIG. 2 is a block schematic diagram of an embodiment of the invention using multiple input and output modules according to the invention;
FIG. 3 is a schematic diagram of an Moving Pictures Experts Group (MPEG) data stream and its video and audio components according to the invention;
FIG. 4 is a block schematic diagram of a parser and four direct memory access (DMA) input engines contained in the Media Switch according to the invention;
FIG. 5 is a schematic diagram of the components of a packetized elementary stream (PES) buffer according to the invention;
FIG. 6 is a schematic diagram of the construction of a PES buffer from the parsed components in the Media Switch output circular buffers;
FIG. 7 is a block schematic diagram of the Media Switch and the various components that it communicates with according to the invention;
FIG. 8 is a block schematic diagram of a high level view of the program logic according to the invention;
FIG. 9 is a block schematic diagram of a class hierarchy of the program logic according to the invention;
FIG. 10 is a block schematic diagram of an embodiment of the clip cache component of the invention according to the invention;
FIG. 11 is a block schematic diagram of an embodiment of the invention that emulates a broadcast studio video mixer according to the invention;
FIG. 12 is a block schematic diagram of a closed caption parser according to the invention;
FIG. 13 is a block schematic diagram of a high level view of an embodiment of the invention utilizing a VCR as an integral component of the invention according to the invention;
FIG. 14 is a diagram of a remote control according to the invention;
FIG. 15 is a block schematic diagram of a high level view of an embodiment of the invention showing the viewer interface module interaction according to the invention;
FIG. 16 is a schematic diagram of a central menu screen according to the invention;
FIG. 17 is a schematic diagram of a program list screen according to the invention;
FIG. 18 is a schematic diagram of a detailed program information screen according to the invention;
FIG. 19 is a schematic diagram of a detailed program information screen according to the invention;
FIG. 20ais a schematic diagram of a small banner displayed over program content according to the invention;
FIG. 20bis a schematic diagram of a medium banner displayed over program content according to the invention;
FIG. 20cis a schematic diagram of a detailed banner displayed over program content according to the invention;
FIG. 21 is a schematic diagram of a suggested program list screen according to the invention;
FIG. 22 is a schematic diagram of a network listing screen according to the invention;
FIG. 23 is a schematic diagram of a program theme list screen according to the invention;
FIG. 24 is a schematic diagram of a to do list screen according to the invention;
FIG. 25 is a schematic diagram of a conflict warning screen according to the invention;
FIG. 26 is a schematic diagram of a trick play bar overlaid on program material according to the invention;
FIG. 27 is a schematic diagram of a the trick bar and its associated components according to the invention;
FIG. 28 is a schematic diagram of a two column multimedia schedule screen according to the invention;
FIG. 29 is a schematic diagram of a two column theme-based schedule screen according to the invention;
FIG. 30 is a schematic diagram of a two column theme-based schedule screen according to the invention;
FIG. 31 is a schematic diagram of a two column theme-based schedule screen according to the invention;
FIG. 32 is a schematic diagram of a two column program schedule screen according to the invention;
FIG. 33 is a schematic diagram of a two column program schedule screen showing a program duration indicator according to the invention;
FIG. 34 is a block schematic diagram of a remote control reading an RFID user tag according to the invention;
FIG. 35 is a block schematic diagram of a mobile data device according to the invention; and
FIG. 36 is a block schematic diagram of a DVR service transferring a user's viewing preferences to a hotel server according to the invention.
DETAILED DESCRIPTIONA method and apparatus for a multimedia mobile personalization system is 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 present invention. It will be apparent, however, that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the present invention.
In the following discussion, in references to the drawings like numerals refer to like parts throughout the several views.
An embodiment of the invention predicts the position in the program material where the user expects to be when the user stops the fast forward or reverse progression of the program material.
Referring toFIG. 1, an embodiment of the invention has anInput Section101,Media Switch102, and anOutput Section103. TheInput Section101 takes television (TV) input streams in a multitude of forms, for example, National Television Standards Committee (NTSC) or PAL broadcast, and digital forms such as Digital Satellite System (DSS), Digital Broadcast Services (DBS), or Advanced Television Standards Committee (ATSC). DBS, DSS and ATSC are based on standards called Moving Pictures Experts Group 2 (MPEG2) and MPEG2 Transport. MPEG2 Transport is a standard for formatting the digital data stream from the TV source transmitter so that a TV receiver can disassemble the input stream to find programs in the multiplexed signal. TheInput Section101 produces MPEG streams. An MPEG2 transport multiplex supports multiple programs in the same broadcast channel, with multiple video and audio feeds and private data. TheInput Section101 tunes the channel to a particular program, extracts a specific MPEG program out of it, and feeds it to the rest of the system. Analog TV signals are encoded into a similar MPEG format using separate video and audio encoders, such that the remainder of the system is unaware of how the signal was obtained. Information may be modulated into the Vertical Blanking Interval (VBI) of the analog TV signal in a number of standard ways; for example, the North American Broadcast Teletext Standard (NABTS) may be used to modulate information ontolines 10 through 20 of an NTSC signal, while the FCC mandates the use ofline 21 for Closed Caption (CC) and Extended Data Services (EDS). Such signals are decoded by the input section and passed to the other sections as if they were delivered via an MPEG2 private data channel.
TheMedia Switch102 mediates between amicroprocessor CPU106, hard disk orstorage device105, andmemory104. Input streams are converted to an MPEG stream and sent to theMedia Switch102. TheMedia Switch102 buffers the MPEG stream into memory. It then performs two operations if the user is watching real time TV: the stream is sent to theOutput Section103 and it is written simultaneously to the hard disk orstorage device105.
TheOutput Section103 takes MPEG streams as input and produces an analog TV signal according to the NTSC, PAL, or other required TV standards. TheOutput Section103 contains an MPEG decoder, On-Screen Display (OSD) generator, analog TV encoder and audio logic. The OSD generator allows the program logic to supply images which will be overlaid on top of the resulting analog TV signal. Additionally, the Output Section can modulate information supplied by the program logic onto the VBI of the output signal in a number of standard formats, including NABTS, CC and EDS.
With respect toFIG. 2, the invention easily expands to accommodate multiple Input Sections (tuners)201,202,203,204, each can be tuned to different types of input. Multiple Output Modules (decoders)206,207,208,209 are added as well. Special effects such as picture in a picture can be implemented with multiple decoders. TheMedia Switch205 records one program while the user is watching another. This means that a stream can be extracted off the disk while another stream is being stored onto the disk.
Referring toFIG. 3, theincoming MPEG stream301 has interleavedvideo302,305,306 andaudio303,304,307 segments. These elements must be separated and recombined to createseparate video308 and audio309 streams or buffers. This is necessary because separate decoders are used to convert MPEG elements back into audio or video analog components. Such separate delivery requires that time sequence information be generated so that the decoders may be properly synchronized for accurate playback of the signal.
The Media Switch enables the program logic to associate proper time sequence information with each segment, possibly embedding it directly into the stream. The time sequence information for each segment is called a time stamp. These time stamps are monotonically increasing and start at zero each time the system boots up. This allows the invention to find any particular spot in any particular video segment. For example, if the system needs to read five seconds into an incoming contiguous video stream that is being cached, the system simply has to start reading forward into the stream and look for the appropriate time stamp.
A binary search can be performed on a stored file to index into a stream. Each stream is stored as a sequence of fixed-size segments enabling fast binary searches because of the uniform timestamping. If the user wants to start in the middle of the program, the system performs a binary search of the stored segments until it finds the appropriate spot, obtaining the desired results with a minimal amount of information. If the signal were instead stored as an MPEG stream, it would be necessary to linearly parse the stream from the beginning to find the desired location.
With respect toFIG. 4, the Media Switch contains four input Direct Memory Access (DMA)engines402,403,404,405 each DMA engine has an associatedbuffer410,411,412,413. Conceptually, each DMA engine has apointer406, a limit for thatpointer407, anext pointer408, and a limit for thenext pointer409. Each DMA engine is dedicated to a particular type of information, for example,video402,audio403, and parsedevents405. Thebuffers410,411,412,413 are circular and collect the specific information. The DMA engine increments thepointer406 into the associated buffer until it reaches thelimit407 and then loads thenext pointer408 and limit409. Setting thepointer406 andnext pointer408 to the same value, along with the corresponding limit value creates a circular buffer. Thenext pointer408 can be set to a different address to provide vector DMA.
The input stream flows through aparser401. Theparser401 parses the stream looking for MPEG distinguished events indicating the start of video, audio or private data segments. For example, when theparser401 finds a video event, it directs the stream to thevideo DMA engine402. Theparser401 buffers up data and DMAs it into thevideo buffer410 through thevideo DMA engine402. At the same time, theparser401 directs an event to theevent DMA engine405 which generates an event into theevent buffer413. When theparser401 sees an audio event, it redirects the byte stream to theaudio DMA engine403 and generates an event into theevent buffer413. Similarly, when theparser401 sees a private data event, it directs the byte stream to the privatedata DMA engine404 and directs an event to theevent buffer413. The Media Switch notifies the program logic via an interrupt mechanism when events are placed in the event buffer.
Referring toFIGS. 4 and 5, theevent buffer413 is filled by theparser401 with events. Eachevent501 in the event buffer has an offset502,event type503, andtime stamp field504. Theparser401 provides the type and offset of each event as it is placed into the buffer. For example, when an audio event occurs, the event type field is set to an audio event and the offset indicates the location in theaudio buffer411. The program logic knows where theaudio buffer411 starts and adds the offset to find the event in the stream. The address offset502 tells the program logic where the next event occurred, but not where it ended. The previous event is cached so the end of the current event can be found as well as the length of the segment.
With respect toFIGS. 5 and 6, the program logic reads accumulated events in theevent buffer602 when it is interrupted by theMedia Switch601. From these events the program logic generates a sequence oflogical segments603 which correspond to the parsedMPEG segments615. The program logic converts the offset502 into theactual address610 of each segment, and records theevent length609 using the last cached event. If the stream was produced by encoding an analog signal, it will not contain Program Time Stamp (PTS) values, which are used by the decoders to properly present the resulting output. Thus, the program logic uses the generatedtime stamp504 to calculate a simulated PTS for each segment and places that into thelogical segment timestamp607. In the case of a digital TV stream, PTS values are already encoded in the stream. The program logic extracts this information and places it in thelogical segment timestamp607.
The program logic continues collectinglogical segments603 until it reaches the fixed buffer size. When this occurs, the program logic generates a new buffer, called a Packetized Elementary Stream (PES)605 buffer containing theselogical segments603 in order, plus ancillary control information. Each logical segment points604 directly to the circular buffer, e.g., thevideo buffer613, filled by theMedia Switch601. This new buffer is then passed to other logic components, which may further process the stream in the buffer in some way, such as presenting it for decoding or writing it to the storage media. Thus, the MPEG data is not copied from one location in memory to another by the processor. This results in a more cost effective design since lower memory bandwidth and processor bandwidth is required.
A unique feature of the MPEG stream transformation into PES buffers is that the data associated with logical segments need not be present in the buffer itself, as presented above. When a PES buffer is written to storage, these logical segments are written to the storage medium in the logical order in which they appear. This has the effect of gathering components of the stream, whether they be in the video, audio or private data circular buffers, into a single linear buffer of stream data on the storage medium. The buffer is read back from the storage medium with a single transfer from the storage media, and the logical segment information is updated to correspond with the actual locations in thebuffer606. Higher level program logic is unaware of this transformation, since it handles only the logical segments, thus stream data is easily managed without requiring that the data ever be copied between locations in DRAM by the CPU.
A unique aspect of the Media Switch is the ability to handle high data rates effectively and inexpensively. It performs the functions of taking video and audio data in, sending video and audio data out, sending video and audio data to disk, and extracting video and audio data from the disk on a low cost platform. Generally, the Media Switch runs asynchronously and autonomously with the microprocessor CPU, using its DMA capabilities to move large quantities of information with minimal intervention by the CPU.
Referring toFIG. 7, the input side of theMedia Switch701 is connected to anMPEG encoder703. There are also circuits specific toMPEG audio704 and vertical blanking interval (VBI)data702 feeding into theMedia Switch701. If a digital TV signal is being processed instead, theMPEG encoder703 is replaced with an MPEG2 Transport Demultiplexor, and theMPEG audio encoder704 andVBI decoder702 are deleted. The demultiplexor multiplexes the extracted audio, video and private data channel streams through the video input Media Switch port.
Theparser705 parses the input data stream from theMPEG encoder703,audio encoder704 andVBI decoder702, or from the transport demultiplexor in the case of a digital TV stream. Theparser705 detects the beginning of all of the important events in a video or audio stream, the start of all of the frames, the start of sequence headers—all of the pieces of information that the program logic needs to know about in order to both properly play back and perform special effects on the stream, e.g. fast forward, reverse, play, pause, fast/slow play, indexing, and fast/slow reverse play.
Theparser705places tags707 into the FIFO706 when it identifies video or audio segments, or is given private data. TheDMA709 controls when these tags are taken out. Thetags707 and the DMA addresses of the segments are placed into theevent queue708. The frame type information, whether it is a start of a video I-frame, video B-frame, video P-frame, video PES, audio PES, a sequence header, an audio frame, or private data packet, is placed into theevent queue708 along with the offset in the related circular buffer where the piece of information was placed. The program logic operating in theCPU713 examines events in the circular buffer after it is transferred to the DRAM714.
TheMedia Switch701 has adata bus711 that connects to theCPU713 and DRAM714. Anaddress bus712 is also shared between theMedia Switch701,CPU713, and DRAM714. A hard disk orstorage device710 is connected to one of the ports of theMedia Switch701. TheMedia Switch701 outputs streams to anMPEG video decoder715 and aseparate audio decoder717. Theaudio decoder717 signals contain audio cues generated by the system in response to the user's commands on a remote control or other internal events. The decoded audio output from the MPEG decoder is digitally mixed718 with the separate audio signal. The resulting signals contain video, audio, and on screen displays and are sent to theTV716.
TheMedia Switch701 takes in 8-bit data and sends it to the disk, while at the same time extracts another stream of data off of the disk and sends it to theMPEG decoder715. All of the DMA engines described above can be working at the same time. TheMedia Switch701 can be implemented in hardware using a Field Programmable Gate Array (FPGA), ASIC, or discrete logic.
Rather than having to parse through an immense data stream looking for the start of where each frame would be, the program logic only has to look at the circular event buffer in DRAM714 and it can tell where the start of each frame is and the frame type. This approach saves a large amount of CPU power, keeping the real time requirements of theCPU713 small. TheCPU713 does not have to be very fast at any point in time. TheMedia Switch701 gives theCPU713 as much time as possible to complete tasks. Theparsing mechanism705 andevent queue708 decouple theCPU713 from parsing the audio, video, and buffers and the real time nature of the streams, which allows for lower costs. It also allows the use of a bus structure in a CPU environment that operates at a much lower clock rate with much cheaper memory than would be required otherwise.
TheCPU713 has the ability to queue up one DMA transfer and can set up the next DMA transfer at its leisure. This gives theCPU713 large time intervals within which it can service theDMA controller709. TheCPU713 may respond to a DMA interrupt within a larger time window because of the large latency allowed. MPEG streams, whether extracted from an MPEG2 Transport or encoded from an analog TV signal, are typically encoded using a technique called Variable Bit Rate encoding (VBR). This technique varies the amount of data required to represent a sequence of images by the amount of movement between those images. This technique can greatly reduce the required bandwidth for a signal, however sequences with rapid movement (such as a basketball game) may be encoded with much greater bandwidth requirements. For example, the Hughes DirecTV satellite system encodes signals with anywhere from 1 to 10 Mb/s of required bandwidth, varying from frame to frame. It would be difficult for any computer system to keep up with such rapidly varying data rates without this structure.
With respect toFIG. 8, the program logic within the CPU has three conceptual components:sources801, transforms802, and sinks803. Thesources801 produce buffers of data.Transforms802 process buffers of data and sinks803 consume buffers of data. A transform is responsible for allocating and queuing the buffers of data on which it will operate. Buffers are allocated as if “empty” to sources of data, which give them back “full”. The buffers are then queued and given to sinks as “full”, and the sink will return the buffer “empty”.
Asource801 accepts data from encoders, e.g., a digital satellite receiver. It acquires buffers for this data from the downstream transform, packages the data into a buffer, then pushes the buffer down the pipeline as described above. Thesource object801 does not know anything about the rest of the system. Thesink803 consumes buffers, taking a buffer from the upstream transform, sending the data to the decoder, and then releasing the buffer for reuse.
There are two types oftransforms802 used: spatial and temporal. Spatial transforms are transforms that perform, for example, an image convolution or compression/decompression on the buffered data that is passing through. Temporal transforms are used when there is no time relation that is expressible between buffers going in and buffers coming out of a system. Such a transform writes the buffer to afile804 on the storage medium. The buffer is pulled out at a later time, sent down the pipeline, and properly sequenced within the stream.
Referring toFIG. 9, a C++ class hierarchy derivation of the program logic is shown. The TiVo Media Kernel (Tmk)904,908,913 mediates with the operating system kernel. The kernel provides operations such as: memory allocation, synchronization, and threading. TheTmkCore904,908,913 structures memory taken from the media kernel as an object. It provides operators, new and delete, for constructing and deconstructing the object. Each object (source901, transform902, and sink903) is multi-threaded by definition and can run in parallel.
TheTmkPipeline class905,909,914 is responsible for flow control through the system. The pipelines point to the next pipeline in the flow fromsource901 to sink903. To pause the pipeline, for example, an event called “pause” is sent to the first object in the pipeline. The event is relayed on to the next object and so on down the pipeline. This all happens asynchronously to the data going through the pipeline. Thus, similar to applications such as telephony, control of the flow of MPEG streams is asynchronous and separate from the streams themselves. This allows for a simple logic design that is at the same time powerful enough to support the features described previously, including pause, rewind, fast forward and others. In addition, this structure allows fast and efficient switching between stream sources, since buffered data can be simply discarded and decoders reset using a single event, after which data from the new stream will pass down the pipeline. Such a capability is needed, for example, when switching the channel being captured by the input section, or when switching between a live signal from the input section and a stored stream.
Thesource object901 is aTmkSource906 and thetransform object902 is aTmkXfrm910. These are intermediate classes that define standard behaviors for the classes in the pipeline. Conceptually, they handshake buffers down the pipeline. Thesource object901 takes data out of a physical data source, such as the Media Switch, and places it into a PES buffer. To obtain the buffer, thesource object901 asks the down stream object in his pipeline for a buffer (allocEmptyBuf). Thesource object901 is blocked until there is sufficient memory. This means that the pipeline is self-regulating; it has automatic flow control. When thesource object901 has filled up the buffer, it hands it back to thetransform902 through the pushFullBuf function.
Thesink903 is flow controlled as well. It calls nextFullBuf which tells thetransform902 that it is ready for the next filled buffer. This operation can block thesink903 until a buffer is ready. When thesink903 is finished with a buffer (i.e., it has consumed the data in the buffer) it calls releaseEmptyBuf. ReleaseEmptyBuf gives the buffer back to thetransform902. Thetransform902 can then hand that buffer, for example, back to thesource object901 to fill up again. In addition to the automatic flow-control benefit of this method, it also provides for limiting the amount of memory dedicated to buffers by allowing enforcement of a fixed allocation of buffers by a transform. This is an important feature in achieving a cost-effective limited DRAM environment.
TheMediaSwitch class909 calls the allocEmptyBuf method of theTmkClipCache912 object and receives a PES buffer from it. It then goes out to the circular buffers in the Media Switch hardware and generates PES buffers. TheMediaSwitch class909 fills the buffer up and pushes it back to theTmkClipCache912 object.
TheTmkClipCache912 maintains acache file918 on a storage medium. It also maintains two pointers into this cache: apush pointer919 that shows where the next buffer coming from thesource901 is inserted; and acurrent pointer920 which points to the current buffer used.
The buffer that is pointed to by the current pointer is handed to theVela decoder class916. TheVela decoder class916 talks to thedecoder921 in the hardware. Thedecoder921 produces a decoded TV signal that is subsequently encoded into an analog TV signal in NTSC, PAL or other analog format. When theVela decoder class916 is finished with the buffer it calls releaseEmptyBuf.
The structure of the classes makes the system easy to test and debug. Each level can be tested separately to make sure it performs in the appropriate manner, and the classes may be gradually aggregated to achieve the desired functionality while retaining the ability to effectively test each object.
Thecontrol object917 accepts commands from the user and sends events into the pipeline to control what the pipeline is doing. For example, if the user has a remote control and is watching TV, the user presses pause and thecontrol object917 sends an event to thesink903, that tells it pause. Thesink903 stops asking for new buffers. Thecurrent pointer920 stays where it is at. Thesink903 starts taking buffers out again when it receives another event that tells it to play. The system is in perfect synchronization; it starts from the frame that it stopped at.
The remote control may also have a fast forward key. When the fast forward key is pressed, thecontrol object917 sends an event to thetransform902 that tells it to move forward two seconds. Thetransform902 finds that the two second time span requires it to move forward three buffers. It then issues a reset event to the downstream pipeline, so that any queued data or state that may be present in the hardware decoders is flushed. This is a critical step, since the structure of MPEG streams requires maintenance of state across multiple frames of data, and that state will be rendered invalid by repositioning the pointer. It then moves thecurrent pointer920 forward three buffers. The next time thesink903 calls nextFullBuf it gets the new current buffer. The same method works for fast reverse in that thetransform902 moves thecurrent pointer920 backwards.
A system clock reference resides in the decoder. The system clock reference is sped up for fast play or slowed down for slow play. The sink simply asks for full buffers faster or slower, depending on the clock speed.
With respect toFIG. 10, two other objects derived from the TmkXfrm class are placed in the pipeline for disk access. One is calledTmkClipReader1003 and the other is calledTmkClipWriter1001. Buffers come into theTmkClipWriter1001 and are pushed to a file on astorage medium1004.TmkClipReader1003 asks for buffers which are taken off of a file on astorage medium1005. ATmkClipReader1003 provides only the allocEmptyBuf and pushFullBuf methods, while aTmkClipWriter1001 provides only the nextFullBuf and releaseEmptyBuf methods. ATmkClipReader1003 therefore performs the same function as the input, or “push” side of aTmkClipCache1002, while aTmkClipWriter1001 therefore performs the same function as the output, or “pull” side of aTmkClipCache1002.
Referring toFIG. 11, an embodiment that accomplishes multiple functions is shown. Asource1101 has a TV signal input. The source sends data to aPushSwitch1102 which is a transform derived from TmkXfrm. ThePushSwitch1102 has multiple outputs that can be switched by thecontrol object1114. This means that one part of the pipeline can be stopped and another can be started at the users whim. The user can switch to different storage devices. ThePushSwitch1102 could output to aTmkClipWriter1106, which goes onto astorage device1107 or write to thecache transform1103.
An important feature of this apparatus is the ease with which it can selectively capture portions of an incoming signal under the control of program logic. Based on information such as the current time, or perhaps a specific time span, or perhaps via a remote control button press by the viewer, aTmkClipWriter1106 may be switched on to record a portion of the signal, and switched off at some later time. This switching is typically caused by sending a “switch” event to thePushSwitch1102 object.
An additional method for triggering selective capture is through information modulated into the VBI or placed into an MPEG private data channel. Data decoded from the VBI or private data channel is passed to the program logic. The program logic examines this data to determine if the data indicates that capture of the TV signal into which it was modulated should begin. Similarly, this information may also indicate when recording should end, or another data item may be modulated into the signal indicating when the capture should end. The starting and ending indicators may be explicitly modulated into the signal or other information that is placed into the signal in a standard fashion may be used to encode this information.
With respect toFIG. 12, an example is shown which demonstrates how the program logic scans the words contained within the closed caption (CC) fields to determine starting and ending times, using particular words or phrases to trigger the capture. A stream of NTSC orPAL fields1201 is presented. CC bytes are extracted from eachodd field1202, and entered in acircular buffer1203 for processing by theWord Parser1204. TheWord Parser1204 collects characters until it encounters a word boundary, usually a space, period or other delineating character. Recall from above, that the MPEG audio and video segments are collected into a series of fixed-size PES buffers. A special segment is added to each PES buffer to hold the words extracted from theCC field1205. Thus, the CC information is preserved in time synchronization with the audio and video, and can be correctly presented to the viewer when the stream is displayed. This also allows the stored stream to be processed for CC information at the leisure of the program logic, which spreads out load, reducing cost and improving efficiency. In such a case, the words stored in the special segment are simply passed to thestate table logic1206.
During stream capture, each word is looked up in a table1206 which indicates the action to take on recognizing that word. This action may simply change the state of therecognizer state machine1207, or may cause thestate machine1207 to issue an action request, such as “start capture”, “stop capture”, “phrase seen”, or other similar requests. Indeed, a recognized word or phrase may cause the pipeline to be switched; for example, to overlay a different audio track if undesirable language is used in the program.
Note that the parsing state table1206 andrecognizer state machine1207 may be modified or changed at any time. For example, a different table and state machine may be provided for each input channel. Alternatively, these elements may be switched depending on the time of day, or because of other events.
Referring toFIG. 11, a PullSwitch is added1104 which outputs to thesink1105. Thesink1105 calls nextFullBuf and releaseEmptyBuf to get or return buffers from thePullSwitch1104. ThePullSwitch1104 can have any number of inputs. One input could be anActionClip1113. The remote control can switch between input sources. Thecontrol object1114 sends an event to thePullSwitch1104, telling it to switch. It will switch from the current input source to whatever input source the control object selects.
An ActionClip class provides for sequencing a number of different stored signals in a predictable and controllable manner, possibly with the added control of viewer selection via a remote control. Thus, it appears as a derivative of a TmkXfrm object that accepts a “switch” event for switching to the next stored signal.
This allows the program logic or user to create custom sequences of video output. Any number of video segments can be lined up and combined as if the program logic or user were using a broadcast studio video mixer.TmkClipReaders1108,1109,1110 are allocated and each is hooked into thePullSwitch1104. ThePullSwitch1104 switches between theTmkClipReaders1108,1109,1110 to combine video and audio clips. Flow control is automatic because of the way the pipeline is constructed. The Push and Pull Switches are the same as video switches in a broadcast studio.
The derived class and resulting objects described here may be combined in an arbitrary way to create a number of different useful configurations for storing, retrieving, switching and viewing of TV streams. For example, if multiple input and output sections are available, one input is viewed while another is stored, and a picture-in-picture window generated by the second output is used to preview previously stored streams. Such configurations represent a unique and novel application of software transformations to achieve the functionality expected of expensive, sophisticated hardware solutions within a single cost-effective device.
With respect toFIG. 13, a high-level system view is shown which implements a VCR backup. TheOutput Module1303 sends TV signals to theVCR1307. This allows the user to record TV programs directly on to video tape. The invention allows the user to queue up programs from disk to be recorded on to video tape and to schedule the time that the programs are sent to theVCR1307. Title pages (EPG data) can be sent to theVCR1307 before a program is sent. Longer programs can be scaled to fit onto smaller video tapes by speeding up the play speed or dropping frames.
TheVCR1307 output can also be routed back into theInput Module1301. In this configuration the VCR acts as a backup system for theMedia Switch1302. Any overflow storage or lower priority programming is sent to theVCR1307 for later retrieval.
TheInput Module1301 can decode and pass to the remainder of the system information encoded on the Vertical Blanking Interval (VBI). TheOutput Module1303 can encode into the output VBI data provided by the remainder of the system. The program logic may arrange to encode identifying information of various kinds into the output signal, which will be recorded onto tape using theVCR1307. Playing this tape back into the input allows the program logic to read back this identifying information, such that the TV signal recorded on the tape is properly handled. For example, a particular program may be recorded to tape along with information about when it was recorded, the source network, etc. When this program is played back into the Input Module, this information can be used to control storage of the signal, presentation to the viewer, etc.
Such a mechanism may be used to introduce various data items to the program logic which are not properly conceived of as television signals. For instance, software updates or other data may be passed to the system. The program logic receiving this data from the television stream may impose controls on how the data is handled, such as requiring certain authentication sequences and/or decrypting the embedded information according to some previously acquired key. Such a method works for normal broadcast signals as well, leading to an efficient means of providing non-TV control information and data to the program logic.
Additionally, although a VCR is specifically mentioned above, any multimedia recording device (e.g., a Digital Video Disk-Random Access Memory (DVD-RAM) recorder) is easily substituted in its place.
Other applications may be substituted for those set forth herein without departing from the spirit and scope of the present invention. For example, the invention can be used in the detection of gambling casino crime. The input section of the invention is connected to the casino's video surveillance system. Recorded video is cached and simultaneously output to external VCRs. The user can switch to any video feed and examine (i.e., rewind, play, slow play, fast forward, etc.) a specific segment of the recorded video while the external VCRs are being loaded with the real-time input video.
Referring again toFIG. 1, an embodiment of the invention provides a viewer interface that allows the viewer to access different functions of the system. The system's construct allows items called video loopsets to be stored on the hard disk orstorage device105. The video loopsets enter the system through input streams into theInput Module101 and converted to MPEG streams and placed onto the storage device by theMedia Switch102. The video loopsets also enter the system in the form of MPEG streams (through a backchannel, VBI, transmission media, etc.), bypass the MPEG conversion cycle by theInput Module101 and are written to thestorage device105 by theMedia Switch102.
The viewer interface program logic (executed by the CPU106) commands theMedia Switch102 to retrieve a video loopset from thestorage device105. A video loopset is a three to four second (the length is dependent upon the amount of information displayed and can be longer) loop of video is created so that the ending and beginning seamlessly merge together to give the effect of a continuous video stream as the system plays the loopset from beginning to end, looping back to the beginning of the loopset each time the end is reached. As detailed above, theOutput Section103 takes MPEG video loopset streams as input and produces an analog TV signal according to the NTSC, PAL, or other required TV standards. The Output Section's103 OSD generator allows the program logic to overlay text and graphics on top of the resulting analog TV signal.
A lower level viewpoint of the system is shown inFIG. 7. TheCPU713 tells theMedia Switch701 that a specific video loopset must be retrieved from thestorage device710 and sent to theMPEG decoder715. On screen displays are created by theCPU713 and routed through the OSD generator to thedigital mixer718. Thedigital mixer718 allows video loopsets, on screen displays, and audio cues to be mixed and sent to the TV or monitor716.
The invention's viewer interface reacts to user input through an input device such as the exemplary remote control shown inFIG. 14. With respect toFIG. 15, the user's commands are processed through theControl Input Module1504. Theviewer interface1503 processes the input commands. Appropriate commands are issued (such as displaying loopsets) to theMedia Control1501. On screen displays are generated by theviewer interface1503 and routed through theOutput Module1505 as described above.
A viewer using this type ofremote control1401 presses theTiVo button1401 and the viewer interface displays a menu as shown inFIG. 16.TiVo Central1601 is a central location that contains a list of areas that the viewer can visit and is easily accessed through a single button push on the remote control.
The viewer interface displays video loopsets in the background area of the screen on a TV or monitor. Here, thecharacter1602 in the upper left-hand portion of the screen is a separate video loopset. The character's loopset animates thecharacter1602 by giving the viewer the sense that the character is alive. His antennae move and he rocks from side to side on his feet. Each element of the screen can be a separate video loopset. The subdued text's1603 loopset rotates the text in a banner-like mode from the right side of the screen to the left side. The rest of the background details are on another loopset. One loopset can be used for the entire background display if so desired. Video loopsets free the CPU from having to draw continuous animations. The system simply plays the loopsets in the same manner as playing any other MPEG stream, thereby offloading the CPU. Additionally, video loopsets are an inexpensive method of displaying high resolution graphics.
Any temporal elements (e.g., names, icons, location indicators) are drawn onto the screen over the video loops using the OSD. Menu items such asNow Showing1604 are drawn over the video loopset. Ahighlight bar1605 is used to indicate the current menu item that can be selected by the user.
Highlight bars can be displayed using video loopsets. Thehighlight bar1605 appears to be drawn onto the screen but is actually a video loopset. Each time the user presses abutton1403 on the remote control to move thehighlight bar1605, an appropriate video loopset is selected for that position.
Alternatively, thehighlight bar1605 can be drawn over the video loopsets in the same manner as a temporal item.
Information is presented in a successive disclosure format. The user navigates through menus by moving to the right (by pressing right side of thebutton1403 on the remote control) to obtain more information or to the left (by pressing the left side of thebutton1403 on the remote control) to see less information and return to the previous location. Theselect button1404 selects the menu item and causes the appropriate action to be executed.
The background colors of each set of menus remains consistent throughout the user's experience. For example, the background screen color for Now Showing is amber/yellow and the background screen color for Network Showcases is purple. The user intuitively knows what menu area he is in through the color cues.
Referring toFIGS. 14, 16, and 17, the invention provides “whispering arrows”1706,1707,1708,1709 on each screen that tell the user that more information is available in that particular direction. These arrows point up1709, down1707, left1708, and right1706. Aright arrow1706 indicates that there is more detailed content that the user can access by pressing the right side of thebutton1403 on theremote control1401. Aleft arrow1708 indicates that a more general level of detail exists that the user can access by pressing the left side of thebutton1403 on theremote control1401. Up1709 and down1707 arrows indicate that the current list has more items above or below, respectively, from the location that the user currently has highlighted with thehighlight bar1710. If an arrow does not exist, then there is nowhere else to go in that direction.
For example, the user simply highlights theNow Showing name1604 and presses the right side of thebutton1403 on theremote control1401. TheNow Showing screen1701 is shown which has a list ofprograms1705 that are displayed to the user in descending order with the most recently obtained program at the top of the list. TheNow Showing listing1705 contains a list of shows that the user requested the system to record and also programs that the system believes are of interest to the user. The system's list is based upon the program preferences that the user has expressed to the system using the thumbs up and thumbs down ratings described below and are indicated with aTiVo logo1712. Ayellow dot1702 is a warning indicator that indicates that a program is going to expire and will be deleted from the hard drive in a short time (e.g., in24 hours). A yellow dot with anexclamation point1704 indicates that a program will be deleted within a much shorter time (e.g., within the next few hours).Green dots1703 indicate that the system will save the program until the user explicitly deletes it. Ared dot1713 indicates that the program is currently being saved on the storage device.
A downarrow1711 is displayed in the lower area of thelisting1705 whenever the user has more information to scroll or page down through. An up arrow is displayed in the upper area of thelisting1705 whenever there is more information to scroll or page up through. The user presses up or down on thebutton1403 on theremote control1401 to scroll up or down, respectively, through the listing. Thechannel button1410 is pressed up or down to page up or down, respectively, through the listing.
When the user presses on the right side of thebutton1403 on theremote control1401, a more detailed program information screen is displayed to the user. Referring toFIG. 18, this screen supplies the user with more information related to the particular program. The user can choose to let the program be deleted automatically by taking noaction1805, view it immediately1801, delete it immediately1803, ask the invention to save the program longer1802, or save until deleted by theuser1802. If the user asks the invention to save the program longer, then the yellow or yellow dot with an exclamation point will disappear. The user can also save a program to an external VCR forarchiving1805. The invention consistently displays thehighlight bar1806, whisperingarrows1810,1811,1812, andvideo loopsets1807. A text description of theprogram1809 is displayed.
A downarrow1813 is shown in the lower portion of the screen to indicate that the user can press down on thechannel button1410 on theremote control1401 to see a detailed program information screen for the next program on the Now Showing list. An up arrow displayed in the upper portion of the screen area indicates that the program list has additional programs in that direction. This functionality allows the user to obtain the same information shown in theNow Showing listing1705 in a more detailed format.
With respect toFIGS. 7, 15, and 18, the invention provides a bookmark function that allows the user to bookmark a program where he left off. TheCPU713 records the frame of the program where the user stopped or the user commands the system to place a bookmark. TheMedia Switch701 updates theCPU713 on the status of the video stream. For example, a user can watch the first half-hour of a two-hour program stored in thestorage device710 and then bookmark the program where he left off or he can place bookmarks within the program to mark points of interest. Alternatively, the invention automatically bookmarks the program for the user if the user exits viewing the program by going to live TV or to the menu mode. The invention places anindicator1708 on the screen, indicating that a bookmark has been saved.
The user can, at any time, access any of his bookmarks and continue viewing the program from the bookmark. When a program is deleted from thestorage device710, the associated bookmark(s) is also deleted. The user can also select and delete a specific bookmark or all bookmarks for a program. Once the program is playing, the user can jump to a bookmark using thejump button1414 on theremote control1401 and press theselect button1406 to remove the bookmark. A bookmark is placed in the same manner by pressing theselect button1406 to create a bookmark.
Bookmarks within a single program can be set for different users. Remote controls are encoded for a specific user in a household. This allows each person in the household to have a personal remote control. The advantage to having individual remote controls is that parental controls, personal preferences, and bookmarks are automatically activated when each remote control is used. TheCPU713 notes that a bookmark belongs to a certain encoded remote control. Each set of data are stored on thestorage device710.
The remote control identifies itself to the system via a coded chip onboard the remote control. TheControl Input Module1504 receives the remote control's command signals. Theviewer interface1503 processes the remote control's identification and checks the preferences on thestorage device1502 for any associated preference files. Theviewer interface1503 then uses the associated preference file (or default preference file if no match was found) bookmark information for the user. Any bookmarks that do not have associated programs stored on thestorage device1502 are ignored and deleted. Theviewer interface1503 commands theMedia Control1501 to display programs with start frames corresponding to the preference file bookmarks, if they exist.
The encoded remote control can also be used for parental controls. Specific remote control(s) can be set up so that different levels of parental controls are engaged for each remote control. Children, for example, will have their own personal remote controls that are set up to not allow them to watch any shows with greater than a G-rating.
Although remote controls are mentioned as a method of accessing individual user preference files, other methods such as manual selection can be used.
Multiple bookmarks for a program are transparent to the user because the remote control that the user uses tells the system to only display and activate that particular user's bookmarks. A user can also see other users' bookmarks if so desired.
The invention's bookmarks can be applied to any video or audio application where the physical position in the material is readily ascertainable e.g., DVDs, VCRs, MP3s, etc.
Users can indicate their preferences for a certain program. A user can rate a particular program with one, two, or three thumbs up, indicating the degree that he likes the program. One, two, or three thumbs down are used to indicate the degree that the user dislikes the program. The degree that the user likes or dislikes the program increases as the number of thumbs up or down increases (i.e., two thumbs up indicates a stronger preference than one thumbs up).
The user can rate a program while he is watching it or viewing the program's information. The accumulation of program ratings allows the system to save related programs onto the system storage device. This influences the performance of the underlying system as described in U.S. Pat. No. 6,233,389, owned by the Applicant.
Referring toFIGS. 19, 20a,20b,and20cthe invention displays the thumbs rating (if it exists)1901 for a particular program to the user whenever an episode of the program is viewed or the user looks at theprogram information1908. Abanner2001 is displayed in the upper region of the screen whenever the user changes channels, transitions to live TV, or commands the banner to be displayed.
The user can rotate through three different levels of banners, each successively containing more information about the program. Thelowest level banner2001 contains minimal information such aschannel2002,station ID2003, andtime2004. Thesecond level banner2005 displays, in addition to the information in theminimal banner2001, information such asprogram title2006,duration2007, program MPAA orTV rating2008, and thumbs rating. Thefinal level banner2009 addsprogram text description2010 to thesecond level banner2005. Theprogram text description2010 is semi-transparent, allowing the user to watch the progress of the program while reading the text.
With respect toFIG. 21, programs that the user has indicated a preference for and other programs that the system believes that the user is interested in (through a user profile) are displayed2102 in the TiVo'sSuggestions area2101.
The user can tell the system to record one instance of a program, the next x number of showings, record all occurrences of a program for a set time period, or get a season pass for a program. A season pass tells the system that the user wants to record each airing of a certain program for the entire season. The system notes, for example, that the program is shown every Monday at 8:00 PM and saves the program on the storage device every Monday at 8:00 PM until the end of the season. A season pass will only be offered to the user if the program is episodic in nature.
At anytime during the viewing of live television, the user is able to tell the system to save the program in progress, record the program the next time, if any, it is shown, or get a season pass for the program. If the user is watching a show and tells the system to record the program in progress, then the system will record the program from that point on and will add onto the saved recording (pre-pending) the portion of the program that has already passed and has been buffered. The user's choices will appear in his profile so he can edit it later.
Referring toFIGS. 22 and 23, aShowcase area2201 contains program listings that certain television or cable networks are promoting2202. These are programs that the networks are currently promoting from their lineups. The user can, for example, move the highlight bar to the right and look at the network listings. The user can chooseNBC2203 by highlighting that particular line and moving thehighlight bar2204 to the right. The list of program categories for NBC will appear on thenext screen2301. The user can then move thehighlight bar2303 to highlight a program category and then move thehighlight bar2303 to the right to see the program listings on the next screen.
Referring again toFIG. 19, a screen displaying the information for a program is shown. The user is given the thumbs rating if it exists1901 along with a program description and channel information. The user is presented with a list of options such as: watch now1902; record theepisode1903; get aseason pass1904; viewupcoming showings1905; cancel theparticular recording1906; and view theme1907 (which displays other shows in the same theme area).
With respect toFIG. 24, TiVo's To DoList2401 contains a listing of theprograms2402 that the system is going to store on the system hard disk. A list of days beginning from the current day is displayed. Each day has a corresponding list of programs that the system will store on the system hard disk. The user can select the day that he wants to query by highlighting the particular day and moving the highlight bar to the right. A list of programs that the system will record on that particular day is displayed. Alternatively, the invention will display the entire list ofprograms2402 with theday2404 that the program will be recorded listed in line with theprogram name2407.
A checkmark next to a program name indicates that the user has requested the system to record the program. Twocheckmarks2403 mean that theprogram2407 is part of a season pass. The user can check or uncheck any program on the list. The programs that are check-marked have a higher priority to be stored on the system hard disk than the unchecked programs.
If the user attempts to checkmark too many programs, the invention will notify the user that there will be insufficient room on the system hard disk. The user is told what programs should be freed up from the programs that are currently or planned to be saved on the system hard disk in order to save the desired program. The user can accept the system's recommendations or he can obtain a listing of what programs are currently stored and scheduled to be stored on the storage device and can choose to remove the unwanted programs from the storage device. The user selects the unwanted programs by placing an “X” next to the program's name or he can let the system select the programs that will be removed.
Referring toFIG. 25, any program schedule conflicts are displayed2501 to the viewer immediately whenever a conflict arises. Such conflicts can be caused, for example, by the viewer selecting two programs to be saved that are shown at the same time or have overlapping times when only one tuner is available.
Referring again toFIG. 14, the viewer can also use the thumbs up1405 and thumbs down1404 buttons on theremote control1401 to tell the system what actors or types of shows he does or does not prefer. For example, the viewer can select actors from a list and place one, two, or three thumbs up or down next to a particular actor's name. The viewer can access his favorite actor list and add or delete actors from the list. Favorite directors are designated in the same way as favorite actors. The system adjusts to the viewer's preferences and suggests programs with the actors, directors, and types of shows that the user prefers.
With respect toFIGS. 7 and 26, as the user watches a program, atrick play bar2601 is overlaid onto the live video. TheCPU713 uses the OSD generator to display thetrick play bar2601 and its associated components through thedigital mixer718 to the TV or monitor. Thetrick play bar2601 visually informs the user of the size of the circular program cache is and, if the cache is not at capacity, how much of the cache is filled. TheCPU713 is informed by theMedia Switch701 of the frame that is being displayed and the cache status.
The current program is stored in a circular cache as described above. Thegreen cache bar2602 inside of thetrick play bar2601 indicates how much of the circular cache is filled. Time marks2603,2604 are displayed inside thetrick play bar2601 giving the user a visual reference point from which to judge the current time and how far back in time the cache has recorded. The time marks2603,2604 can be any increment of time needed, but usually are in half hour or15 minute increments. Every half hour (or selected increment), thecache bar2602 slides to the left. The current time is always between the time indicated atright hand side2610 of thetrick play bar2601 minus the time increment of themiddle time mark2604 when watching live television. The entire length of thetrick play bar2601 is calculated by subtracting the time indicated on theleft hand side2609 of thetrick play bar2601 from the time indicated on theright hand side2610 of thetrick play bar2601.
Aslider2605 moves along thetrick play bar2601 and on top of thecache bar2602. Theslider2605 along with theposition indicator2608 are linked together and tell the user visually where his current position is within the program material. The slider displays thetime mark2605 of the position. Amode indicator2606 is positioned below theslider2605 and follows the slider's2605 movement. Themode indicator2606 displays whether the user is in play, record, pause, slow play, fast play, fast forward (1×, 2×, and 3×), slow reverse play, slow reverse, and fast reverse (1×, 2×, and 3×) modes. The 1×, 2×, and 3× speeds are adjustable by the system to be any variable desired (e.g., 2×, 16×, and 32×).
Thecache bar2602 expands, when the cache has not been filled, to the right as more of the program is stored in the circular cache. If the cache is filled, thecache bar2602 simply shifts to the right. When thecache bar2602 reaches the end of the right side of thetrick play bar2601, it will shift to the left side of thetrick play bar2601 so the right hand end of thecache bar2602 is positioned in thetrick play bar2601 at thetime mark2604. Theslider2605 andposition indicator2608 within thetrick play bar2601 will also shift in unison with thecache bar2602, reflecting the current position in the cache. The time display at theright hand side2607 of thetrick play bar2601 will be one half hour from thetime mark2604 at the middle of the trick play bar2601 (when half hour increments are used).
The left half of thetrick play bar2601 can also display a compressed time scale. The compressed time scale is used when a large circular cache is used. Sometimes it is not desirable to have the right half of thetrick play bar2601 indicating a time span larger than a half an hour because thecache bar2602 shifts to the left when it reaches the end of the right side and can be confusing to the user.
Theslider2605 can be moved anywhere within thecache bar2602 by the user. The user uses theplay1411,rewind1407,fast forward1408,pause1412,slow motion1413,jump1414, andinstant replay1415 buttons to position theslider2605. Thejump button1414 positions theslider2605 at the end of thecache bar2602. While theinstant replay button1415 causes theslider2605 to reposition ten seconds (the time span is system adjustable) backwards into thecache bar2602, thereby allowing the user to view a portion of the program in the same manner as an instant replay operates in football broadcasts.
When the user watches a program that has been recorded, the trick play bar time indicator on theright hand side2610 represents the total time of the program recording. Thecache bar2602 fills the entiretrick play bar2601 indicating that the program is stored entirely on the system. If a partial program is stored, then thecache bar2602 displays the length of the program saved by the system. For example, if the user records a program after it has already started and the system does not have the beginning of the program stored in the cache, then thecache bar2602 will show that the program starts a certain amount of time after the beginning of the program. The same type of behavior occurs when a program being recorded has prematurely ended. Thecache bar2602 will end at the point where the recording stopped. Theslider2605 displays the amount of time (e.g., one hour) in the program that the user is at. Themode indicator2606 operates as described above and below.
Referring toFIG. 27, the components around the trick play bar are shown. The trick play bar is shown by itself2701 and with thecache bar2702,slider2703, and a half-hour timing mark2704. The mode indicator can indicate that a recording is inprogress2704. A unique aspect of the invention is that the user can move around the program material that has been recorded while the actual recording is taking place. Theslider2703 can be moved to any point in thecache bar2702. Thecache bar2702 indicates the progress of the recording. Themode indicator2705 will display any combination ofrecord2706 and play2707, rewind (three speeds)2708,2709,2710, fast forward (three speeds)2711,2712,2713,pause2714, andslow motion2715. Examples of record combined with 2×fast forward2716 and 3×fast forward2717 are shown.
The trick play bar and its associated components are drawn over the program content for a short duration. The trick play bar appears whenever the user activates any of the trick play features i.e., record, play, rewind, fast forward, pause, and slow motion. If the mode is either play or record, then the trick play bar and its associated components will remain on the screen for a short time period. This removes any obstructions from the program material displayed on the screen and is for the convenience of the viewer. This time period is adjustable by the system. The trick play bar and its associated components may be displayed indefinitely if in an editing mode or a dedicated trick play display is used.
Additionally, index or bookmark indicators are displayed over the trick play bar. These marks appear as, for example, a vertical bar that is colored, flagged, or labeled uniquely giving the user visual cues that an index or bookmark exists in that position. The user can sequentially jump to each index or bookmark indicator by pressing thejump button1414 on theremote control1401. Indexes and bookmarks are easily placed or removed by the user as noted above.
The invention's trick play bar can be applied to any video or audio application where the physical position in the material is readily ascertainable e.g., DVDs, VCRs, MP3s, etc.
Another unique aspect of the invention is that the user can watch a pre-recorded program stored on the storage device while the system is recording another program and storing it on the storage device. This simultaneous operation is a natural feature of the architecture of the invention. The number of programs being recorded and stored on the storage device is extended to the number of tuners or sources available in the system.
Referring again toFIGS. 14 and 15, the invention predicts the position (overshoot correction) in the program material where the user expects to be when the user stops the fast forward or reverse modes. The user commands from theremote control1401 are received by theControl Input Module1504. The user initially places the operational mode into fast forward or reverse by pressing thefast forward button1408 or thereverse button1407. Theviewer interface1503 tells theMedia Control1501 to fast forward or reverse the program material. Each successive press of thefast forward1408 or reverse1407 buttons places the system into the 1×, 2×, or 3× fast forward or reverse modes, respectively. When the user wants to stop the fast forward or reverse progression, he simply presses any other media control button, however theplay button1411 is most commonly used.
Theviewer interface1503 receives the command from theControl Input Module1504 and tells theMedia Control1501 to stop. TheMedia Control1501 sends theviewer interface1503 the frame position where the program material was stopped. The viewer interface then tells theMedia Control1501 to transition to the mode the user selected and passes theMedia Control1501 the frame to start the mode from. This frame start position is the present frame with an overshoot correction factor added or subtracted from it.
The invention adapts to the user by remembering how much the user corrects (i.e., reverses or fast forwards) after he stops the fast forward or reverse mode (in each speed). Correction factors are calculated by taking the user's corrections and setting the factors to the average, median, or any other method desired, for each speed. The system will adjust the correction factors if it observes that the user continues to make corrections.
The invention also uses a prediction method to correctly place the user within the program upon transition out of either mode. The prediction method determines if the user is in 1×, 2×, or 3× fast forward or reverse modes and then automatically subtracts or adds, respectively, a time multiple (depending upon the actual speed used for 1×, 2×, or 3×) to the frame where the transition was detected and positions the user at the correct frame. The system fine tunes the time multiple if it sees that the user is consistently correcting after the fast forward or rewind mode stops.
Another method initially tests the user's reaction time using a test video. It asks the user to press thefast forward1408 or reverse1407 button during the test video and then asks the user to position the video to the place that he expected the system to have been. This time span is then used whenever the user uses the fast forward or reverse modes and is adjusted with a multiple for each speed.
A final method allows the user to simply set a sensitivity setting that the system will use as a correction factor. The invention will subtract or add a multiple of the factor to the release frame whenever the user uses the fast forward or reverse modes, respectively.
The invention's overshoot correction can be applied to any video or audio application where the physical position in the material is readily ascertainable e.g., DVDs, VCRs, MP3s, etc.
With respect toFIGS. 7, 14, 28, 29, 30, and 31 the invention displays aprogram guide area2801 to the user which is a list of the programs that are currently airing, was aired, or is scheduled on live TV. Program guide information is stored on thestorage device710. TheCPU713 parses the program guide information and creates program schedule information.
Theprogram guide area2801 is semi-transparent and overlays on theactual broadcast program2802 that the user is currently watching. The user can see how theprogram2802 is progressing while he is browsing theprogram guide schedules2803, thereby allowing the user to immediately switch back to theprogram2802. For example, the user switches to browsing theprogram guide2803 while a commercial break has occurred during the current program. The user sees when the commercial break ends and immediately switches back to theprogram2802.
A simple touch of the LiveTV Guide button1409 on theremote control1401 brings up a centralprogram guide area2801 where the user navigates through the program schedule information. Theprogram guide area2803 presents what is on live TV now, what is on all channels, and what is on a particular channel that is coming up. The invention displays the program guide information in two different modes: two column or three column. Generally, only two columns are shown on the screen at a time to declutter the display and present the information to the user in a friendlier format. The information is not presented in the traditional channel/time grid format.
The twocolumn mode2803 displays the available channels in a rotating endless list fashion in theleft hand column2804 and the programs for the highlighted channel in theright hand column2805. The user scrolls or pages up or down through the channel list by pressing thebutton1403 up or down, or thechannel button1410 up or down, respectively. The interface is consistent throughout all columns with respect to scrolling and paging. Whispering arrows are also consistent in this interface, showing that more information exists in the indicated direction. Information is also more detailed as the highlight bar is moved to the right (successive disclosure) as described above.
Thecurrent time period2807 is shown above theleft column2804 on the screen. Thetime period2807 is easily changed by the user. The user changes thetime period2807 through a single press of the back1407 or forward1408 button on theremote control1401, moving thetime period2807 backward or forward, respectively. Below the time display is the listing of thechannels2804 available to the user. Next to each channel number2809 is thestation ID2810 and thetitle2811 of the current program that is being aired. The user moves thehighlight bar2812 over the channel that he is interested in and adescription2806,2808 of the current program that is showing on the channel2809 is displayed. An embodiment of the invention places thedescription area2806 above the two columns. As the user changes thetime period2807, theprogram titles2811 change to the names of the program that were, are, or will be shown at thattime period2807. The programs in theright hand column2805 will also change to correspond to thetime period2807.
Program information for the program currently showing on the highlighted channel is displayed in theupper area2806,2808 of theprogram guide area2810. All of the data that the user needs to know about the program that is currently selected is displayed in theupper area2806,2808. This information includes: the program title; episode title; program description; the actors or actresses appearing in the program; any advisories; audio parameters; the genre that the program is in; start and stop times; the program's MPAA or TV rating; the logo of the network that the program is being broadcast on; the current time; if the program is selected to be recorded; if it has been selected as a season pass; if the user has expressed a thumbs up or down rating.
The user moves the highlight bar to theright hand column2805 by pressing the right side of thebutton1403 on theremote control1401 allowing him to scroll through theprograms2805 for that particular channel. As each program is highlighted, the program's information (as described above) is displayed in theupper area2806,2808 of theprogram guide area2801.
Theright hand column2805 displays a schedule of the programs for the particular channel. The schedule begins at thetime2807 indicated above theleft column2804. Theprogram name2814 and starttime2813 are displayed. For example,channel2 is highlighted and the right hand column shows all of the programs showing from the current or selected time. The user can move the highlight bar up and down the list ofprograms2805, scrolling through the time slots for each day in the program guide information. As described above, a page up or page down function is also easily accessed by the user. This saves the user the effort of having to scroll through the program list in either column.
The channel number andID2815 are displayed above theright hand column2805. The user changes thechannel number2815 through a single press of the back1407 or forward1408 button on theremote control1401, moving thechannel number2815 backward or forward, respectively, through the channel list. The channel list in theleft hand column2804 follows the user's channel selections, scrolling backward or forward in the channel list. The program list in theright hand column2805 changes to the programs associated with thechannel number2815 selected by the user, starting at the time indicated2807 above theleft hand column2804.
The program list in theright hand column2805 can be shown in two intuitive forms. Thefirst form3201 lists thestart time3202 of each program next to theprogram name3203. Thelist3204 is in descending order from the most recent time to the latest time.
Thesecond form3301 also lists the start time3302 next to each of the program names3303. Thelist3304 continues the time intervals3302 by listing each half, quarter hour, or selectable intervals. The duration of the program is indicated by an arrow3305 extending from the program start time3302 down to theprogram end time3306. This gives the user a visual cue as to the duration of the program time slot.
The user can highlight a program and again move the highlight bar to the right to obtain a screen such as the one shown inFIG. 18. The user is given choices to watch the program now (if the program is currently airing)1802, record theepisode1803, get aseason pass1804, view a list of the upcoming showings of theprogram1805, cancel the recording (if the program is being recorded or is scheduled to be recorded)1806, or view programs in thattheme area1807.
The three column mode adds a higher level column to the two-column mode. This means that, conceptually, an additional column is added to the left of the channel column, although visually, only two columns are displayed at a time. Larger screens and higher resolutions will allow all three columns to be displayed at once. The program guide information is sorted in different ways, e.g., allmovies2901,favorite channels3001, allchannels3101, all sports, etc. Thefirst column3103 contains the sorting methods available to the user. Thesecond column3104 presents the available channels that correspond to the sorting method with the description of the channel column consistent with that of the two-column method. The user simply highlights the preferred sorting method with thehighlight bar3102. The sorted channels then appear in theright hand column3104.
The user can then move the highlight bar to theright hand column3104 by pressing the right side of thebutton1403 on theremote control1401 allowing him to scroll through thechannels3104. The program information for the highlighted channel is displayed in the upper screen area of the program guide area as described above. The user can once again move the highlight bar to the right to obtain the two column channel/program format described above. This two column format may differ (when a sort method other than all channels is selected) in that the channels displayed in the left hand column are those that correspond to the sorting method.
The user presses the LiveTV Guide button1409 again to remove theprogram guide area2801 from the screen and to return to the program viewing mode.
The invention generates transitional sounds through thedigital mixer718, as described above, whenever the user moves the highlight bar to another area. Warning sounds occur when the user attempts an action that is not allowed, e.g., when the user tries to move the highlight bar to an area that does not exist, i.e., where a whispering arrow is not displayed. These sounds can be turned on or off by the user.
Referring again toFIG. 15, a plurality of user preferences can be stored on thestorage device1502. The user preferences can encompass user interface preferences (e.g., background colors, display font size, etc.), viewing preferences and patterns, which of the programs that are stored on the local storage device have been recorded by the user, playlists, etc. The user preferences are recorded as the user operates the system. Some aspects of the user preferences are passive and are determined by the system while others are specifically set by the user.
TheControl Input Module1504 receives the remote control's command signals when the user uses the remote control. The user identification process can occur in many ways. For example, the remote control sends an identifier message to the system via theControl Input Module1504 whenever the user presses a button on the remote control. The message can be a small ID message or a simple binary message header. This allows theControl Input Module1504 to be immediately informed of the user's identity. If another user uses another remote control, then the system can immediately identify the user change.
Another example for the remote control to identify the user to the system is not as up to date. The user can press a button on the remote control that sends an identification message to theControl Input Module1504. This puts the responsibility on the user to perform the identification process. Yet another example allows the system to poll the remote control for an identification message whenever the remote is used.
The remote control can be uniquely encoded by the user or at the factory by storing a unique identifier in the remote control. For simplicity, the remote control's user ID code can be unique within the user's household. This cuts down on the number of unique IDs required.
Theviewer interface1503 processes the remote control's identification and checks the preferences on thestorage device1502 for any associated preference files. Theviewer interface1503 then uses the associated preference file (or default preference file if no match was found) for the user. For example, if theviewer interface1503 finds that the users have just changed, theviewer interface1503 can reconfigure the displayed Now Showing screen as shown inFIG. 17 to display the new user's recorded shows and can adjust display font sizes and background colors to the user's preferences. This allows the system to adapt to children, for example, and present a simple interface that a younger child can respond to and be entertained.
The remote control can also identify the user to the system using other methods. Referring toFIG. 35, a user can have an associatedtag3401, e.g. an RFID tag that can be attached to a key ring, necklace, watch, in his wallet, or even a sub-dermal tag inserted somewhere in the user's body. Theremote control3402 detects the tag via radio signals in a limited radius so the remote control does not get confused by signals emanating from other users' tags.
Theremote control3402 notifies theControl Input Module1504 on themultimedia device3403 of the user's identity.
As noted above, all aspects of the user's experience can be tailored to the preferences of that user. For example, multimedia content such as broadcast or recorded television programs, music play lists, and the like could be sorted, displayed, or restricted, depending on the user identifier. User preferences such as parental controls, channel lineups, programmable button functions such as radio station preset buttons, even room lighting could all be customized. Certain users can have access to system setup information (administrative privilege) while others may be restricted.
Users could be members of groups within a household and share attributes of their preferences. Theviewer interface1503 can allow a user to exchange GUI preferences, for example, so that other users can use his customized user interface and graphics.
An embodiment of the invention allows theControl Input Module1504 on themultimedia device3403 to directly read the user'stag3401. TheControl Input Module1504 sends the information transmitted from the user'stag3401 to theviewer interface1503. Theviewer interface1503 processes the information to determine the user's identity and checks the preferences on thestorage device1502 for any associated preference files as described above.
Another embodiment of the invention uses a photo player or a music player as themultimedia device3403. Themultimedia device3403 detects the user'stag3401 and reads the user's ID from the tag. Themultimedia device3403 finds the user's ID in a list of users and determines that the user has a preference for a certain type of photos or music. Themultimedia device3403 then displays the photos or plays the music that fall into the type that the user prefers.
This embodiment works in a home, for example, where one user prefers classical music and another prefers rock and roll. When one user walks into the room where themultimedia device3403 resides, themultimedia device3403 switches to the type of music that the user prefers. When both users are in the room, the multimedia device acts as described below, finding a common ground between the two users. this embodiment also works for electronic photo displays where themultimedia device3403 displays a different style of photos or selection of photos for each user.
Yet another embodiment of the invention allows theControl Input Module1504 on themultimedia device3403 to directly read a plurality of users' tags. This situation occurs when a family is sitting in the same room using themultimedia device3403. TheControl Input Module1504 reads all of the user tags within its range and sends the identification information that it extracts from the tag signals to theviewer interface1503. Theviewer interface1503 can correlate all of the users' preferences and determine if any intersections exist. Theviewer interface1503 can then display any intersections in program material, e.g., displaying any recorded television shows that all of the users may enjoy. This would allow the system to not display a list of “R” rated movies when there are underage children present, for example.
A more powerful method of identifying the user is to have a memory device in thetag3401. The tag can then store the user's preferences for a plurality of devices, e.g., a DVR, a car radio, the car's climate control settings, an MP3 player, a photo display device, etc. The user'stag3401 can be queried by any device that he is near, such as his car or theremote control3402. Theremote control3402, for example, can transmit the user's preferences to theControl Input Module1504 on themultimedia device3403. This allows the user to use anymultimedia device3403, a DVR for example, that accepts his preferences. Themultimedia device3403 does not have to constantly store the user's preferences to customize his user experience.
This allows the user to go to a hotel, for example, and have the hotel's DVR customize itself to the user. The hotel's DVR can retrieve the user's preferences from histag3401 and customize the DVR's recordings, channels, and UI to the user. This also allows the DVR to target ads stored on the DVR to the user. The DVR can display ads targeted to the user's demographics in a program guide or during a program that the user is watching. The DVR can insert customized commercials that it has determined the user will watch into a TV show that the user is viewing. For example, the commercials can be for local businesses that cater to the user's age and gender or for a car manufacturer that wants to target the users age and gender.
The DVR service provider can charge a fee to the advertisers for the number of ads that the user views or simply for the use of the user's information. The DVR service can also charge a hotel for the use of the user's information. The hotel can charge a fee to local advertisers for displaying their commercials to the user.
FIG. 35 shows a tag characterized as amobile data device3501 that can be independently queried by amultimedia device3502. Themobile data device3501 can be a PDA or a laptop, for example. Themobile data device3501 can carry a large amount of data that can be queried by themultimedia device3502. Themultimedia device3502 can be synched with themobile data device3501. This allows amultimedia device3502 to provide a very detailed customized experience for the user. Themobile data device3501 could carry the user's favorite MP3′s which could be temporarily synched to themultimedia device3502. Themobile data device3501 can store the user's recently recorded programs from his home DVR which can be transferred to themultimedia device3502 upon a synch session. Themobile data device3501 can be used in the same manner as the tags described above.
Although RFID tags are mentioned above, other methods of identifying the user may be used, e.g., computer vision recognition, biometric identification (fingerprint, retinal, IR patterns, etc.), voice analysis, etc.
An embodiment of the invention allows the user to customize his user experience at remote locations via a service.FIG. 36 shows a DVR service example. The user makes an online reservation with a hotel for a specified period of time. The user can simply check a box during his reservation session that indicates that he is a subscriber to aDVR service3602. The hotel'sserver3603 contacts theDVR service3602 for the user's viewing preferences via anetwork3605, such as the Internet. The hotel can have a privacy agreement with the DVR service that protects the user's information.
TheDVR service3602 can contact the user'shome DVR3601 for the user's viewing preferences. TheDVR service3602 receives the user's viewing preferences from the user'shome DVR3601 and forwards the user's preferences to thehotel server3603. TheDVR service3602 deletes any local storage of the user's preferences. This allows theDVR service3602 to preserve the user's privacy.
TheDVR service3602 can also have the user's viewing preferences already stored locally. In that case, theDVR service3602 sends the user's viewing preferences to thehotel server3603.
Thehotel server3603 uses the user's viewing preferences to record programs that the user had scheduled hishome DVR3601 to record during the period of his stay at the hotel. Thehotel server3603 can use the user's viewing preferences to record shows within a few days before the user is to arrive just in case the user has not watched the shows on hishome DVR3601. The user could also specify the number of days or specific shows that he wants recorded before he arrives.
When the user arrives at the hotel, thehotel server3603 makes the programs that it has recorded available to the user via aDVR3604 in the user's room. The advantage to having thehotel server3603 perform the recordings is that it is typically a hotel's practice to assign a room to the user at the time the user checks into the hotel. Therefore, the user's room can be unpredictable. Thehotel server3603 can allow only theDVR3604 in the user's room to access the programs recorded for the user. Alternatively, theDVR3604 can transfer the programs recorded for the user directly to its local storage and have them ready for the user to view. Thehotel server3603 can delete the user's viewing preferences when the user ends his stay at the hotel.
If the user has changed any of his viewing preferences while interacting with theDVR3604 in his hotel room, he can command thehotel server3603 to send an update to theDVR service3602. When theDVR service3602 receives the user's update viewing preferences it can update its locally stored copy of the user's viewing preferences, if it has them. TheDVR service3602 can send the user's viewing preferences changes to the user'shome DVR3601. The user'shome DVR3601 updates its copy of the user's viewing preferences based on the information received fro theDVR service3602.
For example, the user may have viewed a program that was recorded by thehotel server3603 and was also recorded by hishome DVR3601. The user may want to have the program deleted from hishome DVR3601 since he has already viewed the program at thehotel DVR3604. The user can instruct thehotel server3603 to update his viewing preferences and thehotel server3603 notifies theDVR service3602. The DVR service sends the user'shome DVR3601 the viewing preference update and the user'shome DVR3601 then deletes the program from its recorded programs.
An embodiment of the invention allows thehotel server3603 to obtain a program list from theDVR service3602. TheDVR service3602 derives the program list based on the user's viewing preferences when thehotel service3603 requests a program list for the user. TheDVR service3602 sends the program list to thehotel server3603. Thehotel server3603 then records programs from the program list to make programs available to the user when he arrives. This approach allows theDVR service3602 to preserve the user's privacy by retaining the user's viewing preferences and only making a program list available to thehotel server3603. The information from the program list itself does not allow an outsider to derive a user's viewing preferences.
Yet another embodiment of the invention allows thehotel server3603 to provide a list of programs that it has stored locally to theDVR service3602. TheDVR server3602 evaluates the list of programs and creates a sub-list of programs from the list of programs that theDVR service3602 believes the user would like to view based on the user's viewing preferences. TheDVR service3602 sends the sub-list to thehotel server3603. When the user checks into the hotel, thehotel server3603 makes the sub-list of programs available to the user via theDVR3604 in the user's room.
An embodiment of the invention allows thehotel server3603 to aggregate all of its guests' scheduled recordings. Thehotel server3603 can use the aggregated recording schedule to record one copy of a show that may have been scheduled by several guests. The single recording can be accessed by the DVRs in those guests' rooms. Further, thehotel server3603 can examine the user's viewing preferences and select from the programs that it has already recorded any programs that the it finds that the user may like to view. Thehotel server3603 can use the types of programs that the user prefers to make the correlation between the programs that it has already recorded and what it believes the user would like to view. Thehotel server3603 can also use other parameters of the user's viewing preferences to select programs.
TheDVR3604 in the user's hotel room also customizes its user interface using the user's viewing preferences. The user has a viewing experience that can be identical to the user's viewing experience at hishome DVR3601. This can differ if the hotel wants to implement customized commercials, for example.
TheDVR service3602 can also retrieve any recorded programs from the user'shome DVR3601 that the user has indicated that he wants to view at the hotel'sDVR3604. The DVR service forwards the retrieved programs to thehotel server3603. Thehotel server3603 allows theDVR3604 in the user's room to access the retrieved programs.
An embodiment of the invention allows thehotel server3603 to transfer programs to a DVR's local storage across a local network to reduce the load on thehotel server3603.
TheDVR service3602 can charge the hotel a fee for the use of the DVR service's personalization service.
Although a DVR service is described above, any service basis may be used.
Although a hotel server and DVR are described above, the invention can be applied to other multimedia devices and scenarios such as MP3 players, set top boxes, televisions, temperature preferences for a room, lighting preferences for a room, fast food preferences displayed on a device at a fast food vendor, etc. Further, a multimedia device may contact a service directly.
Although the invention is described herein with reference to the preferred embodiment, one skilled in the art will readily appreciate that other applications may be substituted for those set forth herein without departing from the spirit and scope of the present invention. Accordingly, the invention should only be limited by the Claims included below.