US20140324492A1 - Context-based business process management - Google Patents

Context-based business process management Download PDF

Info

Publication number
US20140324492A1
US20140324492A1 US14/326,009 US201414326009A US2014324492A1 US 20140324492 A1 US20140324492 A1 US 20140324492A1 US 201414326009 A US201414326009 A US 201414326009A US 2014324492 A1 US2014324492 A1 US 2014324492A1
Authority
US
United States
Prior art keywords
business process
data processing
processing system
contextual information
contextual
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US14/326,009
Inventor
Fred A. Cummins
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Ent Services Development Corp LP
Original Assignee
Hewlett Packard Development Co LP
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Hewlett Packard Development Co LP filed Critical Hewlett Packard Development Co LP
Priority to US14/326,009 priority Critical patent/US20140324492A1/en
Publication of US20140324492A1 publication Critical patent/US20140324492A1/en
Assigned to HEWLETT PACKARD ENTERPRISE DEVELOPMENT LP reassignment HEWLETT PACKARD ENTERPRISE DEVELOPMENT LP ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: HEWLETT-PACKARD DEVELOPMENT COMPANY, L.P.
Assigned to ENT. SERVICES DEVELOPMENT CORPORATION LP reassignment ENT. SERVICES DEVELOPMENT CORPORATION LP ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: HEWLETT PACKARD ENTERPRISE DEVELOPMENT LP
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/06Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling
    • G06Q10/063Operations research, analysis or management
    • G06Q10/0631Resource planning, allocation, distributing or scheduling for enterprises or organisations
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/06Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/06Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling
    • G06Q10/063Operations research, analysis or management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/06Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling
    • G06Q10/063Operations research, analysis or management
    • G06Q10/0637Strategic management or analysis, e.g. setting a goal or target of an organisation; Planning actions based on goals; Analysis or evaluation of effectiveness of goals
    • G06Q10/06375Prediction of business process outcome or impact based on a proposed change

Definitions

  • Business processes often vary depending on the context in which they are applied. In particular, they may vary based on country, product brand, organization, or other contextual factors.
  • FIG. 1 depicts a block diagram of an example data processing system in which a preferred embodiment can be implemented
  • FIG. 2 depicts a block diagram of an example data processing system network in which an embodiment of the present invention can be implemented
  • FIG. 3 depicts an exemplary block diagram illustrating alternate example actions in the operation of a business process, in accordance with an embodiment of the present invention.
  • FIG. 4 depicts a flowchart of a process in accordance with an example preferred embodiment.
  • FIGS. 1 through 4 discussed below, and the various embodiments used to describe the principles of the present invention in this patent document are by way of illustration only and should not be construed in any way to limit the scope of the invention. Those skilled in the art will understand that the principles of the present invention may be implemented in any suitably arranged device. The numerous innovative teachings of the present application will be described with particular reference to the presently preferred embodiment.
  • Various embodiments include a system, method, and computer program product for context-based business process management, in which business processes can be automatically adapted to the context in which they are used or implemented.
  • FIG. 1 depicts a block diagram of a data processing system in which a preferred embodiment can be implemented.
  • the data processing system depicted includes a processor 102 connected to a level two cache/bridge 104 , which is connected in turn to a local system bus 106 .
  • Local system bus 106 may be, for example, a peripheral component interconnect (PCI) architecture bus.
  • PCI peripheral component interconnect
  • Also connected to local system bus in the depicted example are a main memory 108 and a graphics adapter 110 .
  • LAN local area network
  • WiFi Wireless Fidelity
  • Expansion bus interface 114 connects local system bus 106 to input/output (I/O) bus 116 .
  • I/O bus 116 is connected to keyboard/mouse adapter 118 , disk controller 120 , and I/O adapter 122 .
  • audio adapter 124 Also connected to I/O bus 116 in the example shown is audio adapter 124 , to which speakers (not shown) may be connected for playing sounds.
  • Keyboard/mouse adapter 118 provides a connection for a pointing device (not shown), such as a mouse, trackball, trackpointer, etc.
  • FIG. 1 may vary in particular details.
  • other peripheral devices such as an optical disk drive and the like, also may be used in addition or in place of the hardware depicted.
  • the depicted example is provided for the purpose of explanation only and is not meant to imply architectural limitations with respect to the present invention.
  • a data processing system in accordance with a preferred embodiment of the present invention includes an operating system employing a graphical user interface.
  • the operating system permits multiple display windows to be presented in the graphical user interface simultaneously, with each display window providing an interface to a different application or to a different instance of the same application.
  • An application may also have different views of the same instance. In this case, the different views could be the same process in different contexts.
  • a cursor in the graphical user interface may be manipulated by a user through the pointing device. The position of the cursor may be changed and/or an event, such as clicking a mouse button, generated to actuate a desired response.
  • One of various commercial operating systems such as a version of Microsoft WindowsTM, a product of Microsoft Corporation located in Redmond, Wash. may be employed, and can be suitably modified.
  • the operating system is modified or created as necessary in accordance with the present invention as described.
  • FIG. 2 depicts a block diagram of a data processing system network in which an embodiment of the present invention can be implemented.
  • network 205 is any known type of computer network, including private networks or public networks such as the internet. While network 205 is shown in only one instance here; as known to those of skill in the art, network 205 can be implemented in multiple separate networks, or in the same public or private network system.
  • any data or network communication described herein can be implemented using any known data communications means, such as via telephone modem, xDSL, fiber optic, wireless, etc., or public or private networks. These communications can include data business services, context information, and other related and unrelated data.
  • Server 210 is shown communicating with client systems 215 / 220 via network 205 .
  • Server system 210 is a data processing system server, configured to communicate with multiple different client systems, including client systems 215 / 220 and others.
  • client systems 215 / 220 and server system 210 may be co-located or placed at different locations, or be otherwise structured as known to those of skill in the art, so long as they are capable of together performing the functions described and claimed herein.
  • one or more of the data processing systems depicted in FIG. 2 can be configured to execute a business process locally, deliver a business process to a remote system, or to interact with a business process hosted and operating on a remote system.
  • the communications between systems can be made in any known fashion, and in one embodiment, utilize standard markup-language communications, as known to those of skill in the art.
  • business processes were tailored by local organizations to address requirements of their situation.
  • enterprises may execute business processes centrally for business units located around the world.
  • business process outsourcing services may perform business processes for many different clients with variations required among the different clients. In current business process implementations, however, these required variations cannot be effectively accommodated while maintaining the advantages of central location and deployment of the business processes.
  • a method comprising receiving a client login from a client user; loading contextual information including at least one contextual parameter; determining a business process according to the contextual information; and executing the business process.
  • Preferred embodiments include a system, method, and computer program product for customizing business-process operation according to specific context data.
  • Various disclosed embodiments incorporate context data that include, but are not limited to, some or all of ten contextual parameters for the definition of contexts for business processes: Country, Time Zone, Currency, Language, Company, Operational Entity, Brand, Channel, and Role. Other implementations can use any number of different contextual parameters.
  • a preferred embodiment includes a process definition in which each activity of a business process can perform alternative actions depending on the context of the particular execution.
  • the process definition preferably includes both a definition of the action to be taken depending on the value of one or more contextual parameters, as well as the default action or actions to be taken if none of the contextual parameters includes a value for which an action is defined or if some other error results.
  • a process may be invoked by a human or another process.
  • the context can come from a user's profile, the initiating request or event, or the calling process, including something added as a result of the actions of the calling process.
  • everything about a request i.e., its parameters/content are the context of a request.
  • the context parameters and values that qualify for that alternative are preferably declared and applied at the point of selection at execution time. From the caller's perspective, it is one process. One implementation (that is somewhat restrictive) would be to determine all of the qualified activities when the process is instantiated (initiated). A more general implementation would determine each activity appropriate to the context at the time that activity is to be executed.
  • FIG. 3 depicts an exemplary block diagram illustrating alternate actions in the operation of a business process.
  • the contextual parameters have already been determined.
  • each client can have one or more contextual parameters assigned based on the client location.
  • the system will automatically retrieve contextual parameters related to that client, such as Country, Time Zone, Currency, Language, Company, Operational Entity, Brand, Channel, and Role.
  • contextual parameters are retained throughout the client's session, and each process can preferably access the parameters and use them to customize the process flow, to customize the display to the client user, and for other purposes as will be recognized by those of skill in the art.
  • the designer of the process determines which elements are to be considered the context parameters for the particular process.
  • the choice of context parameters allows the designer to view the process and design it “in that context” without the necessity of considering all other contexts at the same time.
  • the context, or certain context parameters may also be a way of restricting what a particular designer is allowed to change in a process as where a common process is specialized for different users.
  • the exemplary process of FIG. 3 begins at node 305 and initiates activity 310 . There is only one version of this activity.
  • activity 310 When activity 310 is complete, processing proceeds to activity 315 , which is a decision point. There could be alternative versions of the decision based on the context, but in this example, there is only one. If the decision is true (T), then processing proceeds to the alternative activities 320 , 325 , and 330 . This decision could be, for example, whether the “Country” contextual parameter is equal to “United States”.
  • Attributes defined on alternative activities 320 , 325 , and 330 will determine which one is appropriate for the particular context.
  • processing proceeds to activity 345 and then the process is completed at 350 .
  • decision 315 is false (F)
  • processing proceeds to 335 or 340 , depending on the context values, and then the process is complete at 350 .
  • the process path can change significantly depending on the context of the client user, as defined by the contextual parameters.
  • a common system can provide the customized experience and processing required by different client users, gaining the advantages of a centralized implementation while providing the client with the advantages of a customized solution.
  • Another approach is to define a set of context parameters for the entire process and base the selection of alternative activities on the values of one or more of the variables. This has the advantage that the modeling tool can be programmed to display only the activities that would be relevant to a selected context, allowing the analyst to view and refine the complete process in each alternative context.
  • an implementation can define the alternative activities in a hierarchy where one is the default, and others are more specific.
  • the hierarchy can be implicit by always selecting the activity with the most restrictive scope, i.e., the most specific but relevant activity.
  • the selection can be explicitly defined using a decision tree or with a truth table or Venn diagram that identifies the appropriate alternative for every possible combination of context variable values.
  • Some activities can be defined as “no-operation” thus eliminating the activity for its associated contexts. If a no-op were defined as the default, then only activities for specialized contexts would be active at that point in the process.
  • FIG. 4 depicts a flowchart of a process in accordance with a preferred embodiment.
  • Suitable means in a data processing system can implement the process, and computer-executable instructions to perform the process can be stored in a machine-usable medium.
  • the system receives a client login (step 405 ).
  • the login can identify a client enterprise, and individual, or other identifying information about the client user.
  • the business processes described herein are executed on a server data processing system, and the client user logs in through a client data processing system communicating with the server data processing system.
  • the client login need not be done at the same time as the remaining steps, and may not include a specific user manually logging into a system.
  • a client data processing system that is substantially continuously communicating with a server data processing system can be considered to have “logged in” at the time it attaches to and is authenticated by the server data processing system.
  • One or more contextual parameter comprises “contextual information” as used herein.
  • the contextual parameter corresponds to the client login, and can be loaded when the login is processed.
  • the client user can be prompted to enter information, and the contextual information can be received directly from the client user.
  • the contextual data can be detected automatically, such as from the IP address of the client user or in other ways known to those of skill in the art.
  • the system will determine a business process according the contextual parameter(s) (step 415 ).
  • the business process is preferably selected from among a plurality of options, each being conditional on one or more of the contextual parameters.
  • the business process can be defined as a “no operation” as a default or according to specific contextual parameter conditions.
  • the system will execute the appropriate business process (step 420 ), as determined.
  • This execution can include a no operation (that is, nothing is affirmatively executed at this point), and can include providing the user with options, according to the contextual parameters, for further processes.
  • a series of business processes are executed as described, according to user actions, the contextual parameters, and other factors as known to those of skill in the art. Together, this series of processes forms a process path. Each process in the process path can be the only available process at that point, or can be one of a plurality of alternative processes, determined as described above.
  • the process path and overall experience are then customized to the specific client user according to the client user's preferences and context of use.
  • the client initiates a process, and the execution of the process determines the set of activities that will actually be used in the performance of that request.
  • the execution of the process determines the set of activities that will actually be used in the performance of that request. From the client's view, there is only one process, discussed above as the “process path”, and the context-based selection is internal to the process from the client's perspective.
  • the first process in a process path after a client login, will not have alternative processes, and are omitted from the exemplary process illustrated in the flowchart above.
  • the determination of context parameters can be in the execution engine, as in a preferred embodiment, and performed as part of initiating a process, or the process itself may determine context parameters.
  • machine usable mediums include: nonvolatile, hard-coded type mediums such as read only memories (ROMs) or erasable, electrically programmable read only memories (EEPROMs), user-recordable type mediums such as floppy disks, hard disk drives and compact disk read only memories (CD-ROMs) or digital versatile disks (DVDs), and transmission type mediums such as digital and analog communication links
  • ROMs read only memories
  • EEPROMs electrically programmable read only memories
  • user-recordable type mediums such as floppy disks, hard disk drives and compact disk read only memories (CD-ROMs) or digital versatile disks (DVDs
  • transmission type mediums such as digital and analog communication links

Landscapes

  • Business, Economics & Management (AREA)
  • Human Resources & Organizations (AREA)
  • Engineering & Computer Science (AREA)
  • Strategic Management (AREA)
  • Economics (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Educational Administration (AREA)
  • Operations Research (AREA)
  • Game Theory and Decision Science (AREA)
  • Marketing (AREA)
  • Development Economics (AREA)
  • Quality & Reliability (AREA)
  • Tourism & Hospitality (AREA)
  • Physics & Mathematics (AREA)
  • General Business, Economics & Management (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Stored Programmes (AREA)
  • Information Transfer Between Computers (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)

Abstract

A method, and corresponding hardware and software implementations, including receiving a client login from a client user; loading contextual information including at least one contextual parameter; determining a business process according to the contextual information; and executing the business process.

Description

    CROSS REFERENCE TO RELATED APPLICATIONS
  • This application is a continuation of U.S. patent application Ser. No. 11/246,599, entitled “SYSTEM, METHOD, AND COMPUTER PROGRAM PRODUCT FOR CONTEXT-BASED BUSINESS PROCESS MANAGEMENT,” having a filing date of Oct. 7, 2005, which is herein incorporated by reference.
  • BACKGROUND
  • Business processes often vary depending on the context in which they are applied. In particular, they may vary based on country, product brand, organization, or other contextual factors.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 depicts a block diagram of an example data processing system in which a preferred embodiment can be implemented;
  • FIG. 2 depicts a block diagram of an example data processing system network in which an embodiment of the present invention can be implemented;
  • FIG. 3 depicts an exemplary block diagram illustrating alternate example actions in the operation of a business process, in accordance with an embodiment of the present invention; and
  • FIG. 4 depicts a flowchart of a process in accordance with an example preferred embodiment.
  • DETAILED DESCRIPTION
  • In the following detailed description, reference is made to the accompanying drawings which form a part hereof, and in which is shown by way of illustration specific examples in which the disclosure may be practiced. It is to be understood that other examples may be utilized and structural or logical changes may be made without departing from the scope of the present disclosure. The following detailed description, therefore, is not to be taken in a limiting sense, and the scope of the present disclosure is defined by the appended claims. It is to be understood that features of the various examples described herein may be combined, in part or whole, with each other, unless specifically noted otherwise.
  • Certain words and phrases used throughout this patent document are defined: the terms “include” and “comprise,” as well as derivatives thereof, mean inclusion without limitation; the term “or” is inclusive, meaning and/or; the phrases “associated with” and “associated therewith,” as well as derivatives thereof, may mean to include, be included within, interconnect with, contain, be contained within, connect to or with, couple to or with, be communicable with, cooperate with, interleave, juxtapose, be proximate to, be bound to or with, have, have a property of, or the like; and the term “controller” means any device, system or part thereof that controls at least one operation, whether such a device is implemented in hardware, firmware, software or some combination of at least two of the same. It should be noted that the functionality associated with any particular controller may be centralized or distributed, whether locally or remotely. Definitions for certain words and phrases are provided throughout this patent document, and those of ordinary skill in the art will understand that such definitions apply in many, if not most, instances to prior as well as future uses of such defined words and phrases.
  • FIGS. 1 through 4, discussed below, and the various embodiments used to describe the principles of the present invention in this patent document are by way of illustration only and should not be construed in any way to limit the scope of the invention. Those skilled in the art will understand that the principles of the present invention may be implemented in any suitably arranged device. The numerous innovative teachings of the present application will be described with particular reference to the presently preferred embodiment.
  • Various embodiments include a system, method, and computer program product for context-based business process management, in which business processes can be automatically adapted to the context in which they are used or implemented.
  • To provide context for the system and methods disclosed herein, both a hardware context and overall system context are described below. Following that is a more detailed description of the specific functions, structures, and other details of the disclosed embodiments.
  • FIG. 1 depicts a block diagram of a data processing system in which a preferred embodiment can be implemented. The data processing system depicted includes a processor 102 connected to a level two cache/bridge 104, which is connected in turn to a local system bus 106. Local system bus 106 may be, for example, a peripheral component interconnect (PCI) architecture bus. Also connected to local system bus in the depicted example are a main memory 108 and a graphics adapter 110.
  • Other peripherals, such as local area network (LAN)/Wide Area Network/Wireless (e.g. WiFi) adapter 112, may also be connected to local system bus 106. Expansion bus interface 114 connects local system bus 106 to input/output (I/O) bus 116. I/O bus 116 is connected to keyboard/mouse adapter 118, disk controller 120, and I/O adapter 122.
  • Also connected to I/O bus 116 in the example shown is audio adapter 124, to which speakers (not shown) may be connected for playing sounds. Keyboard/mouse adapter 118 provides a connection for a pointing device (not shown), such as a mouse, trackball, trackpointer, etc.
  • Those of ordinary skill in the art will appreciate that the hardware depicted in FIG. 1 may vary in particular details. For example, other peripheral devices, such as an optical disk drive and the like, also may be used in addition or in place of the hardware depicted. The depicted example is provided for the purpose of explanation only and is not meant to imply architectural limitations with respect to the present invention.
  • A data processing system in accordance with a preferred embodiment of the present invention includes an operating system employing a graphical user interface. The operating system permits multiple display windows to be presented in the graphical user interface simultaneously, with each display window providing an interface to a different application or to a different instance of the same application. An application may also have different views of the same instance. In this case, the different views could be the same process in different contexts. A cursor in the graphical user interface may be manipulated by a user through the pointing device. The position of the cursor may be changed and/or an event, such as clicking a mouse button, generated to actuate a desired response.
  • One of various commercial operating systems, such as a version of Microsoft Windows™, a product of Microsoft Corporation located in Redmond, Wash. may be employed, and can be suitably modified. The operating system is modified or created as necessary in accordance with the present invention as described.
  • FIG. 2 depicts a block diagram of a data processing system network in which an embodiment of the present invention can be implemented. In this figure, network 205 is any known type of computer network, including private networks or public networks such as the internet. While network 205 is shown in only one instance here; as known to those of skill in the art, network 205 can be implemented in multiple separate networks, or in the same public or private network system. Of course, any data or network communication described herein can be implemented using any known data communications means, such as via telephone modem, xDSL, fiber optic, wireless, etc., or public or private networks. These communications can include data business services, context information, and other related and unrelated data.
  • Server 210 is shown communicating with client systems 215/220 via network 205. Server system 210 is a data processing system server, configured to communicate with multiple different client systems, including client systems 215/220 and others.
  • It is understood that client systems 215/220 and server system 210 may be co-located or placed at different locations, or be otherwise structured as known to those of skill in the art, so long as they are capable of together performing the functions described and claimed herein.
  • As described herein, one or more of the data processing systems depicted in FIG. 2, whether client or server systems, can be configured to execute a business process locally, deliver a business process to a remote system, or to interact with a business process hosted and operating on a remote system.
  • The communications between systems can be made in any known fashion, and in one embodiment, utilize standard markup-language communications, as known to those of skill in the art.
  • Traditionally, business processes were tailored by local organizations to address requirements of their situation. With the advent of globalization and automation of business processes, enterprises may execute business processes centrally for business units located around the world. In addition, business process outsourcing services may perform business processes for many different clients with variations required among the different clients. In current business process implementations, however, these required variations cannot be effectively accommodated while maintaining the advantages of central location and deployment of the business processes.
  • According to various embodiments, there is disclosed a method, and corresponding hardware and software implementations, comprising receiving a client login from a client user; loading contextual information including at least one contextual parameter; determining a business process according to the contextual information; and executing the business process.
  • Preferred embodiments include a system, method, and computer program product for customizing business-process operation according to specific context data. Various disclosed embodiments incorporate context data that include, but are not limited to, some or all of ten contextual parameters for the definition of contexts for business processes: Country, Time Zone, Currency, Language, Company, Operational Entity, Brand, Channel, and Role. Other implementations can use any number of different contextual parameters.
  • A preferred embodiment includes a process definition in which each activity of a business process can perform alternative actions depending on the context of the particular execution. The process definition preferably includes both a definition of the action to be taken depending on the value of one or more contextual parameters, as well as the default action or actions to be taken if none of the contextual parameters includes a value for which an action is defined or if some other error results.
  • In various embodiments, a process may be invoked by a human or another process. The context can come from a user's profile, the initiating request or event, or the calling process, including something added as a result of the actions of the calling process. In some embodiments, everything about a request (i.e., its parameters/content) are the context of a request.
  • Wherever there is an alternative activity or set of activities (a process), the context parameters and values that qualify for that alternative are preferably declared and applied at the point of selection at execution time. From the caller's perspective, it is one process. One implementation (that is somewhat restrictive) would be to determine all of the qualified activities when the process is instantiated (initiated). A more general implementation would determine each activity appropriate to the context at the time that activity is to be executed.
  • FIG. 3 depicts an exemplary block diagram illustrating alternate actions in the operation of a business process. In this example, it is assumed that the contextual parameters have already been determined. For example, where geographically diverse clients access business services that are hosted on a common server, each client can have one or more contextual parameters assigned based on the client location. When the client “logs in” to his account on the common server, the system will automatically retrieve contextual parameters related to that client, such as Country, Time Zone, Currency, Language, Company, Operational Entity, Brand, Channel, and Role. These contextual parameters are retained throughout the client's session, and each process can preferably access the parameters and use them to customize the process flow, to customize the display to the client user, and for other purposes as will be recognized by those of skill in the art.
  • Preferably, the designer of the process determines which elements are to be considered the context parameters for the particular process. The choice of context parameters allows the designer to view the process and design it “in that context” without the necessity of considering all other contexts at the same time. The context, or certain context parameters, may also be a way of restricting what a particular designer is allowed to change in a process as where a common process is specialized for different users.
  • In an implementation in accordance with a preferred embodiment, there is a distinction between the process during design and the same process during execution. In design, the designer can set the context variables and see the resulting process. At runtime (execution) the context parameters may not all be known at the outset. Setting of context parameters within the process may result in a more complex process, or one that is at greater risk of error, since the designer must ensure that context parameters are set before they are needed.
  • While it is possible, in some embodiments, to determine all of the activities of a process for a given context at the start, it is also possible that the process will determine or change parameters that are context for some of its activities as well as other processes it may invoke. A designer can set all of these for viewing and designing a particular specialization, but that does not mean they are all known at the start of execution of a particular process.
  • The exemplary process of FIG. 3 begins at node 305 and initiates activity 310. There is only one version of this activity.
  • When activity 310 is complete, processing proceeds to activity 315, which is a decision point. There could be alternative versions of the decision based on the context, but in this example, there is only one. If the decision is true (T), then processing proceeds to the alternative activities 320, 325, and 330. This decision could be, for example, whether the “Country” contextual parameter is equal to “United States”.
  • As noted, while this decision is illustrated as a simple true/false, for simplicity of illustration, in practice there can be any number of different process paths depending in the values of the contextual parameters, as defined by the process definitions.
  • Attributes defined on alternative activities 320, 325, and 330 will determine which one is appropriate for the particular context. When alternative activity 320, 325, or 330 is completed, processing proceeds to activity 345 and then the process is completed at 350.
  • Alternatively, if decision 315 is false (F), processing proceeds to 335 or 340, depending on the context values, and then the process is complete at 350.
  • As shown, the process path can change significantly depending on the context of the client user, as defined by the contextual parameters. In this way, a common system can provide the customized experience and processing required by different client users, gaining the advantages of a centralized implementation while providing the client with the advantages of a customized solution.
  • One approach implementing this process model is to introduce a selection specification ahead of each activity where there are alternatives. In this way, the selection of alternatives could be based on any variables associated with the process execution.
  • Another approach is to define a set of context parameters for the entire process and base the selection of alternative activities on the values of one or more of the variables. This has the advantage that the modeling tool can be programmed to display only the activities that would be relevant to a selected context, allowing the analyst to view and refine the complete process in each alternative context.
  • In addition, an implementation can define the alternative activities in a hierarchy where one is the default, and others are more specific. The hierarchy can be implicit by always selecting the activity with the most restrictive scope, i.e., the most specific but relevant activity. Alternatively, the selection can be explicitly defined using a decision tree or with a truth table or Venn diagram that identifies the appropriate alternative for every possible combination of context variable values.
  • Some activities can be defined as “no-operation” thus eliminating the activity for its associated contexts. If a no-op were defined as the default, then only activities for specialized contexts would be active at that point in the process.
  • In alternate embodiments, different business processes could be defined for each different context. This approach could result in a proliferation of business processes, and a substantial burden to appropriately change all of the similar processes when a common business requirement changes. In addition, a context-based invocation decision would be required at each point of invocation of such alternative processes.
  • FIG. 4 depicts a flowchart of a process in accordance with a preferred embodiment. Suitable means in a data processing system can implement the process, and computer-executable instructions to perform the process can be stored in a machine-usable medium.
  • First, the system receives a client login (step 405). As known to those of skill in the art, the login can identify a client enterprise, and individual, or other identifying information about the client user. In a preferred embodiment, the business processes described herein are executed on a server data processing system, and the client user logs in through a client data processing system communicating with the server data processing system. Of course, the client login need not be done at the same time as the remaining steps, and may not include a specific user manually logging into a system. For example, a client data processing system that is substantially continuously communicating with a server data processing system can be considered to have “logged in” at the time it attaches to and is authenticated by the server data processing system.
  • Other conventional steps, known to those of skill in the art, are not illustrated in this figure. These steps can include loading and assigning client profiles, allocating resources, and many others.
  • Next, the system will load at least one contextual parameter (step 410). One or more contextual parameter comprises “contextual information” as used herein. Preferably, the contextual parameter corresponds to the client login, and can be loaded when the login is processed. In alternate embodiments, the client user can be prompted to enter information, and the contextual information can be received directly from the client user. In other embodiments, the contextual data can be detected automatically, such as from the IP address of the client user or in other ways known to those of skill in the art.
  • Next, the system will determine a business process according the contextual parameter(s) (step 415). The business process is preferably selected from among a plurality of options, each being conditional on one or more of the contextual parameters. Preferably, there is also a default business process defined for when other conditions are not met. The business process can be defined as a “no operation” as a default or according to specific contextual parameter conditions.
  • The system will execute the appropriate business process (step 420), as determined. This execution can include a no operation (that is, nothing is affirmatively executed at this point), and can include providing the user with options, according to the contextual parameters, for further processes.
  • In a typical implementation, a series of business processes are executed as described, according to user actions, the contextual parameters, and other factors as known to those of skill in the art. Together, this series of processes forms a process path. Each process in the process path can be the only available process at that point, or can be one of a plurality of alternative processes, determined as described above. By using the processes and techniques described herein, the process path and overall experience are then customized to the specific client user according to the client user's preferences and context of use.
  • Preferably, from the perspective of a client user, the client initiates a process, and the execution of the process determines the set of activities that will actually be used in the performance of that request. From the client's view, there is only one process, discussed above as the “process path”, and the context-based selection is internal to the process from the client's perspective.
  • In many implementations, the first process in a process path, after a client login, will not have alternative processes, and are omitted from the exemplary process illustrated in the flowchart above. There may be a first process that sets context parameters, or there may not, according to design preferences. The determination of context parameters can be in the execution engine, as in a preferred embodiment, and performed as part of initiating a process, or the process itself may determine context parameters.
  • In various embodiments, it is possible to restrict certain context variables so they cannot be changed by a designer or during execution. By doing so, the same root processes can be used by multiple clients in an outsourcing arrangement, to gain economies of scale across multiple clients while preserving the separation of processing and control of each from the others.
  • Other particular innovative features include, but are not limited to, the including ability of the system to display a view a process in a specified context, the ability of the system to restrict a designer or a client user to particular context(s) in order to ensure separation of clients where a system uses the same processes to serve multiple, independent clients, and the ability of the system to have context applied as each activity is executed for selection of alternatives as opposed to activities being determined at the beginning of the process (instance).
  • Those skilled in the art will recognize that, for simplicity and clarity, the full structure and operation of all data processing systems suitable for use with the present invention is not being depicted or described herein. Instead, only so much of a data processing system as is unique to the present invention or necessary for an understanding of the present invention is depicted and described. The remainder of the construction and operation of the data processing system may conform to any of the various current implementations and practices known in the art.
  • It is important to note that while the present invention has been described in the context of a fully functional system, those skilled in the art will appreciate that at least portions of the mechanism of the present invention are capable of being distributed in the form of instructions contained within a machine usable medium in any of a variety of forms, and that the present invention applies equally regardless of the particular type of instruction or signal bearing medium utilized to actually carry out the distribution. Examples of machine usable mediums include: nonvolatile, hard-coded type mediums such as read only memories (ROMs) or erasable, electrically programmable read only memories (EEPROMs), user-recordable type mediums such as floppy disks, hard disk drives and compact disk read only memories (CD-ROMs) or digital versatile disks (DVDs), and transmission type mediums such as digital and analog communication links
  • Although specific examples have been illustrated and described herein, a variety of alternate and/or equivalent implementations may be substituted for the specific examples shown and described without departing from the scope of the present disclosure. This application is intended to cover any adaptations or variations of the specific examples discussed herein. Therefore, it is intended that this disclosure be limited only by the claims and the equivalents thereof

Claims (20)

What is claimed is:
1. A method for managing business processes, comprising:
receiving a client login from a corresponding client user in a data processing system;
loading contextual information including at least one contextual parameter associated with the client login, wherein the data processing system is configured to accept contextual information from a plurality of client logins;
determining, by the data processing system, a customizable business process for the client user, the customizable business process including activities wherein each activity of the customizable business process performs an action selected from a plurality of alternative actions according to the contextual information;
customizing the activities of the customizable business process according to a process definition to generate a version of the customizable business process corresponding with the process definition; and
executing the version of the customizable business process by the data processing system.
2. The data processing system of claim 1, wherein the process definition includes a definition of an action to be taken depending on contextual information.
3. The data processing system of claim 1, wherein the process definition includes a default action to be taken if the contextual information does not include a defined action.
4. The data processing system of claim 1, including permitting the determining of the customizable business process for the client user based on the at least one contextual parameter while the version of the customizable business process is executing.
5. The method of claim 1, wherein the contextual information includes one or more contextual parameters comprising Country, Time Zone, Currency, Language, Company, Operational Entity, Brand, Channel, and Role.
6. The method of claim 1, wherein the business process is determined from a plurality of alternative business processes, each alternative business process being associated at least one contextual parameter.
7. The method of claim 1, wherein the business process is executed in conjunction with at least one other business process, together defining a process path, the process path being customized according to the contextual information.
8. A data processing system comprising a processor and accessible memory, the data processing system configured to perform the steps of:
receiving a client login from a corresponding client user;
loading contextual information including at least one contextual parameter associated with the client login, wherein the data processing system is configured to accept contextual information from a plurality of client logins;
determining a customizable business process for the client user, the customizable business process including activities wherein each activity of the customizable business process performs an action selected from a plurality of alternative actions according to the contextual information;
customizing the activities of the customizable business process according to a process definition to generate a version of the customizable business process corresponding with the process definition; and
executing the version of the customizable business process.
9. The data processing system of claim 8, wherein the process definition includes a definition of an action to be taken depending on contextual information.
10. The data processing system of claim 8, wherein the process definition includes a default action to be taken if the contextual information does not include a defined action.
11. The data processing system of claim 8, including permitting the determining of the customizable business process for the client user based on the at least one contextual parameter while the version of the customizable business process is executing.
12. The data processing system of claim 8, wherein the contextual information includes one or more contextual parameters including Country, Time Zone, Currency, Language, Company, Operational Entity, Brand, Channel, and Role.
13. The data processing system of claim 8, wherein the business process is determined from a plurality of alternative business processes, each alternative business process being associated at least one contextual parameter.
14. The data processing system of claim 8, wherein the business process is executed in conjunction with at least one other business process, together defining a process path, the process path being customized according to the contextual information.
15. A computer program product tangibly embodied in a machine-readable medium, comprising:
computer-executable instructions for receiving a client login from a corresponding client user;
computer-executable instructions for loading contextual information including at least one contextual parameter associated with the client login, wherein the data processing system is configured to accept contextual information from a plurality of client logins;
computer-executable instructions for determining a customizable business process for the client user, the customizable business process including activities wherein each activity of the customizable business process performs an action selected from a plurality of alternative actions according to the contextual information;
computer executable instructions for customizing the activities of the customizable business process according to a process definition to generate a version of the customizable business process corresponding with the process definition; and
computer-executable instructions for executing the version of the customizable business process.
16. The data processing system of claim 15, wherein the process definition includes a definition of an action to be taken depending on contextual information.
17. The data processing system of claim 15, wherein the process definition includes a default action to be taken if the contextual information does not include a defined action.
18. The data processing system of claim 15, including permitting the determining of the customizable business process for the client user based on the at least one contextual parameter while the version of the customizable business process is executing.
19. The computer program product of claim 15, wherein the business process is determined from a plurality of alternative business processes, each alternative business process being associated at least one contextual parameter.
20. The computer program product of claim 15, wherein the business process is executed in conjunction with at least one other business process, together defining a process path, the process path being customized according to the contextual information.
US14/326,009 2005-10-07 2014-07-08 Context-based business process management Abandoned US20140324492A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US14/326,009 US20140324492A1 (en) 2005-10-07 2014-07-08 Context-based business process management

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/246,599 US8775194B2 (en) 2005-10-07 2005-10-07 System, method, and computer program product for context-based business process management
US14/326,009 US20140324492A1 (en) 2005-10-07 2014-07-08 Context-based business process management

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US11/246,599 Continuation US8775194B2 (en) 2005-10-07 2005-10-07 System, method, and computer program product for context-based business process management

Publications (1)

Publication Number Publication Date
US20140324492A1 true US20140324492A1 (en) 2014-10-30

Family

ID=37911943

Family Applications (2)

Application Number Title Priority Date Filing Date
US11/246,599 Active 2031-05-25 US8775194B2 (en) 2005-10-07 2005-10-07 System, method, and computer program product for context-based business process management
US14/326,009 Abandoned US20140324492A1 (en) 2005-10-07 2014-07-08 Context-based business process management

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US11/246,599 Active 2031-05-25 US8775194B2 (en) 2005-10-07 2005-10-07 System, method, and computer program product for context-based business process management

Country Status (2)

Country Link
US (2) US8775194B2 (en)
WO (1) WO2007044158A2 (en)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100031140A1 (en) * 2008-08-01 2010-02-04 Cummins Fred A Verifying An Electronic Document
US20100030604A1 (en) * 2008-08-01 2010-02-04 Cummins Fred A Executing Business Rules in a Business Process
US8977633B2 (en) * 2009-12-15 2015-03-10 Guvera Ip Pty Ltd. System and method for generating a pool of matched content
US8839249B2 (en) * 2011-01-21 2014-09-16 Rackspace Us, Inc. Customizing automated process management

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20010051876A1 (en) * 2000-04-03 2001-12-13 Seigel Ronald E. System and method for personalizing, customizing and distributing geographically distinctive products and travel information over the internet
US20040015405A1 (en) * 2001-02-16 2004-01-22 Gemini Networks, Inc. System, method, and computer program product for end-user service provider selection
US8121874B1 (en) * 1999-05-27 2012-02-21 Accenture Global Services Limited Phase delivery of components of a system required for implementation technology

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6546406B1 (en) * 1995-11-03 2003-04-08 Enigma Information Systems Ltd. Client-server computer system for large document retrieval on networked computer system
US6167409A (en) * 1996-03-01 2000-12-26 Enigma Information Systems Ltd. Computer system and method for customizing context information sent with document fragments across a computer network
US6003046A (en) * 1996-04-15 1999-12-14 Sun Microsystems, Inc. Automatic development and display of context information in structured documents on the world wide web
US6154751A (en) * 1998-05-14 2000-11-28 International Business Machines Corporation Method for executing a user-requested CGI program in a new authentication context while protecting operation of a default web server program
US6961723B2 (en) * 2001-05-04 2005-11-01 Sun Microsystems, Inc. System and method for determining relevancy of query responses in a distributed network search mechanism
US8731983B2 (en) * 2005-02-24 2014-05-20 Sap Ag System and method for designing effective business policies via business rules analysis

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8121874B1 (en) * 1999-05-27 2012-02-21 Accenture Global Services Limited Phase delivery of components of a system required for implementation technology
US20010051876A1 (en) * 2000-04-03 2001-12-13 Seigel Ronald E. System and method for personalizing, customizing and distributing geographically distinctive products and travel information over the internet
US20040015405A1 (en) * 2001-02-16 2004-01-22 Gemini Networks, Inc. System, method, and computer program product for end-user service provider selection

Also Published As

Publication number Publication date
WO2007044158A2 (en) 2007-04-19
US20070083406A1 (en) 2007-04-12
WO2007044158A3 (en) 2007-11-01
US8775194B2 (en) 2014-07-08

Similar Documents

Publication Publication Date Title
US7289966B2 (en) Method and system for adapting the execution of a workflow route
US7185057B2 (en) Individually specifying message output attributes in a messaging system
US9697377B2 (en) On-demand database service system, method and computer program product for conditionally allowing an application of an entity access to data of another entity
US7062537B2 (en) Workflow services architecture
US6606711B2 (en) Object security boundaries
US6816902B1 (en) Method and system for improving workflow performance in workflow application systems
US20120116751A1 (en) Providing message text translations
US20080043976A1 (en) Management of telephone call routing using a directory services schema
US20030061482A1 (en) Software security control system and method
JP2008533549A (en) System and method for application development and deployment
US20140324492A1 (en) Context-based business process management
US9979822B1 (en) Method and system for specifying and processing telephony sessions
EP1620830A2 (en) An end user oriented workflow approach including structured processing of ad hoc workflows with a collaborative process engine
US20110093367A1 (en) Method, apparatus, and computer product for centralized account provisioning
US20060021026A1 (en) System and method for modular network transaction processing with plug-in processing modules and interfaces
US20130226906A1 (en) System And Method For A Self-Configuring Question Answering System
US9141442B1 (en) Automated connector creation for provisioning systems
US20170308361A1 (en) Call Management Method and Apparatus
US8904391B2 (en) Policy-based access control approach to staff activities of a business process
CN110249355A (en) The exposure of Do-Not Disturb state and being arranged using behavior based on it
US7684349B2 (en) Method and system for transparently controlling the behavior of service methods in a service oriented architecture
US20090320089A1 (en) Policy-based user brokered authorization
EP2778956A2 (en) Processing a link on a device
Vallejos et al. The context-dependent role model
US20120144367A1 (en) Events fired pre- and post-method execution

Legal Events

Date Code Title Description
AS Assignment

Owner name: HEWLETT PACKARD ENTERPRISE DEVELOPMENT LP, TEXAS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:HEWLETT-PACKARD DEVELOPMENT COMPANY, L.P.;REEL/FRAME:037079/0001

Effective date: 20151027

AS Assignment

Owner name: ENT. SERVICES DEVELOPMENT CORPORATION LP, TEXAS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:HEWLETT PACKARD ENTERPRISE DEVELOPMENT LP;REEL/FRAME:041041/0716

Effective date: 20161201

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION