1. Field of the Invention
The field of the invention is data processing, or, more specifically, methods, apparatus, and products for managing service subscriptions of a number of devices over a unidirectional transmission channel.
2. Description of Related Art
Some subscription broadcast mechanisms, like satellite radio, require activation codes to be sent to receivers in a unidirectional transmission channel such that all receivers receive the activation codes even if the receiver is not the subject of the activation code. Reactivation codes are sent in a similar manner, one message per receiver broadcast to all receivers regardless of the intended target. As the number of receivers increases, the bandwidth required to broadcast activation and reactivation codes to all of the receivers increases significantly.
Methods, apparatus, and products for managing service subscriptions of a plurality of devices over a unidirectional transmission channel are described in this specification. Such management includes: assigning, by a subscription management module, one or more group identifiers to a device to be activated for a service subscription, each group identifier being an identification of a group of devices having an activated subscription to the service; activating, by the subscription management module, the device's service subscription including broadcasting an activation message that includes a unique identifier of the device, the assigned group identifiers, and an active subscription period being a period of time during which the device's subscription to the service is to be active; and prior to expiration of the active subscription period, broadcasting a reactivation message including at least one of the group identifiers to which the device is assigned.
The foregoing and other objects, features and advantages of the invention will be apparent from the following more particular descriptions of exemplary embodiments of the invention as illustrated in the accompanying drawings wherein like reference numbers generally represent like parts of exemplary embodiments of the invention.
Exemplary methods, apparatus, and products for managing service subscriptions of a number of devices over a unidirectional transmission channel in accordance with the present invention are described with reference to the accompanying drawings, beginning with
The system of
An activation message operates to notify a device that the device's subscription to a service has been activated and the device may provide functionality related to the service. A reactivation message operates to inform the device that the device's subscription has been renewed and service may continue to be provided. In the example unidirectional transmission system of
In prior art systems, a renewal of a service subscription for a device resulted in a separate reactivation message being transmitted to all devices. In order to reactivate four devices in a prior art system, for example, four separate reactivation message are transmitted to all devices. In this way, the system transmits sixteen message, four per reactivation. Further, because the system operations with a unidirectional channel, there is no feedback from the devices indicating whether the message was received. To that end, systems in the prior art will occasionally rebroadcast the same reactivation message periodically a number of times. Such prior art systems do not scale well. Consider, for example, a prior art system in which 100,000 devices are reactivated. In such a prior art system, 100,000 separate reactivation messages are broadcast, resulting in 10 million messages that are transmitted along the unidirectional transmission channel to effect the reactivation of the 100,000 devices. If each reactivation message is then retransmitted just one more time to ensure that the devices actually receive the reactivation message, the number of messages carried on the unidirectional transmission channel increases to 20 million to effect the reactivation of the 100,000 devices.
The subscription management module (104) in the example of
Then, prior to expiration of the active subscription period and after receiving renewal requests for a number of devices assigned to a group identifier, the subscription service module broadcasts a reactivation message that includes at least one of the group identifiers to which the device is assigned. In this way, a single reactivation message may be broadcast (to all devices in the system) to reactivate the service subscription for multiple devices. Consider, for example, that the four devices in the system of
Once a device (106, 108, 110, 112) receives a reactivation message, the device determines whether at least one of the group identifiers included in the reactivation message is assigned to the device. If not, the device ignores the message. If at least one of the group identifiers included in the reactivation message is assigned to the device, however, the device reactivates the service subscription for a reactivation period. The reactivation period may be specified in the reactivation message itself or may be a default time period such as, for example, one year.
The arrangement of devices, modules, towers, and satellites making up the exemplary system illustrated in
Managing service subscriptions of a number of devices over a unidirectional transmission channel in accordance with the present invention is generally implemented with computers, that is, with automated computing machinery. In the system of
Stored in RAM (168) is a subscription management module (104), a module of computer program instructions that, when executed causes the computer (152) to managing service subscriptions of a number of devices over a unidirectional transmission channel in accordance with the present invention. The subscription management module (104) of
The subscription management module may then activate the particular device's (182) service subscription by broadcasting an activation message (206) that includes a unique identifier of the particular device (204), the assigned group identifiers (202), and an active subscription period (210). The active subscription period is a period of time during which the particular device's subscription to the service is to be active.
Then, prior to expiration of the active subscription period and after receiving a renewal request from all devices assigned one of the group identifiers (202) that is also assigned to the particular device, the subscription management module (104) may broadcast a reactivation message (208) that includes at least one of the group identifiers (202) assigned to the particular device.
Also stored in RAM (168) is an operating system (154). Operating systems useful managing service subscriptions of a number of devices over a unidirectional transmission channel according to embodiments of the present invention include UNIX™ Linux™ Microsoft XP™ AIX™ IBM's i5/OS™ and others as will occur to those of skill in the art. The operating system (154), subscription management module (104), group identifiers (202), device identifiers (204), activation and reactivation messages (206, 208), and the subscription period (210) in the example of
The computer (152) of
The example computer (152) of
The exemplary computer (152) of
For further explanation,
The method of
The active service subscription period (312) is a period of time during which the device's subscription to the service is to be active. Broadcasting the activation message may be carried out through one or more data communications messages (packets, frames, etc.) via the unidirectional transmission channel.
The method of
For further explanation,
The method of
The method of
If at least one of the group identifiers included in the reactivation message is not assigned to the device, the method of
In some embodiments, the reactivation period may be specified in the reactivation message (208) as in the example of
For further explanation,
The method of
Each of the categories may be defined or specified by any number of subscription-related characteristics or factors. Examples of such subscription-related characteristics include: age of active subscription; demographic of subscriber; subscription type attributes; customer satisfaction survey results; and frequency of subscriber contacting customer support.
The categories of group identifiers may be organized hierarchically so that the most ‘stable’ subscriptions are assigned to the largest possible group while less stable subscriptions are assigned to smaller groups. Consider an example: if receiver 97 is a member (along with several hundred other receivers) of group 10589 and group 10589 is a hierarchical member (along with group 20471 and several dozen other groups) of parent group 68884, then a reactivation message to group 68884 will reactive several thousand receivers at once—the receivers of group 20471, receivers of group 10589, and the receivers of the other groups included in parent group 68884. If a receiver in group 20471 fails to renew, however, then instead of reactivating parent group 68884, the subscription management module may reactivate group 10589 and dozens of other groups, while reactivating receivers in the affected group 20471 individually. Further, the subscription management module may then reassign groups for all reactivated receivers representing the loss of group 20471.
As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method or computer program product. Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present invention are described above with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
It will be understood from the foregoing description that modifications and changes may be made in various embodiments of the present invention without departing from its true spirit. The descriptions in this specification are for purposes of illustration only and are not to be construed in a limiting sense. The scope of the present invention is limited only by the language of the following claims.
Number | Name | Date | Kind |
---|---|---|---|
5553315 | Sobti et al. | Sep 1996 | A |
6112085 | Garner et al. | Aug 2000 | A |
7356304 | Zoeckler | Apr 2008 | B2 |
7613435 | Reynolds et al. | Nov 2009 | B2 |
7941503 | Benco et al. | May 2011 | B2 |
8019298 | Reynolds et al. | Sep 2011 | B2 |
8184647 | Gupta et al. | May 2012 | B2 |
20020037716 | McKenna et al. | Mar 2002 | A1 |
20060223499 | Pecen et al. | Oct 2006 | A1 |
20070192805 | Dutta et al. | Aug 2007 | A1 |
20080109470 | McGee | May 2008 | A1 |
20100107186 | Varriale et al. | Apr 2010 | A1 |
20110093930 | Bartel-Kurz et al. | Apr 2011 | A1 |
20110201365 | Segura | Aug 2011 | A1 |
20120203822 | Floyd et al. | Aug 2012 | A1 |
Entry |
---|
Allis, R., et al., “Best Practices for Email Marketers,” Aug. 2005, pp. 1-31, IntelliContact Pro, Broadwick Corp., URL: http://www.icontact.com/static/pdf/Email—Marketing—Best—Practices—iContact.pdf. |
Goldberg, J., et al., “Network structures—the internet, IPTV and QoE,” European Broadcasting Union (EBU) Technical Review Online (www.ebu.ch), Oct. 2007, pp. 45-53, [accessed Mar. 3, 2013], URL: http://tech.ebu.ch/docs/techreview/trev—312-kernen—QoE.pdf. |
Wikipedia, “Multicast”, (online), accessed Jan. 16, 2013, 5 pages, URL: http://en.wikipedia.org/wiki/Multicast. |
McMillan, R., “Bug Allowed Free Access to Sirius Radio Service”, PCWorld.com (online), Nov. 24, 2008, [accessed Jan. 16, 2013], 3 pages, URL: http://www.pcworld.com/article/154440/article.html. |
Control Vision Corporation, “The XM Activation Process”, controlvision.com (online) 2004, [accessed Mar. 26, 2013], 2 pages, URL: http://docs.controlvision.com/pages/xm—act.php. |
Number | Date | Country | |
---|---|---|---|
20150118952 A1 | Apr 2015 | US |