The present invention generally relates to the presentation of alternate content within linear television during channel change.
Attracting and retaining viewers has become a key business challenge for television (TV) channel operators as this normally has a direct impact on their revenues. As a result, TV channel operators are increasingly employing strategies/techniques to stop viewers from tuning away between two shows. Examples of such techniques include: “squeezing back” the program credits to present a trailer for the next show; presenting customized advertisements during a commercial break; etc.
The present invention will be understood and appreciated more fully from the following detailed description, taken in conjunction with the drawings in which:
A method for presenting alternate content during a channel change on a video content playing device includes: receiving a viewer's request to tune to a particular channel, retrieving tuning context data from a memory of the video content playing device, where the tuning context data is indicative of a context in which the viewer tunes to the particular channel, processing the tuning context data using a channel function associated with the particular channel to identify alternate content likely to be of interest to a viewer of the particular channel, identifying a network address for the alternate content associated with the particular channel in accordance with a result of the processing, retrieving the alternate content according to the network address, and presenting the alternate content on the video content playing device before presenting the program currently being broadcast on the particular channel.
Linear TV is still the mainstay of the television experience and presents content to viewers in a pre-agreed, ordered sequence, aligned to time/schedule fashion. This schedule is typically the same for all viewers as linear TV is normally broadcast in a one-to-many model.
Linear TV viewers often engage in “channel hopping” navigation techniques allowing them to “taste” content on a variety of different channels quickly. Given that viewers may join a channel at any time, it is not likely that their encounter with a channel will neatly align to program boundaries within its schedule. For example, viewers may join shows that have already begun or are close to their end or they may join a channel whilst it is showing non-program interstitial content such as adverts, promos, trailers, station idents, etc.
The viewers' rendezvous with a channel may be driven by a specific intent (e.g. they have tuned-in to watch a specific program) or may be unintentional (e.g. they have tuned-in because they are channel surfing). In both situations, it is possible that the content currently being broadcast on the channel is not in harmony with the intent, interests or mood of the viewer at that time. As it stands, there is no mechanism for the channel to assess these axes and/or to modify the channel content to be more line with them.
The inventors of the present invention have realized that, in many cases, it may be preferential for the channel to show individual viewers alternate content, for a given time period, in order to minimize the risk of them tuning away and also to maximize their engagement with the channel and its content.
Reference is now made to
In accordance with embodiments described herein, during the zapping time (i.e., between t1 and t2), the video content playing device is operative to collect enough data allowing it to make a judgment of the intent behind the viewer's rendezvous with channel 2. The video content playing device is further operative to process the collected data in view of channel 2's business context and content catalogue in order to identify and present to the viewer, at t2, a personalized alternate content 110 for a given period of time (corresponding to the time difference between t2 and t3 in
After displaying the personalized alternate content 110 and the zapping sequence between channel 1 and channel 2 is complete, the second program 120 currently being broadcast on channel 2 may be presented (at t3 in
The presented alternate content may be of any suitable form and may include any type of information associated with the channel the viewer has tuned to such as video, audio, graphics, pictures, text, and multimedia content. Examples of alternate content to be presented to a viewer include, but are not limited to, the following: advertisements, music or other audio information, icons representing particular services, current promotions, live streams, still images and program suggestions. Table 1 below gives some exemplary alternate contents that may be presented according to different zapping scenarios:
Reference is now made to
It will be appreciated that the depiction of display screen 220 and memory 240 as integrated components of video content playing device 200 may be exemplary. In some embodiments of the present invention, the functionalities of display screen 220 and memory 240 may be implemented as independent components accessed by video content playing device 200. For example, display screen 220 may be implemented as a television on which video content received via I/O module 230 is presented. Furthermore, in some embodiments of the present invention, some or all of the components of video content playing device 200 may be cloud based and accessible via a communications network such as, for example, a LAN (Local Area Network), WAN (Wide Area Network) or the Internet.
It will also be appreciated that video content playing device 200 comprises at least one non-transitory processor-readable storage media (e.g. memory 240). The memory 240 may store instructions, which the processor 210 may execute, in order to perform the methods described herein. Memory 240 may also store some or all of the alternate contents (not shown) that may be presented to the viewer as well as data to be used by the processor 210 to identify which alternate content to present. Memory 240 may comprise read only memory (ROM), random access memory (RAM), magnetic disk storage media devices, optical storage media devices, flash memory devices, electrical, optical, or other physical/tangible (e.g. non-transitory) memory storage devices.
Video content playing device 200 comprises hardware and software components, such as are well-known in the art. It will be appreciated that video content playing device 200 may comprise more than one processor 210. For example, one such processor 210 may be a special purpose processor operative to at least identify and present an alternate content on display screen 220 according to a method described herein. Processor 210 may be operative to execute instructions stored in a memory 240. I/O module 230 may be any suitable hardware and/or software component operative to use protocols such as are known in the art to receive and/or send video content and associated commands and/or instructions.
Reference is now made to
The processor 210 may be operative to collect and store, in the viewer action element 241 of memory 240, data representative of the navigation pattern that preceded a channel change. In other words, this data describes how the viewer reached a particular channel. There are many ways for a viewer to reach a particular channel and different levels of intent may be inferred from each of them. The list below provides some non-limiting examples of data collected by the processor 210 and representative of different navigation patterns:
channel up/down buttons;
sequence of channel up/down buttons by viewer repetition;
sequence of channel up/down buttons by remote control auto-repeat;
direct channel change by typing a channel number;
selection of a channel from an EPG (Electronic Program Guide);
selection of a program from an EPG;
on-screen reminder (auto-tuning);
first channel after STB power on;
selection from companion device or application; etc.
Additional data may also accompany the specifics of the viewer action. For example, but not limited to, the video content playing device 200 may also monitor the channel the viewer came from before the channel change. This may provide, in some situations, additional information on the viewer's intent. For example, when the viewer is tuning to a channel which is a temporally displaced version of the previous channel, it may be inferred that the viewer's intent is to watch again or has missed a particular portion of a program. Another example of additional data may be the frequency with which the navigation has previously occurred. For example, the viewer may have been channel surfing up and down repeatedly over the last fifteen minutes or he/she may have done it only once during this time period.
Additionally, the processor 210 may be operative to collect and store, in the viewer context element 242 of memory 240, data relevant to the viewer and/or the household. The list below provides some non-limiting examples of such data:
demographics and geography;
presence of programs (or genre, subgenres, etc. of programs) in the DVR (Digital Video Recorder) planner;
viewing history;
recording history;
previous responses to linear TV changes made by the system; etc.
Furthermore, the processor 210 may be operative to collect and store, in the schedule context element 243 of memory 240, data representative of the program currently being broadcast on the channel reached by the viewer. The list below provides some non-limiting examples of such data:
current position within the program on the channel;
next program in schedule and when this next program starts;
current promotions relevant to the channel;
information about the program status such as whether it is a live event, a popular show, a first run show;
whether the current position in the program would contain spoilers, such as soccer scores, judge results; etc.
When the viewer tunes to a particular channel, the processor 210 may also be operative to retrieve: data relevant to the tuning context such as, for example, data from the viewer action element 241, the viewer context element 242 and the schedule context element 243 of memory 240; identify a channel function 244 associated with the particular channel; and execute the channel function 244 using the retrieved data. A channel function 244 is employed to increase the likelihood that a “zapping” or “surfing” viewer will stay tuned to the particular channel by processing tuning context data such as elements 241, 242 and 243, in order identifying alternate content that may attract the interest of the viewer.
By way of illustration, in accordance with an exemplary embodiment, data from the viewer action element 241 may indicate that the first channel after STB power-on was an all-sports channel, and that the viewer had been repeatedly changing channels by directly typing in the channel numbers for three other all-sports channels. Data from the viewer context element 242 may indicate that the most of the recordings are of college football games. Data from schedule context element 243 may indicate that a college football game is scheduled to start on the current channel in five minutes. Given such exemplary tuning context data from elements 241, 242 and 243, the channel function 244 may determine that alternate content related to college football, and particularly the game scheduled to begin in five minutes, may attract the interest of the viewer and encourage him/her to stay tuned to the channel until the football game starts. Accordingly, in accordance with the exemplary embodiment, the channel function 244 may be operative to return a n address for a suitable alternate content item, such as, for example, a five minute pre-game review of the scheduled game.
A channel function is typically a set of software instructions defined and controlled by a channel operator enabling the processor 210 to identify which alternate content to present when the viewer tunes to a particular channel. As such, each channel operator may provide at least one channel function that may be stored either locally in memory 240 of the video content playing device 200 or remotely (e.g. in the “cloud”, at a headend, etc.).
Accordingly, a channel function may be understood to be a logical construct which takes contextual input from the system in various classes and computes whether alternative content should be shown. In accordance with embodiments described herein, there may be several implementation options for a concrete instantiation of such a function. For example: a channel function may be implemented as a standard piece of software written in an imperative language such as Java and accessed directly in a runtime environment such as is known in the art. This option may provide maximal flexibility of the algorithms being used, but may also require significant resources in order to perform in the runtime environment. Alternatively, or in addition, the channel function may be implemented within the context of a ruleset within a rules engine. This may serve to normalize the runtime environment requirements, but conversely may also restrict the algorithms used to those that may be expressed as a set of connected rules. Alternatively, or in addition, a decision tree may be used to implement the channel function. A decision tree is a declarative document which may be computed in a single forward pass, thereby limiting its impact on the execution environment, but possibly precluding the use of overly complex decision algorithms in the function.
It will therefore be appreciated by one of ordinary skill in the art that the channel functions may be encoded in pre-defined meta-languages, declarative models or decision matrices, which contain their processing capabilities in some finite way or, alternatively, they may be freely coded in imperative languages by software engineers working for the channel providers. In any case, each channel function 244, when executed by the processor 210 using the data relevant to the tuning context, returns a network address, such as, for example, but not limited to, a URL (Uniform Resource Locator) locating the alternate content to present to the viewer or a NOP (No OPeration) command indicating that no alternate content is to be presented to the viewer.
If the processor 210 receives a URL as result of the channel function processing, the processor 210 is further operative to present the alternate content per the URL to the viewer on the display screen 220 at t2 before switching-back to the program currently being broadcast on the channel at t3. To do so, the processor 210 first retrieves the alternate content using the URL before frame-level switching-in the alternate content into the linear stream and frame-level switching-back to the linear stream once the alternate content has been presented to the viewer. Although Channel 2 may be ready to be presented before t3 (i.e. the zapping process may be achieved before t3), the alternate content is presented for a given period of time defined by the channel function 244 and corresponding to the time duration between t2 and t3 as depicted on
It will be appreciated by one of ordinary skill in the art that the insertion of personalized alternate content 110 introduces a temporary lack of synchronization between the content stream received by the exemplary viewer (as depicted as the ‘Channel 2 personal linear schedule’ and the content stream received by other viewers of “Channel 2” (i.e., “Channel 2 standard linear schedule”). Between t2 and t3, while the exemplary viewer receives alternate content 110, other viewers receive standard content 130. Accordingly, while the exemplary viewer may not receive standard content 130, the switch back video (120) is the same for both the exemplary viewer and other viewers. It will therefore be appreciated that after an initial, period of time (i.e., t2 and t3) where the content received by the exemplary viewer is not synchronized with the content received by the other viewers, eventually (i.e., from t3 forward) the content received by the exemplary is synchronized with Channel 2's standard linear schedule, i.e., the current broadcast stream from “Channel 2”.
If the processor receives a NOP command as result of the channel function processing, no further action is taken by the processor 210. As a result, standard content 130 is presented to the viewer, i.e., the program currently being broadcast on the channel the viewer has tuned to is presented on display screen 220, and alternate content 100 is not presented. Similarly, alternate content 110 is not presented to the viewer if the channel function 244 does not respond in a timely manner (e.g. before the end of the zapping process) or if the URL received by the processor 210 is inaccessible. This situation is illustrated on
Reference is now made to
In response to such a request, processor 210 of video content playing device 200 may retrieve (step 430) data relevant to the tuning context from the viewer action element 241, the viewer context element 242, and the schedule context element 243 of memory 240 (step 430). video content playing device 200 may then identify a channel function 244 corresponding to the particular channel the viewer has tuned to (step 440).
Subsequently, processor 210 of video content playing device 200 may execute the identified channel function 244 using the data relevant to the tuning context described hereinabove (step 450). In other words, the data relevant to the tuning context are retrieved from the viewer action element 241, the viewer context element 242, and the schedule context element 243. This data may then be usable by the processor 210 as input to the channel function 244.
Combining relevant data from these three elements allows the channel function 244 to return an alternate content which is the most in line with the viewer's intent. However, it will be appreciated that, in some deployed systems, it may not be possible to collect and/or retrieve the three classes of data. Therefore, in some embodiments described herein, at least one class of data may be retrieved and used by the channel function 244.
If, according to the result of step 450, the processor 210 receives a network address locating an alternate content in a timely manner (step 460), the processer 210 retrieves (step 470) the alternate content using the network address. Otherwise, the process 400 may proceed to step 490. In some embodiments described herein, alternate contents that may be presented to viewers are prepared in advance and gathered as a catalogue of available alternate contents. Additionally and/or alternatively, alternate contents available to be presented to viewers may be placed in advance at a particular network location or at different network location(s) which is/are accessible in a timely manner, thereby speeding up the retrieval process.
Once retrieved, the processor 210 frame-level switches-in the alternate content within the linear stream and the alternate content is presented to the viewer (step 480). Then, at step 490, the processor 210 frame-level switches-back to the linear stream at the end of the alternate content and the program currently being broadcast on the particular channel is presented. Once the presentation is thusly synchronized with the current program being broadcast, the Process 400 may then end (step 500).
Alternatively, or in addition, the switch back to the linear stream may be done at any suitable time rather than specifically at the end of the alternate content. For example, but not limited to, the switch back may be done at a set time or after a set duration defined by the channel function 244. This may be useful in situations where the alternate content is a live stream (e.g. ambient images from the soccer stadium before a soccer game) with no predefined end or duration. In such a case, the channel function 244 returns to the processor 210 a set time or duration at which the linear stream of the particular channel is to be presented.
In accordance with embodiments described herein, in addition to a URL for alternative content, the channel function 244 may also return an additional piece of metadata. This metadata may indicate how much of the alternative content to show before proceeding to step 490. Where the alternative content is short, for example a 30 second ad, there may be an indication to show the alternative content in its entirety before switching back to the linear stream. In accordance with embodiments described herein, this may be the default behavior for alternative content signaled by channel functions 244.
However, there may be cases where the alternative content is long, never-ending or of indeterminate length. The ambient view of a sports stadium prior to the broadcast of a sports event may be an example of such a case. In such a case, it may not be relevant to wait until the “end of the alternate content” before switching back to the normal linear stream. In such a case, the channel function 244 must therefore indicate the switch back point in the metadata it returns.
The switch back point is therefore a temporal reference which may be either relative to the alternative content, or absolute, based on “wall clock” time. For example, the channel function 244 may indicate that the switch back should occur after 60 seconds of alternative content has been played out. Alternatively it may indicate that the alternative content should continue until 20:00:00 by wall clock time.
Another, more advanced, option may be to initiate switching back based upon a particular broadcast signal. For example, a particular channel may be presenting a series of interstitial announcements prior to the start of a new program. In such a case, the alternate content may be provide in order to increase the likelihood that a “zapping” or “surfing” viewer will stay tuned to the particular channel at least until the new program starts. Accordingly, the channel function 244 may indicate that the presentation of alternative content should continue until the new program has begun its broadcast based upon standard broadcast signaling triggers.
If the processor 210 receives a NOP command, does not receive a response from the channel function 244, or if the URL received is not accessible, no further action is taken and the program currently being broadcast on the particular channel is presented to the viewer once the zapping process is complete (step 490).
It will be appreciated that the video content playing device 200 may receive a further viewer's request to tune to another channel at any time during the process 400. In such a situation, the process 400 returns to step 420.
The process ends at step 500.
It will be appreciated by one of ordinary skill in the art that in accordance with embodiments described herein, the process 400 may be implemented with an optional step allowing users to have an “override” capability in case the alternate content is undesirable to the viewing user. Similarly, in accordance with embodiments described herein, video content playing device 200 may be configured with a user interface (UI) function to enable a viewing user to enter settings to limit to some extent the frequency and/or duration of alternate content presentation. The information entered via this UI function may be included in the tuning context data processed by channel function 244.
It is appreciated that software components of the present invention may, if desired, be implemented in ROM (read only memory) form. The software components may, generally, be implemented in hardware, if desired, using conventional techniques. It is further appreciated that the software components may be instantiated, for example: as a computer program product or on a tangible medium. In some cases, it may be possible to instantiate the software components as a signal interpretable by an appropriate computer, although such an instantiation may be excluded in certain embodiments of the present invention.
It is appreciated that various features of the invention which are, for clarity, described in the contexts of separate embodiments may also be provided in combination in a single embodiment. Conversely, various features of the invention which are, for brevity, described in the context of a single embodiment may also be provided separately or in any suitable subcombination.
It will be appreciated by persons skilled in the art that the present invention is not limited by what has been particularly shown and described hereinabove. Rather the scope of the invention is defined by the appended claims and equivalents thereof: