|Publication number||US7701950 B2|
|Application number||US 11/501,494|
|Publication date||Apr 20, 2010|
|Filing date||Aug 8, 2006|
|Priority date||Aug 8, 2006|
|Also published as||US20080040457|
|Publication number||11501494, 501494, US 7701950 B2, US 7701950B2, US-B2-7701950, US7701950 B2, US7701950B2|
|Original Assignee||International Business Machines Corporation|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (8), Classifications (6), Legal Events (5)|
|External Links: USPTO, USPTO Assignment, Espacenet|
1. Field of the Invention
The invention relates to a computer program product and computerized method and system for the systematic and scientific analysis and evaluation for the programmed prioritization and scheduling of tasks or resources to an individual or group to accomplish competing tasks.
2. Background Art
Many individuals and most knowledge workers in today's society and economy must balance the priorities of tasks that compete for limited time and resources against deadlines. These many individuals and most knowledge workers have access to a variety of personal productivity devices, from personal digital assistants (PDAs) (typically integrated with cellular telephones), sophisticated cell phones, personal computers, and networked personal computers.
These individuals, especially the knowledge workers among them, interact with networked demands and tools and time dependent, prioritizable activities, for example, with financial institutions and transactions (on line banking, billing, bill paying, accounts payable scheduling and ordering, and stock transactions), health care providers (appointment scheduling, prescription management, e-mails to and from providers), and personal issues (birthdays, anniversaries. These same individuals frequently work with or otherwise interact with a variety of traditional applications (for example—general ledger, expense accounting, purchasing, problem management, or personnel systems), workflow, or calendar based applications that automate some of the operations of the enterprise or institutions.
The point of view of most designers of the traditional, workflow, or calendar based applications used by these enterprises and institutions has heretofore been limited. The designers typically see the application as single focused for the provider's application and the user's specific interaction or set of interactions with the provider. Therefore queues and prioritization schemes that implement the enterprise goals within the application are performed in isolation from other enterprise applications as well as from the user's other needs, tasks, and priorities. Consequently, the user, typically a cross-application knowledge worker, is constantly juggling competing priorities.
Most enterprises have responded to this state of affairs by using a de facto single point of contact to drive employees toward priorities associated with enterprise goals. That single point of contact is generally an e-mail interface, frequently an interface to collaboration tools, scheduling tools, and e-mail. However, the e-mail interface was never designed for use as a prioritization and dynamic scheduling tool.
Consequently, the user is presented with a proxy for enterprise goals through poor lenses when the uncorrelated priorities set by the individual user's wants and needs are divorced from enterprise goals and even more distant from the user's capabilities to respond on time.
This goes beyond mere workflow management and calendar management applications, which receive only limited input from heterogeneous applications in their native application context, and do not support inputs from users or users' colleagues.
Thus, there is need for the systematic and scientific analysis and evaluation of end user task scheduling through the programmed prioritization and scheduling of tasks or resources of an individual or group to accomplish competing tasks, preferable on time.
There is a further need for the programmed prioritization and scheduling of tasks or resources to assess the range of tasks, priorities, assess capacities, and provide responses, especially responses consistent with enterprise objectives.
The method, system, and program product of the invention synthesizes cross-application and cross-platform enterprise commitments, provides a mechanism for entering those enterprise commitments at the enterprise, departmental, and personal goal layer levels, provide context switching to move precisely to a desired environment, and accomplish these tasks while respecting a user's individual work state with, for example, semi-pervious interrupt filters.
This is accomplished by a computer based system, which may be networked or off-line (at the time of use), providing the following four functions in an enterprise environment:
At a high level, the above is accomplished in a heterogeneous, personal prioritization manager by a process of
Various aspects of the invention are illustrated in the Figures attached hereto.
The method, system, and program product of the invention synthesizes cross-application and cross-platform enterprise or inter-enterprise commitments, to provide a mechanism for entering those commitments at one or more of the enterprise, departmental, and personal goal layer levels, provide context switching to move precisely to a desired environment, and accomplish these tasks while respecting a user's individual work state with, for example, semi-pervious interrupt filters.
This is accomplished by a computer based system, which may be networked or off-line, as shown in
The network 121 may be a local area network, a wide area network, a TCP/IP internet network, and it may be wired or wireless.
The system 101 shown in
In one embodiment, the system 101 shown in
The method is illustrated in greater detail in
The logic of table 809 is as follows:
This logic, referred to as a “change engine” may be implemented as a state machine, or as “if-then” rules or using combinatorial logic.
This invention is intended to operate on an Intel or Unix family (including the latest Macintoshes) processor. It is also intended to be implemented at a layer that is possible to integrate onto many popular desktop operating systems, including Microsoft Windows 2000, Microsoft Windows XP, Unix or Linux and Mac OS. Significant functions, such as alerting, may be deployed with advantage on various wireless handheld devices—cell phones, PDAs, Smart Phones and the like) Finally, as an implementation choice, Citrix′ Metaframe servers could deliver this invention to any of their target environments.
For example, if the user is dedicated to a specific task, and an instant message or phone call from a teammate on that task is presented, the goal engine will alert the user to the existence of such an interrupt. Note the subtle difference between presenting the actual interrupt—a phone call or instant message—and the existence of such an interrupt. Most users will instinctively answer the message or phone, but are more like to consider the question “An instant message from a teammate exists; would you like to see it?” more thoughtfully.
Finally, the goal engine 1101 shields the user from all lower priority interrupts through determining if the work priority is higher then the interrupt priority 1141. If not it is added to the backlog queue 1143, but if so 1145, the goal engine determines if the user is available, and if so presents the interrupting event to the user 1149. The logic also determines if the interrupt is task specific 1151, and if the interrupt is associated with the user's task at hand 1153. If so, the task is presented to the user, otherwise it goes to the interrupt backlog queue 1143. The goal engine also includes a do not disturb capability 1155.
The following discussion refers to the components depicted in
The application scheduler 1233, therefore, responds to the goal engine's 1101 prioritization by either starting specific applications at specific times for specific roles or by scheduling one application and preventing others from starting before the enterprise goals are satisfied.
Active Status 1231 (including 1231 a and 1231 b). For a long time, phones have had “do not disturb” settings. Some of today's workstation tools, such as Lotus Sametime, have settings for “active”, “do not disturb” and “away”. However, those states are not shared beyond any single application at this time. This invention proposes two novel extensions to such a model.
First, this setting is bidirectional. The user is able to tell the active status component an overriding status setting under normal circumstances. Conversely, when enterprise goals are compromised, the active status component must be able to override the user's setting.
Second, this setting is pervasive. The active status influences the behavior of a wide range of applications: instant messenger, cell phone, IP based phone, e-mail systems, videoconference systems, and any external representation of the user's state, be it a status board or visual status indicator in the computing environment or real world. In general, the goal engine 1101 will set the status indicator, but provision for a user override is important. Similarly, the user can inform the goal engine 1101 when a task changes from active to complete. For example, after the preparation for a meeting is finished, the user would return to the goal engine prioritization for the next priority.
Role Engine 1243. Most knowledge workers function in a variety of roles for the enterprise. During the course of a day, an individual may function in the role of a manager, a subordinate, a knowledge worker, and even an operative in a process. The act of shifting from role to role for significant periods of time usually requires a different mental and workstation focus. Enterprises lose valuable productivity from these time changes. Therefore, the role engine 1243 does three things:
This context switching enables those knowledge workers with multiple roles to configure the workstation specifically for the work to be performed.
Enterprise Goal Engine 1241. The enterprise goal engine is both status and role aware. A simple enterprise goal example can demonstrate this. The enterprise sets a goal of having all performance reviews documented by the end of the second quarter. During the early part of the month of June, the user is reminded gently by the enterprise goal engine to document the reviews. By mid-June, the reminders have become alarms. At the end of June, the enterprise goal engine will override any status or role to place the nearly delinquent manager into the right role and state until the documentation is complete. Upon completion of the goal, the enterprise goal engine returns the user to the prior role and state.
The enterprise goal engine 1241 is aware of the user's commitments based on a calculation of the time associated with the task, the time already allocated to the task and the time available to be allocated to the task.
The following represents a sample of the types of inputs presented to the enterprise goal engine:
The user's calendar becomes the key object for processing requests, scheduling requests and prioritizing the assignment of scarce resource. It is expected that many requests will be rescheduled due to changing enterprise priorities. If they cannot be extended, the user will be allowed to indicate that the gap will be closed with overtime or that the gap cannot be closed. If the latter is true, the enterprise goal engine will communicate with the requester of the work item.
The enterprise goal engine 1241 is configured from two places. First, the user performs configuration activities using a Control Panel. The enterprise performs goal setting activities using an Enterprise Control Panel. These goals are delivered to the user through existing software delivery tools. The enterprise level goals should be maintained by the enterprise application owner. Similar ownership and maintenance responsibilities accrue to each level of application, knowledge database or team room tasks.
External Information Manager 1221. Many of the needs of a knowledge worker come from sources outside the enterprise. To meet these needs and focus on the goals of the enterprise, the external information manager component performs three functions:
For example, it might be argued that a peek at The Late Show with David Letterman Top Ten list can improve productivity by improving the social interaction among peers that encourages subsequent enterprise-specific knowledge sharing. It can clearly be argued that such content is not high priority. On the other hand, a news report from The New York Times about a merger involving a major client must be presented quickly to the user.
The enterprise goal engine 1241, therefore, sorts the changed content from the external information manager into high priority information in support of enterprise goals and low priority information that only indirectly supports enterprise goals and presents them to the active status engine for communication.
Application Adapters 1261. Like the External Information Manager, the Application Adapters provide valuable, specific functions to the enterprise goal engine.
For example, suppose that the problem management system has received a top severity problem report assigned to this user. Also assume that the enterprise priority settings require such problem reports to be delivered instantly to the owning technician. As the application adapter presents this to the enterprise goal engine, the engine announces the arrival of the interrupt to the user immediately. As the user accepts this interrupt, the engine also saves the prior state and task activities (for later reinstatement) and then switches to the problem management workstation configuration.
Setting goals. This invention preferably has multiple goal setting entry points. First, enterprise application owners much have the capability and authority to set enterprise wide goals.
The invention may be implemented, for example, by having the system for Prioritizing workload and tasks by first determining if a prioritization state change is necessary, and if so setting priorities to change the prioritization state, and if not examining prioritization state determining inputs, calculating new prioritization states, and updating prioritization states as a software application, in a dedicated processor or set of processors, or in a dedicated processor or dedicated processors with dedicated code. The code executes a sequence of machine-readable instructions, which can also be referred to as code. These instructions may reside in various types of code-bearing media. In this respect, one aspect of the present invention concerns a program product, comprising a code-bearing medium or code-bearing media tangibly embodying a program of machine-readable instructions executable by a digital processing apparatus to perform a method for searching, extracting, transforming, loading, and presenting priority data from a database management system as a software application.
This code-bearing medium may comprise, for example, memory in a server. The memory in the server may be non-volatile storage, a data disc, or even memory on a vendor server for downloading to a processor for installation. Alternatively, the instructions may be embodied in a code-bearing medium such as the optical data storage disc. Alternatively, the instructions may be stored on any of a variety of machine-readable data storage mediums or media, which may include, for example, a “hard drive”, a RAID array, a RAMAC, a magnetic data storage diskette (such as a floppy disk), magnetic tape, digital optical tape, RAM, ROM, EPROM, EEPROM, flash memory, magneto-optical storage, paper punch and/or cards. As an example, the machine-readable instructions may comprise software object code, compiled from a language such as “C++”, Java, Pascal, ADA, assembler, and the like.
Additionally, the program code may, for example, be compressed, encrypted, or both, and may include executable code, script code and wizards for installation, as in Zip code and cab code. As used herein the term machine-readable instructions or code residing in or on code-bearing media include all of the above means of delivery.
While the foregoing disclosure shows a number of illustrative embodiments of the invention, it will be apparent to those skilled in the art that various changes and modifications can be made herein without departing from the scope of the invention as defined by the appended claims. Furthermore, although elements of the invention may be described or claimed in the singular, the plural is contemplated unless limitation to the singular is explicitly stated.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US4642756||Mar 15, 1985||Feb 10, 1987||S & H Computer Systems, Inc.||Method and apparatus for scheduling the execution of multiple processing tasks in a computer system|
|US5369570||Nov 14, 1991||Nov 29, 1994||Parad; Harvey A.||Method and system for continuous integrated resource management|
|US6115640 *||Jan 16, 1998||Sep 5, 2000||Nec Corporation||Workflow system for rearrangement of a workflow according to the progress of a work and its workflow management method|
|US6408277||Jun 21, 2000||Jun 18, 2002||Banter Limited||System and method for automatic task prioritization|
|US6618730||Jun 16, 2000||Sep 9, 2003||Ge Capital Commercial Finance, Inc.||Methods and systems for managing workflow|
|US6640230||Sep 27, 2000||Oct 28, 2003||International Business Machines Corporation||Calendar-driven application technique for preparing responses to incoming events|
|US20040139448||Jan 14, 2003||Jul 15, 2004||Hope Clifford C.||Interative escalation in an event management system|
|US20040148299 *||Dec 19, 2003||Jul 29, 2004||Microsoft Corporation||Automated workflow composable action model|
|Cooperative Classification||H04L67/322, G06Q10/10|
|European Classification||G06Q10/10, H04L29/08N31Q|
|Sep 7, 2006||AS||Assignment|
Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NYGARD, CRAIG;REEL/FRAME:018237/0922
Effective date: 20060802
Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION,NEW YO
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NYGARD, CRAIG;REEL/FRAME:018237/0922
Effective date: 20060802
|Nov 29, 2013||REMI||Maintenance fee reminder mailed|
|Jan 16, 2014||AS||Assignment|
Owner name: TWITTER, INC., CALIFORNIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:INTERNATIONAL BUSINESS MACHINES CORPORATION;REEL/FRAME:032075/0404
Effective date: 20131230
|Feb 27, 2014||FPAY||Fee payment|
Year of fee payment: 4
|Feb 27, 2014||SULP||Surcharge for late payment|