1. Field
The present disclosure relates to transmission of notifications, and more particularly, to methods and systems for transmitting a plurality of notifications in a notification pool.
2. Background
Businesses and governmental entities, including municipalities and schools, are ever more reliant on communicating through the mass transmission of notifications to their staff, citizens and family members of students to keep these constituencies apprized of important events, and sometimes of emergencies. For example, a school principal might need to inform the parent of every child that the school will be closed the next day due to some unforeseen event such as flooding, fire, or freezing conditions. Such notifications might be sent to telephones, facsimiles, pagers, electronic mail (e-mail), and/or text messages. These notifications will typically vary in their degree of importance, in the number of recipients, or in the immediacy with which they must be sent. Regardless of these varying factors, as a practical matter, each notification being transmitted is typically placed in a linear queue by the processing system sending these notifications. The processing system may then send the notifications to a provider who specializes in transmitting them. Such provider may use, for example, a first-in-first-out (FIFO) rule or last-in-first-out (LIFO) to determine the sequence of transmission.
One of the shortcomings found to exist in the system described is that if 10,000 notifications are placed into a queue that is configured for FIFO and then a subsequent batch of 100 notifications is placed into the queue, the 10,000 notifications would all have to be processed from the queue prior to the 100 notifications being processed. But some of the 100 notifications in the later batch may be extremely urgent, whereas many of the 10,000 notifications may be non-urgent. The systems of the prior art may require that all 10,000 notifications issue before any of the 100 notifications, including the urgent notifications within the 100 notifications. This is a disadvantageous outcome.
It has further been found that current mass notification systems may exacerbate problems that the system is put into operation to solve. For example, in an area where telecommunications equipment has been degraded by a cause such as a hurricane or tornado, current transmission systems may overload and flood telecommunications networks and thereby actually prevent the distribution of pertinent information. Moreover, such overloading may have the potential to block necessary agencies (Red Cross, Police, Fire, etc.) from utilizing those telecommunications channels for communicating.
There is a need for an appropriate sequencing system that can identify the urgent notifications in later batches, and blend them into the earlier batches in a fair way, so that urgent notifications are treated urgently even though they may be placed in the transmission queue for transmission at a later point in time. The same need may apply to notifications of lesser urgency, but which may nevertheless be more urgent than lower priority notifications placed in an earlier batch.
Further, there is a need for an appropriate sequencing system by which the foregoing problems may be mitigated. Embodiments of the disclosed systems and methods address these and other needs.
The present disclosure describes systems and methods whereby a notification to be sent may be created by a user to a mass of recipients who may use various different devices to receive the notification. The disclosed systems and methods provide a form of control over the sequencing of notifications in a large pool of notifications created from various batches of notifications that are awaiting transmission.
In certain aspects of the disclosure, a method for transmitting a plurality of notifications in a notification pool is provided. The method includes determining a first notification batch having the plurality of notifications, and assigning a priority weight to each of the plurality of notifications, at least two of the priority weights being different. The method further includes inserting the first notification batch into the notification pool, and transmitting the plurality of notifications in the notification pool sequentially, based on the priority weights of the plurality of notifications.
In a further aspect of the disclosure, a system for transmitting a plurality of notifications is provided. The system includes a processor configured to determine a first notification batch having the plurality of notifications, and to assign a priority weight to each of the plurality of notifications, at least two of the priority weights being different. The processor is further configured to insert the first notification batch into the notification pool, and to transmit the plurality of notifications in the notification pool sequentially, by selecting for next transmission the notification in the notification pool with the lowest priority weight.
In yet a further aspect of the disclosure, a machine-readable medium encoded with instructions for transmitting a plurality of notifications is provided. The instructions include code for determining a first notification batch having the plurality of notifications, and assigning a priority weight to each of the plurality of notifications, at least two of the priority weights being different. The instructions further include code for inserting the first notification batch into the notification pool, and transmitting the plurality of notifications in the notification pool sequentially, by selecting for next transmission the notification in the notification pool with the lowest priority weight.
The assigning the priority weight to each of the plurality of notifications may be based on a notification class associated with each of the plurality of notifications. The assigning the priority weight may include assigning to each notification in a first notification class a priority weight that increases with each notification by a constant first increment, and assigning to each notification in a second notification class a priority weight that increases with each notification by a constant second increment different than the first increment.
The determining of the first notification batch may occur at a first time, and each notification may be time stamped with the first time. At a second time later than the first time, a second notification batch having a plurality of notifications may be determined. A priority weight may be assigned to each of the plurality of notifications in the second notification batch, wherein a starting priority weight of the first notification of the second notification batch is not less than the lowest priority weight of any notification in the notification pool. The second notification batch may be inserted into the notification pool for transmission with the other notifications in the notification pool.
The assigning of a priority weight to each of the plurality of notifications in the second notification batch may include assigning to each notification in the second notification batch a priority weight that increases with each notification by a third increment. The size of the constant third increment may be based on a notification class associated with each notification in the second notification batch.
Each notification in the second notification batch may be stamped with the second time. The first time stamp may be subtracted from the second time stamp to obtain a time lag between the first and second notification batches. The size of the third increment may be based upon the time lag.
The notification class may be one of an emergency class, an outreach class, an attendance class, and a retry class, the retry class corresponding to a notification attempt which was previously unsuccessful. The transmitting the plurality of notifications in the notification pool sequentially may include selecting for next transmission the notification in the notification pool with the lowest priority weight. Each of the plurality of notifications may be at least one of an email notification, a telephone notification, a cellular phone notification, a facsimile notification, a text message, and a pager notification.
The determining of the first notification batch may include preparing the first notification batch. In addition, the determining of the first notification batch may include receiving the first notification batch.
In another aspect of the disclosure, a method for transmitting a set of notifications in a notification pool is provided. The method includes determining a first notification batch having at least one notification, and assigning a priority weight to each of the notifications in the first notification batch. The method also includes inserting the first notification batch into the notification pool, and transmitting the notifications in the notification pool sequentially, based on the priority weights of the notifications. In certain aspects of the method, the first notification batch includes a plurality of notifications, and at least two of the priority weights assigned to each of the notifications in the first notification batch are different.
It is understood that other configurations of the subject technology will become readily apparent to those skilled in the art from the following detailed description, wherein various configurations of the subject technology are shown and described by way of illustration. As will be realized, the subject technology is capable of other and different configurations and its several details are capable of modification in various other respects, all without departing from the scope of the subject technology. Accordingly, the drawings and detailed description are to be regarded as illustrative in nature and not as restrictive.
With reference to the drawings, which are provided by way of exemplification and not limitation, there are disclosed embodiments for disseminating a mass of outgoing digital notifications to a selected group, or groups, of recipients by way of various communication methods. More specifically, the selection of individual notifications from a mass pool of outgoing digital notifications for sequential priority transmission to recipients is disclosed.
As an example, a notification might be: “Please clear your brush before fire season.” The selected recipients might be a group of residents who live within a fire zone. The time and date to send might be tonight at 7:00 pm, and the methods of transmission to recipients selected by the user might include telephone and e-mail delivery. These choices are exemplary only.
Once the notification is received from the user 22 by the CPU 26, it is stored by the CPU 26, in a local or remote memory associated with the CPU 26, as a notification file 32. The notification file 32 may be associated with a transmission data file 34 for later use, as set forth more fully below. Firstly, it may be noted that if the notification received is an ordinary voice notification via an interface 24 which is a telephone, the analogue voice signal may be converted to a digital sound file such as a .wav file and stored by the CPU 26 as such. If the notification received via the interface 24 is an email or a submission to a website, it may be stored by the CPU 26 as a .txt file, but it may also be converted to a sound file using TTS (text-to-speech) software. If the notification is received as facsimile, it may be stored by the CPU 26 as a .pdf file. All of these are stored pending distribution to the appropriate recipients in the appropriate form.
Once the notification file 32 is stored by the CPU 26, it is associated with the transmission data file 34 which is structured to include one or more of a number of data sets 36-44 that will later assist in controlling the transmission of the notification file 32. For example, the user 22 may insert information into the data sets 36-44 by entering key strokes (telephone key, computer key, etc.) in response to queries from the CPU as to what information should be entered in the data sets 36-44. The data sets 36-44 will then be associated with the notification file 32, as described. The information in the data sets 36-44 may be as follows: A time set 36 contains information relating to the time (e.g., date and time of day) the notification is scheduled for distribution. A recipient set 38 contains information relating to the class of recipients the notification is intended to reach. For example, the recipients may be all the parents of students at a school between 6th and 8th grades. A location set 40 contains information relating to the geographical locations the notification is intended to reach. For example, the intended recipients may be all the residents in a town living on one side of a river, or next to a combustible forest. Further data sets may be generated from information provided in preceding sets. For example, a number set 42 may be generated by the CPU 26 from the information entered into the recipient set 38, wherein the CPU 26 calculates the number of intended recipients of the notification, and enters that number into the number set 44 for later use, as described below. A sender identity set 44 may contain the identity of the user 22 who created the notification, and information relating to the status and rights of that user 22. The status and rights of the user 22 would be obtained based on the code entered by the user 22 to access the CPU 26 in order to leave the notification. For example, the user identity set 44 may indicate that the user 22 is the principal of a school who would legitimately want to reach a large audience of parents of students at the school. Alternatively, the user identity set 44 may indicate that the user is a teacher of 8th grade, who would typically want to reach only the parents of students in her 8th grade class, or perhaps all the 8th grade students in the school, but whose legitimate interest would not include communicating with the parents of all the students at a school. With particular relevance to the present invention, a class set (not shown) may be included to identify the class of notification. For example, a notification may be placed for mass transmission that notifies of an emergency, such as a shooting incident at a school, or a traffic incident on the way to school. Alternatively, a notification may be placed merely as an outreach communication to parents, with less urgency, or it may merely relate to attendance record of a particular group of students. Finally, a notification may be a “retry,” one which was placed before but did not succeed in getting through. Such notifications may be given the lowest priority in a batch of notifications, because it has been found that a first retry typically also does not succeed in getting through. Information indicating the priority or urgency of the notification may also be included in at least one of these data sets.
As noted above, the notification 32 may be created in a plurality of formats (e.g., .wav, .txt, .html, or .pdf). For example, the notification 32 may be created in at least one format, based on whether the notification is received via interface 24 as a voice notification, an email, a website, or a facsimile. Once the notification 32 is created in the appropriate plurality of formats (e.g., .wav, .txt, or .pdf) and is associated with the transmission data file 34 with its data sets, the CPU 26 stores the notification and associated data file in a delivery interface 46. The delivery interface 46 is configured to hold the notification in storage 48 until a triggering event occurs, as more fully described below.
When such triggering event occurs, the delivery interface 46 causes the notification to be distributed, according to known methods, to a mass of recipients, e.g. recipients 60-66 of
The result is that, once the triggering event occurs, a single notification (having been delivered to the CPU 26 by an enabled user 22 possessing an access code) is eventually transmitted to masses of recipients identified by the user 22. Such a single notification may be combined with numerous similar notifications (e.g., in a notification batch) for mass transmission at approximately the same time. This capability of the system places power in the hands of an institution or group of people to keep classes of citizens informed of events that are directly relevant to them on a real time basis.
In certain embodiments, the CPU 26 may store a request from a user 22 to store a notification in a database, instead of storing the notification in a local or remote memory associated with the CPU 26 as a notification file 32. In certain such embodiments, the notification may include an audio file in an appropriate format (e.g., .wav, .pcm, .mp3).
Considering now further aspects of the disclosed systems and methods, reference to an example of a type of problem that may be encountered will now be described. A first notification batch may include notifications to, for example, 10,000 recipients. Yet if a second notification batch is then immediately created and transmitted for sending to, for example, 100 recipients, the second notification batch may have to wait until all 10,000 of the first batch of notifications are sent. This is an undesirable situation, specifically where both batches have urgent and non-urgent notifications. Thus, there is a need for a solution so that at least priority recipients of the second batch can be promoted in the overall queue to be sent before some of the low priority notifications in the first batch are sent to designated recipients.
In another aspect of the type of problem which may be encountered, a pool or queue might contain 10,000 phone notifications which have been placed in a batch for transmission. Some of these notifications are of a higher priority than others. In addition, some of these notifications may have been placed, for example, in a queue or pool of notifications at 12:00 am while others were for example inserted into the queue at 12:15 am. In this particular instance, a problem is that the CPU may not assign a higher priority to urgent notifications in the third batch than non-urgent notifications in the second or first batches, so that at least some urgent notifications in the third batch may not receive priority over the low priority notifications in the first and second batches.
Accordingly, there is described herein systems and methods for mitigating this and other problems, with reference to a particular example that may be understood with reference to
When all the notifications in the batch have been assigned Notification-ID's and Priority Weightings, the CPU 26 commences transmitting the notifications in a serial sequence, following a method in which it selects for next transmission the Notification-ID having the lowest remaining Priority Weighting. For example, as shown in
Where two or more notifications have the same Priority Weighting, the system merely selects the next one of them linearly, until all with the same weighting are transmitted, before moving on to the Notification-ID with the next lowest Priority Weighting. Thus, for example, with reference to
As shown in the example of
The new batch of Emergency Notifications is shown in the bottom line of
Having set forth by example the process by which notification batches are processed into a pool for sequential transmission by a CPU, reference to
In step 202, a first notification batch having the plurality of notifications is determined (e.g., received or prepared) at a first time. This notification batch may include notifications of various classes (or types) such as Emergency notifications, Outreach notifications, Attendance notifications, Retry notifications, and the like. In step 204, each notification is time stamped with the first time. According to one aspect of the invention, the CPU waits for a notification batch to arrive, and when it arrives, each notification is time stamped with the current time. In step 206, a priority weight is assigned to each of the plurality of notifications, at least two of the priority weights being different. The CPU may assign, within a first class of notification, a priority weight that increases with each notification by a constant first increment. For example, where the importance of the notification is high, the incremental weight increase is low. The same is done for notifications in other notification classes, applying a different increment where the importance of the notification class is different. In step 208, the first notification batch is inserted into the notification pool. In step 210, the next notification in the notification pool is transmitted, based on the priority weights of the plurality of notifications. In other words, the plurality of notifications in the notification pool is transmitted in sequence based on the priority weights. According to one embodiment of the invention, the Notification-ID with the lowest priority weight is selected for next transmission.
Next, at decision step 212, an inquiry is made as to whether any notifications remain. If the answer to this inquiry is no, the process ends at step 222. Otherwise, at decision step 214, an inquiry is made as to whether a new notification batch having a plurality of notifications has been determined. If the answer to this inquiry is no, the process returns to step 210, in which the next notification in the notification pool is transmitted, based on the priority weights of the plurality of notifications.
If a new notification batch has been determined at decision step 214, each notification is time stamped with the time associated with the new notification batch, at step 216. In step 218, a time lag is determined for each notification, by subtracting the first time stamp from the new time stamp. In step 220, a priority weight is assigned to each of the plurality of notifications in the new notification batch, wherein a starting priority weight of the first notification of the new notification batch is preferably not less than the lowest priority weight of any notification in the notification pool.
The assigning the priority weight to each of the plurality of notifications may include assigning to each notification a priority weight that increases with each notification by a constant increment. The size of the increment may be based on a notification class associated with each notification and/or upon the time lag. For example, if a predetermined time threshold has been crossed in passing from the first time stamp to the second time stamp, an aging factor is multiplied by the increment that would ordinarily be applied to notifications of a single class.
Following step 220, the process returns to step 208, in which the new notification batch is inserted into the notification pool, with the other notifications in the pool. As noted above, the notification for next transmission is chosen based on priority weight. Preferably, the notification having the lowest priority weight in the pool is selected for next transmission. When all the notifications in the pool are transmitted, the process ends at step 222, and the CPU waits for the next batch of notifications to be determined (e.g., received or prepared), whereupon the process starts again from the beginning at step 202.
Computer system 800 may be coupled via I/O module 804 to a display device, such as a cathode ray tube (“CRT”) or liquid crystal display (“LCD”) for displaying information to a computer user. An input device, such as, for example, a keyboard, or a mouse may also be coupled to computer system 800 via I/O module 804 for communicating information and command selections to processor 802.
According to one aspect of the present disclosure, the transmission of a plurality of notifications in a notification pool may be implemented using a computer system 800 in response to processor 802 executing one or more sequences of one or more instructions contained in memory 810. Such instructions may be read into memory 810 from another machine-readable medium, such as data storage device 806. Execution of the sequences of instructions contained in main memory 810 causes processor 802 to perform the process steps described herein. One or more processors in a multi-processing arrangement may also be employed to execute the sequences of instructions contained in memory 810. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions to implement various embodiments of the present disclosure. Thus, embodiments of the present disclosure are not limited to any specific combination of hardware circuitry and software.
The term “machine-readable medium” as used herein refers to any medium that participates in providing instructions to processor 802 for execution. Such a medium may take many forms, including, but not limited to, non-volatile media, volatile media, and transmission media. Non-volatile media include, for example, optical or magnetic disks, such as data storage device 806. Volatile media include dynamic memory, such as memory 806. Transmission media include coaxial cables, copper wire, and fiber optics, including the wires that comprise bus 808. Transmission media can also take the form of acoustic or light waves, such as those generated during radio frequency and infrared data communications. Common forms of machine-readable media include, for example, floppy disk, a flexible disk, hard disk, magnetic tape, any other magnetic medium, a CD-ROM, DVD, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, a RAM, a PROM, an EPROM, a FLASH EPROM, any other memory chip or cartridge, a carrier wave, or any other medium from which a computer can read.
Those of skill in the art would appreciate that the various illustrative blocks, modules, elements, components, methods, and algorithms described herein may be implemented as electronic hardware, computer software, or combinations of both. Furthermore, these may be partitioned differently than what is described. To illustrate this interchangeability of hardware and software, various illustrative blocks, modules, elements, components, methods, and algorithms have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system. Skilled artisans may implement the described functionality in varying ways for each particular application.
It is understood that the specific order or hierarchy of steps or blocks in the processes disclosed is an illustration of exemplary approaches. Based upon design preferences, it is understood that the specific order or hierarchy of steps or blocks in the processes may be rearranged. The accompanying method claims present elements of the various steps in a sample order, and are not meant to be limited to the specific order or hierarchy presented.
The previous description is provided to enable any person skilled in the art to practice the various aspects described herein. Various modifications to these aspects will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other aspects. Thus, the claims are not intended to be limited to the aspects shown herein, but is to be accorded the full scope consistent with the language claims, wherein reference to an element in the singular is not intended to mean “one and only one” unless specifically so stated, but rather “one or more.” Unless specifically stated otherwise, the term “some” refers to one or more. Pronouns in the masculine (e.g., his) include the feminine and neuter gender (e.g., her and its) and vice versa. All structural and functional equivalents to the elements of the various aspects described throughout this disclosure that are known or later come to be known to those of ordinary skill in the art are expressly incorporated herein by reference and are intended to be encompassed by the claims. Moreover, nothing disclosed herein is intended to be dedicated to the public regardless of whether such disclosure is explicitly recited in the claims. No claim element is to be construed under the provisions of 35 U.S.C. §112, sixth paragraph, unless the element is expressly recited using the phrase “means for” or, in the case of a method claim, the element is recited using the phrase “step for.”
This application claims priority to U.S. Provisional Patent App. No. 61/140,814, filed on Dec. 24, 2008, the entire contents of which are herein incorporated by reference.
Number | Date | Country | |
---|---|---|---|
61140814 | Dec 2008 | US |