Implementations are described that relate to providing program guide information. Various particular implementations relate to providing program guides for a hospitality context.
Program guides are typically provided for most video distribution systems that provide a variety of programs for consumption on one or more available channels. The program guides provide information about the programming on the available channels. Users typically access a program guide to help make a viewing decision.
According to a general aspect, a request is received. The request is to present a program guide on a display. The program guide provides information about programs that are available on multiple channels. In response to receiving the request, a program guide screen is provided. At least a portion of the provided program guide screen is visually divided in both a horizontal direction and a vertical direction into multiple sections. Each of the multiple sections includes information about programs available on respective distinct channels.
According to another general aspect, a program guide screen is generated. At least a portion of the program guide screen is visually divided in both a horizontal direction and a vertical direction into multiple sections. Each of the multiple sections includes information about programs available on respective distinct channels. A signal is provided that conveys the program guide screen.
According to another general aspect, a signal or signal structure includes a program guide screen section. The program guide screen section conveys a program guide screen for which at least a portion is visually divided in both a horizontal direction and a vertical direction into multiple sections. Each of the multiple sections includes information about programs available on respective distinct channels.
The details of one or more implementations are set forth in the accompanying drawings and the description below. Even if described in one particular manner, it should be clear that implementations may be configured or embodied in various manners. For example, an implementation may be performed as a method, or embodied as an apparatus, such as, for example, an apparatus configured to perform a set of operations or an apparatus storing instructions for performing a set of operations, or embodied in a signal. Other aspects and features will become apparent from the following detailed description considered in conjunction with the accompanying drawings and the claims.
Various implementations provide an alternative to a traditional program guide, with the alternative being aimed at the perceived needs of the average guest of a hotel or similar establishment. In various implementations, an alternative is provided to a traditional line-oriented program guide. The line-oriented program guide typically provides a view of programming for multiple hours, and frequently multiple days or weeks, into the future, with each channel occupying an entire line of the program guide. In contrast, various described implementations provide a mosaic-based approach that provides a navigable block-based listing.
A mosaic is used to refer to a display presentation that includes blocks, also referred to as tiles, with each block providing programming information for a separate channel. The mosaic display presentation generally includes multiple blocks in each of two directions, such as, for example, a horizontal direction and a vertical direction.
In several implementations, the block-based listing provides the following basic information that is typically desired by a user, such as, for example, a hotel guest, a student housing resident, or a senior living or assisted living resident:
Note that the information identifying what is playing “now” and “next” is provided, in several implementations, by the Program and System Information Protocol (“PSIP”) or another protocol for transmitting program information. PSIP is typically defined as the protocol used in the Advanced Television Systems Committee (“ATSC”) digital television system for carrying metadata about each channel in a broadcast Moving Picture Experts Group (“MPEG”) transport stream of a television (“TV”) station, and for publishing information about television programs so that viewers can select what to watch by title and description.
Navigation in various implementations uses the traditional arrow keys on a remote control. In various implementations, a user uses these keys to move a highlight box to a block of the mosaic that lists the program that the user wants to watch. The user then provides an input to immediately move to the channel that is showing the desired program. The input is, in various implementations, for example, an input provided through a remote control. Various implementations using a remote control allow the user to provide the input, for immediately moving to the highlighted channel, by allowing the user to press, for example, an “enter” key, a “go” key, or an “OK” key on the remote control.
Various implementations described in this application provide solutions that address one or more of a variety of problems. One such problem arises from the fact that many program guide systems need to be able to render a different guide for each room or TV at the property, at the same time. This problem arises, at least in part, due to the facts that (i) the system provides a guide that is oriented around the current channel being viewed, and (ii) the system does not know what channel will be the channel currently being viewed when the guest starts a guide search. To be able to provide a different guide for each TV requires large bandwidth and processing power at the headend in addition to back channel communication.
Various implementations described in this application address this problem by, for example, analyzing what pieces of information are most useful to the average user. Several such implementations allow a rendering of fewer guide pages because the guide is started at a selected set channel instead of at the channel to which the guest is tuned when the guest presses “guide” on the remote. This reduces both the bandwidth needed, as well as the processing power needed, at the headend. Two example renderings are discussed below with respect to
Various implementations also include video mosaics that display live video in a mosaic format with box navigation. Providing live video has certain advantages. However, particular implementations avoid the inclusion of live video in order, for example, to reduce bandwidth and processing power requirements, to reduce delays to the user, and/or to avoid the expense of additional headend equipment that is frequently needed to provide the video mosaic. Such delays arise, for example, because when the live video displays commercials the user cannot typically determine what program is playing on that channel and so must wait until the commercial is finished.
Referring to
The system 100 includes a single receiver 110 and multiple TVs 120. The receiver 110 is part of the “headend” and is configured to send channel information to the TVs 120. Each of the TVs 120 is typically located in individual rooms at a facility such as a hotel or motel.
The system 100 includes a satellite receiver 130, and various implementations of the receiver 110 are capable of tuning and transcrypting up to 24 satellite channels. Transcrypting refers, for example, to receiving a signal and changing the modulation to be suitable for wide distribution, for example, with in a property (such as, for example, a hotel, a dormitory, and/or a campus environment). The satellite signal is tuned and demodulated in the receiver 110. The receiver 110 produces an MPEG-2 transport stream having packets, for example, user datagram protocol (“UDP”) packets. The packets contain data and video programming to be distributed. The transport stream is then IP-encapsulated using standard Internet protocols and Internet RFCs (Requests for Comment) and is sent out of the receiver 110 using an Ethernet interface.
The receiver 110 of various implementations also includes a processor and a memory (not shown). The processor is used to generate program guide still images that are provided as a program guide to the TVs 120. The processor of these implementations also updates the program guide still images regularly to reflect new programming information. The generated program guide still images are, in various implementations, stored in the memory.
The system 100 includes a modulator 140, which is also typically part of the headend. In various implementations, the modulator 140 is a Quadrature Amplitude Modulation (“QAM”) modulator, and the modulator 140 performs transcrypting. In several such implementations, the data leaving the receiver 110 is in a format suitable for input to an edge QAM device or for distribution on an IPTV network.
The distribution to an IPTV network is not shown in
In various implementations, the broadcast video encoding format (for example, MPEG-2 or MPEG-4 compression) is preserved for both QAM input and IPTV distribution. Additionally, the output transport stream is encrypted using any of a variety of different encryption standards, such as, for example, the Pro:Idiom encryption standard.
The modulator 140 modulates the MPEG-2 transport stream. In various implementations, the modulator 140 modulates the MPEG-2 transport stream on one of twelve carrier frequencies. Other implementations use a different number of carrier frequencies, either more or less, and even adaptable. The number of carrier frequencies does not limit the number of transport streams.
In typical implementations, each input stream corresponds to a program channel, which results in an output modulated channel. The output modulated channel is combined, by the modulator 140, with all other modulated channels provided from the modulator 140 and output over a coaxial cable distribution system 150, shown in
Although not shown in
It is important to note that the pseudo-interactive guide is generated at the video distribution headend, which in
In other words, instead of generating an interactive guide interface within a receiver, every static image that is part of the guide is rendered in the headend. The headend distributes each guide still on a separate sub-channel to each of the receivers (for example, the TVs or set-top boxes).
The guide stills can be mapped across sub-channels in a predetermined, fixed manner, or the headend can direct the receivers (for example, the TVs or set-top boxes) to recognize the guide stills with, for example, channel identifiers or management services commands. After the mapping is determined, there is no need in various implementations for a back channel (providing communication from the receiver to the headend) for the receiver to navigate the guide. Additionally, changes to the guide data channel mapping can be communicated along the front channel from the headend. For example, if a program channel is re-mapped to another channel number, then the corresponding program guide still images would be recreated. The re-mapping would later be reflected to the user when the modified program guide still images are displayed in response to the user requesting program guide information. In various implementations, the creation of program guide still images is automated based on a received mapping.
When a user of an in-room receiver presses the “guide” key command of a remote control, the receiver tunes to the modulated channel (for example, QAM sub-channel) displaying the guide data (a still image) corresponding with the currently tuned channel. While the receiver is displaying a guide data channel, navigation key presses tune to other channels containing the corresponding guide data still images.
As discussed earlier, systems that try to replicate a traditional Program Guide are typically faced with the challenge of providing a large number of static images representing all of the portions of the traditional Program Guide. That is, information about all of the channels and across all available time periods. As discussed earlier, the portion of the traditional Program Guide that each user in each room wishes to view is unknown, and often differs between users. This can result in a requirement for large bandwidth between the headend and the TVs, as well as large processing power requirements at the headend.
The pseudo-interactive guide of various implementations described in this application addresses one or more of these issues. More specifically, various implementations modify the traditional Program Guide so that the modified guide meets the perceived needs of the average viewer. For example, as discussed above, instead of the traditional line-based view with visibility for multiple hours ahead, the Mosaic-based approach of the various implementations provides a navigable block-based listing providing basic information needed by the guest.
Referring to
The provider section 210 includes an indication of the provider. In the case of
The program section 220 includes a mosaic of sixteen blocks or tiles, arranged in four rows of four blocks. Each block represents a different programming channel, and includes information about that programming channel. The lower right block 240 is typical, and includes a channel name and/or logo 242, a channel number 244, a Playing Now identifier 246, and a Playing Next identifier 248.
The channel name and/or logo 242 provides the name and/or logo of a particular programming channel. The channel number 244 provides the numeric value of the particular programming channel. The Playing Now identifier 246 provides the name of the program that is currently playing on the particular programming channel. The Playing Next identifier 248 provides the name of the program that will be playing next on the particular programming channel.
For the block 240, the channel name and/or logo 242 is The Weather Channel, the channel number 244 is channel 34, the Playing Now identifier 246 is the program titled “Day Planner”, and the Playing Next identifier 248 is the program titled “Weather by the Billions”. The other fifteen blocks in the screen shot 200, from left to right, and top to bottom, have the information shown in Table 1:
The screen shot 200 also includes a highlight box 250 that indicates the channel that a user may be interested in viewing. In
In a typical operation of the screen shot 200, a user would press a guide button on a remote control in a hotel room. A TV in the hotel room would then tune to a set guide channel, pre-determined at the headend. To the guest, it would look like the guide, such as the screen shot 200, was just provided in response to the request. However, if the system 100 is being used, the guide would have been provided to the TV all along, and the TV would simply not have displayed it until the guide button was pressed.
The guest would use the arrow keys on the remote to navigate to their desired channel or to the next page of program information. For example, the guest would navigate among the blocks of the screen shot 200 using the arrow keys of the remote control. The block that is currently selected will have the highlight box 250 around it. Each block presents the guest with the basic information to allow the guest to make an informed decision about whether to select that channel for viewing. After the guest selects the desired channel, the guest presses a key such as, for example, “enter” on the remote control, and the TV tunes to the selected channel.
The guest is presented with information that has been determined to be useful for a typical guest. This information is the channel name and/or logo, the channel number, the name of the program currently playing on the channel, and the name of the program playing next on the channel. In many circumstances, a typical guest can make a viewing decision based on one or more of these pieces of information. These pieces are often useful for one or more of the following reasons:
Conversely, guests typically are not interested in making a viewing decision based on what is playing beyond the next program. For that reason, most implementations do not identify more than one future program for a given channel. Such systems avoid clutter and allow a guest to focus on useful information.
Additionally, the guest is often aided in making a viewing decision by having the information for the different channels organized in a mosaic, as in
If the programming system provides more channels than fit on one screen, the guest can scroll to another screen. In
Implementations vary in a variety of details, such as, for example, how many additional channels are displayed upon one press of the down arrow key. In one implementation, one new row of blocks is provided, and the bottom three rows of blocks are scrolled up to make room for the new block at the bottom of the program section 220. This has the advantage of allowing the guest's eyes to remain focused on one part of the screen, and the guest can press the down arrow key multiple times, examining one new row of blocks each time.
Another implementation provides a completely new set of sixteen blocks each time the down arrow key is pressed. This has the advantage of allowing the guest to move more quickly through the program guide if desired by the guest.
Providing a completely new set of sixteen blocks also has the advantage of reducing the number of separate screens that the system has to be able to produce. For example, if there are only thirty-two channels available, and if a system provides sixteen new channels on each program guide screen, then a system only needs two screen shots. In contrast, if a system provides only one new row with every request for new additional channels, then at least five screen shots are needed. The five would include, for example, (i) channels 1-16, (ii) channels 5-20, (iii) channels 9-24, (iv) channels 13-28, and (v) channels 17-32.
Recall that in many implementations, as explained earlier, each possible screen is provided from the headend continuously on a separate sub-channel. In such systems, the appropriate screen is displayed by merely selecting the corresponding sub-channel, without requiring a back channel for requesting guide information from the headend.
Various implementations always provide the screen shot 200 when the guest presses the guide button. This also provides advantages over systems that provide a guide screen that is oriented around the current channel. One manner of orienting around the current channel is to place the current channel near the middle of the guide screen. A “middle” position is, for example, the position highlighted by the highlight box 250 in
For example, if there are only thirty-two channels available, then only two screen shots need to be prepared. In contrast, if the current channel were to be positioned near the middle of the screen, then perhaps thirty-two screen shots would need to be prepared. This may be achieved, for example, by having the channels in a circular queue or buffer for display, and always putting the current channel in a designated “middle” block.
Clearly, the number of blocks in a program guide screen can be varied in different implementations.
Referring to
(i) the channel name 242 is toward the right side of the block 240 in the screen shot 300, but toward the left side of the block 240 in the screen shot 200,
The screen shot 300 offers an advantage for guests that prefer to focus on the channel number. Because the channel number 244 of the screen shot 300 is toward the left side of the blocks, and because the channel number is larger, a guest's eyes often will more easily identify the channel number.
The implementations of
The implementations of
Referring to
The process 400 includes receiving a program guide request (410). In at least one implementation, the operation 410 includes receiving a request to present a program guide on a display. The program guide provides information about programs that are available on multiple channels.
The process 400 includes providing a mosaic program guide screen in response to the request (420). In at least one implementation, the operation 420 includes providing, in response to receiving the request, a program guide screen. At least a portion of the provided program guide screen is visually divided in both a horizontal direction and a vertical direction into multiple sections. Each of the multiple sections includes information about programs available on respective distinct channels. In particular implementations, the multiple sections include sections whose positions differ in at least the horizontal position (for example, blocks in the same row of section 220 in
In at least one implementation, the operation 410 is performed by a TV, a set-top box, or a computer, that receives a request from a guest. The set-top box is, in various implementations, coupled to a TV in a hotel room, with each room including a set-top box and a TV. The request is received when the guest presses the “guide” button on a remote control.
In various implementations, the operation 420 is performed by a TV, a set-top box, or a computer, providing a program guide screen such as the screen shot 200 or the screen shot 300. The program guide screen is provided, in certain implementations, from a set-top box to a TV for eventual display by the TV, or from a receiver unit of a TV to a screen of the TV. Other implementations provide the program guide screen from a computer processing component to a computer display or to a TV. In various implementations, the program guide screen is provided to a remote display, such as, for example, a second screen, a tablet, or a cell phone. The request for a program guide screen also comes, in various implementations, from such a remote device.
Various implementations of the process 400 provide one or more other features, such as, for example:
Referring to
The process 500 includes generating a mosaic program guide screen (510). In at least one implementation, the operation 510 includes generating a program guide screen. At least a portion of the generated program guide screen is visually divided in both a horizontal direction and a vertical direction into multiple sections. Each of the multiple sections includes information about programs available on respective distinct channels. In particular implementations, the multiple sections include sections whose positions differ in at least the horizontal position (for example, blocks in the same row of section 220 in
The process 500 includes providing the mosaic program guide screen (520). In at least one implementation, the operation 520 includes providing a signal that conveys the program guide screen.
In at least one implementation, the operation 510 is performed by a portion of a headend system, such as by the receiver 110. The receiver 110 of various implementations generates the program guide still images that are provided as a program guide to the TVs 120. The receiver 110, of these implementations, also updates the program guide still images regularly to reflect new program names for “Now” and “Next” as well as to reflect program changes and/or re-mappings.
In various implementations, the operation 520 is performed by a portion of a headend system, such as by the receiver 110 or the modulator 140. The receiver 110 provides, for example, one or more digital files that include the program guide still images for the mosaic program guide. The one or more files are provided to the modulator 140. The modulator 140 modulates each of the program guide screens onto a separate sub-channel of a signal, and provides the signal for distribution to the TVs in the hotel rooms.
In at least one implementation of the operation 520 that uses the system 100, each program guide still image is modulated on a separate QAM sub-channel (such as, for example, 33-2, 33-3, 33-4, etc.). The number of sub-channels would be determined, for example, by the number of channels at the property, the number of tiles (blocks) per screen, and whether navigation to additional channels (see the additional channel section 230) displayed one additional row or an entire new page.
Various implementations of the process 500 provide one or more other features, such as, for example:
Various implementations of the processes 400 and 500 are performed by an apparatus that includes one or more processors collectively configured to perform one or more of the process implementations described. Additionally, certain implementations of the processes 400 and 500 are performed by a processor readable medium having stored thereon instructions for causing one or more processors to collectively perform one or more of the process implementations described.
Referring to
More specifically, the screen shot 600 includes a banner section 610 and a program section 620. The banner section 610 includes a video window 612, provided as a picture-in-a-picture, that displays the current programming from a highlighted channel, as explained below. The banner section 610 also includes:
The program section 620 includes a mosaic-based program guide that includes a series of blocks providing program guide information for respective programming channels. The program section 620 displays ten blocks at a time in two rows of five. A scroll bar 625 is used to scroll through additional rows, or screens, of blocks. Other implementations use down arrows and up arrows as an alternative, or in addition, to the scroll bar 625. Yet further implementations provide the scroll bar 625 as an indicator of the approximate position in the mosaic-based program guide blocks (also referred to as a channel list), and not as a tool for navigating (that is, a user does not scroll using the “scroll bar” of such implementations).
A block 630 is shown with a highlight box 640, indicating that the block 630 is highlighted in the program guide. The highlight box 640 is typically navigated using, for example, arrows keys of a remote control.
Each of the blocks includes particular pieces of information, as shown and discussed for the block 630. The block 630 includes:
In other implementations, these two-part channel numbers that include a primary and a secondary channel are set up as “Virtual Channels” from the headend. For example, in one implementation, a setup is performed at the headend to assign channel 81-2 to show as channel 25, and to assign channel 82-1 to show as channel 26. This allows the viewer to have a simpler, more recognizable channel ring.
Other blocks in the screen shot 600 are for additional programming channels. The channels displayed in the screen shot 600 include CNN in HD on channel 80-1, ESPN in HD on channel 80-2, ESPN 2 in HD on channel 81-1, Bravo in HD on channel 82-1, COM in HD on channel 82-2, AMC in HD on channel 83-1, A&E in HD on channel 83-2, The History Channel in HD on channel 83-1, and the National Geographic Channel in HD on channel 84-2.
Referring to
The banner section 710 includes the channel logo 632, the channel number 634, and the channel name 636. The banner section 710 also includes a “now showing” section 714 that includes the name of a program that is currently showing on the selected channel, which is 81-2 for the HGTV network in HD. The current program is Designed to Sell. The banner section 710 further includes a “next showing” section 716 that includes the name of a program that will be playing after the currently playing program on the selected channel. The next program is House Hunters.
The banner section 710 of various implementations is also able to display the current program summary or description field 618. Certain implementations, for example, provide this field 618 when an “INFO” button on a remote control is pressed.
The content section 720 shows the current program from the selected channel. In typical implementations, the banner section 710 disappears after a pre-defined period of time, after which the content section 720 takes up the entire screen.
It should be clear that the implementations of
The implementation of
Notably, the structure of the implementations of
Many variations of the implementation of
Further, in various implementations as indicated above, the banner section 710 automatically appears as a viewer channel surfs. Thus, the banner section 710 is displayed for every new channel that a viewer selects.
The program guide of the implementation of
The program guide screen that is first displayed upon a user request can be different, depending on what channel the user had most recently selected, or can be the same regardless of what channel the user had most recently selected for viewing.
In various headend implementations, in which a headend provides the program guide of
Typical implementations of
Additionally, various implementations provide a signal, or a signal structure, that includes a program guide screen section. The program guide screen section conveys a program guide screen for which at least a portion is visually divided in both a horizontal direction and a vertical direction into multiple sections. Multiple sections in both the horizontal direction and the vertical direction include information about programs available on respective distinct channels. Various other implementations provide a processor readable medium that stores such a signal or a signal structure.
Various implementations include a scrolling feature. Implementations can provide the scrolling upon request of the guest, for example, by the guest pressing arrow keys on a remote. Other implementations include a self-scrolling feature that automatically scrolls through the available channels when the program guide is being displayed. Whether the scrolling is manual, automatic, or some combination, various implementations provide quick display of available channels to a guest because there are relatively few screens required to present all of the available channels.
This application provides multiple figures, including the block diagrams of
Various implementations have been described that receive satellite television signals, and then provide programming channels on coaxial cable. Other implementations use different transmission technologies and media, however. For example, channels can be received on one or more of a terrestrial broadcast link, a coaxial cable, or a fiber optic cable, and can be ATSC-based or Internet-based. Programming channels can be distributed from a headend over a wireless connection or a wired connection, and can be ATSC-based or Internet-based.
We have thus provided a number of implementations. Various implementations provide a block-based program guide for a user. It should be noted, however, that variations of the described implementations, as well as additional applications, are contemplated and are considered to be within our disclosure. Additionally, features and aspects of described implementations may be adapted for other implementations.
Reference to “one embodiment” or “an embodiment” or “one implementation” or “an implementation” of the present principles, as well as other variations thereof, mean that a particular feature, structure, characteristic, and so forth described in connection with the embodiment is included in at least one embodiment of the present principles. Thus, the appearances of the phrase “in one embodiment” or “in an embodiment” or “in one implementation” or “in an implementation”, as well any other variations, appearing in various places throughout the specification are not necessarily all referring to the same embodiment.
Additionally, this application or its claims may refer to “determining” various pieces of information. Determining the information may include one or more of, for example, estimating the information, calculating the information, predicting the information, or retrieving the information from memory.
Further, this application or its claims may refer to “accessing” various pieces of information. Accessing the information may include one or more of, for example, receiving the information, retrieving the information (for example, memory), storing the information, processing the information, transmitting the information, moving the information, copying the information, erasing the information, calculating the information, determining the information, predicting the information, or estimating the information.
A video presentation system is included in various implementations. Such a system can take many forms, depending on the implementation. Various video presentation systems include, for example, a TV, a TV in combination with a set-top box, a computer, or a computer in combination with a set-top box.
It is to be appreciated that the use of any of the following “/”, “and/or”, and “at least one of”, for example, in the cases of “NB”, “A and/or B” and “at least one of A and B”, is intended to encompass the selection of the first listed option (A) only, or the selection of the second listed option (B) only, or the selection of both options (A and B). As a further example, in the cases of “A, B, and/or C” and “at least one of A, B, and C” and “at least one of A, B, or C”, such phrasing is intended to encompass the selection of the first listed option (A) only, or the selection of the second listed option (B) only, or the selection of the third listed option (C) only, or the selection of the first and the second listed options (A and B) only, or the selection of the first and third listed options (A and C) only, or the selection of the second and third listed options (B and C) only, or the selection of all three options (A and B and C). This may be extended, as readily apparent by one of ordinary skill in this and related arts, for as many items listed.
Additionally, many implementations may be implemented in a processor, such as, for example, a post-processor or a pre-processor. Various processing modules discussed in this application do, in various implementations, include multiple processors (sub-processors) that are collectively configured to perform, for example, a process, a function, or an operation. For example, the receiver 110, as well as other processing components, is, in various implementations, composed of multiple sub-processors that are collectively configured to perform the operations of that component.
The implementations described herein may be implemented in, for example, a method or a process, an apparatus, a software program, a data stream, or a signal. Even if only discussed in the context of a single form of implementation (for example, discussed only as a method), the implementation of features discussed may also be implemented in other forms (for example, an apparatus or program). An apparatus may be implemented in, for example, appropriate hardware, software, and firmware. The methods may be implemented in, for example, an apparatus such as, for example, a processor, which refers to processing devices in general, including, for example, a computer, a microprocessor, an integrated circuit, or a programmable logic device. Processors also include communication devices, such as, for example, computers, cell phones, tablets, portable/personal digital assistants (“PDAs”), and other devices that facilitate communication of information between end-users.
Implementations of the various processes and features described herein may be embodied in a variety of different equipment or applications. Examples of such equipment include an encoder, a decoder, a post-processor, a pre-processor, a video coder, a video decoder, a video codec, a web server, a television, a set-top box, a router, a gateway, a modem, a laptop, a personal computer, a tablet, a cell phone, a PDA, and other communication devices. As should be clear, the equipment may be mobile and even installed in a mobile vehicle.
Additionally, the methods may be implemented by instructions being performed by a processor, and such instructions (and/or data values produced by an implementation) may be stored on a processor-readable medium such as, for example, an integrated circuit, a software carrier or other storage device such as, for example, a hard disk, a compact diskette (“CD”), an optical disc (such as, for example, a DVD, often referred to as a digital versatile disc or a digital video disc), a random access memory (“RAM”), or a read-only memory (“ROM”). The instructions may form an application program tangibly embodied on a processor-readable medium. Instructions may be, for example, in hardware, firmware, software, or a combination. Instructions may be found in, for example, an operating system, a separate application, or a combination of the two. A processor may be characterized, therefore, as, for example, both a device configured to carry out a process and a device that includes a processor-readable medium (such as a storage device) having instructions for carrying out a process. Further, a processor-readable medium may store, in addition to or in lieu of instructions, data values produced by an implementation.
As will be evident to one of skill in the art, implementations may produce a variety of signals formatted to carry information that may be, for example, stored or transmitted. The information may include, for example, instructions for performing a method, or data produced by one of the described implementations. For example, a signal may be formatted to carry as data the channel programming information for the channels available on a system. Such a signal may be formatted, for example, as an electromagnetic wave (for example, using a radio frequency portion of spectrum) or as a baseband signal. The formatting may include, for example, encoding a data stream and modulating a carrier with the encoded data stream. The information that the signal carries may be, for example, analog or digital information. The signal may be transmitted over a variety of different wired or wireless links, as is known. The signal may be stored on a processor-readable medium.
A number of implementations have been described. Nevertheless, it will be understood that various modifications may be made. For example, elements of different implementations may be combined, supplemented, modified, or removed to produce other implementations. Additionally, one of ordinary skill will understand that other structures and processes may be substituted for those disclosed and the resulting implementations will perform at least substantially the same function(s), in at least substantially the same way(s), to achieve at least substantially the same result(s) as the implementations disclosed. Accordingly, these and other implementations are contemplated by this application.
This application claims the benefit of (i) U.S. provisional application No. 61/730,641, filed Nov. 28, 2012, and titled “Method and Apparatus for Auto-Tuning Program Guides”, (ii) PCT application No. PCT/US12/057166, filed Sep. 26, 2012, and titled “User Interfaces for Content Distribution Systems”, and (iii) PCT application No. PCT/US12/054744, filed Sep. 12, 2012, and titled “Method and Apparatus for QAM Modulator Channel Duplication”. The contents of each of these benefit applications are incorporated by reference herein for all purposes.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US12/69744 | 12/14/2012 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
61730641 | Nov 2012 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/US2012/057166 | Sep 2012 | US |
Child | 14425502 | US | |
Parent | PCT/US2012/054744 | Sep 2012 | US |
Child | PCT/US2012/057166 | US |