The invention provides in some aspects a distributed rules processing system that includes a first and second digital data processors that are coupled to one another by one or more networks. A rules base and a transactional data base are each coupled to one of the digital data processors; both may be coupled to the same digital data processor or otherwise. One or more coordination modules (e.g., “proxies”), each of which is associated with a respective one of the digital data processors, makes available to a selected one of those digital data processors from the other of those digital data processors (i) one or more selected rules from the rules base, and/or (ii) one or more data from the transactional database on which those rules are to be executed. The selected digital data processor executes one or more of the selected rules as a rules engine, executes one or more of the selected rules using a rules engine, and/or processes one or more data from the transactional database with rules executing on a rules engine.

Patent
   9270743
Priority
Feb 18 2011
Filed
Oct 29 2014
Issued
Feb 23 2016
Expiry
Feb 18 2031

TERM.DISCL.
Assg.orig
Entity
Large
13
687
currently ok
1. A distributed processing system comprising:
a server digital data processor coupled to a rules base that stores a plurality of rules that define an application, wherein the server digital data processor operates on a cloud platform,
an integration link used for communication of one or more data between the application and a tenant legacy system during execution of the application, wherein at least one integration rule among the plurality of rules defines the integration link, and wherein the tenant legacy system comprises at least one of a database and a web service that is communicatively coupled to the server digital data processor,
one or more coordination modules associated with a respective one of the server digital data processor and the tenant legacy system that facilitate the communication between the tenant legacy system and the application in accordance with the integration rule and other tenant legacy system information accessible to the server digital data processor, and
a firewall that is coupled to the one or more networks and that interrupts the integration link between the application and the tenant legacy system, absent intervention of the one or more coordination modules and the other tenant legacy system information accessible to the server digital data processor,
wherein a tenant data center environment is simulated such that the one or more coordination modules and the tenant legacy system information accessible to the server digital data processor obviate a need to reconfigure the integration rule, so as to maintain the integration link regardless of execution of the application on the server digital data processor or a tenant digital data processor, and wherein the tenant legacy system is directly accessible to the tenant digital processor without the firewall preventing such access.
10. A method of distributed rules processing, the method comprising:
coupling a server digital data processor to a rules base that stores a plurality of rules that define an application, wherein the server digital data processor operates on a cloud platform,
defining an integration link for communication of one or more data between the application and a tenant legacy system during execution of the application, wherein at least one integration rule among the plurality of rules defines the integration link, and wherein the tenant legacy system comprises at least one of a database and a web service that is communicatively coupled to the server digital data processor,
facilitating the communication between the tenant legacy system and the application, via one or more coordination modules associated with a respective one of the server digital data processor and the tenant legacy system, in accordance with the integration rule and other tenant legacy system information accessible to the server digital data processor, and
simulating a tenant data center environment such that the one or more coordination modules and the tenant legacy system information accessible to the server digital data processor obviate a need to reconfigure the integration rule, so as to maintain the integration link regardless of execution of the application on the server digital data processor or a tenant digital data processor, wherein the tenant legacy system is directly accessible to the tenant digital processor without a firewall preventing such access, and
wherein the firewall is coupled to the one or more networks and interrupts the integration link between the application and the tenant legacy system, absent intervention of the one or more coordination modules and the other tenant legacy system information accessible to the server digital data processor.
2. The system of claim 1, wherein the one or more coordination modules facilitate the communication between the tenant legacy system and the application by making available the tenant legacy information to the server digital data processor in response to a request from a rules engine executing on at least one of the server digital data processor and the tenant digital data processor.
3. The system of claim 2, wherein the one or more coordination modules make available the tenant legacy information to the server digital data processor by opening one or more communications ports on the firewall.
4. The system of claim 3, wherein the one or more coordination modules make available the tenant legacy information to the tenant digital data processor by opening a single communications port on the firewall and obviate a need to open a plurality of communications ports on the firewall.
5. The system of claim 1, wherein the one or more coordination modules retrieve the tenant legacy information for use in execution of one or more selected rules from the rules base coupled to the server digital data processor.
6. The system of claim 1, wherein the one or more coordination modules transfer one or more selected rules from the rules base coupled to the server digital data processor for execution on the tenant digital data processor.
7. The system of claim 1, wherein the at least one integration rule defines the integration link according to at least one of a Simple Object access Protocol (SOAP) integration method, a .NET integration method, a Java integration method, and an Enterprise Java Beans (EJB) integration method.
8. The system of claim 1, wherein the server digital data processor transmits the one or more coordination modules to the tenant digital data processor in response to a request to access one or more resources available to the server digital data processor.
9. The system of claim 8, wherein the server digital data processor installs the one or more transmitted coordination modules in a web browser executing on the tenant digital data processor.
11. The method of claim 10, wherein the facilitating the communication between the tenant legacy system and the application comprises making available, via the one or more communication modules, the tenant legacy information to the server digital data processor in response to a request from a rules engine executing on at least one of the server digital data processor and the tenant digital data processor.
12. The method of claim 11, wherein the making available the tenant legacy information to the server digital data processor comprises opening one or more communications ports on the firewall.
13. The method of claim 12, wherein the making available the tenant legacy information to the tenant digital data processor comprises opening a single communications port on the firewall so as to obviate a need to open a plurality of communications ports on the firewall.
14. The method of claim 10, further comprising retrieving the tenant legacy information, via the one or more coordination modules, for use in execution of one or more selected rules from the rules base coupled to the server digital data processor.
15. The method of claim 10, further comprising transferring one or more selected rules from the rules base coupled to the server digital data processor, via the one or more coordination modules, for execution on the tenant digital data processor.
16. The method of claim 10, wherein the at least one integration rule defines the integration link according to at least one of a Simple Object access Protocol (SOAP) integration method, a .NET integration method, a Java integration method, and an Enterprise Java Beans (EJB) integration method.
17. The method of claim 10, further comprising transmitting the one or more coordination modules from the server digital data processor to the tenant digital data processor, in response to a request to access one or more resources available to the server digital data processor.
18. The method of claim 17, further comprising installing the one or more transmitted coordination modules, via the server digital data processor, in a web browser executing on the tenant digital data processor.

The invention relates to digital data processing and, more particularly, for example, to distributed processing of rules bases.

Computer systems that facilitate business operations based on information specific to an industry or enterprise are well known in the art. These typically rely on rules identifying situations that are expected to arise during enterprise operation and the applicable responses. Such systems have been used in a range of applications, from health care to automotive repair. The rules on which they rely come from experts in the field, from the collective experience of workers on the “front line,” or a combination of these and other sources.

Though many computer systems of this sort incorporate application-specific knowledge directly into source code (using, for example, a sequence of “if . . . then . . . else” statements, or the like), more complex systems store that knowledge separately from the programs that access it. Some use “rules bases” that store application-specific information in tables, database records, database objects, and so forth. Examples of systems of this type are disclosed in commonly assigned U.S. Pat. No. 5,826,250, entitled “Rules Bases and Methods of Access Thereof” and U.S. Pat. No. 7,640,222, entitled “Rules Base Systems and Methods with Circumstance Translation,” the teachings of both of which are incorporated herein by reference.

These and other rules-based business process management (BPM) applications are commonly used in enterprise computing, for example, where they facilitate a range of business operations, from marketing to manufacturing to distribution to technical support. By way of example, a BPM application can implement data-processing workflows to support the processing of transactional data ranging from customer service requests received by retail and banking enterprises to the routing and resolution of health care claims by insurance enterprises.

With increasing frequency, enterprise software applications incorporate architectures that permit their use “in the cloud,” that is, over the Internet, with computing resources delivered up to each user on demand. In a sense, this extends the client-server model of past eras from the physical confines of the enterprise to the expanse of the world.

Where a common architecture of the past might provide for software that executes on a server, e.g., located at enterprise headquarters, and that processes requests entered by support personnel at the enterprise's branch offices, the new cloud architectures permit servicing of requests by servers located around the world. In operation, any given request by a user on a client device might as well be attended to by a server located in a neighboring state as in a neighboring country. Thus, while cloud applications are often initially tested behind an enterprise firewall, they are typically architected for final deployment outside that firewall, on a dynamically changing set of third-party servers (e.g., owned by Amazon, SalesForce, Google, or other cloud-computing providers).

BPM applications can be deployed in the cloud, like other enterprise applications. However since business process management often goes to the heart of the enterprise, chief executives, IT directors, and corporate boards have yet to fully embrace this model, mainly, for fear that storing rules bases and/or transactional data exposes them to theft or wrongful disclosure.

Other software applications are evolving similarly. Those that traditionally ran solely on the “desktop,” are now increasingly being executed in the cloud. Word processing is one example. Microsoft, Google and other software providers would as soon enterprise (and other) customers store documents and execute word processing via the cloud, as via locally deployed desktop applications. Unfortunately, this results in uneven usage of information technology resources, with network infrastructure and desktop computers being alternately overwhelmed and underutilized, depending on the cycle of the day, month and year.

An object of this invention is to provide improved systems and methods for digital data processing. A more particular object is to provide improved systems and methods for business process management, for example, rules processing.

A further object is to provide such improved systems and methods as facilitate deployment of BPM and other rules-processing applications on multiple digital data processors.

A still further object is to provide such improved systems and methods as facilitate such deployment in distributed environments, such as, for example, in cloud computing environments.

Yet a still further object is to provide such improved systems and methods as provide better security for BPM and other rules-processing applications in such distributed environments.

Still yet a further object is to provide such improved systems and methods as better utilize computing and networking resources in applications so distributed.

The foregoing are among the objects attained by the invention, which provides in some aspects a distributed rules processing system that includes first and second digital data processors that are coupled to one another by one or more networks. A rules base and a transactional data base are each coupled to one of the digital data processors; both may be coupled to the same digital data processor or otherwise.

One or more coordination modules (e.g., “proxies”), each of which is associated with a respective one of the digital data processors, makes available to a selected one of those digital data processors from the other of those digital data processors (i) one or more selected rules from the rules base, and/or (ii) one or more data from the transactional database on which those rules are to be executed. The selected digital data processor executes one or more of the selected rules as a rules engine, executes one or more of the selected rules using a rules engine, and/or processes one or more data from the transactional database with rules executing using a rules engine.

According to related aspects of the invention, the first and second digital data processors of a distributed rules processing system, e.g., of the type described above, can be disposed remotely from one another and can coupled for communication by the Internet, as well optionally by local area networks, wide area networks, and so forth. A firewall and/or other such functionality that is coupled to one or more of those networks prevents the selected digital data processor from accessing from the other digital data processor (i) the selected rules and/or (i) the data on which those rules are to be executed.

Further related aspects of the invention provide a distributed rules processing system, e.g., of the type described above, wherein one or more of the coordination modules make the selected rules and/or data available to the selected digital data processor from the other digital data processor in response to a request from the rules engine.

Thus, by way of example, in a system according to the foregoing aspects of the invention, the first digital data processor can include a rules base, e.g., for processing credit card information. The second digital data processor can, likewise, include a data base of transactional data, e.g., pertaining to opening of credit card account, purchases against the credit cards, refunds, and so forth.

According to one operational scenario of such a system (and to illustrate methods according to further aspects of the invention) a rules engine operating, for example, on the first digital data processor can utilize a proxy operating, for example, on the second digital data processor to access transactional data that is “behind the firewall” on the second digital data processor for processing by the rules engine with rules already accessible to the first data data processor (e.g., on account of its inclusion of and/or coupling to the rules base).

To that end, by way of non-limiting example, in related aspects of the invention, the coordination modules (or proxies) make the selected rules and/or data available to the selected digital data processor from the other digital data processor by opening one or more communications ports on that other digital data processor.

Continuing the above example, in a related operational scenario, a coordination module executing on the first data processor can respond to transactional data base access requests generated by the rules engine to determine whether that data base is coupled to the first digital data processor and, if not, to cooperate with the coordination module on the second digital data processor to make the transactional data available to the rules engine from the second digital data processor.

Conversely, according to the operational scenario of a system paralleling those described in the examples above, a rules engine executing on the second digital data processor can utilize a proxy operating, for example, on the first digital data processor, to access rules necessary to process transactional data already accessible to the data processor (e.g., on account of its inclusion of and/or coupling to the transactional data base).

In other related aspects, the invention provides a distributed rules processing system, e.g., of the type described above, in which one or more of the coordination modules make the selected rules and/or data available to the selected digital data processor from the other digital data processor in response to a request from that other digital data processor.

In further related aspects of the invention, a request made from the other digital data processor in a distributed rules processing system, e.g., of type described above, is made by a rules engine executing on that other digital data processor.

Continuing the example above (and to illustrate methods according to still further aspects of the invention), in a system according to the foregoing aspects of the invention, a rules engine operating on the first digital data processor can utilize the proxy operating on the second digital data processor to access some transactional data in the data base on the second digital data processor for processing by the rules engine on the first digital data processor (and/or, conversely, to store transactional data processed by that rules engine to that transactional data base). It can also effect, through use of that proxy and/or its counterpart on the first digital data processor, transfer of selected rules to the second digital data processor for execution by its rules engine, e.g., on other data stored (and/or to be stored) in the transactional database.

These and other aspects of the invention are evident in the drawings and in the description that follows.

A more complete understanding of the invention may be attained by reference to the drawings, in which

FIG. 1 depicts a digital data processing system for distributed rules processing according to one practice of the invention;

FIG. 2 depicts a method of operation of a coordination module in a system of FIG. 1; and

FIG. 3 depicts operation of a coordination module in a system according to the invention within a multi-tenant cloud-based environment.

FIG. 1 depicts a digital data processing system 10 for distributed processing in a rules-based system according to one practice of the invention. The illustrated system includes client (or “tenant”) digital data processors 12, 14 that are coupled via network 16 for communication with server digital data processor 18.

The client digital data processors 12, 14 are conventional desktop computers, workstations, minicomputers, laptop computers, tablet computers, PDAs or other digital data processing apparatus of the type that are commercially available in the marketplace and that are suitable for operation in the illustrated system as described herein, all as adapted in accord with the teachings hereof.

The server digital data processor 18 is, likewise, a digital data processing apparatus of the type commercially available in the marketplace suitable for operation in the illustrated system as described herein, as adapted in accord with the teachings hereof. Though the server 18 is typically implemented in a server-class computer, such as a minicomputer, it may also be implemented in a desktop computer, workstation, laptop computer, tablet computer, PDA or other suitable apparatus (again, as adapted in accord with the teachings hereof).

Network 16 comprises one or more networks suitable for supporting communications among and between illustrated digital data processors 12, 14, 18. Illustrated network 16 comprises one or more public networks, specifically, the Internet, though, in other embodiments, it may include (instead or in addition) one or more other networks of the type known in the art, e.g., local area networks (LANs), wide area networks (WANs), metropolitan area networks (MANs), and or Internet(s).

Illustrated client computer 12 comprises central processing, memory, storage and input/output units and other constituent components (not shown) of the type conventional in the art that are configured to form application 12a, transaction database 12b, rules base 12c, and coordination module 12d, in accord with the teachings hereof. One or more of these constituent components, and/or portions thereof, may be absent in various embodiments of the invention. Thus, for example, as suggested by dashed lines, the digital data processor 12 may not include a rules base. Conversely, it may include a portion of a rules base but not transaction database or it may include neither. In other embodiments, it may include a coordination module 12d (described below) but not a transaction database, rules base or an application, all by way of non-limiting example.

The central processing, memory, storage and input/output units of client digital data processor 12 may be configured to form and/or may be supplemented by other elements of the type known in the art desirable or necessary to support elements 12a-12d in accord with the teachings hereof, as well as to support other operations of the digital data processor 12. These can include, by way of non-limiting example, peripheral devices (such as keyboards and monitors), operating systems, database management systems, and network interface cards and software, e.g., for supporting communications between digital data processor 12 and other devices over network 16.

Digital data processor 12 is coupled to network 16 via firewall 12e. This is a conventional device of the type known in the art (as otherwise configured in accord with the teachings hereof) suitable for blocking unauthorized access, yet, permitting authorized access, to the digital data processor 12, including (but not limited to) data and rules bases 12b, 12c.

Firewall 12e, which is constructed and operated in the conventional manner known in the art, may comprise a “hardware” (or stand-alone) firewall and/or it may comprise a software firewall configured from the constituent and/or other components of digital data processor 12, again, in the conventional manner known in the art.

The constituent components of illustrated client digital data processor 14 may similarly be configured in accord with the teachings hereof to form application 14a, transaction database 14b, rules base 14c, and coordination module 14d. As well, they may be supplemented by other elements of the type known in the art desirable or necessary to support elements 14a-14d in accord with the teachings hereof, as well as to support other operations of the digital data processor 14. The client digital data processor 14 may also include a firewall 14e, e.g., constructed and operated like device 12e, discussed above, to block unauthorized access, yet, permit authorized access, to the digital data processor 14, including (but not limited to) data and rules bases 14b, 14c.

Although digital data processors 12 and 14 are depicted and described in like manner here, it will be appreciated that this is for sake of generality and convenience: in other embodiments, these devices may differ in architecture and operation from that shown and described here and/or from each other, all consistent with the teachings hereof. Moreover, it will be appreciated that although only two closely positioned client devices 12, 14 are shown, other embodiments may have greater or fewer numbers of these devices disposed near and/or far from one another, collocated behind one or more common firewalls 12e, 14e or otherwise.

Like client digital data processors 12, 14, server digital data processor 18 comprises central processing, memory, storage and input/output units and other constituent components (not shown) of the type conventional in the art that are configured in accord with the teachings hereof to form rules engine 18a, transaction database 18b, rules base 18c, and coordination module 18d, one or more of which (and/or portions thereof) may be absent in various embodiments of the invention. The digital data processor 18 may also include a firewall 18e, e.g., constructed and operated like device 12e, discussed above, to block unauthorized access, yet, permit authorized access, to the digital data processor 18, including (but not limited to) data and rules bases 18b, 18c.

Although only a single server digital data processor 18 is depicted and described here, it will be appreciated that other embodiments may have greater or fewer numbers of these devices disposed near and/or far from one another, collocated behind one or more common firewalls 18e or otherwise. Indeed, in preferred such embodiments, the digital data processor 18 is configured as a server on a “cloud” platform, e.g., of the type commercially available from Amazon, SalesForce, Google, or other cloud-computing providers. As above, those other servers may differ in architecture and operation from that shown and described here and/or from each other, all consistent with the teachings hereof.

Rules bases 12c, 14c, 18c comprise conventional rules bases of the type known in the art (albeit configured in accord with the teachings hereof) for storing rules (e.g., scripts, logic, controls, instructions, metadata etc.) and other application-related information in tables, database records, database objects, and so forth. Preferred such rules and rules bases are of the type described in the aforementioned incorporated-by-reference U.S. Pat. No. 5,826,250, entitled “Rules Bases and Methods of Access Thereof” and U.S. Pat. No. 7,640,222, entitled “Rules Base Systems and Methods with Circumstance Translation,” though, rules and rules bases that are architected and/or operated differently may be used as well.

As noted above, not all of these rules bases may be present in any given embodiment. Conversely, some embodiments may utilize multiples rules bases, e.g., an enterprise-wide rules base 18c on the server 18 and domain-specific rules bases on the client devices 12, 14, all by way of example. Moreover, to the extent that multiple rules bases are provided in any given embodiment, they may be of like architecture and operation as one another; though, they may be disparate in these regards, as well.

In some embodiments, rules may comprise meta-information structures. These are structures that can include data elements and/or method elements. The latter can be procedural or declarative. In the former regard, for example, such a structure may be procedural insofar as it comprises one or more of a series or ordered steps. In the latter regard, such a structure may be declarative, for example, insofar as it sets forth (declares) a relation between variables, values, and so forth (e.g., a loan rate calculation or a decision-making criterion), or it declares the desired computation and/or result without specifying how the computations should be performed or the result achieved. By way of non-limiting example, the declarative portion of a meta-information structure may declare the desired result of retrieval of a specified value without specifying the data source for the value or a particular query language (e.g., SQL, CQL, .QL etc.) to be used for such retrieval. In other cases, the declarative portion of a meta-information structure may comprise declarative programming language statements (e.g., SQL). Still other types of declarative meta-information structures are possible.

While some rules may comprise meta-information structures that are wholly procedural and others may comprise those that are wholly declarative, the illustrated embodiment also contemplates rules that comprise both procedural and declarative meta-information structures, i.e., rules that have meta-information structure portions that are declarative, as well as meta-information structure portions that are procedural.

Furthermore, rules of the illustrated embodiment that comprise meta-information structures may also reference and/or incorporate other such rules, which themselves may, in turn, reference and/or incorporate still other such rules. As a result, editing such rule may affect one or more rules (if any) that incorporate it.

An advantage of rules that comprise meta-information structures over conventional rules is that they provide users with the flexibility to apply any of code-based and model-driven techniques in the development and modification of software applications and/or computing platforms. Particularly, like models in a model-driven environment, meta-information structures comprise data elements that can be used to define any aspect of a complex system at a higher level of abstraction than source code written in programming languages such as Java or C++. On the other hand, users may also embed programming language statements into meta-information structures if they deem that to be the most efficient design for the system being developed or modified. At run-time, the data elements of the meta-information structures along with programming language statements (if any) are automatically converted into executable code by a rules engine (e.g., 18a).

Thus, in some embodiments, rules may be the primary artifacts that get created, stored (e.g., in a rules base) or otherwise manipulated to define and/or modify the overall functionality of rules-based applications that may automate and/or manage various types of work in different business domains at run-time. By way of non-limiting example, a plurality of rules stored in a rules base (e.g., 12c, 14c, 18c) may be configured to define all aspects (e.g., user interface, decision logic, integration framework, process definition, data model, reports, security settings etc.) of a software application. Such a software application may include specialized software that is used within a specific industry or a business function (e.g., human resources, finance, healthcare, telecommunications etc.), or it may include a cross-industry application (e.g., a project management application), or any other type of software application. As the software application executes on a digital data processor (e.g. any of 12, 14 and 18), any portion of the rules that define the application may be retrieved from a rules bases (e.g. any of 12c, 14c and 18c) and processed/executed (e.g., using a rules engine 18a as defined below) in response to requests/events signaled to and/or detected by the digital data processor at run-time.

Transactional data bases 12b, 14b, 18b comprise conventional data bases of the type known in the art (albeit configured in accord with the teachings hereof) for storing corporate, personal, governmental or other data that may be any of generated, stored, retrieved and otherwise processed (hereinafter, collectively referred to as “processed”) by rules in one or more of the rules bases 12c, 14c, 18c. The data may be financial data, customer records, personal data, run-time data related to an application, or other type of data and it may be stored in tables, database records, database objects, and so forth.

As above, not all of the illustrated transactional data bases may be present in any given embodiment. Conversely, some embodiments may utilize multiple transactional database bases, e.g., an enterprise-wide data base 18b on the server 18 and branch-office specific data bases on the client devices 12, 14, all by way of example. Moreover, to the extent that multiple transactional data bases are provided in any given embodiment, they may be of like architecture and operation as one another; though, they be disparate in these regards, as well.

Illustrated digital data processor 18 also includes rules engine 18a of the type conventionally known in the art (albeit configured in accord with the teachings hereof) for use in processing/executing rules from a rules base in order to process data in (and/or for storage to) a transactional database, e.g., in connection with events signaled to and/or detected by the engine. Preferred such rules engines are of the type described in the aforementioned incorporated-by-reference U.S. Pat. No. 5,826,250, entitled “Rules Bases and Methods of Access Thereof” and U.S. Pat. No. 7,640,222, entitled “Rules Base Systems and Methods with Circumstance Translation” and/or U.S. patent application Ser. No. 11/681,269, filed Mar. 2, 2007, entitled “Proactive Performance Management For Multi-User Enterprise Software Systems,” the teachings too of which are incorporated by reference herein—all as adapted in accord without the teachings hereof.

The rules engine 18a may be implemented in a single software program, in multiple software programs/modules, or a combination of software modules/programs. Moreover, it may comprise programming instructions, scripts, or rules (e.g., rules stored in rules base 18c) and/or a combination thereof.

Though, in the illustrated embodiment in FIG. 1, the rules engine 18a executes on the server 18, in other embodiments, the techniques described herein may be employed to execute the rules engine 18a on or over multiple digital data processors (e.g., 12, 14 and 18). For instance, the rules engine 18a may initially be invoked for execution on a single digital data processor (e.g., 18). Subsequently, portions of it (or, potentially, the entirety of it) may be apportioned, distributed and executed over multiple digital data processors using the techniques described herein.

Such distributed execution of the rules engine can be advantageous, by way of non-limiting example, when execution of an enterprise-wide BPM application necessitates access to sensitive corporate or personal data during intermediate processing steps. For example, in an enterprise with decentralized record-keeping, the rules engine 18a can be utilized to generate a summary report that requires analysis of sensitive personnel-related data maintained in local branch offices. To that end, the engine 18a executes rules for performing preparatory tasks, such as, zeroing out data collection variables and identifying local offices to be queried. The engine 18a also retrieves from rules base 18c or otherwise generate rules that will serve as rules engines (e.g., 12a, 14a) customized or otherwise suited for execution on digital data processing equipment 12, 14 at those offices, as well as rules for execution on those engines 12a, 14a to analyze (and anonymize) sensitive data from the respective offices. Both the rules engine-defining rules and the data analysis rules are distributed to the equipment 12, 14, where they perform these functions and send the requisite information back to server 18 for reporting the BPM application executing there. Such distributed execution has the advantage of permitting the BPM application executing using engine 18a to generate an enterprise-wide report, without necessitating the transmission of sensitive data outside the confines of the local offices.

By way of further example, the rules engine 18a can have two distinct portions, e.g., one that embodies the algorithm for rule selection (e.g., in the manner of the rule finder disclosed in U.S. Pat. No. 5,825,260, assigned to the assignee hereof and incorporated by reference herein), and the other that generates/executes the executable code once the requisite rule has been selected. The rules engine 18a (or other functionality) can apportion and distributed these portions separately as required.

Take, for example, an instance where server 18 gets a request for executing a “loan validation” process for a specific context. Server 18 stores rules for multiple versions of the “loan validation” process for different contexts. However, the server does not have the computing power to execute the ‘rule finder’ algorithm to select the right version and/or the server doesn't have the code generation portion of the engine to execute the selected rule. Server retrieves the rules for all versions of “loan validation” process and transmits them along with the rule selection portion of the engine to a remote digital data processor that has installed thereon the code generation portion of a rules engine. Upon receiving the rule finder portion of the engine along with the rules for all versions, the correct loan validation process is selected and executed on the target digital data processor.

The foregoing are examples those skilled in the art will appreciate that still other ways of implementing/executing the rules engine 18a are possible. By way of non-limiting example, the rules engine 18a may have additional distinct components/portions that can be apportioned and distributed separately. These may include (but are not limited to) a data access component used for processing data during rule execution, a session management component for keeping track of activity across sessions of interaction with a digital data processor and/or a performance monitoring component for monitoring and interacting with various system resources/event logs in order to manage performance thresholds. Still other types of distinct components/portions may be part of the rules engine 18a.

Applications 12a and 14a, of digital data processors 12, 14, respectively, may too comprise rules engines of the type described above, as adapted in accord with the teachings hereof. These applications may be configured (e.g., at least partially using rules stored in a rules base as described above) as stand-alone applications and/or may be embedded in (or coupled) to other software applications, e.g., web browsers. While in some embodiments, such applications 12a, 14a are architected and operated similarly to rules engine 18a, in other embodiments they embody a subset of the functionality of engine 18a, e.g., suited to the processing resources and/or demands of the digital data processors 12, 14 upon which they operate. Instead or in addition, such applications 12a, 14a can comprise other functionality than that provided in rules engine 18a, again, for example, suited to the processing resources and/or demands of the digital data processors 12, 14 upon which they operate.

For sake of simplicity, the discussion that follows focuses on aspects of operation of rules engine 18a; it will be appreciated that other rules engines (e.g., 12a, 14a in certain embodiments) may operate similarly in these regards.

As noted above, rules engine 18a processes/executes rules from a rules base in order to process data in (and/or for storage to) a transactional database. In instances where the engine 18a executes rules from rules base 18c in order to process data in (and/or store data to) database 18b, the engine 18a may operate in the conventional manner known in the art. However, where any of (i) the data to be accessed (or stored) is resident in a data base 12b, 14b of another of the digital data processors, (ii) the rules to be executed (including, potentially, those defining the rules engine 18a or a portion thereof) are contained in a rules base 12c, 14c of another of those digital data processors, and (iii) the rules (again, potentially, those defining the rules engine 18a or a portion thereof) are to be executed using the rules engine 12a, 12b of another of those digital data processors, the rules engine 18a works with one or more of the coordination modules to effect the desired processing. Even in instances where the rules, portions of the engine, and/or data required to effect the desired processing is local to digital data processor 18, the rules engine 18a may work with the coordination modules (e.g., 12d, 14d, 18d) to effect the desired processing over multiple digital data processors (e.g., for access to more computing resources/power) in accord with the teachings hereof.

In this regard, coordination modules 12d, 14d, 18d comprise functionality resident on (and/or coupled to) each of the respective processors 12, 14, 18 that facilitate access to and transfer of rules, the rules engine or portion thereof, or data (and, preferably, all three) between the digital data processors. In this regard, operation of the module(s) 12d, 14d, 18d can include one or more of (i) obviating obstacles presented by firewalls 12e, 14e, 18e or other functionality to such inter-processor accesses and transfers, (ii) effecting such access and transfers, and (iii) querying a digital data processor to determine whether it has resources (e.g., a rules base, a transactional data base, a portion of or the entire rules engine, and/or computing power) to facilitate the completion of a task (e.g., by executing a given one or more rules on a given set of data).

As above, not all of the coordination modules 12d, 14d, 18d are utilized in all embodiments. Conversely, other embodiments may utilize additional such modules, e.g., one module per digital data processor for facilitating rules access/transfer between digital data processors, one module for facilitating transaction access/transfer, and so forth. Likewise, some such modules could be directed to querying digital data processors for resources, while others are directed to access and transfers. These and other such variations are within the ken of those of ordinary skill in the art based on the teachings hereof.

The modules 12d, 14d, 18d may comprise stand-alone functionality stored and executing within each respective digital data processors 12, 14 18. Alternatively, they may comprises functionality that is embedded in the rules engine 18a and/or applications 12a, 14a and/or into other applications or operating system functions resident on the respective devices 12, 14, 18. Moreover, in embodiments that include multiple such modules 12d, 14d, 18d, functionality may be distributed and/or divided among them.

Still further, although the modules 12d, 14d, 18d are shown forming part of the respective digital data processors 12, 14, 18 in the illustrated embodiment, in other embodiments one or more of those modules may execute on still other digital data processors (not shown) that are in communication coupling with the respective processors 12, 14, 18 and that otherwise provide the functionality described here.

Operation of a coordination module 18d in accord with one practice of the invention is illustrated in FIG. 2. It will be appreciated that the sequence of steps shown in that drawing and discussed below is by way of example and that other embodiments may perform the same or different functions using alternate sequences of steps.

In step 20, the module, which may be coupled to a local rules engine 18a, responds to a request for access to a rule by determining if that rule is present in a rules base 18c local to the digital data processor 18—and, for example, it is therefore accessible to a local engine 18a without crossing the firewall 12e, 14e of another digital data processor. The module 18d can make that determination by checking for the presence of the local rules base 18c and/or, if present, by determining if the requested rule itself is present. Alternatively, or in addition, the module 18d can make the determination by checking parameters or other indicators of rule presence, e.g., in the rule request signaled to any of the module 18a and the engine 18a and/or request made by the engine 18a. The parameters or other indicators of rule presence may also be found in a registry of the digital data processor 18 and/or elsewhere.

If the determination of step 20 is in the affirmative, operation proceeds to step 22, where the module 18d determines if data implicated by the rule (e.g., data to be processed by the rule or otherwise necessary for its execution) is present in a data base 18b local to the digital data processor 18—and, again, for example, it is therefore accessible to the local engine 18a without crossing the firewall 12e, 14e of another digital data processor. The module 18d can make that determination by checking for the presence of the local data base 18b and/or, if present, by determining if the requested data are present. Alternatively, or in addition, the module 18d can make the determination by checking parameters or other indicators of data presence, e.g., in the rule request signaled to any of the module 18d and the engine 18a and/or request made by the engine 18a. The parameters or other indicators of rule presence may also be found in a registry of the digital data processor 18 and/or elsewhere.

If the determination of step 22 is affirmative, operation proceeds to step 24, where the module 18d determines if the portion of rules engine (e.g., 18a) that is required to execute the requested rule is present locally on digital data processor 18. To this end, the module can query for local presence on digital data processor 18 of component(s)/module(s) that make up requisite portions(s) of rules engine. In other embodiments, e.g., where those requisite portion(s) are implemented using rules, the module 18d can determine, for example, if those rules are locally present by querying a local database/repository (e.g., rules base 18c, transaction data base 18b). Alternatively, or in addition, the module can check parameters or other indicators of engine presence, e.g., in the rule request signaled to any of the module 18d and the engine 18a and/or request made by the engine 18a, in a registry of the digital data processor 18 and/or elsewhere.

If the determination of step 24 is in the affirmative, operation proceeds to step 26, where the module 18d determines if the rule is to be executed locally, i.e., on digital data processor 18 or whether it is to be executed remotely, e.g., on digital data processors 12, 14. The module 18d can make that determination using a variety of methods including, but not limited to, querying a local rules engine (e.g., 18a) and/or by checking parameters or other indicators, e.g., in the rule request signaled to any of the module 18d and the engine 18a and/or request made by the engine 18a. The parameters or other indicators of rule presence may also be found in a registry of the digital data processor 18 and/or elsewhere. Alternatively, or in addition, the module 18d can make the determination based on load-balancing, network speed and traffic, data coherency or other factors within the ken of those of ordinary skill in the art based on the teachings hereof.

If the determination in steps 20, 22, 24 and 26 is in the affirmative—that is, all resources required to execute the requested rule are present locally at digital data processor 18 and the rule is to be executed there, the determination in step 28 is affirmative and the operation proceeds to step 30, where the module 18d defers to local engine 18a for execution of the requested rule on the required data. The engine 18a (or the required portion thereof) proceeds by accessing the rule and data in the local rules and data bases 18b, 18c, and by executing the rule to process the data accordingly.

If the determination in any of steps 20, 22 and 24 is in the negative—that is, if any of the requested rule, required data and engine (or portion thereof) are not locally present on digital data processor 18, the operation proceeds to step 32, where the module queries one or more other digital data processors (e.g., 12, 14) to determine the location(s) of any of the requested rule, required data and engine (or portion thereof). By way of non-limiting example, the module 18d can determine the location of the requested rule (and corresponding rules base), required data and engine (or portion thereof) by checking parameters or other indicators, e.g., in the rule request signaled to any of the module 18d and the engine 18a and/or request made by the engine 18a, in a registry of the digital data processor 18 and/or elsewhere. Alternatively, or in addition, module 18d can query the digital data processors 12, 14 directly to determine if any of the required/requested resources are maintained by them. Preferably, this is accomplished by communication between module 18d and its counterparts 12d, 14d on each of digital data processors 12, 14—which modules 12d, 14d can, themselves, query the local digital data processor 12, 14 for the requisite resource(s).

If the determination in step 32 is in the negative for any of the required/requested resources, the operation proceeds to and terminates at step 38 where the coordination module returns an error message in response to the requested rule indicating the absence or unavailability of any of the requested rule, required data and engine (or portion thereof).

If the determination in step 32 is in the affirmative for any of the requested/required resources that were not already present locally at digital data processor 18 (as previously determined by steps 20-24), the operation proceeds to step 26 to make the decision of local versus remote execution of the requested rule as described above. If the determination in step 26 is affirmative, at least one of the requested rule, required data and engine (or portion thereof) that is located remotely at another digital data processor (e.g., 12 or 14) as identified in step 32, is retrieved in step 40 before executing the requested rule locally on digital data processor 18 in step 30. As indicated by the callout 46, such retrieval is performed by the module 18d, following a negative determination in step 28 by (i) validating that the one or more digital data processors identified in step 32 (e.g., 12 and/or 14) will grant access to the requested/required resource(s) and, (ii) retrieving that/those resource(s) from those one or more digital data processors (i.e., 12 and/or 14) to digital data processor 18.

In regard to step 40(i), the module 18d can validate that the one or more identified digital data processors will grant access by querying the digital data processor(s) identified in step 32 accordingly. This can be done, for example, through communication with the module 12d, 14d of the identified digital data processor, which module can validate the presence of any of the requested/required resource (if it has not already done so). In some embodiments, the validating module (e.g., 12d or 14d) can open a communications port in the respective digital data processor and can prepare the requested/resource for access via that port.

In regard to step 40(ii), the module 18d retrieves and/or transfers the requested/required resource from the one or more identified digital data processors to digital data processor 18 for local execution. In some embodiments, a local rules engine 18d (if already present) may access the requested/required resource (e.g., data, transaction database, rule and/or rules base) directly from the identified digital data processor, e.g., via a port opened in step 40(i). In other embodiments, the module 18d may also transfer one or more requested/required resources to an identified digital data processor (e.g., 12 or 14) for the requested processing to be performed remotely at the identified digital data processor. Alternatively, or in addition, the module 18d may also notify the identified digital data processor (e.g., 12 or 14) and, preferably, its respective coordination module, identified in step 32, passing to it the relevant information for the requested processing to be performed (e.g., identity of the rule to be executed). The identified digital data processor may perform the requested processing using the resources/information provided to it. In other embodiments where the required resources are not transferred along with the relevant information, the identified digital data processor may perform the requested processing by utilizing the methodology of FIG. 2 itself in order to access the required resources in connection therewith. The discussion that follows provides further details about this step.

Upon completion of step 40, control transfers to any of steps 30, 42 or 44 depending upon the outcome of the previous steps in the operation of the coordination module 18d, as indicated in the drawing. Thus, continuing with the current example of retrieving requested/required resources in step 40 from one or more identified digital data processors (e.g., 12 and/or 14) for local execution at digital data processor 18, control transfers to step 30 to complete the requested processing. However, if the determination in step 26 is in the negative—that is, it is determined that the requested rule is to be executed remotely, then the appropriate location for the completion of such remote processing is based upon a combination of steps 34-44 as well as the outcome of previous steps 20-24.

By way of non-limiting example, despite the local presence of all the requested/required resources on digital data processor 18 (i.e., affirmative responses in steps 20-24), a negative determination in step 26 may be due to parameters or other indicators in a local registry of the digital data processor 18 and/or e.g., in the rule request signaled to any of the module 18d and the engine 18a and/or request made by the engine 18a. In this case, there is no previously identified location from step 32. Thus, the response to step 34 is in the negative and the operation proceeds to step 36 where the module 18d determines if there is another digital data processor (e.g., 12, 14) suited for executing the requested rule. In some embodiments, it makes that determination by querying the local rules engine 18a and/or by checking the parameters or other indicators as mentioned above. Alternatively, or in addition, the module 18d can make the determination based on load-balancing, network speed and traffic, availability of the required/requested resources (or portions thereof) on one or more other digital data processors, data coherency or other factors within the ken of those of ordinary skill in the art based on the teachings hereof. For example, a query during the operation at step 36 (or at a prior step) may reveal that an alternative digital data processor with higher computing power than processor 18 and/or another digital data processor identified in a local registry, has all of the required/requested resources. In that case, module 18d may simply notify the alternative digital data processor (and/or its coordination module) to perform the requested processing as opposed to performing it locally or remotely at the other digital data processor that was identified in the local registry. More generally, this example is also reflective of some embodiments discussed throughout this document that may involve scenarios and/or steps where duplicate versions, or at least versions that are comparable in terms of functionality, of one or more requested/required resources may exist at multiple locations

If the determination in step 36 is negative, the operation proceeds to and terminates at step 38 in the illustrated embodiment where the coordination module 18d returns an error message indicating the absence or unavailability of a suitable digital data processor for remote execution of the requested processing/rule. In other embodiments, if the requested/required resources are present locally, the coordination module may ignore the negative outcome of step 26 and execute the requested rule locally as default if a suitable remote digital data processor (e.g., 12 and 14) is not identified in step 36.

If the determination in step 36 is in the affirmative, coordination module 18d any of transfers the requested/required resources from the digital data processor 18 and/or provides the relevant information to the other identified digital data processor in step 36 e.g., by employing the methodology discussed above in connection with steps 40(i) and (ii). In some embodiments, coordination module 18d may only transfer a portion of the requested/required resources if it is determined (as mentioned above) that another identified digital data processor(s) already possesses the remaining portion of the requested/required resources. Once any such transfer and/or notification is completed in step 40 from digital data processor 18, processing is completed by executing the requested rule remotely in step 44 at the other digital data processor that is identified in step 36.

Preceding the negative determination in step 26, a negative outcome in any of steps 20-24 indicates that at least one of the requested/required resources is not locally present on digital data processor 18 and that one or more digital data processors (e.g., 12 and/or 14) may have been identified in step 32 to locate such requested/required resource as previously discussed. In situations where (i) at least one but not all of the determinations in steps 20-24 are in the affirmative, (ii) the determination in step 26 is in the negative, and (iii) the determination in step 34 is affirmative, the operation proceeds to remotely execute the requested rule. If only one digital data processor was identified in step 32, then module 18d transfers the portion of the requested/required resources at digital data processor 18 (e.g., by employing the methodology discussed above in connection with steps 40(i) and (ii)) to the single digital data processor identified in step 32, where the remaining requested/required resources are located. Once that transfer is completed in step 40, the requested rule/processing is performed remotely in step 42 at the location identified in step 32.

In other embodiments, two or more locations may be identified in step 32 e.g., the required data may be located at digital data processor 12 and the engine may be located at digital data processor 14. In such embodiments, where the step 26 response is negative and the step 34 response is affirmative, module 18d may prioritize all available location options based upon various factors including, but not limited to, prioritization criteria specified in the rule request signaled to module 18d and/or the engine 18a, prioritization rules stored in rules base 18c and/or elsewhere on digital data processor 18. Alternatively, or in addition, module 18d may prioritize all available location options based upon the relative computing resources (e.g., CPU, memory etc.) at each location, network traffic or any other factors within the ken of those of ordinary skill in the art based on the teachings hereof. In any event, module 18d will transfer the portion of the requested/required resources from digital data processor 18 to the highest priority location and once the transfer(s) is completed in step 40, the requested rule/processing is performed remotely at that location in step 42.

A negative determination in step 26 may be followed by a negative determination in step 34. Following the combined negative determinations, an attempt is made via step 36 (as described above) to identify one or more digital data processors other than local processor 18 or the one or more digital data processors identified in step 32.

By way of example, a request may be signaled to coordination module 18d to execute one or more rules that define a plurality of reports. These report rules may be stored locally in rules base 18c and the rules engine 18a required to execute the requested report rules may also be locally present on server digital data processor 18. However, the determination in step 22 may be in the negative because the data to be processed by the requested report rules is not locally present. In such an instance, operation proceeds to step 32 where the coordination module 18d attempts to locate the one or more digital data processors that maintain the required data for reports execution. In one embodiment, the coordination module 18d identifies the location of such digital data processors (e.g., 12, 14) by querying a local registry on digital data processor 18 using parameters or other indicators of data location specified in the rule request that was signaled to the coordination module 18d. The query of the local registry may, for example, reveal that a portion of the required data is located in the transaction database 12b on digital data processor 12 and the remaining portion of the required data is located in the transaction database 14b on digital data processor 14. Next, operation proceeds to step 26 where it may be determined, for example, that the reports will not be executed locally at digital data processor 18 because a pre-requisite for such local execution is data retrieval from digital data processors 12 and 14 over a very slow network connection (e.g., 16). In such an instance, a negative outcome of step 26 is followed by a determination in step 34 of whether to execute the requested report rules remotely on digital data processor 12, 14 or at both locations. This determination may be based on various factors including, but not limited to, load balancing and the correlation between the requested report rules and the required data for requested rule execution at each location. Thus, for example, if CPU speed is sufficient for both digital data processors 12, 14 (e.g., as determined by the registry query mentioned above) and the requested rules can be apportioned to be separately executed at both locations, the operation may proceed through steps 34, 40 and 42 such that the respective portions of the report rules along with the required engine 18a may be transferred appropriately to digital data processors 12 and 14 for remote execution. Alternatively, the determination in step 34 may be that the requested report rules cannot be independently executed at different locations. In that case, the required data and/or transaction data base (e.g., 12b, 14b) is retrieved and/or transferred, along with the requested report rules and engine 18a, to a single digital data processor for execution. In that case, the transfer destination may, for example, be determined based upon a higher CPU speed or any other factor.

As previously mentioned, a retrieval and/or transfer of rules, engine or data between digital data processors 12, 14 and 18 can be accomplished by employing the methodology discussed above in connection with steps 40(i) and 40(ii). Thus, for example, after the determination in step 34 is in the affirmative, the location(s) of the required data for the report rules may be validated (if not already done) through communication between coordination modules 12d, 14d and 18d. In some embodiments, the validating module (e.g., 12d or 14d) can open a communications port in the respective digital data processor and can prepare the required data for access via that port.

Once the ports are opened, the digital data processors 12, 14 and 18 can freely communicate information among each other in step 40(ii). Thus, if it has been determined that digital data processor 12 is to execute the requested report rules, module 18d retrieves the required data portion and/or transaction data base 14b from digital data processor 14 and transfers it to the digital data processor 12. Furthermore, the requested report rules and the required engine 18a are transferred from digital data processor 18 to the target digital data processor 12. Once such retrieval and transfer is completed, the requested report rules are executed in step 42.

In some embodiments, local registries, files or databases (e.g., 12b, 12c, 14b, 14c, 18b, 18c) on any of digital data processors 12, 14 and 18 are updated following the retrieval and/or transfer of rules, rule bases, engine (or any portion thereof), data and transaction data bases from/to such digital data processors. This allows digital data processors 12, 14 and 18 to handle future requests for rule execution accurately and/or efficiently. By way of illustration, once the requested report rules and engine 18a are transferred from digital data processor 18 to digital data processor 12 in the example above, the local registries on any of digital data processors 12, 18 can be updated to reflect such transfer. The operation of coordination module 18d is adjusted accordingly to respond to subsequent requests for execution of those report rules that are any of signaled to and received by the module and/or digital data processor 18.

It will be appreciated that the illustrated embodiment of the operation of coordination module 18d in FIG. 2 is merely exemplary and that certain steps may be omitted, modified or re-ordered without departing from the scope of the disclosure herein. In some embodiments, for example, any of the modules 12d, 14d and 18d may be configured differently based on the business and/or technical requirements that drive the use of the techniques and systems described herein.

By way of non-limiting example, the systems and techniques described herein may be used for provisioning a computing platform as a service (e.g., commercially available Platform-as-a-Service or “PaaS” offerings) over the internet to multiple concurrent users (e.g., from different companies or “tenant” organizations) for application development, testing and/or deployment in a way that provides more flexibility and ease of use without sacrificing data security as compared to the conventional technology/tools available on the market today.

In one such embodiment, the server 18 depicted in FIG. 1 is configured as a cloud-based computing platform comprising hardware and software components (e.g., business process management software) that are used by users 11 from one or more tenant organizations over the internet (e.g., network 16) to develop, test and/or deploy their enterprise applications. Such shared use of resources among multiple tenant organizations on a cloud-based server (e.g., 18) allows each respective tenant to quickly develop, test and deploy their applications while avoiding the cost and complexity of buying the underlying hardware and software components and hosting them in their own data centers.

Despite its many benefits, the multi-tenant architecture have traditionally presented significant challenges related to data security and integration between cloud-based application(s) and the legacy systems/resources located within each of the respective tenants' data centers. These challenges are exacerbated by the business need of many of the tenant organizations who want to take the hybrid approach of leveraging a cloud-based platform (e.g., server 18) to develop/test their application(s) and eventually migrating them for deployment within the respective data centers, and vice versa. Given the prior state of the technology, one major drawback of this hybrid approach is that the integration configuration of the tenant application(s) with respect to other applications and/or systems (e.g., data bases) has to be updated each time the tenant application is migrated in/out of the tenant data center.

Thus, for example, enterprise software applications are typically developed and tested by tenants on a server by creating and/or modifying a plurality rules that may be stored in a rules base present on the server. These rules can define all aspects of such tenant applications including their integration with other applications and/or systems, some of which may be located behind tenant firewalls in the tenant's data center. Thus, in order to enable communication between a tenant application on server and other applications, systems and/or functionality located behind tenant firewalls (hereinafter collectively referred to as “tenant legacy systems”), the integration rules for the tenant applications might attempt to obviate the obstacles presented by the firewalls, e.g., by opening multiple ports in the tenant firewall depending upon, e.g., the integration method (e.g., SOAP, .NET, JAVA, EJB etc.) and/or the type of tenant legacy system (e.g., SQL database, web service etc.) that is being linked to the tenant application. If that same tenant application is then subsequently deployed within the tenant's data center (i.e., within the tenant firewalls), the integration rules for that application must be reconfigured to establish the direct link between the tenant application and the tenant legacy systems without any intermediate firewall.

Similarly, a tenant may develop and test its application within its data center before migrating it outside its firewall for deployment on a cloud-server. At run-time of the application, a rules engine on the server might execute one or more of the plurality of rules that define the application in response to requests/events received by server e.g., from users within a tenant data center. The data processed during run-time by such rules could potentially either be stored in the database local to the server or it may be stored in remote tenant data bases that may not be accessible to server (e.g., due to firewalls) to effect the desired processing. In such a system, the conventional prior art approach would require that the integration rules of the tenant application be reconfigured upon migration of the tenant application to the cloud-based server in order to avoid any errors/interruptions during execution of such tenant applications on cloud-based servers due to inaccessibility of the required data and/or other resources.

Systems and techniques described herein overcome these drawbacks, for example, when configured as described below, by allowing tenant organizations to simulate their data center environment on an external cloud-based infrastructure (e.g., server 18), thus obviating the need to reconfigure the integration framework of the tenant application(s) upon migration.

This and other benefits of the systems and techniques described herein become apparent in embodiments of the type illustrated FIG. 1 which are configured such that digital data processor 18 operates as a server on a “cloud” platform, e.g., of the type commercially available from Amazon, SalesForce, Google, or other cloud-computing providers. In such embodiments, digital data processors 12 and 14 can be, for example, different “tenant” digital data processors that are in communication with the server 18 over network(s) to access resources (e.g., rules, applications, modules, database, rules bases, data, code, scripts, hardware etc.) that may be either “generic” (i.e., available to users/systems associated with all tenants that are able to connect to the server 18) or “tenant-specific” (i.e., only accessible to users/systems associated with a particular tenant).

As a departure from the conventional approach mentioned above, embodiments of the invention configured as described herein allow tenant organizations to build seamless integration between their enterprise application(s) and the tenant legacy systems without having to reconfigure the application(s) multiple times depending upon where the application(s) is developed, tested and/or deployed. This is accomplished by establishing communication between coordination modules that are installed on the cloud-based server (or wherever the application is developed, tested and/or deployed outside the tenant firewall) as well as within each tenant's data center.

Accordingly, for example, the first time a user 11 signals/sends a request (e.g., HTTP request or otherwise) using digital data processor (e.g., 12, 14, 11a) to access any of the resources that are located on the server 18, any of the coordination module 18d and engine 18a first authenticate the user by e.g., matching parameters or other indicators of user identification in the request with data related to authorized tenant users previously stored in any of the local data bases (e.g., 18b, 18c), registries, files and elsewhere. If the user is authenticated/verified as an authorized user who is able to access resources on server 18 on behalf of a tenant organization, a coordination module (e.g., 12d, 14d) can be transmitted back in response to their initial request. The coordination module that is transmitted back (e.g., 12d, 14d) may be installed on any digital data processor (e.g., 12, 14, 11a) located behind/protected by the firewall of the tenant organization that the user is associated with. In one embodiment, the coordination module transmitted back to the authorized tenant user may be installed in the web browser of the digital data processor being used by the tenant user to communicate with server 18. Upon installation, the coordination module (e.g., 12d, 14d) may prompt the user to provide information related to the tenant legacy systems that may need to be integrated with the tenant application(s) on server 18. This information is then be transmitted to server 18 where it is stored in any of the local data bases (e.g., 18b, 18c), registries, files and elsewhere.

Thus, when an authorized user starts to develop and test applications on server 18 on behalf of tenant organizations and stores the legacy system information for that tenant on the server 18, any of the authorized developers associated with that tenant organization can configure integration rules for tenant application(s) on server 18 in exactly the same way as if they were developing the integration rules on a digital data processor located within that tenant's data center. Similarly, even if the integration rules were first built within that tenant's data center and then later migrated to server 18, the legacy system information on server 18 coupled with the communication between coordination module 18d and the coordination module located within the tenant's data center (e.g., 12d, 14d) obviate the need to reconfigure the integration rules to maintain the integration links that are defined by such rules.

FIG. 3 illustrates operation of an embodiment of the invention and particularly, for example, operation of module 18d on digital data processor 18 at run-time within a multi-tenant cloud-based environment as described above. In one such embodiment, the module 18d can be configured to omit a few steps and simplify its operation as compared to the illustrated embodiment in FIG. 2. Namely steps 20, 24, 34, 36 and 44 of the operation depicted in FIG. 2 are omitted in here FIG. 3 for various reasons. For example, the platform-as-a-service business model by its very nature typically requires that the service provider (e.g., salesforce.com, Google etc.) provision all required hardware and software components to its tenants. Thus, the coordination module may not need to verify the local presence of all required portions of rules engine 18a in step 24. In fact, all requests by users for rule execution on behalf of the tenants at run-time may initially be signaled to and/or received by engine 18a. After the authentication/verification process (as described above) for the user making the request, the rules engine 18a may also verify the availability of the requested rule before working with module 18d to access the required data in step 22. Therefore, even though rules engine 18a may employ the same techniques as step 20 illustrated in FIG. 2 to verify the local presence of the requested rule, that step 20 can be omitted from the simplified operation of module 18d in the illustrated embodiment.

Once the verification process related to user authentication and local rule presence is completed, coordination module 18d will respond to requests for data access in substantially the same way as described previously in connection with FIG. 2. That is, the module 18d will verify the local presence of the required data on server 18 using the techniques discussed previously. If locally present, the module will typically defer to the local engine 18a for local execution the rule on the required data through steps 26-30. On the other hand, if the required data and/or database are not locally present, the coordination module 18d will attempt to identify the location of the required data in step 32 by checking any of the tenant information, user information, parameters and other indicators of data presence e.g., in the request signaled to the engine 18a and/or the module 18d. In addition or instead, the module 18d may also check integration rules (if any) that may be referenced by or otherwise related to the requested rule and/or the tenant legacy system information that may be found in a registry, data base or elsewhere on the digital data processor 18. Once the appropriate tenant location of the required data is identified in step 32, the coordination module 18d may retrieve the data for local execution of the requested rule(s) and/or transfer the requested rule(s) to the identified tenant location for execution, all as previously discussed in connection with steps 26-30 and 40, 42 and 46 depicted FIG. 2.

It will be appreciated that while effecting any of notifications, transfers and retrieval of data and/or rules in step 40 of the illustrated embodiment, the coordination module 18d may only open a single port in the tenant firewall. That is a more secure approach than opening multiple ports (e.g., based on integration methods etc.) as required by the conventional approach described above.

It will be appreciated that steps 34, 36 and 44 from the operation depicted in FIG. 2 are also omitted from the illustrated embodiment in FIG. 3 for the sake of simplicity. It is entirely possible, for example, that the identified tenant location (e.g., digital data processor 12) in step 32 may not have the required resources (e.g., computing power and/or rules engine) for the requested rule(s) execution. In that case, the coordination module 18d may work with the local coordination module (e.g., 12d) at the appropriate tenant data center to identify one or more other digital data processors with the necessary resources within that data center for the execution of the requested rules(s).

Described above are systems and methods meeting the foregoing objects. It will be appreciated that the embodiment illustrated and described herein are merely examples of the invention and other embodiments incorporating changes thereto fall within the scope thereof.

Frenkel, Benjamin A.

Patent Priority Assignee Title
10467200, Mar 12 2009 Pegasystems, Inc. Techniques for dynamic data processing
10469396, Oct 10 2014 PEGASYSTEMS INC Event processing with enhanced throughput
10572236, Dec 30 2011 Pegasystems, Inc. System and method for updating or modifying an application without manual coding
10698599, Jun 03 2016 PEGASYSTEMS, INC, Connecting graphical shapes using gestures
10698647, Jul 11 2016 PEGASYSTEMS INC Selective sharing for collaborative application usage
10838569, Mar 30 2006 Pegasystems Inc. Method and apparatus for user interface non-conformance detection and correction
11048488, Aug 14 2018 Pegasystems, Inc.; PEGASYSTEMS, INC Software code optimizer and method
11057313, Oct 10 2014 Pegasystems Inc. Event processing with enhanced throughput
11381662, Dec 28 2015 SAP SE Transition of business-object based application architecture via dynamic feature check
11567945, Aug 27 2020 PEGASYSTEMS INC Customized digital content generation systems and methods
11727283, May 19 2020 International Business Machines Corporation Rule distribution across instances of rules engine
9658735, Mar 30 2006 Pegasystems Inc. Methods and apparatus for user interface optimization
9678719, Mar 30 2009 Pegasystems Inc. System and software for creation and modification of software
Patent Priority Assignee Title
4047059, May 24 1976 RCA Corporation Comparator circuit
4344142, Sep 26 1973 N O-RING CORPORATION Direct digital control of rubber molding presses
4602168, Mar 28 1984 National Semiconductor Corporation Low offset CMOS comparator circuit
4607232, Apr 01 1985 Fairchild Semiconductor Low voltage amplifier circuit
4659944, Apr 08 1985 Motorola, Inc. High voltage detection circuit
4701130, Jan 11 1985 INTERACTIVE TRAINING TECHNOLOGIES, INC , A CORP OF OR Software training system
4866634, Aug 10 1987 MOODY S RISK MANAGEMENT SERVICES, INC Data-driven, functional expert system shell
4884217, Sep 30 1987 PAVILION TECHNOLOGIES, INC Expert system with three classes of rules
4895518, Nov 02 1987 Greenhalgh Technologies Computerized diagnostic reasoning evaluation system
4930071, Jun 19 1987 IntelliCorp, Inc.; INTELLICORP, INC , A DE CORP Method for integrating a knowledge-based system with an arbitrary database system
4953106, May 23 1989 NCR Corporation Technique for drawing directed graphs
5062060, Jan 05 1987 Motorola Inc Computer human interface comprising user-adjustable window for displaying or printing information
5077491, Nov 30 1990 Motorola, Inc. Low standby current comparator having a zero temperature coefficient with hysterisis
5093794, Aug 22 1989 United Technologies Corporation Job scheduling system
5119465, Jun 19 1989 HEWLETT-PACKARD DEVELOPMENT COMPANY, L P System for selectively converting plurality of source data structures through corresponding source intermediate structures, and target intermediate structures into selected target structure
5129043, Aug 14 1989 INTERNATIONAL BUSINESS MACHINES CORPORATION, ARMONK, NY 10504 A CORP OF DE Performance improvement tool for rule based expert systems
5136184, May 24 1991 Analog Devices, Incorporated Fast-acting current comparator
5136523, Jun 30 1988 HEWLETT-PACKARD DEVELOPMENT COMPANY, L P System for automatically and transparently mapping rules and objects from a stable storage database management system within a forward chaining or backward chaining inference cycle
5140671, Jan 26 1990 International Business Machines Corporation Expert system debugger
5193056, Mar 11 1991 SIGNATURE FINANCIAL GROUP, INC Data processing system for hub and spoke financial services configuration
5199068, Jan 22 1991 Professional Achievement Systems, Inc.; PROFESSIONAL ACHIEVEMENT SYSTEMS, INC Computer-based training system with student verification
5204939, Dec 14 1989 FUJITSU LIMITED, 1015, KAMIKODANAKA, NAKAHARA-KU, KAWASAKI-SHI, KANAGAWA, 211 JAPAN Rule base processing system and rule evaluation control method therein
5228116, Jul 15 1988 Aicorp., Inc. Knowledge base management system
5259766, Dec 13 1991 EDUCATIONAL TESTING SERVICE A CORP OF NEW YORK Method and system for interactive computer science testing, anaylsis and feedback
5262941, Mar 30 1990 DEUTSCHE FINANCIAL SERVICES CORPORATION Expert credit recommendation method and system
5267175, Sep 12 1986 HEWLETT-PACKARD DEVELOPMENT COMPANY, L P Data base access mechanism for rules utilized by a synthesis procedure for logic circuit design
5267865, Feb 11 1992 JRL ENTERPRISES, INC Interactive computer aided natural learning method and apparatus
5270920, May 13 1991 L-3 Communications Corporation Expert system scheduler and scheduling method
5276359, Feb 02 1993 Current-input type interface circuit of a mouse
5276885, Apr 18 1991 Carnegie Group Single step mapping in topological order of the queued class and instance frames of a semantic network to a static working memory
5291394, Jun 01 1990 Freescale Semiconductor, Inc Manufacturing control and capacity planning system
5291583, Dec 14 1990 RACAL-DATACOM, INC Automatic storage of persistent ASN.1 objects in a relational schema
5295256, Dec 14 1990 Progress Software Corporation Automatic storage of persistent objects in a relational schema
5297279, May 30 1990 Texas Instruments Incorporated; TEXAS INSTRUMENTS INCORPORATED, A CORP OF DE System and method for database management supporting object-oriented programming
5301270, Dec 18 1989 Accenture Global Services Limited Computer-assisted software engineering system for cooperative processing environments
5310349, Apr 30 1992 COMPASSLEARNING, INC Instructional management system
5311422, Jun 28 1990 The United States of America as represented by the Administrator of the General purpose architecture for intelligent computer-aided training
5326270, Aug 29 1991 INTROSPECT TECHNOLOGIES, INC System and method for assessing an individual's task-processing style
5333254, Oct 02 1991 Xerox Corporation Methods of centering nodes in a hierarchical display
5339390, Mar 05 1990 SAP America, Inc Operating a processor to display stretched continuation of a workspace
5374932, Aug 02 1993 Massachusetts Institute of Technology Airport surface surveillance system
5379366, Jan 29 1993 7 DEGREES, INC Method for representation of knowledge in a computer as a network database system
5379387, Aug 02 1990 Carlstedt Elektronik AB Arithmetic unit for structure arithmetic
5381332, Dec 09 1991 GENERAL DYNAMICS C4 SYSTEMS, INC Project management system with automated schedule and cost integration
5386559, Jul 16 1992 International Business Machines Corporation Variant domains and variant maps in a versioned database management system
5395243, Sep 25 1991 National Education Corporation; THOMSON LEARNING, INC Interactive learning system
5412756, Dec 22 1992 Mitsubishi Denki Kabushiki Kaisha Artificial intelligence software shell for plant operation simulation
5421011, Dec 20 1991 International Business Machines Corporation; INTERNATIONAL BUSINESS MACHINES CORPORATION A CORP OF NEW YORK Method and system for access and accounting control in a data processing system by using a single resource account for a user or a group of users
5421730, Nov 27 1991 National Education Corporation; THOMSON LEARNING, INC Interactive learning system providing user feedback
5446397, Feb 26 1992 NEC Corporation Current comparator
5446885, May 15 1992 INTERNATIONAL BUSINESS MACHINES CORPORATION, A CORP OF NY Event driven management information system with rule-based applications structure stored in a relational database
5450480, Aug 25 1992 Intellectual Ventures II LLC Method of creating a telecommunication service specification
5463682, Aug 25 1992 Intellectual Ventures II LLC Method of creating user-defined call processing procedures
5473732, Nov 02 1993 Relational artificial intelligence system
5477170, Feb 17 1994 NEC Corporation Comparator capable of preventing large noise voltage
5481647, Mar 22 1991 Raff Enterprises, Inc. User adaptable expert system
5499293, Jan 24 1995 University of Maryland Privacy protected information medium using a data compression method
5504879, Jul 16 1992 International Business Machines Corporation Resolution of relationship source and target in a versioned database management system
5512849, Apr 30 1993 North American Philips Corporation Low power intelligent current source for monitoring a high voltage
5519618, Aug 02 1993 Massachusetts Institute of Technology Airport surface safety logic
5537590, Aug 05 1993 DIAGNOSTIC SYSTEMS CORPORATION; DIAGNOSTICS SYSTEMS CORPORATION Apparatus for applying analysis rules to data sets in a relational database to generate a database of diagnostic records linked to the data sets
5542024, Jul 09 1992 Johnson & Johnson Graphically used expert system tool background of the invention
5542078, Sep 29 1994 FIRESTAR SOFTWARE, INC Object oriented data store integration environment for integration of object oriented databases and non-object oriented data facilities
5548506, Mar 17 1994 Automated, electronic network based, project management server system, for managing multiple work-groups
5561740, Dec 13 1994 International Business Machines Corporation Method and system for providing multiple instances in a single multiple-instance object
5579223, Dec 24 1992 Microsoft Technology Licensing, LLC Method and system for incorporating modifications made to a computer program into a translated version of the computer program
5579486, Jan 14 1993 Apple Inc Communication node with a first bus configuration for arbitration and a second bus configuration for data transfer
5586311, Feb 14 1994 PAICINES PINNACLES LLC Object oriented data access and analysis system
5596752, Sep 01 1989 OBJECTSTAR INTERNATIONAL LIMITED System for creating, editing, displaying, and executing rules-based programming language rules having action part subsets for both true and false evaluation of the conditional part
5597312, May 04 1994 Qwest Communications International Inc Intelligent tutoring method and system
5608789, Aug 23 1992 Intellectual Ventures II LLC Method of creating user-defined call processing procedures
5611076, Sep 21 1994 Micro Data Base Systems, Inc. Multi-model database management system engine for databases having complex data models
5627979, Jul 18 1994 International Business Machines Corporation System and method for providing a graphical user interface for mapping and accessing objects in data stores
5630127, May 15 1992 International Business Machines Corporation Program storage device and computer program product for managing an event driven management information system with rule-based application structure stored in a relational database
5649192, Jan 15 1993 General Electric Company Self-organized information storage system
5655118, Mar 21 1994 TTI Inventions C LLC Methods and apparatus for managing information on activities of an enterprise
5664206, Jan 14 1994 Sun Microsystems, Inc. Method and apparatus for automating the localization of a computer program
5675753, Apr 24 1995 Qwest Communications International Inc Method and system for presenting an electronic user-interface specification
5678039, Sep 30 1994 Borland Software Corporation System and methods for translating software into localized versions
5689663, Jun 19 1992 Rovi Technologies Corporation Remote controller user interface and methods relating thereto
5715450, Sep 27 1995 Oracle America, Inc Method of selecting and presenting data from a database using a query language to a user of a computer system
5732192, Nov 30 1994 The United States of America as represented by the Administrator of the Global qualitative flow-path modeling for local state determination in simulation and analysis
5754740, Nov 11 1994 LD TECHNOLOGIES, LLC Production system
5761063, Mar 11 1993 Lear Corporation Design and engineering project management system
5761673, Jan 31 1996 Oracle International Corporation Method and apparatus for generating dynamic web pages by invoking a predefined procedural package stored in a database
5765140, Nov 17 1995 Verizon Patent and Licensing Inc Dynamic project management system
5768480, Oct 21 1994 Alcatel Lucent Integrating rules into object-oriented programming systems
5788504, Oct 16 1995 CAPITAL ANALYTICS, INC Computerized training management system
5795155, Apr 01 1996 HEWLETT-PACKARD DEVELOPMENT COMPANY, L P Leadership assessment tool and method
5809212, Jul 12 1993 New York University Conditional transition networks and computational processes for use interactive computer-based systems
5815415, Jan 19 1996 Bentley Systems, Incorporated Computer system for portable persistent modeling
5819257, Jan 31 1997 THE CHASE MANHATTAN BANK, AS COLLATERAL AGENT Process for providing transitive closure using fourth generation structure query language (SQL)
5822780, Dec 31 1996 EMC IP HOLDING COMPANY LLC Method and apparatus for hierarchical storage management for data base management systems
5825260, Feb 15 1996 Daimler-Benz Aerospace AG Directional coupler for the high-frequency range
5826077, Apr 30 1990 Texas Instruments Incorporated Apparatus and method for adding an associative query capability to a programming language
5826239, Dec 17 1996 Hewlett Packard Enterprise Development LP Distributed workflow resource management system and method
5826250, Jun 19 1996 PEGASYSTEMS INC Rules bases and methods of access thereof
5826252, Jun 28 1996 General Electric Company System for managing multiple projects of similar type using dynamically updated global database
5829983, Sep 02 1994 Fujitsu Limited System for carrying out educational management
5831607, Jan 25 1996 International Business Machines Corporation Method for adapting multiple screens of information for access and use on a single graphical panel in a computer system
5832483, Dec 13 1996 EMC IP HOLDING COMPANY LLC Distributed control interface for managing the interoperability and concurrency of agents and resources in a real-time environment
5841435, Jul 26 1996 International Business Machines Corporation Virtual windows desktop
5841673, Jan 30 1995 NEC Corporation System and method for processing graphic delay data of logic circuit to reduce topological redundancy
5864865, Mar 24 1997 EMC IP HOLDING COMPANY LLC Management information base listing viewer
5873096, Oct 08 1997 Oracle America, Inc Method of maintaining a network of partially replicated database system
5875334, Oct 27 1995 International Business Machines Corporation System, method, and program for extending a SQL compiler for handling control statements packaged with SQL query statements
5875441, May 07 1996 FUJI XEROX CO , LTD Document database management system and document database retrieving method
5880614, Sep 24 1994 ITT Manufacturing Enterprises Inc. Circuit arrangement for evaluating the output signal of an active sensor
5880742, Sep 17 1993 SAP America, Inc Spreadsheet image showing data items as indirect graphical representations
5886546, Jun 27 1996 LG Semicon Co., Ltd. Current/voltage converter, sense amplifier and sensing method using same
5890146, May 02 1996 U.S. Philips Corporation Adaptive process modelling and control
5890166, Jul 16 1992 International Business Machines Corporation Versioned-database management system in which tasks are associated with promote groups which comprise a set of parts whose changes are to be promoted
5892512, Jul 06 1996 International Business Machines Corporation Selection of operations in a computer system
5907490, Jun 10 1997 HEWLETT-PACKARD DEVELOPMENT COMPANY, L P System and method for project management and assessment
5907837, Jul 17 1995 Microsoft Technology Licensing, LLC Information retrieval system in an on-line network including separate content and layout of published titles
5910748, Jul 16 1996 SGS-THOMSON MICROELECTRONICS S A Power amplifier in bicmos technology having an output stage in MOS technology
5911138, Jun 04 1993 International Business Machines Corporation Database search facility having improved user interface
5918222, Mar 17 1995 Kabushiki Kaisha Toshiba Information disclosing apparatus and multi-modal information input/output system
5920717, Dec 20 1995 NEC Corporation Method and apparatus for automated program-generation
5930795, Jan 21 1997 GOOGLE LLC Supporting dynamic tables in SQL query compilers
5945852, Mar 31 1998 Google Technology Holdings LLC CMOS comparator output circuit with high gain and hysteresis
5974441, Jun 07 1995 GOOGLE LLC WWW client server interactive system method with Java (™)
5974443, Sep 26 1997 InterVoice Limited Partnership Combined internet and data access system
5978566, Jul 12 1996 Microsoft Technology Licensing, LLC Client side deferred actions within multiple MAPI profiles
5983267, Sep 23 1997 PENCON SYSTEMS, INC System for indexing and displaying requested data having heterogeneous content and representation
5987415, Mar 23 1998 Microsoft Technology Licensing, LLC Modeling a user's emotion and personality in a computer user interface
5990742, Nov 26 1997 MONTEREY RESEARCH, LLC Differential amplifier circuit
5995948, Nov 21 1997 Bank One, Delaware, National Association Correspondence and chargeback workstation
5995958, Mar 04 1997 System and method for storing and managing functions
6008673, Sep 30 1997 Intel Corporation High speed, low power, current mode comparator
6008808, Dec 31 1997 CIENA LUXEMBOURG S A R L ; Ciena Corporation Tools for data manipulation and visualization
6012098, Feb 23 1998 International Business Machines Corp. Servlet pairing for isolation of the retrieval and rendering of data
6020768, May 13 1998 CSR TECHNOLOGY INC CMOS low-voltage comparator
6023704, Jan 29 1998 International Business Machines Corporation Apparatus and method for swapping identities of two objects to reference the object information of the other
6023714, Apr 24 1997 Microsoft Technology Licensing, LLC Method and system for dynamically adapting the layout of a document to an output device
6023717, Oct 30 1996 Qualcomm Incorporated Method and apparatus for polyphase digital filtering in a mobile telephone
6028457, Sep 18 1996 Siemens Aktiengesellschaft CMOS comparator
6037890, Sep 30 1997 Intel Corporation Ultra high speed, low power, flash A/D converter utilizing a current mode regenerative comparator
6044373, Sep 29 1997 International Business Machines Corporation Object-oriented access control method and system for military and commercial file systems
6044466, Nov 25 1997 International Business Machines Corp. Flexible and dynamic derivation of permissions
6078982, Mar 24 1998 MICRO FOCUS LLC Pre-locking scheme for allowing consistent and concurrent workflow process execution in a workflow management system
6085188, Mar 30 1998 International Business Machines Corporation Method of hierarchical LDAP searching with relational tables
6085198, Jun 05 1998 HANGER SOLUTIONS, LLC Integrated three-tier application framework with automated class and table generation
6091226, Mar 12 1998 Renesas Electronics Corporation Voltage judgment circuit and battery cell pack having the same
6092036, Jun 02 1998 Wilmington Trust, National Association, as Administrative Agent Multi-lingual data processing system and system and method for translating text used in computer software utilizing an embedded translator
6092083, Feb 26 1997 Oracle America, Inc Database management system which synchronizes an enterprise server and a workgroup user client using a docking agent
6094652, Jun 10 1998 Oracle International Corporation Hierarchical query feedback in an information retrieval system
6098172, Sep 12 1997 THE CHASE MANHATTAN BANK, AS COLLATERAL AGENT Methods and apparatus for a computer network firewall with proxy reflection
6105035, Feb 17 1998 WSOU Investments, LLC Method by which notions and constructs of an object oriented programming language can be implemented using a structured query language (SQL)
6108004, Oct 21 1997 SAP SE GUI guide for data mining
6122632, Jul 21 1997 CONCENTRIX CVG CUSTOMER MANAGEMENT DELAWARE LLC Electronic message management system
6125363, Mar 30 1998 ZEOSOFT TECHNOLOGY GROUP, INC Distributed, multi-user, multi-threaded application development method
6130679, Feb 13 1997 Intel Corporation Data reduction and representation method for graphic articulation parameters gaps
6137797, Nov 27 1996 IBM Corporation Process definition for source route switching
6144997, Jun 27 1994 CLOUD SATCHEL LLC System and method for accessing and distributing electronic documents
6151595, Apr 17 1998 Xerox Corporation Methods for interactive visualization of spreading activation using time tubes and disk trees
6151624, Feb 03 1998 R2 SOLUTIONS LLC Navigating network resources based on metadata
6154738, Mar 27 1998 PRODUCT ASSOCIATION TECHNOLOGIES, LLC Methods and apparatus for disseminating product information via the internet using universal product codes
6167441, Nov 21 1997 PayPal, Inc Customization of web pages based on requester type
6177932, Aug 21 1998 LT TECH, LLC Method and apparatus for network based customer service
6185516, Mar 06 1990 Alcatel Lucent Automata-theoretic verification of systems
6185534, Mar 23 1998 Microsoft Technology Licensing, LLC Modeling emotion and personality in a computer user interface
6192371, Apr 28 1999 WSOU Investments, LLC Object morphing in an object oriented computing environment using relational database query procedure
6194919, Dec 30 1997 HYUNDAI ELECTRONICS INDUSTRIES CO , LTD Main amplifier
6212502, Mar 23 1998 Microsoft Technology Licensing, LLC Modeling and projecting emotion and personality from a computer user interface
6216135, Feb 26 1997 Oracle America, Inc Method of determining visibility to a remote database client of a plurality of database transactions having variable visibility strengths
6233332, Jun 03 1998 AVAYA Inc System for context based media independent communications processing
6233617, Feb 26 1997 Oracle America, Inc Determining the visibility to a remote database client
6240417, Aug 13 1997 AVAYA Inc Integration of legacy database management systems with ODBC-compliant application programs
6243713, Aug 24 1998 SEEKR TECHNOLOGIES INC Multimedia document retrieval by application of multimedia queries to a unified index of multimedia data for a plurality of multimedia data types
6246320, Feb 25 1999 TELESIS GROUP, INC, THE; TELESIS GROUP, INC , THE; E-WATCH, INC Ground link with on-board security surveillance system for aircraft and other commercial vehicles
6275073, Oct 30 1998 Fujitsu Limited Differential input circuit
6275790, Jul 28 1999 International Business Machines Corporation Introspective editor system, program, and method for software translation
6281896, Mar 31 1998 Ricoh Company, LTD Data processor controlled interface with multiple tree of elements views expandable into individual detail views
6282547, Aug 25 1998 ACTIVISION PUBLISHING, INC Hyperlinked relational database visualization system
6300947, Jul 06 1998 Wistron Corporation Display screen and window size related web page adaptation system
6304259, Feb 09 1998 International Business Machines Corporation Computer system, method and user interface components for abstracting and accessing a body of knowledge
6308163, Mar 16 1999 HEWLETT-PACKARD DEVELOPMENT COMPANY, L P System and method for enterprise workflow resource management
6313834, Nov 23 1998 International Business Machines Corporation Multi-format and multi-view synchronized data editor
6314415, Nov 04 1998 CCH Incorporated Automated forms publishing system and method using a rule-based expert system to dynamically generate a graphical user interface
6324693, Feb 27 1997 Oracle America, Inc Method of synchronizing independently distributed software and database schema
6330554, Jun 03 1999 Microsoft Technology Licensing, LLC Methods and apparatus using task models for targeting marketing information to computer users based on a task being performed
6338074, Jul 23 1997 ServiceNow, Inc System for enterprise-wide work flow automation
6341277, Nov 17 1998 International Business Machines Corporation System and method for performance complex heterogeneous database queries using a single SQL expression
6341293, Jul 13 1994 Apple Inc Real-time computer "garbage collector"
6344862, May 29 1998 Hewlett Packard Enterprise Development LP User interface mechanism for manipulating context in computer management applications
6349238, Sep 16 1998 Verizon Patent and Licensing Inc System and method for managing the workflow for processing service orders among a variety of organizations within a telecommunications company
6351734, Sep 09 1998 Unisys Corporation; JOHNSON, CHARLES A System and method for resource allocation and planning
6356286, Dec 10 1998 TWITTER, INC User-interactive computer display interface with a tree having a plurality of user selectable nodes representing a plurality of search queries to a tabular database
6359633, Jan 15 1999 R2 SOLUTIONS LLC Apparatus and method for abstracting markup language documents
6366299, Feb 21 2000 Verizon Patent and Licensing Inc Multidimensional information visualization using attribute rods
6369819, Apr 17 1998 GOOGLE LLC Methods for visualizing transformations among related series of graphs
6370537, Jan 14 1999 JPMORGAN CHASE BANK, N A , AS SUCCESSOR AGENT System and method for the manipulation and display of structured data
6380910, Jan 10 2001 WSOU Investments, LLC Wireless communications device having a compact antenna cluster
6380947, Jul 22 1999 AT&T Corp. Method and apparatus for displaying and tree scrolling a hierarchical data structure
6381738, Jul 16 1999 International Business Machines Corporation Method for optimizing creation and destruction of objects in computer programs
6389460, May 13 1998 PALO ALTO NETWORKS, INC Method and apparatus for efficient storage and retrieval of objects in and from an object storage device
6389510, Apr 25 2000 Alcatel Lucent Method and apparatus for caching web-based information
6393605, Nov 18 1998 Oracle America, Inc Apparatus and system for efficient delivery and deployment of an application
6396885, Dec 02 1998 BlackBerry Limited Co-channel interference reduction in wireless communications systems
6405211, Jul 08 1999 WAYPOINT GLOBAL II, INC Object-oriented representation of technical content and management, filtering, and synthesis of technical content using object-oriented representations
6405251, Mar 25 1999 AVAYA MANAGEMENT L P Enhancement of network accounting records
6415259, Jul 15 1999 CGI TECHNOLOGIES AND SOLUTIONS INC Automatic work progress tracking and optimizing engine for a telecommunications customer care and billing system
6415283, Oct 13 1998 Oracle International Corporation Methods and apparatus for determining focal points of clusters in a tree structure
6418448, Dec 06 1999 METHOD AND APPARATUS FOR PROCESSING MARKUP LANGUAGE SPECIFICATIONS FOR DATA AND METADATA USED INSIDE MULTIPLE RELATED INTERNET DOCUMENTS TO NAVIGATE, QUERY AND MANIPULATE INFORMATION FROM A PLURALITY OF OBJECT RELATIONAL DATABASES OVER THE WEB
6421571, Feb 29 2000 BN CORPORATION, LLC Industrial plant asset management system: apparatus and method
6426723, Jan 19 2001 Microsoft Technology Licensing, LLC Antenna arrangement for multiple input multiple output communications systems
6429870, Feb 13 1997 Intel Corporation Data reduction and representation method for graphic articulation parameters (GAPS)
6430571, Jul 16 1998 International Business Machines Corporation Multi-frame output form that facilitates internet search and update in a hierarchical database
6430574, Jul 22 1999 AT&T Corp. Method and apparatus for displaying and header scrolling a hierarchical data structure
6437799, Mar 03 1999 International Business Machines Corporation Method and apparatus for logical zooming of a directed graph
6446065, Jul 05 1996 Hitachi, Ltd. Document retrieval assisting method and system for the same and document retrieval service using the same
6446089, Feb 26 1997 Oracle America, Inc Method of using a cache to determine the visibility to a remote database client of a plurality of database transactions
6446200, Mar 25 1999 RPX CLEARINGHOUSE LLC Service management
6446256, Jun 30 1999 Microsoft Technology Licensing, LLC Extension of parsable structures
6448964, Mar 15 1999 CA, INC Graphic object manipulating tool
6453038, Jun 03 1998 AVAYA Inc System for integrating agent database access skills in call center agent assignment applications
6463346, Oct 08 1999 AVAYA Inc Workflow-scheduling optimization driven by target completion time
6463440, Apr 08 1999 International Business Machines Corporation; IBM Corporation Retrieval of style sheets from directories based upon partial characteristic matching
6469715, Mar 19 1999 IGRAFX, LLC System and method for controlling the operation of a graphical object using a project
6469716, Mar 19 1999 IGRAFX, LLC System and method for processing data for a graphical object
6473467, Mar 22 2000 QUALCOMM INCORPORATED, A CORP OF DELAWARE Method and apparatus for measuring reporting channel state information in a high efficiency, high performance communications system
6473748, Aug 31 1998 CALLIDUS SOFTWARE INCORPORATED; Verizon Patent and Licensing Inc System for implementing rules
6493331, Mar 30 2000 Qualcomm INC Method and apparatus for controlling transmissions of a communications systems
6493399, Mar 05 1998 DELAWARE, UNIVERSITY OF Digital wireless communications systems that eliminates intersymbol interference (ISI) and multipath cancellation using a plurality of optimal ambiguity resistant precoders
6493731, Jan 27 1999 GOOGLE LLC Document management system for recording and viewing the history of document use
6493754, Aug 10 1995 Computer Associates Think, Inc Method and apparatus for analyzing communications on different threads
6496812, May 13 2000 OBJECT POWER, INC Method and system for measuring and valuing contributions by group members to the achievement of a group goal
6496833, Nov 01 1999 Oracle America, Inc System and method for generating code for query object interfacing
6502239, Nov 12 1998 CA, INC Method and apparatus for round-trip software engineering
6509898, Apr 17 1998 GOOGLE LLC Usage based methods of traversing and displaying generalized graph structures
6513018, May 05 1994 Fair, Isaac and Company, Inc.; FAIR, ISAAC AND COMPANY, INCORPORATED Method and apparatus for scoring the likelihood of a desired performance result
6526440, Jan 30 2001 GOOGLE LLC Ranking search results by reranking the results based on local inter-connectivity
6526457, Oct 30 1996 Computer Associates Think, Inc Systems utility object interface for facilitating software portability
6529217, Jun 15 1999 Microsoft Technology Licensing, LLC System and method for graphically displaying a set of data fields
6529899, Jan 12 2000 International Business Machines Corporation System and method for registering and providing a tool service
6529900, Jan 14 1999 International Business Machines Corporation Method and apparatus for data visualization
6530079, Jun 02 1999 International Business Machines Corporation Method for optimizing locks in computer programs
6532474, Nov 13 1997 Sharp Kabushiki Kaisha Apparatus and method for carrying out data linkage among a plurality of applications
6539374, Jun 03 1999 Microsoft Technology Licensing, LLC Methods, apparatus and data structures for providing a uniform representation of various types of information
6542912, Oct 16 1998 Red Hat, Inc Tool for building documents for commerce in trading partner networks and interface definitions based on the documents
6546381, Nov 02 1998 International Business Machines Corporation Query optimization system and method
6546406, Nov 03 1995 ENIGMA INFORMATION SYSTEMS LTD Client-server computer system for large document retrieval on networked computer system
6549904, Jun 25 1999 Amazon Technologies, Inc Auction notification system
6556226, Jun 08 1999 CEDAR LANE TECHNOLOGIES INC Method, apparatus and article of manufacture for displaying content in a multi-dimensional topic space
6556983, Jan 12 2000 I P ENGINE, INC Methods and apparatus for finding semantic information, such as usage logs, similar to a query using a pattern lattice data space
6556985, Jul 23 1999 TELERAN TECHNOLOGIES, L P Rule construction and application
6559864, Nov 19 1998 X-Net Associates, Inc.; X NET ASSOCIATES, INC Method and system for displaying and providing access to data on a monitor
6560592, Mar 19 1998 LONGWAVE LLC Multi-model computer database storage system with integrated rule engine
6560649, Feb 10 1999 AVAYA Inc Hierarchical service level remediation for competing classes based upon achievement of service level goals
6567419, Sep 11 2000 R2 SOLUTIONS LLC Intelligent voice converter
6571222, Feb 12 1999 Fujitsu Limited Trading system
6577769, Sep 18 1999 GAMIGO INC Data compression through adaptive data size reduction
6583800, Jul 14 1998 Method and device for finding, collecting and acting upon units of information
6584464, Mar 19 1999 IAC SEARCH & MEDIA, INC Grammar template query system
6584569, Mar 03 2000 FINJAN BLUE, INC System for determining web application vulnerabilities
6594662, Jul 01 1998 CPA GLOBAL FIP LLC Method and system for gathering information resident on global computer networks
6597381, Jul 24 1999 Intelligent Reasoning Systems, Inc. User interface for automated optical inspection systems
6597775, Sep 29 2000 Fair Isaac Corporation Self-learning real-time prioritization of telecommunication fraud control actions
6598043, Oct 04 1999 Jarg Corporation Classification of information sources using graph structures
6606613, Jun 03 1999 Microsoft Technology Licensing, LLC Methods and apparatus for using task models to help computer users complete tasks
6625657, Mar 25 1999 AVAYA Holdings Limited System for requesting missing network accounting records if there is a break in sequence numbers while the records are transmitting from a source device
6629138, Jul 21 1997 CLOUD SOFTWARE GROUP, INC Method and apparatus for storing and delivering documents on the internet
6636850, Dec 28 2000 FairIsaac and Company, Inc. Aggregate score matching system for transaction records
6636901, Jan 30 1998 Apple Inc Object-oriented resource lock and entry register
6643638, Mar 25 2000 System and method for storing and computing data and functions
6643652, Jan 14 2000 SABA SOFTWARE, INC Method and apparatus for managing data exchange among systems in a network
6661889, Jan 18 2000 AVAYA Inc Methods and apparatus for multi-variable work assignment in a call center
6661908, Jan 13 1999 Computer Associates Think, Inc Signature recognition system and method
6678679, Oct 10 2000 RELATIVITY ODA LLC Method and system for facilitating the refinement of data queries
6678773, Jan 13 2000 SHENZHEN XINGUODU TECHNOLOGY CO , LTD Bus protocol independent method and structure for managing transaction priority, ordering and deadlocks in a multi-processing system
6678882, Jun 30 1999 Qwest Communications International Inc Collaborative model for software systems with synchronization submodel with merge feature, automatic conflict resolution and isolation of potential changes for reuse
6684261, Jul 19 1993 Apple Inc Object-oriented operating system
6690788, Jun 03 1998 AVAYA Inc Integrated work management engine for customer care in a communication system
6691067, Apr 07 1999 BMC Software, Inc. Enterprise management system and method which includes statistical recreation of system resource usage for more accurate monitoring, prediction, and performance workload characterization
6691230, Oct 15 1998 GOOGLE LLC Method and system for extending Java applets sand box with public client storage
6701314, Jan 21 2000 Leidos, Inc System and method for cataloguing digital information for searching and retrieval
6711565, Jun 18 2001 Oracle America, Inc Method, apparatus, and system for previewing search results
6721747, Jan 14 2000 Saba Software, Inc. Method and apparatus for an information server
6728702, Jun 18 2001 Oracle America, Inc System and method to implement an integrated search center supporting a full-text search and query on a database
6728852, Jun 30 2000 Oracle America, Inc Method and apparatus for reducing heap size through adaptive object representation
6732095, Apr 13 2001 Oracle America, Inc Method and apparatus for mapping between XML and relational representations
6732111, Mar 03 1998 Siebel Systems, Inc. Method, apparatus, system, and program product for attaching files and other objects to a partially replicated database
6748422, Oct 19 2000 eBay Inc System and method to control sending of unsolicited communications relating to a plurality of listings in a network-based commerce facility
6750858, Oct 25 1993 Apple Inc Object-oriented window area display system
6751663, Mar 25 1999 AVAYA MANAGEMENT L P System wide flow aggregation process for aggregating network activity records
6754475, Jun 28 2002 Google Technology Holdings LLC Transmission performance measurement and use thereof
6756994, Aug 07 2000 Canon Kabushiki Kaisha Method and apparatus for handling secondary dependencies
6763351, Jun 18 2001 Oracle America, Inc Method, apparatus, and system for attaching search results
6771706, Mar 23 2001 Qualcomm Incorporated Method and apparatus for utilizing channel state information in a wireless communication system
6772148, Oct 04 1999 Jarg Corporation Classification of information sources using graphic structures
6772350, May 15 1998 WILMINGTON TRUST, NATIONAL ASSOCIATION, AS COLLATERAL AGENT System and method for controlling access to resources in a distributed environment
6778971, Jun 03 1999 Microsoft Technology Licensing, LLC Methods and apparatus for analyzing computer-based tasks to build task models
6782091, Oct 13 2000 Virtual call distribution system
6785341, May 11 2001 Qualcomm Incorporated Method and apparatus for processing data in a multiple-input multiple-output (MIMO) communication system utilizing channel state information
6788114, Jun 27 2003 Dialog Semiconductor GmbH Comparator with high-voltage inputs in an extended CMOS process for higher voltage levels
6792420, Jun 29 2001 International Business Machines Corporation Method, system, and program for optimizing the processing of queries involving set operators
6804330, Jan 04 2002 Oracle America, Inc Method and system for accessing CRM data via voice
6807632, Jan 21 1999 EMC IP HOLDING COMPANY LLC Content addressable information encapsulation, representation, and transfer
6810429, Feb 03 2000 Mitsubishi Electric Research Laboratories, Inc Enterprise integration system
6820082, Apr 03 2000 International Business Machines Corporation Rule based database security system and method
6829655, Mar 28 2001 Siebel Systems, Inc. Method and system for server synchronization with a computing device via a companion device
6831668, Apr 03 2000 Business Objects Software Ltd Analytical reporting on top of multidimensional data model
6839682, May 06 1999 CALLAHAN CELLULAR L L C Predictive modeling of consumer financial behavior using supervised segmentation and nearest-neighbor matching
6847982, Apr 12 1996 Computer Associates Think, Inc. Intelligent data inventory and asset management system method and apparatus
6851089, Oct 25 1999 Amazon Technologies, Inc Software application and associated methods for generating a software layer for structuring semistructured information
6856575, Oct 21 2002 Schlumberger Technology Corporation Monitoring a microseismic event
6856992, May 15 2001 OBJECTSTORE, INC Methods and apparatus for real-time business visibility using persistent schema-less data storage
6859787, Aug 08 1996 eBay, Inc. Method and system for providing order status information using an update status flag
6865546, Apr 19 2000 Amazon Technologies, Inc Methods and systems of assisting users in purchasing items
6865566, May 09 2000 HNC SOFTWARE, INC Approach for re-using business rules
6865575, Jul 06 2000 GOOGLE LLC Methods and apparatus for using a modified index to provide search results in response to an ambiguous search query
6867789, Feb 15 2000 JPMORGAN CHASE BANK, N A System and method for generating graphical user interfaces
6918222, Sep 09 2003 Illinois Tool Works Inc. Fastener for spacing object from substrate
6920615, Nov 29 2000 GOOGLE LLC Method and system for service-enablement gateway and its service portal
6925457, Jul 27 2001 OBJECTSTORE, INC Methods and apparatus for querying a relational data store using schema-less queries
6925609, Jan 31 2000 International Business Machines Corporation Hybrid task and file oriented user interface
6927728, Mar 13 2003 Google Technology Holdings LLC Method and apparatus for multi-antenna transmission
6934702, May 04 2001 Oracle America, Inc Method and system of routing messages in a distributed search network
6940917, Aug 27 2002 Qualcomm Incorporated Beam-steering and beam-forming for wideband MIMO/MISO systems
6944644, Sep 30 1998 Emrys Technologies, Ltd. Event management in a system with separate application and graphical user interface processing
6954737, Nov 05 2001 JOHNSONDIVERSEY, INC Method and apparatus for work management for facility maintenance
6956845, Sep 26 1997 Verizon Patent and Licensing Inc Integrated customer web station for web based call management
6959432, Mar 08 2001 ESCHER TECHNOLOGIES, LTD Process and system for developing mathematically validated object-oriented software
6961725, May 16 2002 Industrial Technology Research Institute Method of a data range search with plural pre-set rules
6965889, May 09 2000 HNC SOFTWARE, INC Approach for generating rules
6966033, Sep 28 2001 EMC IP HOLDING COMPANY LLC Methods and apparatus for graphically managing resources
6976144, May 06 2003 PEGASYSTEMS INC Methods and apparatus for digital data processing with mutable inheritance
6985912, Jul 22 2002 Thought, Inc.; THOUGHT, INC Dynamic object-driven database manipulation and mapping system having a simple global interface and an optional multiple user need only caching system with disable and notify features
7020869, Dec 01 2000 Progress Software Corporation Business rules user interface for development of adaptable enterprise applications
7028225, Sep 25 2001 PATH RELIABILITY, INC Application manager for monitoring and recovery of software based application processes
7031901, May 13 1998 X-ACT SCIENCE INC System and method for improving predictive modeling of an information system
7035808, Oct 20 1999 AVAYA Inc Arrangement for resource and work-item selection
7058367, Jan 31 2003 Sony Corporation Rate-adaptive methods for communicating over multiple input/multiple output wireless systems
7058637, May 15 2001 OBJECTSTORE, INC Methods and apparatus for enterprise application integration
7064766, Oct 18 2001 Microsoft Technology Licensing, LLC Intelligent caching data structure for immediate mode graphics
7073177, May 10 2001 Oracle America, Inc Resource managing system for changing resource consumption state of the lower priority resource entity to more restrictive state when resource reached critical level
7076558, Feb 27 2002 Microsoft Technology Licensing, LLC User-centric consent management system and method
7089193, May 09 2001 PROCHAIN SOLUTIONS, INC Multiple project scheduling system
7103173, Jul 09 2001 Noble Systems Corporation System and method for preemptive goals based routing of contact records
7124145, Mar 27 2003 Millennium IT (USA) Inc.; MILLENNIUM IT USA INC System and method for dynamic business logic rule integration
7139999, Aug 31 1999 Accenture Global Services Limited Development architecture framework
7143116, Aug 08 2003 Hitachi, LTD Method of controlling total disk usage amount in virtualized and unified network storage system
7171145, Dec 13 2002 Ricoh Company, Ltd. Developing device and process cartridge for an image forming apparatus
7171415, May 04 2001 Oracle America, Inc Distributed information discovery through searching selected registered information providers
7174514, Mar 28 2001 Oracle America, Inc Engine to present a user interface based on a logical structure, such as one for a customer relationship management system, across a web site
7178109, Aug 12 2003 PEGASYSTEMS INC Process/viewer interface
7194380, Feb 28 2003 PEGASYSTEMS INC Classification using probability estimate re-sampling
7289793, Dec 03 2001 Acacia Research Group LLC Method and apparatus for displaying real-time information objects between a wireless mobile user station and multiple information sources based upon event driven parameters and user modifiable object manifest
7302417, May 02 2005 Synopsys, Inc Method and apparatus for improving efficiency of constraint solving
7318020, Oct 08 2003 Microsoft Technology Licensing, LLC Methods and systems for external localization
7318066, Apr 30 2003 Michael Philip, Kaufman System and method for generating automatic user interface for arbitrarily complex or large databases
7334039, Feb 01 2002 Oracle International Corporation Techniques for generating rules for a dynamic rule-based system that responds to requests for a resource on a network
7343295, Apr 05 2000 Automated complaint resolution system
7353229, May 26 2000 EXITEXCHANGE CORPORATION, A TEXAS CORPORATION Post-session internet advertising system
7398391, Jan 23 1998 EMC Corporation Content addressable information encapsulation, representation, and transfer
7406475, Jan 09 2001 British Telecommunications public limited company Software tool for heuristic search methods
7412388, Dec 12 2003 International Business Machines Corporation Language-enhanced programming tools
7415731, Jan 23 1998 EMC IP HOLDING COMPANY LLC Content addressable information encapsulation, representation, and transfer
7505827, Nov 06 1998 Honeywell INC Automated finite capacity scheduler
7526481, Apr 19 1999 Oracle International Corporation Web servers with queryable dynamic caches
7536294, Jan 08 2002 Oracle International Corporation Method and apparatus for translating computer programs
7555645, Jan 06 2005 Oracle International Corporation Reactive audit protection in the database (RAPID)
7574494, Oct 15 1999 INTERDIGITAL CE PATENT HOLDINGS User interface for a bi-directional communication system
7596504, Aug 20 2003 International Business Machines Corporation Management of support center calls
7640222, Mar 03 2006 PEGASYSTEMS INC Rules base systems and methods with circumstance translation
7647417, Mar 15 2006 NetApp, Inc. Object cacheability with ICAP
7665063, May 26 2004 Pegasystems, Inc. Integration of declarative rule-based processing with procedural programming
7685013, Nov 04 1999 JPMorgan Chase Bank System and method for automatic financial project management
7689447, Oct 26 2005 Uber Technologies, Inc Worklist integration of logical and physical tasks
7711919, May 06 2003 Pegasystems Inc. Methods and apparatus for digital data processing with mutable inheritance
7779395, Mar 05 2004 Adobe Inc System and method for routing data
7787609, Oct 06 2005 AVAYA LLC Prioritized service delivery based on presence and availability of interruptible enterprise resources with skills
7818506, Dec 13 2002 Open Text SA ULC Method and system for cache management
7844594, Jun 18 1999 ACCESSIFY, LLC Information search, retrieval and distillation into knowledge objects
7870244, Jun 25 2002 International Business Machines Corporation Monitoring performance of applications in a distributed environment
7937690, May 23 2006 Hewlett Packard Enterprise Development LP Evaluating performance of software application
7971180, Jun 13 2007 International Business Machines Corporation Method and system for evaluating multi-dimensional project plans for implementing packaged software applications
7983895, Nov 09 2004 Daybreak Game Company LLC System and method for generating grammatically correct text strings
8001519, Jun 27 2007 International Business Machines Corporation Model driven development including aspect integration tool
8037329, Jan 31 2007 Hewlett-Packard Development Company, L.P.; HEWLETT-PACKARD DEVELOPMENT COMPANY, L P Systems and methods for determining power consumption profiles for resource users and using the profiles for resource allocation
8073802, Mar 03 2006 Pegasystems, Inc. Rules base systems and methods with circumstance translation
8250525, Mar 02 2007 PEGASYSTEMS, INC Proactive performance management for multi-user enterprise software systems
8335704, Jan 28 2005 PEGASYSTEMS INC Methods and apparatus for work management and routing
8386960, Aug 29 2008 Adobe Inc Building object interactions
8468492, Mar 30 2009 PEGASYSTEMS INC System and method for creation and modification of software applications
8479157, May 26 2004 Pegasystems Inc. Methods and apparatus for integration of declarative rule-based processing with procedural programming in a digital data-processing evironment
8516193, Mar 30 2006 PEGASYSTEMS INC Techniques for content-based caching in a computer system
8843435, Mar 12 2009 PEGASYSTEMS INC Techniques for dynamic data processing
8880487, Feb 18 2011 PEGASYSTEMS, INC Systems and methods for distributed rules processing
8924335, Mar 30 2006 PEGASYSTEMS, INC Rule-based user interface conformance methods
8959480, May 26 2004 Pegasystems Inc. Methods and apparatus for integration of declarative rule-based processing with procedural programming in a digital data-processing environment
9026733, Nov 06 2009 Pegasystems Inc. Content-based caching using a content identifier at a point in time
20010013799,
20010035777,
20010047355,
20010049682,
20010052108,
20010054064,
20020010855,
20020013804,
20020029161,
20020042831,
20020049603,
20020049715,
20020049788,
20020054152,
20020059566,
20020070972,
20020073337,
20020091677,
20020091678,
20020091710,
20020091835,
20020093537,
20020107684,
20020118688,
20020120598,
20020120627,
20020120762,
20020133502,
20020177232,
20020178232,
20020181692,
20020184610,
20030001894,
20030004934,
20030004951,
20030009239,
20030014399,
20030037145,
20030050834,
20030050927,
20030050929,
20030061209,
20030065544,
20030066031,
20030074352,
20030074369,
20030084401,
20030109951,
20030115281,
20030135358,
20030152212,
20030154380,
20030191626,
20030198337,
20030200254,
20030200371,
20030202617,
20030222680,
20030229529,
20030229544,
20040024603,
20040034651,
20040049479,
20040049509,
20040054610,
20040064552,
20040068517,
20040088199,
20040103014,
20040117759,
20040122652,
20040133416,
20040133876,
20040139021,
20040145607,
20040147138,
20040162812,
20040162822,
20040167765,
20040205672,
20040220792,
20040236566,
20040243587,
20040268221,
20040268299,
20050027563,
20050039191,
20050044198,
20050050000,
20050055330,
20050059566,
20050060372,
20050071211,
20050104628,
20050125683,
20050132048,
20050138162,
20050144023,
20050165823,
20050198021,
20050216235,
20050228875,
20050234882,
20050267770,
20050288920,
20060004845,
20060015388,
20060020783,
20060041861,
20060053125,
20060063138,
20060064486,
20060064667,
20060075360,
20060080082,
20060080401,
20060092467,
20060100847,
20060101386,
20060101393,
20060106846,
20060139312,
20060149751,
20060167655,
20060173724,
20060173871,
20060206303,
20060206305,
20060218166,
20060271559,
20060271920,
20060288348,
20070005623,
20070010991,
20070028225,
20070038765,
20070055938,
20070061789,
20070094199,
20070118497,
20070130130,
20070136068,
20070143163,
20070143851,
20070203756,
20070208553,
20070226031,
20070233902,
20070239646,
20070260584,
20070294644,
20080002823,
20080046462,
20080077384,
20080085502,
20080109467,
20080163253,
20080184230,
20080189679,
20080195377,
20080196003,
20080208785,
20080216055,
20080216060,
20080263510,
20090007084,
20090018998,
20090075634,
20090083697,
20090132232,
20090138844,
20090158407,
20090164494,
20090171938,
20090276206,
20090282384,
20100011338,
20100088266,
20100107137,
20100217737,
20120041921,
20130007267,
20130231970,
20130254833,
20140019400,
20150089406,
DE19911098,
EP549208,
EP669717,
EP996916,
EP1015997,
EP1019807,
EP1073955,
EP1073992,
EP1135723,
EP1163604,
EP1183636,
EP1196882,
EP1203310,
EP1208482,
EP1212668,
EP1240592,
EP1277102,
EP1277119,
EP1277120,
EP1277153,
EP1277155,
EP1277329,
EP1374083,
EP1382030,
EP1386241,
EP1393172,
EP1393188,
EP1402336,
EP1407384,
EP1430396,
EP1438649,
EP1438654,
EP1438672,
EP1483685,
EP1490747,
EP1490809,
EP1492232,
EP1782183,
EP1830312,
EP1840803,
EP2115581,
RE38633, May 17 1994 ENPAT, INC Automated, electronic network based, project management server system
RE39918, Apr 30 1993 STMicroelectronics, Inc. Direct current sum bandgap voltage comparator
WO33187,
WO33217,
WO33226,
WO33235,
WO33238,
WO52553,
WO52603,
WO67194,
WO140958,
WO175610,
WO175614,
WO175747,
WO175748,
WO176206,
WO177787,
WO179994,
WO2056249,
WO2080006,
WO2080015,
WO2082300,
WO2084925,
WO2088869,
WO2091346,
WO2101517,
WO2103576,
WO221254,
WO244947,
WO3021393,
WO3029923,
WO3029955,
WO3030005,
WO3030013,
WO3030014,
WO3058504,
WO3069500,
WO3071380,
WO3071388,
WO3073319,
WO3077139,
WO3085503,
WO3085580,
WO2004001613,
WO2004003684,
WO2004003766,
WO2004003885,
WO2004046882,
WO2004061815,
WO2004086197,
WO2004086198,
WO2004095207,
WO2004095208,
WO2004114147,
WO2005001627,
WO2005003888,
WO2005010645,
WO2005117549,
WO2006081536,
WO2007033922,
WO2008109441,
WO2009097384,
WO9838564,
WO9840807,
WO9905632,
WO9945465,
WO9950784,
/////
Executed onAssignorAssigneeConveyanceFrameReelDoc
Jun 02 2011CLINTON, JOHN W PEGASYSTEMS INC ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0353370194 pdf
Jun 02 2011TREFLER, ALANPEGASYSTEMS INC ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0353370194 pdf
Jun 02 2011FRENKEL, BENJAMINPEGASYSTEMS INC ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0353370194 pdf
Oct 29 2014Pegasystems Inc.(assignment on the face of the patent)
Nov 05 2019PEGASYSTEMS INC PNC Bank, National AssociationSECURITY INTEREST SEE DOCUMENT FOR DETAILS 0510160631 pdf
Date Maintenance Fee Events
Oct 07 2019M1551: Payment of Maintenance Fee, 4th Year, Large Entity.
Oct 07 2019M1554: Surcharge for Late Payment, Large Entity.
Oct 16 2023M1552: Payment of Maintenance Fee, 8th Year, Large Entity.
Oct 16 2023M1555: 7.5 yr surcharge - late pmt w/in 6 mo, Large Entity.
Oct 16 2023REM: Maintenance Fee Reminder Mailed.


Date Maintenance Schedule
Feb 23 20194 years fee payment window open
Aug 23 20196 months grace period start (w surcharge)
Feb 23 2020patent expiry (for year 4)
Feb 23 20222 years to revive unintentionally abandoned end. (for year 4)
Feb 23 20238 years fee payment window open
Aug 23 20236 months grace period start (w surcharge)
Feb 23 2024patent expiry (for year 8)
Feb 23 20262 years to revive unintentionally abandoned end. (for year 8)
Feb 23 202712 years fee payment window open
Aug 23 20276 months grace period start (w surcharge)
Feb 23 2028patent expiry (for year 12)
Feb 23 20302 years to revive unintentionally abandoned end. (for year 12)