WO2008109441A1 - Proactive performance management for multi-user enterprise software systems - Google Patents
Proactive performance management for multi-user enterprise software systems Download PDFInfo
- Publication number
- WO2008109441A1 WO2008109441A1 PCT/US2008/055503 US2008055503W WO2008109441A1 WO 2008109441 A1 WO2008109441 A1 WO 2008109441A1 US 2008055503 W US2008055503 W US 2008055503W WO 2008109441 A1 WO2008109441 A1 WO 2008109441A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- application
- users
- quotas
- classes
- consumption
- Prior art date
Links
- 238000011161 development Methods 0.000 claims abstract description 33
- 238000004519 manufacturing process Methods 0.000 claims abstract description 29
- 238000012544 monitoring process Methods 0.000 claims abstract description 23
- 230000003466 anti-cipated effect Effects 0.000 claims abstract description 6
- 238000000034 method Methods 0.000 claims description 27
- 238000012545 processing Methods 0.000 claims description 21
- 238000012360 testing method Methods 0.000 claims description 13
- 230000011664 signaling Effects 0.000 claims description 9
- 238000004891 communication Methods 0.000 claims description 7
- 230000008878 coupling Effects 0.000 claims description 5
- 238000010168 coupling process Methods 0.000 claims description 5
- 238000005859 coupling reaction Methods 0.000 claims description 5
- 230000004075 alteration Effects 0.000 claims description 4
- 230000000977 initiatory effect Effects 0.000 claims 1
- 230000008569 process Effects 0.000 description 8
- 238000010586 diagram Methods 0.000 description 4
- 230000000694 effects Effects 0.000 description 4
- 238000013459 approach Methods 0.000 description 3
- 238000013461 design Methods 0.000 description 3
- 230000006870 function Effects 0.000 description 2
- 230000007246 mechanism Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 101000606504 Drosophila melanogaster Tyrosine-protein kinase-like otk Proteins 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 239000000470 constituent Substances 0.000 description 1
- 238000012937 correction Methods 0.000 description 1
- 230000006866 deterioration Effects 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 238000007670 refining Methods 0.000 description 1
- 238000005067 remediation Methods 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 230000026676 system process Effects 0.000 description 1
- 238000013519 translation Methods 0.000 description 1
- 238000010200 validation analysis Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3409—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3438—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment monitoring of user actions
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3442—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for planning or managing the needed capacity
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3447—Performance evaluation by modeling
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2201/00—Indexing scheme relating to error detection, to error correction, and to monitoring
- G06F2201/81—Threshold
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2201/00—Indexing scheme relating to error detection, to error correction, and to monitoring
- G06F2201/86—Event-based monitoring
Definitions
- the invention pertains to digital data processing and more particularly, by way of example, to proactively managing development and performance of digital data processing applications.
- the invention can be applied, by way of example, to the design and implementation of enterprise software systems.
- an object of this invention is to provide improved methods and apparatus for digital data processing.
- a related object of the invention is to provide such methods and apparatus as facilitate the design of applications, e.g., for the enterprise.
- Yet another object of the invention is to provide such methods and apparatus as facilitate the design of right-sized and appropriately scalable applications.
- the invention provides, in some aspects, systems for proactive management of performance of a software application based on monitoring it (and/or one or more of its components) during the course of development.
- Those systems include a performance monitor that signals alerts upon determining that usage of the application (or its components) by users of like classes (or roles) may exceed quotas, when the application is placed in production mode.
- the performance monitor signals the aforementioned alerts to software application developers and/or a centralized monitoring environment. This can be done proactivcly, e.g., without requiring active querying by the developers.
- the performance monitor can, moreover, log the alerts.
- Yet further aspects of the invention provide systems as described above that include a model defining a relationship between users and resources estimated to be consumed by them during use of the application in production mode.
- Those resources can include processing capacity, memory capacity and/or network bandwidth of one or more digital data processors on which the application will execute.
- Yet still further aspects of the invention provide such systems in which the model defines quotas for usage of the application in production mode and/or one or more components thereof by users in each of one or more classes.
- Related aspects provide such systems in which the model defines such quotas on the basis of individual and multiple users in such classes.
- Still yet further aspects of the invention provide such systems in which the quotas include expected and/or maximum permitted usage of the application in production mode by users in each of one or more classes.
- the invention provides systems paralleling those described above for monitoring applications executing in a production environment. Those systems signal alerts upon determining that usage of the application (or its components) by users of like classes (or roles) exceed quotas defined for those classes. Related aspects of the invention provide such systems as limit usage of the application by users if quotas for their respective classes are exceeded.
- Further related aspects of the invention provide such systems that signal alerts upon determining that usage of the application (or its components) by users of like classes (or roles) are approaching quotas defined for those classes. Such systems can make those determinations by comparing actual usage of the application by users in each of one or more classes with expected usage for those respective classes.
- Still yet further aspects of the invention provide such systems that include sending the alerts generated during application production mode (i.e., run-time mode) to developers and/ or a centralized monitoring environment. Further related aspects of the invention include systems which log the alerts generated during application production mode.
- application production mode i.e., run-time mode
- the invention provides such systems that utilize performance histories in defining the aforementioned model and/or its constituent quotas.
- aspects of the invention provide systems as described above that utilize like models during monitoring the application (and/or one or more of its components) during both development and production mode. Related aspects of the invention provide such systems that utilize differing models during those respective modes.
- Still yet other aspects of the invention provide systems as described above in which the aforesaid model and/or monitoring of the application are also effected by a rules base executed on such an engine.
- the invention provides methods for proactive management of performance of software applications paralleling the operations of the systems described above.
- Such methods can include responding to signaling, e.g., during application development, that usage of the application (or its components) by users of like classes may exceed quotas by altering (i) implementation of the application, (ii) allocation of time for such implementation, (iii) quotas defined for the respective classes, (iv) allocation of resources to the
- Figure 1 depicts a digital data processing system and environment according to one practice of the invention
- Figure 2 depicts a flow diagram illustrating a development mode operation of a digital data processing system according to one practice of the invention.
- Figure 3 depicts a flow diagram illustrating a production mode operation of a digital data processing system according to one practice of the invention.
- Figure 1 depicts a system 10 and environment for proactively managing performance of a software application 34, particularly, for example, a multi-user enterprise application, according to one practice of the invention.
- system 10 executes on exemplary digital data processor 12, which may be a personal computer, workstation, mainframe, or other digital data processing apparatus of the type known in the art capable of executing applications, programs and/or processes.
- Illustrated digital data processor 12 executes in a network environment of the type typical in a business enterprise, e.g., one including further digital data processors 20 - 30 — which themselves may comprise personal computers, workstations, mainframes, or other digital data processing apparatus. In other embodiments, digital data processor 12 may operate alone or in other environments, networked or otherwise. In any event, illustrated digital data processors 20 - 30 are coupled to digital data processor 12 via a network 32, such as the Internet, a local-area network (LAN), wide-area network (WAN), or otherwise, that may be public, private, IP-based, etc.
- LAN local-area network
- WAN wide-area network
- data processors 20 - 24 are used in development mode, e.g., by software engineers, test engineers, systems administrators, etc. (collectively, "developers") to develop, test and maintain/or software application 34.
- data processors 26 - 30 are employed by users to execute instantiations of the application 34.
- digital data processor 12 assumes both roles for sake of simplicity of discussion — i.e., it is treated as if used by developers to develop, test and maintain the application, as well as by users to execute the application.
- Illustrated digital data processor 12 includes rules base 40 constructed and accessed in the conventional manner known in the art of rules bases.
- the digitally encoded rules 41 that it contains arc likewise formatted and stored in the conventional manner known in the art.
- An example of the structure, operation and use of the rules base 40 and rules 41 is provided in commonly assigned United States Patent No. 5,826,250, entitled “Rules Bases and Methods of Access Thereof and United States Patent Application Serial No. 11/368,360, filed March 3, 2006, entitled “Rules Base Systems and Methods with Circumstance Translation,” the teachings of both of which are incorporated herein by reference.
- Illustrated digital data processor 12 also includes rules engine 42 of the type conventionally known in the art for use in processing rules, e.g., retrieved from a rules base 40, in order to respond to (or otherwise handle) events signaled to and/or detected by the engine 42.
- rules engine 42 of the type conventionally known in the art for use in processing rules, e.g., retrieved from a rules base 40, in order to respond to (or otherwise handle) events signaled to and/or detected by the engine 42.
- Illustrated digital data processor 12 further includes a software development environment (SDE) 51 that facilitates development of rules-based (or other) applications, e.g., application 34.
- SDE software development environment
- This may include a text editor, an interpreter/compiler, libraries, or otherwise — all of the type known in the ai_g_ . adapted in accord with the teachings hereof.
- the SDE 51 may, itself, be comp f rules that execute on engine 42, or otherwise.
- system 10 includes a resource model (or simply "model”) 44 and a performance monitor 36.
- Resource model 44 which in the illustrated embodiment executes on rules engine 42, comprises a set of rules 45 which, by way of non-limiting example, defines and models relationships between users (given their respective roles, as described herein) and resources estimated to be consumed by them (as well, optionally, as those actually consumed by them) during use of the application 34 in production mode.
- model 44 comprises rules 45 that are executed on engine 42, in other embodiments the model 44 may be defined and/or executed otherwise. In instances, such as the illustrated embodiment, where the model 44 is defined by rules 45, those rules can provide functionality attributed to the model below (and elsewhere herein), though, in other embodiments, that functionality can be incorporated in other elements of the system (e.g., the performance monitor 36). Consistent with the remarks above, though model 44 is shown as executing on digital data processor 12, it will be appreciated that, like application 34, it may execute on or over multiple digital data processors.
- Performance monitor 36 also executing on rules engine 42, comprises a set of rules 55, which are in communications coupling with the application 34 (e.g., via RPC or otherwise) and which monitor the application in order to, inter alia, (i) signal alerts if predicted (or actual) usage of the application or its components by users of like classes may (or does) exceed quotas, and/or (ii) limit usage of the application or its components by users if quotas for their respective classes are approached, met or exceeded.
- such monitoring is performed in real-time and persistently, so as to afford developers, users and others (e.g., system administrators) proactive and immediate feedback regarding expected or actual application performance.
- such proactive and up-to-date feedback is achieved by monitoring the application aftcr-thc-fact, e.g., following each compilation, build and/or run of the application 34, at the end of each work day, et cetera.
- monitoring the application refers to monitoring not only the application 24 in development and/or production modes, but also monitoring resources (e.g., processor capacity, network bandwidth, disk storage, etc.) impacted by the application. In this manner, the performance monitor 36 helps insure that performance of the application will meet or exceed expectations/specifications.
- resources e.g., processor capacity, network bandwidth, disk storage, etc.
- performance monitor 36 is defined by rules 55 that are executed on engine 42, though, in other embodiments the monitor 36 may be defined and/or executed otherwise. Moreover, though performance monitor 36 is shown as executing on digital data processor 12, it will be appreciated that, like application 34, it may execute on or over multiple digital data processors.
- Illustrated application 34 also executing on the rules engine 42, comprises a set of rules 53 defining one or more software applications written, tested and revised by developers and executed by users.
- a software application 34 can be a multi-user enterprise software system (e.g., business process management application), and the like.
- the application 34 can comprise one or more components, modules, systems, and so forth (collectively, "components"), as is common in the art.
- application 34 is defined by rules 53 that are executed on engine 42, in other embodiments the application 34 may be defined and/or executed otherwise.
- development mode activity by developers with respect to an application (e.g., in writing, testing and revising the application) is referred to as “development mode.”
- production mode activity by users (e.g., in running the application) is referred to as “production mode.”
- development mode precedes production mode in the application life cycle, the term development mode can include subsequent activity — as where developers revise an application to fix "bugs," add new functionality, etc.
- resource model 44 models a relationship between users (given their respective roles) and their estimated (and, optionally, actual) consumption of resources in connection with application 34. It is used with the performance monitor 36 to gauge expected or actual resource consumption during development and production modes of the application 34 — and, specifically, to insure that consumption falls within defined quotas — and, thereby to insure adequate performance.
- illustrated model 44 defines user roles or classes for anticipated (or actual) application users. These can include, for example, general classes, like “power user” and “limited user,” and/or specific classes, like “sales executive,” “phone operator,” and so forth.
- the model can, further, assign actual or expected users to specific ones of these classes.
- the model 44 may be supplemented or supplanted in each of these functions by other elements of the Lsystem 10, digital data processor 12, or otherwise.
- the model can define user roles/classes and assign specific users to those classes based on look-up tables contained elsewhere on the digital data processor (e.g., operating system user tables).
- Illustrated model 44 further defines, on the basis of user roles, consumption quotas 46, 47 for use of resources by application 34.
- Those resources can include, by way of example, processor, memory, input/output, communications, network or other resources of the digital data processor 12 and/or network (or other) environment on which the application 34 operates.
- the quotas 46, 47 can include both maximum and expected figures. More particularly, for example, the quotas 46, 47 can include, for each of at least selected resources, (1) maximum system resource consumption 46 for a user (or users) in a given role/class, and/or (2) expected system resource consumption 47 for a user (or users) in a given role/class.
- maximum resource consumption quotas 46 can indicate that (i) an individual user of the limited class is permitted to consume no more than 0.2 percent of the processor capacity, peak, and (ii) 200 kbytes/sec on the network, peak, during use of the application.
- maximum quotas 46 can indicate that (i) all simultaneous users of the limited class are permitted to consume no more than 15 percent of processor capacity, peak, and (ii) 3 Mbytes/sec on the network, peak, during use of the application.
- expected resource consumption quotas 47 can indicate that (i) an individual user of the limited class is permitted to consume no more than 0.1 percent of processor capacity, on average, and (ii) 10 kbytes/sec on the network, on average, during use of the application.
- quotas 46 can indicate that (i) all simultaneous users of the limited class are permitted to consume 5 percent of processor capacity, on average, and (ii) 1 Mbytes/sec on the network, on average, during use of the application.
- the expected system resource consumption quota 47 is lower than quota 46, and is utilized to alert developers, system administrators, etc., that an execution or interaction by a given user or developer is approaching the respective user role's maximum allowed resource consumption quota 47.
- This two-tier quota system is used in the illustrated embodiment, for example, to give developers advanced warning of possible performance deterioration, thereby giving them ample opportunity to address the problem (e.g., changing the implementation). Though only two quotas per resource — maximum 46 and expected 47 — are discussed here, in alternative embodiments, a lesser or greater number of quotas may be employed.
- the model further defines quotas 48, 49 for the numbers of users of each class that are simultaneously permitted to use the application itself and/or its components (collectively, "application,” unless indicated otherwise).
- application two quotas are provided in the illustrated embodiment: a maximum number 48 of users per respective class, and an expected number 49 of users per expected class.
- quotas may be alternatively defined, e.g., the model might define that application 34 can be used by 500 simultaneous users, 20 of who can be power users.
- a lesser or greater number of quotas may be employed
- model 44 models (e.g., predicts) how use of the application 34 and its components by users, e.g., of given classes, relates to resource consumption.
- a simple model 44 might define the following "user consumption relationships":
- execution of subsystem X of the application by user of the "power” class additionally consumes 0.5 percent of the processor capacity and transmits 40 kbytes/ sec on the network execution of subsystem Y of the application by a user of the "limited” class additionally consumes 0.35 percent of the processor capacity and transmits 100 kbytes/sec on the network execution of subsystem Y of the application by user of the "power” class additionally consumes 0.6 percent of the processor capacity and transmits 150 kbytes/sec on the network.
- the model can predict — given specifics of the application 34 (e.g., number of remote calls made, disk usage, memory requirements, etc.) — whether the resource consumption quotas (and, therefore, expected performance) will be exceeded when the application is executed by, individual, expected and/or maximum numbers of users in each class.
- the performance monitor 46 can make use of this to gather application specifics, apply them to the model 44 and report quota violations to the developer, e.g., by the alert mechanism discussed below.
- the predicative capabilities of the model 44 need not be used (though, they may be, in some embodiments). Rather, in that mode, the performance monitor 46 can gather actual statistics about resource consumption and compare them against quotas maintained in the model, again, reporting, violations to the developer, system administrator, etc. — or, limiting execution of the application to specific numbers/types of users.
- the quotas 46 - 49 form part of the rules base 45 defined by the developer, his/her project manager and/or other persons involved in defining the requirements for application 34 (collectively, the "project manager").
- the model 44 can utilize and/or incorporate performance histories that are, for example, gathered by the performance monitor 36 during production mode (e.g., in connection with the alerts discussed below) and/or collected from logs on the digital data processor 12, networking system, or otherwise.
- the model utilizes the historical performance information to update the rules 45 that reflect "user consumption relationships.” Operation
- FIG. 2 is a flow diagram depicting the operation of system 10 in development mode.
- developers create, test and/or revise software application 34 in the conventional manner, e.g., using SDE 51.
- rules engine 42 executes rules 53 defining the application 34, and developers modify those rules 53 (or add new rules) within the SDE 51 (e.g., via a text editor or other component of the SDE 51) in order, for example, to alter the functionality and/or performance characteristics of application 34.
- the performance monitor 36 monitors the SDE 51, e.g., in real-time (for example, while the developer enters lines of code, issue commands for validation and/or compilation of modules, and/or save modules to disk or a software repository) or responds to direct invocation by the developers, to test the application-in-development against the model 44 to ensure that performance will meet or exceed expectations/ specifications when it is deployed (i.e., enters production mode).
- the performance monitor 36 obtains from the SDE 51 specifics of the application 34 (e.g., as noted above, number of remote calls made, disk usage, memory requirements, etc.) and applies them to the model by way of function calls or otherwise.
- the model 44 and, more particularly, the rules 45 that represent it, execute on the rules engine 30 and determine whether the resource consumption quotas will be exceeded (and, therefore, expected performance not achieved), given the specifics provided.
- the model 44 can report quota violations to the SDE 51 which, in turn, can alert the developer.
- the model 44 generates results directly to the developer.
- the reported quota violations can include identification of quota violated, measure of expected violations, etc., and, thereby, facilitate correction of the application by the developer and/or modification of quotas by the project manager, as reflected in steps 270, 280.
- the developer and/or product manager can respond to such alerts by (i) allocating additional time for implementation of the application (or fixes thereto), (ii) allocating additional resources to the application, and/or (iii) refining the "user consumption relationships" defined by the model. Additionally, such alerts can motivate personnel responsible for development, management and/or procurement of the application to communicate in regard to potential implementation and/or alteration of the application, the model, or otherwise.
- the performance monitor 36 signals the developer with a high-priority alert or warning (e.g., a "red light” warning). This can take the form of, for example, a pop-up window on a developer's screen/terminal 20 - 24, an email to a developer, and so forth.
- a high-priority alert or warning e.g., a "red light” warning.
- the performance monitor 36 signals the developer with a low-priority alert or warning (e.g., a "yellow light” warning).
- alert categories e.g., high-priority, low-priority, etc.
- alerts may be signaled by other and/or additional mechanisms to those mentioned above.
- alerts are sent to are signals not only to developers but also to a log and/or a centralized monitoring environment, e.g., a database maintained by project manager(s) or other personnel responsible for development of application 34. This facilitates identifying and categorizing alerts, e.g., to improve overall developer and application performance.
- Operation of system 10 in production mode parallels that of operation during development mode.
- the rules engine 42, resource model 44, and performance monitor 36 operate in the manner described above, e.g., in connection with Figure 2.
- application 34 has "gone live,” and the predictive capabilities of the model 44 need not be used. Rather, the performance monitor 36 monitors actual use of the application 34 and resource consumed by it.
- the "specifics" applied to the model 44 by the monitor 36 in production mode are actual statistics about resource consumption by actual users.
- FIG. 3 is a flow diagram illustrating operation of system 10 during production mode. Steps 300 - 350 parallel steps 200 - 250 in Figure 2.
- the monitor 36 sends "red light” and/or "yellow light” alert(s) 38 to developers, project managers, systems administrators, or other personnel (and, where appropriate, to end-users) depending on whether actual usage violates a maximum quota 46, 48 or an expected quota 47, 49.
- the violations in production mode can (unlike development mode) include violations of the expected and maximum user quotas 48, 49.
- the alerts 38 can also be logged to the centralized monitoring environment.
- the resource model 44 may utilize performance histories to facilitate entry of quotas and definition of rules defining "user consumption relationships.” To this end, the alerts can be logged for access by the model 44 and/or they can effect logging of detailed performance statistics which may also be accessed by the model.
- the monitor 36 can limit usage of the application 34 by one or more users upon determining that usage (individual or collective) violates one or more quotas (typically, maximum consumption quotas 46). This can be effected, e.g., when a red light warning condition has been signaled, by preventing additional users from executing the application and/or by terminating the processes of one or more offending users. See step 360.
Landscapes
- Engineering & Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- Quality & Reliability (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Debugging And Monitoring (AREA)
- Stored Programmes (AREA)
Abstract
The invention provides, in some aspects, systems for proactive management of development and performance of a software application based on monitoring it (and/or one or more of its components) during the course of development or execution. Those systems signal alerts upon determining that actual or expected usage of the application (or its components) by users of like classes (or roles) is anticipated to, or does, exceed quotas, when the application is placed in production mode.
Description
Proactive Performance Management for Multi-User Enterprise Software Systems
Background of the Invention
The invention pertains to digital data processing and more particularly, by way of example, to proactively managing development and performance of digital data processing applications. The invention can be applied, by way of example, to the design and implementation of enterprise software systems.
Enterprise software systems routinely fail to process transactions quickly enough to satisfy business needs, especially as the number of users and intensity of processing increases. It has traditionally been difficult to "spec out" requirements for new software projects that would avoid these scalability and performance issues, since application development itself introduces much variability. In addition, original assumptions about the scalability of a system frequently turn out to be invalid. This is exacerbated by changing user requirements.
The end result is often that an application completed by a developer has performance and scaling characteristics that differ significantly from the customer's needs. In order to remedy this, the "completed" application can be sent back for further development — which starts a vicious cycle. Alternatively, it may be necessary to buy significantly more computer hardware to run the application and, thereby, create a conflict with the original budget.
A related problem exists after the application has moved into production. Unanticipated resource consumption by some users or system processes may result in the entire system or application becoming non-responsive.
It is a common expectation that enterprise software vendors provide performance guidelines that ensure a certain number of users can be supported on a given capacity platform. This approach offers a false sense of security, since, in reality, there is a great amount of variability in the application development process that invalidates the vendor's assumptions.
To accommodate this, customers can test the performance of applications at the end of the development process by simulating a large number of users and measuring application response. A drawback here is that, by the time a performance problem is discovered, remediation may involve significant expense, e.g., buying new hardware, sending the application back to development, redefining the specification for the project, and so forth.
It is possible to test the performance of the application concurrently with the development process. However, this requires a dedicated set of human and computer resources. It is also difficult to test the developmental application, except at certain milestones when it is stable. If the performance results are unsatisfactory, or significantly different from original assumptions, any attempts to remediate are likely to interfere with the development process and to throw development off-track.
Another approach is to perform a detailed analysis of a system's or application's behavior with a single user and then project how the system will behave as the number of users increases; see, United States Patent Publication No. 2005/0216235, entitled "Scalability Test and Analysis"). This approach suffers from the same limitations as above, e.g., it requires a completed application to measure and project performance.
In view of the foregoing, an object of this invention is to provide improved methods and apparatus for digital data processing.
A related object of the invention is to provide such methods and apparatus as facilitate the design of applications, e.g., for the enterprise.
Yet another object of the invention is to provide such methods and apparatus as facilitate the design of right-sized and appropriately scalable applications.
Summary of the Invention
The foregoing are among the objects attained by the invention which provides, in some aspects, systems for proactive management of performance of a software application based on monitoring it (and/or one or more of its components) during the course of development. Those systems include a performance monitor that signals alerts upon determining that usage of the application (or its components) by users of like classes (or roles) may exceed quotas, when the application is placed in production mode.
Further aspects of the invention provide such systems in which the performance monitor signals the aforementioned alerts to software application developers and/or a centralized monitoring environment. This can be done proactivcly, e.g., without requiring active querying by the developers. The performance monitor can, moreover, log the alerts.
Yet further aspects of the invention provide systems as described above that include a model defining a relationship between users and resources estimated to be consumed by them during use of the application in production mode. Those resources can include processing capacity, memory capacity and/or network bandwidth of one or more digital data processors on which the application will execute.
Yet still further aspects of the invention provide such systems in which the model defines quotas for usage of the application in production mode and/or one or more components thereof by users in each of one or more classes. Related aspects provide such systems in which the model defines such quotas on the basis of individual and multiple users in such classes.
Still yet further aspects of the invention provide such systems in which the quotas include expected and/or maximum permitted usage of the application in production mode by users in each of one or more classes.
In other aspects, the invention provides systems paralleling those described above for monitoring applications executing in a production environment. Those systems signal alerts upon determining that usage of the application (or its components) by users of like classes (or
roles) exceed quotas defined for those classes. Related aspects of the invention provide such systems as limit usage of the application by users if quotas for their respective classes are exceeded.
Further related aspects of the invention provide such systems that signal alerts upon determining that usage of the application (or its components) by users of like classes (or roles) are approaching quotas defined for those classes. Such systems can make those determinations by comparing actual usage of the application by users in each of one or more classes with expected usage for those respective classes.
Still yet further aspects of the invention provide such systems that include sending the alerts generated during application production mode (i.e., run-time mode) to developers and/ or a centralized monitoring environment. Further related aspects of the invention include systems which log the alerts generated during application production mode.
In other aspects, the invention provides such systems that utilize performance histories in defining the aforementioned model and/or its constituent quotas.
Other aspects of the invention provide systems as described above that utilize like models during monitoring the application (and/or one or more of its components) during both development and production mode. Related aspects of the invention provide such systems that utilize differing models during those respective modes.
Still yet other aspects of the invention provide systems as described above in which the aforesaid model and/or monitoring of the application are also effected by a rules base executed on such an engine.
In yet still other aspects, the invention provides methods for proactive management of performance of software applications paralleling the operations of the systems described above. Such methods can include responding to signaling, e.g., during application development, that usage of the application (or its components) by users of like classes may exceed quotas by altering (i) implementation of the application, (ii) allocation of time for such implementation, (iii) quotas defined for the respective classes, (iv) allocation of resources to the
- A -
application, and/or (v) definition of the relationships defined in the model. Tn related aspects of the invention, personnel responsible for development, management and/or procurement of the application can respond to such signaling by communicating with one another in regard to potential implementation of one or more such alterations. Further related aspects of the invention include modifying the model to reflect such alterations.
These and other aspects of the invention are evident in the drawings and in the description that follows.
Brief Description of the Illustrated Embodiment
A more complete understanding of the invention may be attained by reference to the drawings, in which:
Figure 1 depicts a digital data processing system and environment according to one practice of the invention;
Figure 2 depicts a flow diagram illustrating a development mode operation of a digital data processing system according to one practice of the invention; and
Figure 3 depicts a flow diagram illustrating a production mode operation of a digital data processing system according to one practice of the invention.
Detailed Description of the Illustrated Embodiment
Architecture
Figure 1 depicts a system 10 and environment for proactively managing performance of a software application 34, particularly, for example, a multi-user enterprise application, according to one practice of the invention. In the illustrated embodiment, system 10 executes on exemplary digital data processor 12, which may be a personal computer, workstation, mainframe, or other digital data processing apparatus of the type known in the art capable of executing applications, programs and/or processes.
Illustrated digital data processor 12 executes in a network environment of the type typical in a business enterprise, e.g., one including further digital data processors 20 - 30 — which themselves may comprise personal computers, workstations, mainframes, or other digital data processing apparatus. In other embodiments, digital data processor 12 may operate alone or in other environments, networked or otherwise. In any event, illustrated digital data processors 20 - 30 are coupled to digital data processor 12 via a network 32, such as the Internet, a local-area network (LAN), wide-area network (WAN), or otherwise, that may be public, private, IP-based, etc.
In a typical embodiment, illustrated here, data processors 20 - 24 are used in development mode, e.g., by software engineers, test engineers, systems administrators, etc. (collectively, "developers") to develop, test and maintain/or software application 34. Likewise, data processors 26 - 30 are employed by users to execute instantiations of the application 34. In the discussion that follows, digital data processor 12 assumes both roles for sake of simplicity of discussion — i.e., it is treated as if used by developers to develop, test and maintain the application, as well as by users to execute the application. Moreover, it is also assumed for sake of simplicity of discussion that application 34 executes on a single digital data processor; however, in practice, the application 34 may execute on or over multiple digital data processors (e.g., in client-server mode, peer-to-peer mode, etc.).
Illustrated digital data processor 12 includes rules base 40 constructed and accessed in the conventional manner known in the art of rules bases. The digitally encoded rules 41 that it contains arc likewise formatted and stored in the conventional manner known in the art. An example of the structure, operation and use of the rules base 40 and rules 41 is provided in commonly assigned United States Patent No. 5,826,250, entitled "Rules Bases and Methods of Access Thereof and United States Patent Application Serial No. 11/368,360, filed March 3, 2006, entitled "Rules Base Systems and Methods with Circumstance Translation," the teachings of both of which are incorporated herein by reference.
Illustrated digital data processor 12 also includes rules engine 42 of the type conventionally known in the art for use in processing rules, e.g., retrieved from a rules base 40, in order to respond to (or otherwise handle) events signaled to and/or detected by the engine 42.
Illustrated digital data processor 12 further includes a software development environment (SDE) 51 that facilitates development of rules-based (or other) applications, e.g., application 34. This may include a text editor, an interpreter/compiler, libraries, or otherwise — all of the type known in the ai_g_ . adapted in accord with the teachings hereof. The SDE 51 may, itself, be comp f rules that execute on engine 42, or otherwise.
With continued reference to Figure 1, system 10 includes a resource model (or simply "model") 44 and a performance monitor 36. Resource model 44, which in the illustrated embodiment executes on rules engine 42, comprises a set of rules 45 which, by way of non-limiting example, defines and models relationships between users (given their respective roles, as described herein) and resources estimated to be consumed by them (as well, optionally, as those actually consumed by them) during use of the application 34 in production mode.
Though, in the illustrated embodiment, model 44 comprises rules 45 that are executed on engine 42, in other embodiments the model 44 may be defined and/or executed otherwise. In instances, such as the illustrated embodiment, where the model 44 is defined by rules 45, those rules can provide functionality attributed to the model below (and elsewhere herein),
though, in other embodiments, that functionality can be incorporated in other elements of the system (e.g., the performance monitor 36). Consistent with the remarks above, though model 44 is shown as executing on digital data processor 12, it will be appreciated that, like application 34, it may execute on or over multiple digital data processors.
Performance monitor 36, also executing on rules engine 42, comprises a set of rules 55, which are in communications coupling with the application 34 (e.g., via RPC or otherwise) and which monitor the application in order to, inter alia, (i) signal alerts if predicted (or actual) usage of the application or its components by users of like classes may (or does) exceed quotas, and/or (ii) limit usage of the application or its components by users if quotas for their respective classes are approached, met or exceeded. In the illustrated embodiment, such monitoring is performed in real-time and persistently, so as to afford developers, users and others (e.g., system administrators) proactive and immediate feedback regarding expected or actual application performance. In other embodiments, such proactive and up-to-date feedback is achieved by monitoring the application aftcr-thc-fact, e.g., following each compilation, build and/or run of the application 34, at the end of each work day, et cetera.
As used herein, the phrase "monitoring the application" refers to monitoring not only the application 24 in development and/or production modes, but also monitoring resources (e.g., processor capacity, network bandwidth, disk storage, etc.) impacted by the application. In this manner, the performance monitor 36 helps insure that performance of the application will meet or exceed expectations/specifications.
As above, in the illustrated embodiment, performance monitor 36 is defined by rules 55 that are executed on engine 42, though, in other embodiments the monitor 36 may be defined and/or executed otherwise. Moreover, though performance monitor 36 is shown as executing on digital data processor 12, it will be appreciated that, like application 34, it may execute on or over multiple digital data processors.
Illustrated application 34, also executing on the rules engine 42, comprises a set of rules 53 defining one or more software applications written, tested and revised by developers
and executed by users. By way of non-limiting example, such a software application 34 can be a multi-user enterprise software system (e.g., business process management application), and the like. Moreover, the application 34 can comprise one or more components, modules, systems, and so forth (collectively, "components"), as is common in the art. Though, in the illustrated embodiment, application 34 is defined by rules 53 that are executed on engine 42, in other embodiments the application 34 may be defined and/or executed otherwise.
As used herein, activity by developers with respect to an application (e.g., in writing, testing and revising the application) is referred to as "development mode." Activity by users (e.g., in running the application) is referred to as "production mode." Although, in the typical application, development mode precedes production mode in the application life cycle, the term development mode can include subsequent activity — as where developers revise an application to fix "bugs," add new functionality, etc.
Resource Model
As noted, resource model 44 models a relationship between users (given their respective roles) and their estimated (and, optionally, actual) consumption of resources in connection with application 34. It is used with the performance monitor 36 to gauge expected or actual resource consumption during development and production modes of the application 34 — and, specifically, to insure that consumption falls within defined quotas — and, thereby to insure adequate performance.
To this end, illustrated model 44 defines user roles or classes for anticipated (or actual) application users. These can include, for example, general classes, like "power user" and "limited user," and/or specific classes, like "sales executive," "phone operator," and so forth. The model can, further, assign actual or expected users to specific ones of these classes. The model 44 may be supplemented or supplanted in each of these functions by other elements of the Lsystem 10, digital data processor 12, or otherwise. Thus, for example, the model can define user roles/classes and assign specific users to those classes based on look-up tables contained elsewhere on the digital data processor (e.g., operating system user tables).
Illustrated model 44 further defines, on the basis of user roles, consumption quotas 46, 47 for use of resources by application 34. Those resources can include, by way of example, processor, memory, input/output, communications, network or other resources of the digital data processor 12 and/or network (or other) environment on which the application 34 operates. In the illustrated embodiment, the quotas 46, 47 can include both maximum and expected figures. More particularly, for example, the quotas 46, 47 can include, for each of at least selected resources, (1) maximum system resource consumption 46 for a user (or users) in a given role/class, and/or (2) expected system resource consumption 47 for a user (or users) in a given role/class.
As an example, maximum resource consumption quotas 46 can indicate that (i) an individual user of the limited class is permitted to consume no more than 0.2 percent of the processor capacity, peak, and (ii) 200 kbytes/sec on the network, peak, during use of the application. Alternatively, or in addition, maximum quotas 46 can indicate that (i) all simultaneous users of the limited class are permitted to consume no more than 15 percent of processor capacity, peak, and (ii) 3 Mbytes/sec on the network, peak, during use of the application.
Similarly, by way of example, expected resource consumption quotas 47 can indicate that (i) an individual user of the limited class is permitted to consume no more than 0.1 percent of processor capacity, on average, and (ii) 10 kbytes/sec on the network, on average, during use of the application. Alternatively, or in addition, quotas 46 can indicate that (i) all simultaneous users of the limited class are permitted to consume 5 percent of processor capacity, on average, and (ii) 1 Mbytes/sec on the network, on average, during use of the application.
Typically, the expected system resource consumption quota 47 is lower than quota 46, and is utilized to alert developers, system administrators, etc., that an execution or interaction by a given user or developer is approaching the respective user role's maximum allowed resource consumption quota 47. This two-tier quota system is used in the illustrated embodiment, for example, to give developers advanced warning of possible performance deterioration, thereby giving them ample opportunity to address the problem (e.g., changing the implementation). Though only two quotas per resource — maximum 46 and expected 47 — are
discussed here, in alternative embodiments, a lesser or greater number of quotas may be employed.
The model further defines quotas 48, 49 for the numbers of users of each class that are simultaneously permitted to use the application itself and/or its components (collectively, "application," unless indicated otherwise). As above, two quotas are provided in the illustrated embodiment: a maximum number 48 of users per respective class, and an expected number 49 of users per expected class. Those skilled in the art will appreciate the such quotas may be alternatively defined, e.g., the model might define that application 34 can be used by 500 simultaneous users, 20 of who can be power users. As above, though only two quotas per class — maximum 48 and expected 49 — are discussed here, in alternative embodiments, a lesser or greater number of quotas may be employed
Still further, the model 44 models (e.g., predicts) how use of the application 34 and its components by users, e.g., of given classes, relates to resource consumption. In this regard, a simple model 44 might define the following "user consumption relationships":
• each user (regardless of class) executing the application consumes 0.1 percent of the processor capacity and transmits 10 kbytes/sec on the network
• execution of subsystem X of the application by a user of the "limited" class additionally consumes 0.3 percent of the processor capacity and transmits 30 kbytes/ sec on the network
• execution of subsystem X of the application by user of the "power" class additionally consumes 0.5 percent of the processor capacity and transmits 40 kbytes/ sec on the network execution of subsystem Y of the application by a user of the "limited" class additionally consumes 0.35 percent of the processor capacity and transmits 100 kbytes/sec on the network execution of subsystem Y of the application by user of the "power" class additionally consumes 0.6 percent of the processor capacity and transmits 150 kbytes/sec on the network.
Tn view of the foregoing, it will be appreciated that the model can predict — given specifics of the application 34 (e.g., number of remote calls made, disk usage, memory requirements, etc.) — whether the resource consumption quotas (and, therefore, expected performance) will be exceeded when the application is executed by, individual, expected and/or maximum numbers of users in each class. During development mode of the application 34, the performance monitor 46 can make use of this to gather application specifics, apply them to the model 44 and report quota violations to the developer, e.g., by the alert mechanism discussed below.
During production mode, the predicative capabilities of the model 44 need not be used (though, they may be, in some embodiments). Rather, in that mode, the performance monitor 46 can gather actual statistics about resource consumption and compare them against quotas maintained in the model, again, reporting, violations to the developer, system administrator, etc. — or, limiting execution of the application to specific numbers/types of users.
In the illustrated embodiment, the quotas 46 - 49 form part of the rules base 45 defined by the developer, his/her project manager and/or other persons involved in defining the requirements for application 34 (collectively, the "project manager"). To facilitate this, particularly, in regard to development work on new versions and/or modifications of application 34, the model 44 can utilize and/or incorporate performance histories that are, for example, gathered by the performance monitor 36 during production mode (e.g., in connection with the alerts discussed below) and/or collected from logs on the digital data processor 12, networking system, or otherwise. This can be achieved, for example, by execution of rules in the rules base 45 that periodically, on demand, or otherwise, identify those logs and extract relevant records for storage, e.g., in the model, and display or permit query by the project manager when new quotas are being defined. In preferred embodiments, the model utilizes the historical performance information to update the rules 45 that reflect "user consumption relationships."
Operation
Figure 2 is a flow diagram depicting the operation of system 10 in development mode. In step 200, developers create, test and/or revise software application 34 in the conventional manner, e.g., using SDE 51. In the illustrated embodiment, rules engine 42 executes rules 53 defining the application 34, and developers modify those rules 53 (or add new rules) within the SDE 51 (e.g., via a text editor or other component of the SDE 51) in order, for example, to alter the functionality and/or performance characteristics of application 34.
In step 210, the performance monitor 36 monitors the SDE 51, e.g., in real-time (for example, while the developer enters lines of code, issue commands for validation and/or compilation of modules, and/or save modules to disk or a software repository) or responds to direct invocation by the developers, to test the application-in-development against the model 44 to ensure that performance will meet or exceed expectations/ specifications when it is deployed (i.e., enters production mode).
To this end, the performance monitor 36 obtains from the SDE 51 specifics of the application 34 (e.g., as noted above, number of remote calls made, disk usage, memory requirements, etc.) and applies them to the model by way of function calls or otherwise. The model 44 and, more particularly, the rules 45 that represent it, execute on the rules engine 30 and determine whether the resource consumption quotas will be exceeded (and, therefore, expected performance not achieved), given the specifics provided.
As reflected in steps 220 — 280, the model 44 can report quota violations to the SDE 51 which, in turn, can alert the developer. In other embodiments, the model 44 generates results directly to the developer. Regardless, the reported quota violations can include identification of quota violated, measure of expected violations, etc., and, thereby, facilitate correction of the application by the developer and/or modification of quotas by the project manager, as reflected in steps 270, 280.
Alternatively, or additionally, the developer and/or product manager can respond to such alerts by (i) allocating additional time for implementation of the application (or fixes thereto), (ii) allocating additional resources to the application, and/or (iii) refining the "user consumption relationships" defined by the model. Additionally, such alerts can motivate personnel responsible for development, management and/or procurement of the application to communicate in regard to potential implementation and/or alteration of the application, the model, or otherwise.
As illustrated in steps 220, 240, when the model detects violation of a maximum resource quota 46, the performance monitor 36 signals the developer with a high-priority alert or warning (e.g., a "red light" warning). This can take the form of, for example, a pop-up window on a developer's screen/terminal 20 - 24, an email to a developer, and so forth. Alternatively, as illustrated in steps 230, 250, when the model detects violation of an expected resource quota 47, the performance monitor 36 signals the developer with a low-priority alert or warning (e.g., a "yellow light" warning). Again, this can take the form of, for example, a pop-up window on a developer's screen/terminal 20 - 24, an email to a developer, and so forth. In the illustrated embodiment, alert categories (e.g., high-priority, low-priority, etc.) are associated with the alerts to reflect the importance of the anticipated quota violation; in other embodiments additional and/or other categories may be used. Likewise, alerts may be signaled by other and/or additional mechanisms to those mentioned above.
In preferred embodiments, alerts are sent to are signals not only to developers but also to a log and/or a centralized monitoring environment, e.g., a database maintained by project manager(s) or other personnel responsible for development of application 34. This facilitates identifying and categorizing alerts, e.g., to improve overall developer and application performance.
Operation of system 10 in production mode (i.e., run-time execution of application 34) parallels that of operation during development mode. Generally, the rules engine 42, resource model 44, and performance monitor 36 operate in the manner described above, e.g., in connection with Figure 2. In production mode, however, application 34 has "gone live," and the predictive capabilities of the model 44 need not be used. Rather, the performance monitor
36 monitors actual use of the application 34 and resource consumed by it. Thus, the "specifics" applied to the model 44 by the monitor 36 in production mode are actual statistics about resource consumption by actual users.
Figure 3 is a flow diagram illustrating operation of system 10 during production mode. Steps 300 - 350 parallel steps 200 - 250 in Figure 2. For example, in step 340 and 350, the monitor 36 sends "red light" and/or "yellow light" alert(s) 38 to developers, project managers, systems administrators, or other personnel (and, where appropriate, to end-users) depending on whether actual usage violates a maximum quota 46, 48 or an expected quota 47, 49. Note, that the violations in production mode can (unlike development mode) include violations of the expected and maximum user quotas 48, 49. As above, the alerts 38 can also be logged to the centralized monitoring environment. Also as noted, the resource model 44 (or performance monitor 36, etc.) may utilize performance histories to facilitate entry of quotas and definition of rules defining "user consumption relationships." To this end, the alerts can be logged for access by the model 44 and/or they can effect logging of detailed performance statistics which may also be accessed by the model.
In production mode, unlike development mode, the monitor 36 can limit usage of the application 34 by one or more users upon determining that usage (individual or collective) violates one or more quotas (typically, maximum consumption quotas 46). This can be effected, e.g., when a red light warning condition has been signaled, by preventing additional users from executing the application and/or by terminating the processes of one or more offending users. See step 360.
Described herein are methods and systems meeting the objects set forth above, among others. It will be appreciated that the illustrated embodiment and those otherwise discussed herein are merely examples of the invention and that other embodiments, incorporating changes thereto, fall within the scope of the invention.
Claims
1. A system for proactive management of performance of a software application, comprising
A. a software development environment,
B. a performance monitor in communications coupling with the software development environment, the performance monitor monitoring any of creation, revision and testing of the software application in the software development environment, and
C. the performance monitor signaling an alert upon determining that execution of the application and/or a component thereof by a user and/or consumption of digital data processing resources during such execution is anticipated to exceed one or more quotas for a class to which the user belongs.
2. The system of claim 1, wherein the performance monitor signals the alert to a developer and/or a centralized monitoring environment.
3. The system of claim 1, wherein the performance monitor estimates consumption of the one or more resources based on prior monitoring of actual consumption during execution of the application.
4. The system of claim 1, comprising a model defining a relationship between (i) users in each of one or more classes and (ii) estimated consumption of resources by such users during execution of the application.
5. The system of claim 4, wherein those resources include any of processing capacity, memory capacity and/or network bandwidth.
6. The system of claim 4, in which the model defines quotas for usage of the application and/or one or more components thereof in production mode by users in each of one or more classes.
7. The system of claim 4, in which the model defines quotas for consumption of resources during usage of the application and/or one or more components thereof in production mode by users in each of one or more classes.
8. The system of claim 4, wherein the model defines such quotas on the basis of individual and multiple users in such classes.
9. The system of claim 4, wherein the quotas include any of (i) maximum permitted usage of the application by users in each of one or more classes, and (ii) expected usage of the application by users in each of one or more classes.
10. A system for proactive management of performance of a software application, comprising
A. one or more digital data processing resources,
B. a performance monitor in communications coupling with one or more of the digital data processing resources, the performance monitor monitoring any of (i) usage of the application and/or one or more components thereof by a user, and (ii) consumption of the one or more resources during usage of the application and/or one or more components thereof by the user, and
C. the performance monitor signaling an alert upon determining that such usage by the user and/or consumption of resources during such usage exceeds one or more quotas for a class to which the user belongs.
11. The system of claim 10, comprising U.S. Express Mail Label
A. a software development environment, and wherein
B. the performance monitor is in communications coupling with the software development environment and monitors any of creation, revision and testing of the software application in the software development environment, and
C. the performance monitor signaling an alert upon determining that execution of the application and/or a component thereof by a user and/or consumption of digital data processing resources during such execution is anticipated to exceed one or more quotas for a class to which the user belongs.
12. A method for proactive management of performance of a software application, comprising
A. monitoring any of creation, revision and testing of the software application in a software development environment, and
B. signaling an alert upon determining that execution of the application and/or a component thereof by a user and/or consumption of digital data processing resources during such execution is anticipated to exceed one or more quotas for a class to which the user belongs.
13. The method of claim 12, comprising signaling the alert to a developer and/or a centralized monitoring environment.
14. The method of claim 12, comprising consumption of the one or more resources based on prior monitoring of actual consumption during execution of the application.
15. The method of any of claims 12, comprising modeling a relationship between (i) users in each of one or more classes and (ii) estimated consumption of resources by such users during execution of the application.
16. The method of claim 15, wherein those resources include any of processing capacity, memory capacity and/or network bandwidth of the one or more digital data processing resources.
17. The method of claim 15 , in which the modeling step includes defining quotas for execution of the application and/or one or more components thereof by users in each of one or more classes.
18. The method of claim 17, in which the modeling step includes defining quotas for consumption of resources during execution of the application and/or one or more components thereof by users in each of one or more classes.
19. The method of claim 15, in which the modeling step includes defining such quotas on the basis of individual and multiple users in such classes.
20. The method of claim 15, wherein the quotas include any of (i) maximum permitted usage of the application by users in each of one or more classes, and (ii) expected usage of the application by users in each of one or more classes.
21. The method of claim 12 comprising responding to signaling in step (B) by one or more of altering (i) implementation of the application, (ii) allocation of time for such implementation, (iii) quotas defined for the respective classes, (iv) allocation of resources to the application, and/or (v) definition of the relationships defined in the model.
22. The method of clam 21, wherein the responding step includes at least initiating communications among personnel responsible for any of development, management and/ or procurement of the application in regard to potential implementation of one or more such alterations.
23. A system for proactive management of performance of a software application, comprising A. one or more digital data processing resources, including a processor,
B. a performance monitor in communications coupling with one or more of the digital data processing resources, the performance monitor monitoring any of (i) usage of the application and/or one or more components thereof by one or more users, and (ii) consumption of the one or more resources during such usage, and
C. the performance monitor any of (i) signaling an alert, and (ii) limiting usage of the application by one or more users upon determining that such usage and/or consumption of resources exceeds one or more quotas for one or more classes to which the one or more users belong.
24. The system of claim 23, wherein the performance monitor monitors (i) usage of the application and/or one or more components thereof during production mode of the application by the user, and (ii) consumption of the one or more resources during such production mode.
25. The system of claim 24, wherein the performance monitor signals an alert to a developer and/or a centralized monitoring environment.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP08731127.0A EP2115581B1 (en) | 2007-03-02 | 2008-02-29 | Proactive performance management for multi-user enterprise software systems |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/681,269 | 2007-03-02 | ||
US11/681,269 US8250525B2 (en) | 2007-03-02 | 2007-03-02 | Proactive performance management for multi-user enterprise software systems |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2008109441A1 true WO2008109441A1 (en) | 2008-09-12 |
Family
ID=39734038
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2008/055503 WO2008109441A1 (en) | 2007-03-02 | 2008-02-29 | Proactive performance management for multi-user enterprise software systems |
Country Status (3)
Country | Link |
---|---|
US (2) | US8250525B2 (en) |
EP (1) | EP2115581B1 (en) |
WO (1) | WO2008109441A1 (en) |
Cited By (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8250525B2 (en) | 2007-03-02 | 2012-08-21 | Pegasystems Inc. | Proactive performance management for multi-user enterprise software systems |
US8335704B2 (en) | 2005-01-28 | 2012-12-18 | Pegasystems Inc. | Methods and apparatus for work management and routing |
US8479157B2 (en) | 2004-05-26 | 2013-07-02 | Pegasystems Inc. | Methods and apparatus for integration of declarative rule-based processing with procedural programming in a digital data-processing evironment |
US8880487B1 (en) | 2011-02-18 | 2014-11-04 | Pegasystems Inc. | Systems and methods for distributed rules processing |
US8924335B1 (en) | 2006-03-30 | 2014-12-30 | Pegasystems Inc. | Rule-based user interface conformance methods |
US9195936B1 (en) | 2011-12-30 | 2015-11-24 | Pegasystems Inc. | System and method for updating or modifying an application without manual coding |
US9678719B1 (en) | 2009-03-30 | 2017-06-13 | Pegasystems Inc. | System and software for creation and modification of software |
US10467200B1 (en) | 2009-03-12 | 2019-11-05 | Pegasystems, Inc. | Techniques for dynamic data processing |
US10469396B2 (en) | 2014-10-10 | 2019-11-05 | Pegasystems, Inc. | Event processing with enhanced throughput |
US10698647B2 (en) | 2016-07-11 | 2020-06-30 | Pegasystems Inc. | Selective sharing for collaborative application usage |
US10698599B2 (en) | 2016-06-03 | 2020-06-30 | Pegasystems, Inc. | Connecting graphical shapes using gestures |
US11048488B2 (en) | 2018-08-14 | 2021-06-29 | Pegasystems, Inc. | Software code optimizer and method |
US11567945B1 (en) | 2020-08-27 | 2023-01-31 | Pegasystems Inc. | Customized digital content generation systems and methods |
Families Citing this family (21)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7640222B2 (en) * | 2006-03-03 | 2009-12-29 | Pegasystems Inc. | Rules base systems and methods with circumstance translation |
US20090138292A1 (en) * | 2007-11-26 | 2009-05-28 | International Business Machines Corporation | Driving software product changes based on usage patterns gathered from users of previous product releases |
US9178785B1 (en) * | 2008-01-24 | 2015-11-03 | NextAxiom Technology, Inc | Accounting for usage and usage-based pricing of runtime engine |
US20090192839A1 (en) * | 2008-01-27 | 2009-07-30 | Krishnamoorthy Ramamoorthy | Systems and methods for providing controlled process execution |
US8635593B2 (en) * | 2008-05-13 | 2014-01-21 | Hewlett-Packard Development Company, L.P. | Dynamic autocompletion tool |
US20100042656A1 (en) * | 2008-08-18 | 2010-02-18 | Microsoft Corporation | Claim generation for testing claims-based applications |
US20110214106A1 (en) * | 2010-02-26 | 2011-09-01 | International Business Machines Corporation | Indicating the effect of program modifications on program performance in an integrated development environment |
US20110219425A1 (en) * | 2010-03-08 | 2011-09-08 | Ying Xiong | Access control using roles and multi-dimensional constraints |
CN103109263A (en) * | 2010-06-01 | 2013-05-15 | 惠普发展公司,有限责任合伙企业 | Methods, apparatus, and articles of manufacture to deploy software applications |
US8560963B1 (en) * | 2011-07-12 | 2013-10-15 | Sprint Communications Company L.P. | Providing notifications of wireless data consumption in a wireless communication device |
GB201111975D0 (en) * | 2011-07-13 | 2011-08-31 | Centrix Software Ltd | Modelling virtualized infrastructure |
US9253058B2 (en) * | 2012-02-01 | 2016-02-02 | International Business Machines Corporation | Deploying an executable with historical performance data |
US9317415B2 (en) * | 2013-06-03 | 2016-04-19 | Google Inc. | Application analytics reporting |
US9959329B2 (en) | 2013-07-03 | 2018-05-01 | Sap Se | Unified master report generator |
US9747136B2 (en) * | 2014-12-09 | 2017-08-29 | Vmware, Inc. | Methods and systems that allocate cost of cluster resources in virtual data centers |
WO2017058956A1 (en) * | 2015-09-29 | 2017-04-06 | Weebly, Inc. | Application dashboard |
US10708151B2 (en) * | 2015-10-22 | 2020-07-07 | Level 3 Communications, Llc | System and methods for adaptive notification and ticketing |
US10339454B2 (en) | 2016-01-07 | 2019-07-02 | Red Hat, Inc. | Building a hybrid reactive rule engine for relational and graph reasoning |
EP3486326A1 (en) | 2017-11-21 | 2019-05-22 | Jennewein Biotechnologie GmbH | Method for the purification of n-acetylneuraminic acid from a fermentation broth |
US11409948B2 (en) | 2018-12-10 | 2022-08-09 | Block, Inc. | Centralized brand asset management |
US11977858B2 (en) | 2022-02-07 | 2024-05-07 | T-Mobile Usa, Inc. | Centralized intake and capacity assessment platform for project processes, such as with product development in telecommunications |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20010052108A1 (en) * | 1999-08-31 | 2001-12-13 | Michel K. Bowman-Amuah | System, method and article of manufacturing for a development architecture framework |
US20040117759A1 (en) * | 2001-02-22 | 2004-06-17 | Rippert Donald J | Distributed development environment for building internet applications by developers at remote locations |
US20060064486A1 (en) * | 2004-09-17 | 2006-03-23 | Microsoft Corporation | Methods for service monitoring and control |
US20060173871A1 (en) * | 2005-02-01 | 2006-08-03 | Seiko Epson Corporation | Resource managing system, resource managing program and resource managing method |
Family Cites Families (497)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4344142A (en) * | 1974-05-23 | 1982-08-10 | Federal-Mogul Corporation | Direct digital control of rubber molding presses |
US4047059A (en) | 1976-05-24 | 1977-09-06 | Rca Corporation | Comparator circuit |
US4602168A (en) | 1984-03-28 | 1986-07-22 | National Semiconductor Corporation | Low offset CMOS comparator circuit |
US4701130A (en) | 1985-01-11 | 1987-10-20 | Access Learning Technology Corporation | Software training system |
US4607232A (en) | 1985-04-01 | 1986-08-19 | Raytheon Company | Low voltage amplifier circuit |
US4659944A (en) | 1985-04-08 | 1987-04-21 | Motorola, Inc. | High voltage detection circuit |
US5267175A (en) * | 1986-09-12 | 1993-11-30 | Digital Equipment Corporation | Data base access mechanism for rules utilized by a synthesis procedure for logic circuit design |
US5062060A (en) | 1987-01-05 | 1991-10-29 | Motorola Inc. | Computer human interface comprising user-adjustable window for displaying or printing information |
US4930071A (en) * | 1987-06-19 | 1990-05-29 | Intellicorp, Inc. | Method for integrating a knowledge-based system with an arbitrary database system |
US4866634A (en) * | 1987-08-10 | 1989-09-12 | Syntelligence | Data-driven, functional expert system shell |
US4884217A (en) | 1987-09-30 | 1989-11-28 | E. I. Du Pont De Nemours And Company | Expert system with three classes of rules |
US4895518A (en) | 1987-11-02 | 1990-01-23 | The University Of Michigan | Computerized diagnostic reasoning evaluation system |
US5136523A (en) * | 1988-06-30 | 1992-08-04 | Digital Equipment Corporation | 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 |
US5228116A (en) * | 1988-07-15 | 1993-07-13 | Aicorp., Inc. | Knowledge base management system |
US4953106A (en) | 1989-05-23 | 1990-08-28 | At&T Bell Laboratories | Technique for drawing directed graphs |
US5119465A (en) | 1989-06-19 | 1992-06-02 | Digital Equipment Corporation | System for selectively converting plurality of source data structures through corresponding source intermediate structures, and target intermediate structures into selected target structure |
US5129043A (en) | 1989-08-14 | 1992-07-07 | International Business Machines Corporation | Performance improvement tool for rule based expert systems |
US5093794A (en) | 1989-08-22 | 1992-03-03 | United Technologies Corporation | Job scheduling system |
AU646408B2 (en) * | 1989-09-01 | 1994-02-24 | Objectstar International Limited | A system for program execution on a host data processing machine |
US5204939A (en) * | 1989-12-14 | 1993-04-20 | Fujitsu Limited | Rule base processing system and rule evaluation control method therein |
US5301270A (en) | 1989-12-18 | 1994-04-05 | Anderson Consulting | Computer-assisted software engineering system for cooperative processing environments |
US5140671A (en) | 1990-01-26 | 1992-08-18 | International Business Machines Corporation | Expert system debugger |
JP3245655B2 (en) | 1990-03-05 | 2002-01-15 | インキサイト ソフトウェア インコーポレイテッド | Workspace display processing method |
US6185516B1 (en) | 1990-03-06 | 2001-02-06 | Lucent Technologies Inc. | Automata-theoretic verification of systems |
US5262941A (en) * | 1990-03-30 | 1993-11-16 | Itt Corporation | Expert credit recommendation method and system |
US5761493A (en) | 1990-04-30 | 1998-06-02 | Texas Instruments Incorporated | Apparatus and method for adding an associative query capability to a programming language |
US5297279A (en) * | 1990-05-30 | 1994-03-22 | Texas Instruments Incorporated | System and method for database management supporting object-oriented programming |
US5291394A (en) | 1990-06-01 | 1994-03-01 | Motorola, Inc. | Manufacturing control and capacity planning system |
US5311422A (en) | 1990-06-28 | 1994-05-10 | The United States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration | General purpose architecture for intelligent computer-aided training |
SE9002558D0 (en) | 1990-08-02 | 1990-08-02 | Carlstedt Elektronik Ab | PROCESSOR |
US5466885A (en) * | 1990-09-27 | 1995-11-14 | Furukawa Denki Kogyo Kabushiki Kaisha | Magnetically shielding structure |
US5077491A (en) | 1990-11-30 | 1991-12-31 | Motorola, Inc. | Low standby current comparator having a zero temperature coefficient with hysterisis |
US5291583A (en) * | 1990-12-14 | 1994-03-01 | Racal-Datacom, Inc. | Automatic storage of persistent ASN.1 objects in a relational schema |
US5295256A (en) * | 1990-12-14 | 1994-03-15 | Racal-Datacom, Inc. | Automatic storage of persistent objects in a relational schema |
US5199068A (en) | 1991-01-22 | 1993-03-30 | Professional Achievement Systems, Inc. | Computer-based training system with student verification |
US5193056A (en) * | 1991-03-11 | 1993-03-09 | Signature Financial Group Inc. | Data processing system for hub and spoke financial services configuration |
US5481647A (en) | 1991-03-22 | 1996-01-02 | Raff Enterprises, Inc. | User adaptable expert system |
US5276885A (en) * | 1991-04-18 | 1994-01-04 | Carnegie Group | Single step mapping in topological order of the queued class and instance frames of a semantic network to a static working memory |
US5270920A (en) | 1991-05-13 | 1993-12-14 | Hughes Training, Inc. | Expert system scheduler and scheduling method |
US5136184A (en) | 1991-05-24 | 1992-08-04 | Analog Devices, Incorporated | Fast-acting current comparator |
US5326270A (en) | 1991-08-29 | 1994-07-05 | Introspect Technologies, Inc. | System and method for assessing an individual's task-processing style |
US5395243A (en) | 1991-09-25 | 1995-03-07 | National Education Training Group | Interactive learning system |
US5333254A (en) | 1991-10-02 | 1994-07-26 | Xerox Corporation | Methods of centering nodes in a hierarchical display |
US5421730A (en) | 1991-11-27 | 1995-06-06 | National Education Training Group, Inc. | Interactive learning system providing user feedback |
US5381332A (en) | 1991-12-09 | 1995-01-10 | Motorola, Inc. | Project management system with automated schedule and cost integration |
US5259766A (en) | 1991-12-13 | 1993-11-09 | Educational Testing Service | Method and system for interactive computer science testing, anaylsis and feedback |
US5421011A (en) * | 1991-12-20 | 1995-05-30 | International Business Machines Corporation | 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 |
US5267865A (en) | 1992-02-11 | 1993-12-07 | John R. Lee | Interactive computer aided natural learning method and apparatus |
JP2882163B2 (en) | 1992-02-26 | 1999-04-12 | 日本電気株式会社 | Comparator |
US5310349A (en) | 1992-04-30 | 1994-05-10 | Jostens Learning Corporation | Instructional management system |
US5446885A (en) | 1992-05-15 | 1995-08-29 | International Business Machines Corporation | Event driven management information system with rule-based applications structure stored in a relational database |
US5542024A (en) * | 1992-07-09 | 1996-07-30 | Johnson & Johnson | Graphically used expert system tool background of the invention |
US5890166A (en) * | 1992-07-16 | 1999-03-30 | 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 |
US5504879A (en) * | 1992-07-16 | 1996-04-02 | International Business Machines Corporation | Resolution of relationship source and target in a versioned database management system |
US5386559A (en) * | 1992-07-16 | 1995-01-31 | International Business Machines Corporation | Variant domains and variant maps in a versioned database management system |
US5450480A (en) | 1992-08-25 | 1995-09-12 | Bell Communications Research, Inc. | Method of creating a telecommunication service specification |
US5463682A (en) | 1992-08-25 | 1995-10-31 | Bell Communications Research, Inc. | Method of creating user-defined call processing procedures |
US5412756A (en) | 1992-12-22 | 1995-05-02 | Mitsubishi Denki Kabushiki Kaisha | Artificial intelligence software shell for plant operation simulation |
US5579223A (en) | 1992-12-24 | 1996-11-26 | Microsoft Corporation | Method and system for incorporating modifications made to a computer program into a translated version of the computer program |
US5579486A (en) | 1993-01-14 | 1996-11-26 | Apple Computer, Inc. | Communication node with a first bus configuration for arbitration and a second bus configuration for data transfer |
US5649192A (en) * | 1993-01-15 | 1997-07-15 | General Electric Company | Self-organized information storage system |
US5379366A (en) * | 1993-01-29 | 1995-01-03 | Noyes; Dallas B. | Method for representation of knowledge in a computer as a network database system |
US5276359A (en) | 1993-02-02 | 1994-01-04 | Chiang Ting Chi | Current-input type interface circuit of a mouse |
WO1994020918A1 (en) | 1993-03-11 | 1994-09-15 | Fibercraft/Descon Engineering, Inc. | Design and engineering project management system |
DE69417622T2 (en) | 1993-04-30 | 1999-09-09 | Stmicroelectronics | Voltage comparator with a summation of direct currents based on the bandgap principle and supply voltage switch containing them |
TW239190B (en) | 1993-04-30 | 1995-01-21 | Philips Electronics Nv | |
US5809212A (en) | 1993-07-12 | 1998-09-15 | New York University | Conditional transition networks and computational processes for use interactive computer-based systems |
US6684261B1 (en) * | 1993-07-19 | 2004-01-27 | Object Technology Licensing Corporation | Object-oriented operating system |
US5519618A (en) | 1993-08-02 | 1996-05-21 | Massachusetts Institute Of Technology | Airport surface safety logic |
US5374932A (en) | 1993-08-02 | 1994-12-20 | Massachusetts Institute Of Technology | Airport surface surveillance system |
US5537590A (en) | 1993-08-05 | 1996-07-16 | Amado; Armando | Apparatus for applying analysis rules to data sets in a relational database to generate a database of diagnostic records linked to the data sets |
US5632009A (en) | 1993-09-17 | 1997-05-20 | Xerox Corporation | Method and system for producing a table image showing indirect data representations |
US5522025A (en) * | 1993-10-25 | 1996-05-28 | Taligent, Inc. | Object-oriented window area display system |
US5473732A (en) * | 1993-11-02 | 1995-12-05 | Chang; Hou-Mei H. | Relational artificial intelligence system |
DE69430421T2 (en) | 1994-01-14 | 2003-03-06 | Sun Microsystems, Inc. | Method and device for automating the environment adaptation of computer programs |
US5477170A (en) | 1994-02-17 | 1995-12-19 | Nec Corporation | Comparator capable of preventing large noise voltage |
US5548506A (en) | 1994-03-17 | 1996-08-20 | Srinivasan; Seshan R. | Automated, electronic network based, project management server system, for managing multiple work-groups |
US5655118A (en) | 1994-03-21 | 1997-08-05 | Bell Communications Research, Inc. | Methods and apparatus for managing information on activities of an enterprise |
US5597312A (en) | 1994-05-04 | 1997-01-28 | U S West Technologies, Inc. | Intelligent tutoring method and system |
US6513018B1 (en) * | 1994-05-05 | 2003-01-28 | Fair, Isaac And Company, Inc. | Method and apparatus for scoring the likelihood of a desired performance result |
US5862321A (en) | 1994-06-27 | 1999-01-19 | Xerox Corporation | System and method for accessing and distributing electronic documents |
US6341293B1 (en) * | 1994-07-13 | 2002-01-22 | Object Technology Licensing Corp | Real-time computer “garbage collector” |
US5627979A (en) * | 1994-07-18 | 1997-05-06 | International Business Machines Corporation | System and method for providing a graphical user interface for mapping and accessing objects in data stores |
JPH0876680A (en) | 1994-09-02 | 1996-03-22 | Fujitsu Ltd | Management education system |
US5611076A (en) | 1994-09-21 | 1997-03-11 | Micro Data Base Systems, Inc. | Multi-model database management system engine for databases having complex data models |
DE4434180A1 (en) | 1994-09-24 | 1996-03-28 | Teves Gmbh Alfred | Circuit arrangement for evaluating the output signal of an active sensor |
US5542078A (en) * | 1994-09-29 | 1996-07-30 | Ontos, Inc. | Object oriented data store integration environment for integration of object oriented databases and non-object oriented data facilities |
US5678039A (en) | 1994-09-30 | 1997-10-14 | Borland International, Inc. | System and methods for translating software into localized versions |
US5768480A (en) | 1994-10-21 | 1998-06-16 | Lucent Technologies Inc. | Integrating rules into object-oriented programming systems |
JP2840923B2 (en) | 1994-11-11 | 1998-12-24 | 富士通株式会社 | Production system |
US5732192A (en) | 1994-11-30 | 1998-03-24 | The United States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration | Global qualitative flow-path modeling for local state determination in simulation and analysis |
US5561740A (en) * | 1994-12-13 | 1996-10-01 | International Business Machines Corporation | Method and system for providing multiple instances in a single multiple-instance object |
US5499293A (en) | 1995-01-24 | 1996-03-12 | University Of Maryland | Privacy protected information medium using a data compression method |
JP2765506B2 (en) | 1995-01-30 | 1998-06-18 | 日本電気株式会社 | Logic circuit delay information retention method |
US5918222A (en) | 1995-03-17 | 1999-06-29 | Kabushiki Kaisha Toshiba | Information disclosing apparatus and multi-modal information input/output system |
US5701451A (en) | 1995-06-07 | 1997-12-23 | International Business Machines Corporation | Method for fulfilling requests of a web browser |
US6311324B1 (en) * | 1995-06-07 | 2001-10-30 | Intel Corporation | Software profiler which has the ability to display performance data on a computer screen |
US5907837A (en) | 1995-07-17 | 1999-05-25 | Microsoft Corporation | Information retrieval system in an on-line network including separate content and layout of published titles |
US5781449A (en) * | 1995-08-10 | 1998-07-14 | Advanced System Technologies, Inc. | Response time measurement apparatus and method |
US5715450A (en) | 1995-09-27 | 1998-02-03 | Siebel Systems, Inc. | Method of selecting and presenting data from a database using a query language to a user of a computer system |
US5788504A (en) | 1995-10-16 | 1998-08-04 | Brookhaven Science Associates Llc | Computerized training management system |
US5875334A (en) * | 1995-10-27 | 1999-02-23 | International Business Machines Corporation | System, method, and program for extending a SQL compiler for handling control statements packaged with SQL query statements |
US6546406B1 (en) | 1995-11-03 | 2003-04-08 | Enigma Information Systems Ltd. | Client-server computer system for large document retrieval on networked computer system |
US5765140A (en) | 1995-11-17 | 1998-06-09 | Mci Corporation | Dynamic project management system |
US5832483A (en) | 1995-12-15 | 1998-11-03 | Novell, Inc. | Distributed control interface for managing the interoperability and concurrency of agents and resources in a real-time environment |
US5920717A (en) | 1995-12-20 | 1999-07-06 | Nec Corporation | Method and apparatus for automated program-generation |
US5815415A (en) * | 1996-01-19 | 1998-09-29 | Bentley Systems, Incorporated | Computer system for portable persistent modeling |
US5761673A (en) | 1996-01-31 | 1998-06-02 | Oracle Corporation | Method and apparatus for generating dynamic web pages by invoking a predefined procedural package stored in a database |
DE19605569A1 (en) | 1996-02-15 | 1997-08-21 | Daimler Benz Aerospace Ag | Directional coupler for the high frequency range |
US5873096A (en) | 1997-10-08 | 1999-02-16 | Siebel Systems, Inc. | Method of maintaining a network of partially replicated database system |
US5795155A (en) | 1996-04-01 | 1998-08-18 | Electronic Data Systems Corporation | Leadership assessment tool and method |
US6366930B1 (en) * | 1996-04-12 | 2002-04-02 | Computer Associates Think, Inc. | Intelligent data inventory & asset management systems method and apparatus |
GB9609189D0 (en) * | 1996-05-02 | 1996-07-03 | Philips Electronics Nv | Adaptive process modelling and control |
JPH09297768A (en) | 1996-05-07 | 1997-11-18 | Fuji Xerox Co Ltd | Management device and retrieval method for document data base |
US5826250A (en) * | 1996-06-19 | 1998-10-20 | Pegasystems Inc. | Rules bases and methods of access thereof |
KR100218306B1 (en) | 1996-06-27 | 1999-09-01 | 구본준 | Current / voltage converters and sense amplifiers and sensing methods using them |
US5826252A (en) | 1996-06-28 | 1998-10-20 | General Electric Company | System for managing multiple projects of similar type using dynamically updated global database |
US5978566A (en) | 1996-07-12 | 1999-11-02 | Microsoft Corporation | Client side deferred actions within multiple MAPI profiles |
FR2751488B1 (en) | 1996-07-16 | 1998-10-16 | Sgs Thomson Microelectronics | POWER AMPLIFIER IN BICMOS TECHNOLOGY WITH OUTPUT STAGE IN MOS TECHNOLOGY |
US6047264A (en) * | 1996-08-08 | 2000-04-04 | Onsale, Inc. | Method for supplying automatic status updates using electronic mail |
DE19638087C2 (en) | 1996-09-18 | 1999-09-02 | Siemens Ag | CMOS comparator |
US6526457B1 (en) * | 1996-10-30 | 2003-02-25 | Computer Associates Think, Inc. | Systems utility object interface for facilitating software portability |
US6023717A (en) | 1996-10-30 | 2000-02-08 | Qualcomm Incorporated | Method and apparatus for polyphase digital filtering in a mobile telephone |
US7165020B2 (en) | 1998-05-29 | 2007-01-16 | Citicorp Development Center, Inc. | Multi-language phrase editor and method thereof |
US6137797A (en) | 1996-11-27 | 2000-10-24 | International Business Machines Corporation | Process definition for source route switching |
US5826239A (en) * | 1996-12-17 | 1998-10-20 | Hewlett-Packard Company | Distributed workflow resource management system and method |
US5822780A (en) | 1996-12-31 | 1998-10-13 | Emc Corporation | Method and apparatus for hierarchical storage management for data base management systems |
US5930795A (en) * | 1997-01-21 | 1999-07-27 | International Business Machines Corporation | Supporting dynamic tables in SQL query compilers |
US5819257A (en) * | 1997-01-31 | 1998-10-06 | Lucent Technologies Inc. | Process for providing transitive closure using fourth generation structure query language (SQL) |
US5818463A (en) | 1997-02-13 | 1998-10-06 | Rockwell Science Center, Inc. | Data compression for animated three dimensional objects |
WO1998038587A1 (en) | 1997-02-26 | 1998-09-03 | Siebel Systems, Inc. | Method of using a cache to determine the visibility to a remote database client of a plurality of database transactions |
WO1998038762A2 (en) | 1997-02-26 | 1998-09-03 | Siebel Systems, Inc. | Determining visibility to a remote database client |
WO1998040804A2 (en) | 1997-02-26 | 1998-09-17 | Siebel Systems, Inc. | Distributed relational database |
AU6183698A (en) | 1997-02-26 | 1998-09-18 | Siebel Systems, Inc. | Method of determining visibility to a remote database client of a plurality of database transactions having variable visibility strengths |
WO1998040805A2 (en) | 1997-02-27 | 1998-09-17 | Siebel Systems, Inc. | Method of synchronizing independently distributed software and database schema |
WO1998040807A2 (en) | 1997-02-27 | 1998-09-17 | Siebel Systems, Inc. | Migrating to a successive software distribution level |
JP2001513926A (en) | 1997-02-28 | 2001-09-04 | シーベル システムズ,インコーポレイティド | Partially replicated distributed database with multiple levels of remote clients |
US5995958A (en) | 1997-03-04 | 1999-11-30 | Xu; Kevin Houzhi | System and method for storing and managing functions |
US6023714A (en) | 1997-04-24 | 2000-02-08 | Microsoft Corporation | Method and system for dynamically adapting the layout of a document to an output device |
US5907490A (en) | 1997-06-10 | 1999-05-25 | Electronic Data Systems Corporation | System and method for project management and assessment |
US6038601A (en) * | 1997-07-21 | 2000-03-14 | Tibco, Inc. | Method and apparatus for storing and delivering documents on the internet |
US6122632A (en) | 1997-07-21 | 2000-09-19 | Convergys Customer Management Group Inc. | Electronic message management system |
US6338074B1 (en) * | 1997-07-23 | 2002-01-08 | Filenet Corporation | System for enterprise-wide work flow automation |
US6052685A (en) | 1997-08-13 | 2000-04-18 | Mosaix, Inc. | Integration of legacy database management systems with ODBC-compliant application programs |
US6098172A (en) | 1997-09-12 | 2000-08-01 | Lucent Technologies Inc. | Methods and apparatus for a computer network firewall with proxy reflection |
US5983267A (en) | 1997-09-23 | 1999-11-09 | Information Architects Corporation | System for indexing and displaying requested data having heterogeneous content and representation |
US5974443A (en) | 1997-09-26 | 1999-10-26 | Intervoice Limited Partnership | Combined internet and data access system |
US6574661B1 (en) | 1997-09-26 | 2003-06-03 | Mci Communications Corporation | Integrated proxy interface for web based telecommunication toll-free network management using a network manager for downloading a call routing tree to client |
US6044373A (en) | 1997-09-29 | 2000-03-28 | International Business Machines Corporation | Object-oriented access control method and system for military and commercial file systems |
US6037890A (en) | 1997-09-30 | 2000-03-14 | Intel Corporation | Ultra high speed, low power, flash A/D converter utilizing a current mode regenerative comparator |
US6167441A (en) | 1997-11-21 | 2000-12-26 | International Business Machines Corporation | Customization of web pages based on requester type |
US5995948A (en) * | 1997-11-21 | 1999-11-30 | First Usa Bank, N.A. | Correspondence and chargeback workstation |
US6044466A (en) | 1997-11-25 | 2000-03-28 | International Business Machines Corp. | Flexible and dynamic derivation of permissions |
JPH11163644A (en) | 1997-11-26 | 1999-06-18 | Fujitsu Ltd | Output circuit of differential amplifier circuit |
US6769019B2 (en) | 1997-12-10 | 2004-07-27 | Xavier Ferguson | Method of background downloading of information from a computer network |
KR100293446B1 (en) | 1997-12-30 | 2001-07-12 | 김영환 | Main amplifier |
US6023704A (en) * | 1998-01-29 | 2000-02-08 | International Business Machines Corporation | Apparatus and method for swapping identities of two objects to reference the object information of the other |
US6636901B2 (en) * | 1998-01-30 | 2003-10-21 | Object Technology Licensing Corp. | Object-oriented resource lock and entry register |
US6151624A (en) | 1998-02-03 | 2000-11-21 | Realnames Corporation | Navigating network resources based on metadata |
US6105035A (en) * | 1998-02-17 | 2000-08-15 | Lucent Technologies, Inc. | Method by which notions and constructs of an object oriented programming language can be implemented using a structured query language (SQL) |
US6012098A (en) | 1998-02-23 | 2000-01-04 | International Business Machines Corp. | Servlet pairing for isolation of the retrieval and rendering of data |
US6732111B2 (en) | 1998-03-03 | 2004-05-04 | Siebel Systems, Inc. | Method, apparatus, system, and program product for attaching files and other objects to a partially replicated database |
EP1073955B1 (en) | 1998-03-03 | 2008-04-16 | Siebel Systems, Inc. | Method, system, apparatus and program product for distribution and instantiation of software upgrades |
US6493399B1 (en) | 1998-03-05 | 2002-12-10 | University Of Delaware | Digital wireless communications systems that eliminates intersymbol interference (ISI) and multipath cancellation using a plurality of optimal ambiguity resistant precoders |
JP2947256B1 (en) | 1998-03-12 | 1999-09-13 | 日本電気株式会社 | Voltage determination circuit and battery pack including the same |
US6560592B1 (en) | 1998-03-19 | 2003-05-06 | Micro Data Base Systems, Inc. | Multi-model computer database storage system with integrated rule engine |
US6185534B1 (en) | 1998-03-23 | 2001-02-06 | Microsoft Corporation | Modeling emotion and personality in a computer user interface |
US6078982A (en) | 1998-03-24 | 2000-06-20 | Hewlett-Packard Company | Pre-locking scheme for allowing consistent and concurrent workflow process execution in a workflow management system |
US6154738A (en) | 1998-03-27 | 2000-11-28 | Call; Charles Gainor | Methods and apparatus for disseminating product information via the internet using universal product codes |
US5963953A (en) | 1998-03-30 | 1999-10-05 | Siebel Systems, Inc. | Method, and system for product configuration |
US6125363A (en) | 1998-03-30 | 2000-09-26 | Buzzeo; Eugene | Distributed, multi-user, multi-threaded application development method |
US6085188A (en) | 1998-03-30 | 2000-07-04 | International Business Machines Corporation | Method of hierarchical LDAP searching with relational tables |
US5945852A (en) | 1998-03-31 | 1999-08-31 | Motorola, Inc. | CMOS comparator output circuit with high gain and hysteresis |
US6151595A (en) | 1998-04-17 | 2000-11-21 | Xerox Corporation | Methods for interactive visualization of spreading activation using time tubes and disk trees |
US6369819B1 (en) | 1998-04-17 | 2002-04-09 | Xerox Corporation | Methods for visualizing transformations among related series of graphs |
US6509898B2 (en) | 1998-04-17 | 2003-01-21 | Xerox Corporation | Usage based methods of traversing and displaying generalized graph structures |
US6389460B1 (en) | 1998-05-13 | 2002-05-14 | Compaq Computer Corporation | Method and apparatus for efficient storage and retrieval of objects in and from an object storage device |
US7031901B2 (en) * | 1998-05-13 | 2006-04-18 | Abu El Ata Nabil A | System and method for improving predictive modeling of an information system |
US6020768A (en) | 1998-05-13 | 2000-02-01 | Oak Technology, Inc. | CMOS low-voltage comparator |
US6772350B1 (en) * | 1998-05-15 | 2004-08-03 | E.Piphany, Inc. | System and method for controlling access to resources in a distributed environment |
US6092036A (en) | 1998-06-02 | 2000-07-18 | Davox Corporation | Multi-lingual data processing system and system and method for translating text used in computer software utilizing an embedded translator |
US6085198A (en) * | 1998-06-05 | 2000-07-04 | Sun Microsystems, Inc. | Integrated three-tier application framework with automated class and table generation |
US6094652A (en) | 1998-06-10 | 2000-07-25 | Oracle Corporation | Hierarchical query feedback in an information retrieval system |
US6594662B1 (en) | 1998-07-01 | 2003-07-15 | Netshadow, Inc. | Method and system for gathering information resident on global computer networks |
US6300947B1 (en) | 1998-07-06 | 2001-10-09 | International Business Machines Corporation | Display screen and window size related web page adaptation system |
US6583800B1 (en) | 1998-07-14 | 2003-06-24 | Brad Ridgley | Method and device for finding, collecting and acting upon units of information |
US6177932B1 (en) | 1998-08-21 | 2001-01-23 | Kana Communications, Inc. | Method and apparatus for network based customer service |
US6243713B1 (en) | 1998-08-24 | 2001-06-05 | Excalibur Technologies Corp. | Multimedia document retrieval by application of multimedia queries to a unified index of multimedia data for a plurality of multimedia data types |
US6473748B1 (en) | 1998-08-31 | 2002-10-29 | Worldcom, Inc. | System for implementing rules |
US6351734B1 (en) | 1998-09-09 | 2002-02-26 | Unisys Corporation | System and method for resource allocation and planning |
US6349238B1 (en) | 1998-09-16 | 2002-02-19 | Mci Worldcom, Inc. | System and method for managing the workflow for processing service orders among a variety of organizations within a telecommunications company |
US6377973B2 (en) | 1998-09-30 | 2002-04-23 | Emrys Technologies, Ltd. | Event management in a system with application and graphical user interface processing adapted to display predefined graphical elements resides separately on server and client machine |
US6415283B1 (en) | 1998-10-13 | 2002-07-02 | Orack Corporation | Methods and apparatus for determining focal points of clusters in a tree structure |
US6691230B1 (en) | 1998-10-15 | 2004-02-10 | International Business Machines Corporation | Method and system for extending Java applets sand box with public client storage |
US8006177B1 (en) | 1998-10-16 | 2011-08-23 | Open Invention Network, Llc | Documents for commerce in trading partner networks and interface definitions based on the documents |
JP2000138573A (en) | 1998-10-30 | 2000-05-16 | Fujitsu Ltd | Differential input circuit |
US6314415B1 (en) | 1998-11-04 | 2001-11-06 | Cch Incorporated | Automated forms publishing system and method using a rule-based expert system to dynamically generate a graphical user interface |
US7505827B1 (en) | 1998-11-06 | 2009-03-17 | Honeywell International Inc. | Automated finite capacity scheduler |
US6502239B2 (en) * | 1998-11-12 | 2002-12-31 | Computer Associates Think, Inc | Method and apparatus for round-trip software engineering |
US6341277B1 (en) | 1998-11-17 | 2002-01-22 | International Business Machines Corporation | System and method for performance complex heterogeneous database queries using a single SQL expression |
US6549908B1 (en) | 1998-11-18 | 2003-04-15 | Siebel Systems, Inc. | Methods and apparatus for interpreting user selections in the context of a relation distributed as a set of orthogonalized sub-relations |
EP1163604A4 (en) | 1998-11-30 | 2002-01-09 | Siebel Systems Inc | Assignment manager |
WO2000033235A1 (en) | 1998-11-30 | 2000-06-08 | Siebel Systems, Inc. | State models for monitoring processes |
JP2002531896A (en) | 1998-11-30 | 2002-09-24 | シーベル システムズ,インコーポレイティド | Call center using smart script |
WO2000033217A1 (en) | 1998-11-30 | 2000-06-08 | Siebel Systems, Inc. | Client server system with thin client architecture |
AU2035600A (en) | 1998-11-30 | 2000-06-19 | Siebel Systems, Inc. | Development tool, method, and system for client server appications |
US6396885B1 (en) | 1998-12-02 | 2002-05-28 | Nortel Networks Limited | Co-channel interference reduction in wireless communications systems |
US7526468B2 (en) * | 1999-01-08 | 2009-04-28 | Computer Associates Think, Inc. | System and method for recursive path analysis of DBMS procedures |
AU775328B2 (en) * | 1999-01-13 | 2004-07-29 | Computer Associates Think, Inc. | Signature recognition system and method |
US6359633B1 (en) * | 1999-01-15 | 2002-03-19 | Yahoo! Inc. | Apparatus and method for abstracting markup language documents |
US6941321B2 (en) | 1999-01-26 | 2005-09-06 | Xerox Corporation | System and method for identifying similarities among objects in a collection |
JP2000235493A (en) | 1999-02-12 | 2000-08-29 | Fujitsu Ltd | Trading equipment |
US6246320B1 (en) | 1999-02-25 | 2001-06-12 | David A. Monroe | Ground link with on-board security surveillance system for aircraft and other commercial vehicles |
JP3484096B2 (en) | 1999-03-03 | 2004-01-06 | インターナショナル・ビジネス・マシーンズ・コーポレーション | Logical zoom method in logical zoom device for directed graph |
US20020072951A1 (en) | 1999-03-03 | 2002-06-13 | Michael Lee | Marketing support database management method, system and program product |
US6574635B2 (en) | 1999-03-03 | 2003-06-03 | Siebel Systems, Inc. | Application instantiation based upon attributes and values stored in a meta data repository, including tiering of application layers objects and components |
US6448964B1 (en) * | 1999-03-15 | 2002-09-10 | Computer Associates Think, Inc. | Graphic object manipulating tool |
US6308163B1 (en) | 1999-03-16 | 2001-10-23 | Hewlett-Packard Company | System and method for enterprise workflow resource management |
US6584464B1 (en) * | 1999-03-19 | 2003-06-24 | Ask Jeeves, Inc. | Grammar template query system |
US6405251B1 (en) | 1999-03-25 | 2002-06-11 | Nortel Networks Limited | Enhancement of network accounting records |
US6446200B1 (en) | 1999-03-25 | 2002-09-03 | Nortel Networks Limited | Service management |
US6625657B1 (en) | 1999-03-25 | 2003-09-23 | Nortel Networks 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 |
US6751663B1 (en) | 1999-03-25 | 2004-06-15 | Nortel Networks Limited | System wide flow aggregation process for aggregating network activity records |
US6691067B1 (en) * | 1999-04-07 | 2004-02-10 | 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 |
US6463440B1 (en) | 1999-04-08 | 2002-10-08 | International Business Machines Corporation | Retrieval of style sheets from directories based upon partial characteristic matching |
US6192371B1 (en) * | 1999-04-28 | 2001-02-20 | Lucent Technologies, Inc | Object morphing in an object oriented computing environment using relational database query procedure |
US6430539B1 (en) * | 1999-05-06 | 2002-08-06 | Hnc Software | Predictive modeling of consumer financial behavior |
US6530079B1 (en) | 1999-06-02 | 2003-03-04 | International Business Machines Corporation | Method for optimizing locks in computer programs |
US6539374B2 (en) | 1999-06-03 | 2003-03-25 | Microsoft Corporation | Methods, apparatus and data structures for providing a uniform representation of various types of information |
US6606613B1 (en) | 1999-06-03 | 2003-08-12 | Microsoft Corporation | Methods and apparatus for using task models to help computer users complete tasks |
US6778971B1 (en) | 1999-06-03 | 2004-08-17 | Microsoft Corporation | Methods and apparatus for analyzing computer-based tasks to build task models |
US6330554B1 (en) | 1999-06-03 | 2001-12-11 | Microsoft Corporation | Methods and apparatus using task models for targeting marketing information to computer users based on a task being performed |
US7844594B1 (en) | 1999-06-18 | 2010-11-30 | Surfwax, Inc. | Information search, retrieval and distillation into knowledge objects |
US6549904B1 (en) * | 1999-06-25 | 2003-04-15 | Amazon.Com, Inc. | Auction notification system |
US6678882B1 (en) * | 1999-06-30 | 2004-01-13 | 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 |
US6446256B1 (en) | 1999-06-30 | 2002-09-03 | Microsoft Corporation | Extension of parsable structures |
US6405211B1 (en) | 1999-07-08 | 2002-06-11 | Cohesia Corporation | Object-oriented representation of technical content and management, filtering, and synthesis of technical content using object-oriented representations |
US6415259B1 (en) | 1999-07-15 | 2002-07-02 | American Management Systems, Inc. | Automatic work progress tracking and optimizing engine for a telecommunications customer care and billing system |
US6381738B1 (en) | 1999-07-16 | 2002-04-30 | International Business Machines Corporation | Method for optimizing creation and destruction of objects in computer programs |
US6556985B1 (en) * | 1999-07-23 | 2003-04-29 | Teleran Technologies, Inc. | Rule construction and application |
US6275790B1 (en) | 1999-07-28 | 2001-08-14 | International Business Machines Corporation | Introspective editor system, program, and method for software translation |
US20020054152A1 (en) | 1999-08-23 | 2002-05-09 | Murugan Palaniappan | Menu infrastructure apparatus and method |
US6577769B1 (en) | 1999-09-18 | 2003-06-10 | Wildtangent, Inc. | Data compression through adaptive data size reduction |
US6598043B1 (en) | 1999-10-04 | 2003-07-22 | Jarg Corporation | Classification of information sources using graph structures |
US7574494B1 (en) | 1999-10-15 | 2009-08-11 | Thomson Licensing | User interface for a bi-directional communication system |
US20030050927A1 (en) | 2001-09-07 | 2003-03-13 | Araha, Inc. | System and method for location, understanding and assimilation of digital documents through abstract indicia |
US6851089B1 (en) * | 1999-10-25 | 2005-02-01 | Amazon.Com, Inc. | Software application and associated methods for generating a software layer for structuring semistructured information |
US6496833B1 (en) | 1999-11-01 | 2002-12-17 | Sun Microsystems, Inc. | System and method for generating code for query object interfacing |
US6714952B2 (en) | 1999-11-10 | 2004-03-30 | Emc Corporation | Method for backup and restore of a multi-lingual network file server |
US6324568B1 (en) | 1999-11-30 | 2001-11-27 | Siebel Systems, Inc. | Method and system for distributing objects over a network |
US6418448B1 (en) | 1999-12-06 | 2002-07-09 | Shyam Sundar Sarkar | 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 |
US7064241B2 (en) | 2000-01-05 | 2006-06-20 | The United States Of America As Represented By The Secretary Of The Navy | Chemical and biological warfare decontaminating solution using peracids and germinants in microemulsions, process and product thereof |
US6556983B1 (en) | 2000-01-12 | 2003-04-29 | Microsoft Corporation | Methods and apparatus for finding semantic information, such as usage logs, similar to a query using a pattern lattice data space |
US6529899B1 (en) | 2000-01-12 | 2003-03-04 | International Business Machines Corporation | System and method for registering and providing a tool service |
US6678773B2 (en) | 2000-01-13 | 2004-01-13 | Motorola, Inc. | Bus protocol independent method and structure for managing transaction priority, ordering and deadlocks in a multi-processing system |
US6643652B2 (en) | 2000-01-14 | 2003-11-04 | Saba Software, Inc. | Method and apparatus for managing data exchange among systems in a network |
AU2001229464A1 (en) | 2000-01-14 | 2001-07-24 | Saba Software, Inc. | Method and apparatus for a web content platform |
AU2001229371A1 (en) | 2000-01-14 | 2001-07-24 | Saba Software, Inc. | Information server |
AU2001226401A1 (en) | 2000-01-14 | 2001-07-24 | Saba Software, Inc. | Method and apparatus for a business applications server |
DE60024793T2 (en) | 2000-01-19 | 2006-08-10 | Koninklijke Philips Electronics N.V. | VOLTAGE LEVEL DETECTOR CIRCUIT |
US6701314B1 (en) | 2000-01-21 | 2004-03-02 | Science Applications International Corporation | System and method for cataloguing digital information for searching and retrieval |
US6810429B1 (en) | 2000-02-03 | 2004-10-26 | Mitsubishi Electric Research Laboratories, Inc. | Enterprise integration system |
US7366977B2 (en) | 2000-02-04 | 2008-04-29 | Aol Llc A Delaware Limited Liability Company | Method and systems of automated client-server data validation |
US6867789B1 (en) * | 2000-02-15 | 2005-03-15 | Bank One, Delaware, National Association | System and method for generating graphical user interfaces |
EP1264263A2 (en) | 2000-02-25 | 2002-12-11 | Saba Software, Inc. | Method for enterprise workforce planning |
US6586972B2 (en) | 2000-02-28 | 2003-07-01 | Valorbec, Limited Partnership | Transistor-mismatch-insensitive current comparator cell |
WO2001065330A2 (en) | 2000-03-03 | 2001-09-07 | Sanctum Ltd. | System for determining web application vulnerabilities |
US6853920B2 (en) | 2000-03-10 | 2005-02-08 | Smiths Detection-Pasadena, Inc. | Control for an industrial process using one or more multidimensional variables |
US20030037145A1 (en) | 2000-03-15 | 2003-02-20 | Michael Fagan | Apparatus and method of allocating communications resources |
AU2001245801A1 (en) | 2000-03-16 | 2001-09-24 | Poly Vista, Inc. | A system and method for analyzing a query and generating results and related questions |
US20020091677A1 (en) * | 2000-03-20 | 2002-07-11 | Sridhar Mandayam Andampikai | Content dereferencing in website development |
US6473467B1 (en) | 2000-03-22 | 2002-10-29 | Qualcomm Incorporated | Method and apparatus for measuring reporting channel state information in a high efficiency, high performance communications system |
CA2403797A1 (en) | 2000-03-23 | 2001-10-04 | The Johns Hopkins University | Method and system for bio-surveillance detection and alerting |
US6643638B1 (en) | 2000-03-25 | 2003-11-04 | Kevin Houzhi Xu | System and method for storing and computing data and functions |
US6493331B1 (en) | 2000-03-30 | 2002-12-10 | Qualcomm Incorporated | Method and apparatus for controlling transmissions of a communications systems |
US6577726B1 (en) | 2000-03-31 | 2003-06-10 | Siebel Systems, Inc. | Computer telephony integration hotelling method and system |
US6732100B1 (en) | 2000-03-31 | 2004-05-04 | Siebel Systems, Inc. | Database access method and system for user role defined access |
US6336137B1 (en) | 2000-03-31 | 2002-01-01 | Siebel Systems, Inc. | Web client-server system and method for incompatible page markup and presentation languages |
US7266502B2 (en) | 2000-03-31 | 2007-09-04 | Siebel Systems, Inc. | Feature centric release manager method and system |
AU2001249621A1 (en) | 2000-03-31 | 2001-10-15 | Siebel Systems, Inc. | Thin client method and system for generating page delivery language output from applets, views, and screen definitions |
EP1277155A1 (en) | 2000-03-31 | 2003-01-22 | Siebel Systems, Inc. | Workflow processes method and system |
US6820082B1 (en) | 2000-04-03 | 2004-11-16 | Allegis Corporation | Rule based database security system and method |
US6831668B2 (en) | 2000-04-03 | 2004-12-14 | Business Objects, S.A. | Analytical reporting on top of multidimensional data model |
AU2001257605A1 (en) | 2000-04-14 | 2001-10-30 | Savvion Incorporated | System and method for dynamically managing electronic business process |
US6865546B1 (en) * | 2000-04-19 | 2005-03-08 | Amazon.Com, Inc. | Methods and systems of assisting users in purchasing items |
WO2001086592A2 (en) | 2000-05-09 | 2001-11-15 | Hnc Software Inc. | Approach for generating rules |
US6496812B1 (en) * | 2000-05-13 | 2002-12-17 | Object Power, Inc. | Method and system for measuring and valuing contributions by group members to the achievement of a group goal |
AU2001264965A1 (en) | 2000-05-26 | 2001-12-11 | Exitexchange Corporation | Post-session internet advertising system |
US7865358B2 (en) | 2000-06-26 | 2011-01-04 | Oracle International Corporation | Multi-user functionality for converting data from a first form to a second form |
US6728852B1 (en) * | 2000-06-30 | 2004-04-27 | Sun Microsystems, Inc. | Method and apparatus for reducing heap size through adaptive object representation |
US6865575B1 (en) | 2000-07-06 | 2005-03-08 | Google, Inc. | Methods and apparatus for using a modified index to provide search results in response to an ambiguous search query |
US7103173B2 (en) | 2001-07-09 | 2006-09-05 | Austin Logistics Incorporated | System and method for preemptive goals based routing of contact records |
US6756994B1 (en) * | 2000-08-07 | 2004-06-29 | Canon Kabushiki Kaisha | Method and apparatus for handling secondary dependencies |
US20020042831A1 (en) | 2000-08-16 | 2002-04-11 | Jeffrey Capone | System and method for building applications that adapt for multiple device and protocol standards |
US20020059566A1 (en) | 2000-08-29 | 2002-05-16 | Delcambre Lois M. | Uni-level description of computer information and transformation of computer information between representation schemes |
US6957199B1 (en) | 2000-08-30 | 2005-10-18 | Douglas Fisher | Method, system and service for conducting authenticated business transactions |
AU2001288463A1 (en) | 2000-08-30 | 2002-03-13 | Citibank, N.A. | Method and system for internet hosting and security |
EP1402336A2 (en) | 2000-09-07 | 2004-03-31 | Fair Isaac Corporation | Mechanism and method for dynamic question handling through an electronic interface |
WO2002021259A1 (en) | 2000-09-08 | 2002-03-14 | The Regents Of The University Of California | Data source integration system and method |
US6567419B1 (en) * | 2000-09-11 | 2003-05-20 | Yahoo! Inc. | Intelligent voice converter |
US6597775B2 (en) | 2000-09-29 | 2003-07-22 | Fair Isaac Corporation | Self-learning real-time prioritization of telecommunication fraud control actions |
US6678679B1 (en) | 2000-10-10 | 2004-01-13 | Science Applications International Corporation | Method and system for facilitating the refinement of data queries |
US6782091B1 (en) * | 2000-10-13 | 2004-08-24 | Dunning Iii Emerson C | Virtual call distribution system |
US6748422B2 (en) * | 2000-10-19 | 2004-06-08 | Ebay Inc. | System and method to control sending of unsolicited communications relating to a plurality of listings in a network-based commerce facility |
US20020118688A1 (en) | 2000-10-25 | 2002-08-29 | Ravi Jagannathan | Generation of fast busy signals in data networks |
US7885981B2 (en) | 2000-10-31 | 2011-02-08 | Michael Philip Kaufman | System and method for generating automatic user interface for arbitrarily complex or large databases |
WO2002059793A2 (en) | 2000-10-31 | 2002-08-01 | Michael Philip Kaufman | System and method for generating automatic user interface for arbitrarily complex or large databases |
AU2001293263A1 (en) | 2000-11-28 | 2002-06-11 | Asera, Inc. | Workflow driven rules-based generation of personalizable web pages |
US6920615B1 (en) | 2000-11-29 | 2005-07-19 | Verizon Corporate Services Group Inc. | Method and system for service-enablement gateway and its service portal |
US7020869B2 (en) * | 2000-12-01 | 2006-03-28 | Corticon Technologies, Inc. | Business rules user interface for development of adaptable enterprise applications |
US7290061B2 (en) | 2000-12-05 | 2007-10-30 | Citrix Systems, Inc. | System and method for internet content collaboration |
US7596791B2 (en) | 2000-12-19 | 2009-09-29 | Emc Corporation | Methods and techniques for delivering rich Java applications over thin-wire connections with high performance and scalability |
US7363308B2 (en) | 2000-12-28 | 2008-04-22 | Fair Isaac Corporation | System and method for obtaining keyword descriptions of records from a large database |
US6636850B2 (en) * | 2000-12-28 | 2003-10-21 | Fairisaac And Company, Inc. | Aggregate score matching system for transaction records |
US7254773B2 (en) | 2000-12-29 | 2007-08-07 | International Business Machines Corporation | Automated spell analysis |
US20020133502A1 (en) | 2001-01-05 | 2002-09-19 | Rosenthal Richard Nelson | Method and system for interactive collection of information |
US20020091678A1 (en) | 2001-01-05 | 2002-07-11 | Miller Nancy E. | Multi-query data visualization processes, data visualization apparatus, computer-readable media and computer data signals embodied in a transmission medium |
CA2433996C (en) | 2001-01-09 | 2012-03-13 | British Telecommunications Public Limited Company | Software tool for heuristic search methods |
US6380910B1 (en) | 2001-01-10 | 2002-04-30 | Lucent Technologies Inc. | Wireless communications device having a compact antenna cluster |
US7904595B2 (en) | 2001-01-18 | 2011-03-08 | Sdl International America Incorporated | Globalization management system and method therefor |
US6426723B1 (en) | 2001-01-19 | 2002-07-30 | Nortel Networks Limited | Antenna arrangement for multiple input multiple output communications systems |
US7917888B2 (en) | 2001-01-22 | 2011-03-29 | Symbol Technologies, Inc. | System and method for building multi-modal and multi-channel applications |
US6526440B1 (en) * | 2001-01-30 | 2003-02-25 | Google, Inc. | Ranking search results by reranking the results based on local inter-connectivity |
US7581230B2 (en) | 2001-02-06 | 2009-08-25 | Siebel Systems, Inc. | Adaptive communication application programming interface |
US6983238B2 (en) | 2001-02-07 | 2006-01-03 | American International Group, Inc. | Methods and apparatus for globalizing software |
US6804677B2 (en) | 2001-02-26 | 2004-10-12 | Ori Software Development Ltd. | Encoding semi-structured data for efficient search and browsing |
GB2373073A (en) * | 2001-03-08 | 2002-09-11 | Escher Technologies Ltd | Process and system for developing validated and optimised object-oriented software |
US7194454B2 (en) | 2001-03-12 | 2007-03-20 | Lucent Technologies | Method for organizing records of database search activity by topical relevance |
US6771706B2 (en) | 2001-03-23 | 2004-08-03 | Qualcomm Incorporated | Method and apparatus for utilizing channel state information in a wireless communication system |
US7363388B2 (en) | 2001-03-28 | 2008-04-22 | Siebel Systems, Inc. | Method and system for direct server synchronization with a computing device |
US6829655B1 (en) | 2001-03-28 | 2004-12-07 | Siebel Systems, Inc. | Method and system for server synchronization with a computing device via a companion device |
US7174514B2 (en) | 2001-03-28 | 2007-02-06 | Siebel Systems, 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 |
US20030206192A1 (en) | 2001-03-31 | 2003-11-06 | Mingte Chen | Asynchronous message push to web browser |
US20030018705A1 (en) | 2001-03-31 | 2003-01-23 | Mingte Chen | Media-independent communication server |
US7930196B2 (en) | 2001-04-11 | 2011-04-19 | Fair Isaac Corporation | Model-based and data-driven analytic support for strategy development |
US6732095B1 (en) | 2001-04-13 | 2004-05-04 | Siebel Systems, Inc. | Method and apparatus for mapping between XML and relational representations |
US7257820B2 (en) | 2001-04-14 | 2007-08-14 | Siebel Systems, Inc. | Method and system for using integration objects with enterprise business applications |
GB0110326D0 (en) | 2001-04-27 | 2001-06-20 | Ibm | Method and apparatus for interoperation between legacy software and screen reader programs |
US7761288B2 (en) | 2001-04-30 | 2010-07-20 | Siebel Systems, Inc. | Polylingual simultaneous shipping of software |
US6934702B2 (en) | 2001-05-04 | 2005-08-23 | Sun Microsystems, Inc. | Method and system of routing messages in a distributed search network |
US7171415B2 (en) | 2001-05-04 | 2007-01-30 | Sun Microsystems, Inc. | Distributed information discovery through searching selected registered information providers |
US7089193B2 (en) | 2001-05-09 | 2006-08-08 | Prochain Solutions, Inc. | Multiple project scheduling system |
US7000199B2 (en) | 2001-05-09 | 2006-02-14 | Fairisaac And Company Inc. | Methodology for viewing large strategies via a computer workstation |
US6832248B1 (en) * | 2001-05-10 | 2004-12-14 | Agami Systems, Inc. | System and method for managing usage quotas |
US7073177B2 (en) * | 2001-05-10 | 2006-07-04 | Sun Microsystems, Inc. | Resource managing system for changing resource consumption state of the lower priority resource entity to more restrictive state when resource reached critical level |
US6785341B2 (en) | 2001-05-11 | 2004-08-31 | Qualcomm Incorporated | Method and apparatus for processing data in a multiple-input multiple-output (MIMO) communication system utilizing channel state information |
US6856992B2 (en) | 2001-05-15 | 2005-02-15 | Metatomix, Inc. | Methods and apparatus for real-time business visibility using persistent schema-less data storage |
US7058637B2 (en) | 2001-05-15 | 2006-06-06 | Metatomix, Inc. | Methods and apparatus for enterprise application integration |
US6925457B2 (en) | 2001-07-27 | 2005-08-02 | Metatomix, Inc. | Methods and apparatus for querying a relational data store using schema-less queries |
EP1405067A2 (en) | 2001-05-23 | 2004-04-07 | University Of Florida | Method and apparatus for detecting illicit substances |
US6782383B2 (en) | 2001-06-18 | 2004-08-24 | Siebel Systems, Inc. | System and method to implement a persistent and dismissible search center frame |
US6728702B1 (en) * | 2001-06-18 | 2004-04-27 | Siebel Systems, Inc. | System and method to implement an integrated search center supporting a full-text search and query on a database |
US6763351B1 (en) | 2001-06-18 | 2004-07-13 | Siebel Systems, Inc. | Method, apparatus, and system for attaching search results |
US6711565B1 (en) | 2001-06-18 | 2004-03-23 | Siebel Systems, Inc. | Method, apparatus, and system for previewing search results |
US6792420B2 (en) | 2001-06-29 | 2004-09-14 | International Business Machines Corporation | Method, system, and program for optimizing the processing of queries involving set operators |
US20030004934A1 (en) | 2001-06-29 | 2003-01-02 | Richard Qian | Creating and managing portable user preferences for personalizion of media consumption from device to device |
US7130861B2 (en) | 2001-08-16 | 2006-10-31 | Sentius International Corporation | Automated creation and delivery of database content |
US7580871B2 (en) | 2001-08-31 | 2009-08-25 | Siebel Systems, Inc. | Method to generate a customizable product configurator |
US20030050834A1 (en) | 2001-09-07 | 2003-03-13 | Sergio Caplan | System and method for dynamic customizable interactive portal active during select computer time |
US7103875B1 (en) | 2001-09-21 | 2006-09-05 | Siebel Systems, Inc. | Methods and apparatus for integrated, automatic pseudo localization of software |
US7028225B2 (en) | 2001-09-25 | 2006-04-11 | Path Communications, Inc. | Application manager for monitoring and recovery of software based application processes |
AUPR796701A0 (en) | 2001-09-27 | 2001-10-25 | Plugged In Communications Pty Ltd | Database query system and method |
AUPR796801A0 (en) | 2001-09-27 | 2001-10-25 | Plugged In Communications Pty Ltd | Computer user interface tool for navigation of data stored in directed graphs |
US20030065544A1 (en) | 2001-09-28 | 2003-04-03 | Elzinga C. Bret | Method and system for performing dynamic scheduling |
US6978445B2 (en) | 2001-09-28 | 2005-12-20 | Siebel Systems, Inc. | Method and system for supporting user navigation in a browser environment |
US6993712B2 (en) | 2001-09-28 | 2006-01-31 | Siebel Systems, Inc. | System and method for facilitating user interaction in a browser environment |
US6724399B1 (en) | 2001-09-28 | 2004-04-20 | Siebel Systems, Inc. | Methods and apparatus for enabling keyboard accelerators in applications implemented via a browser |
US7962565B2 (en) | 2001-09-29 | 2011-06-14 | Siebel Systems, Inc. | Method, apparatus and system for a mobile web client |
US8359335B2 (en) | 2001-09-29 | 2013-01-22 | Siebel Systems, Inc. | Computing system and method to implicitly commit unsaved data for a world wide web application |
US6901595B2 (en) | 2001-09-29 | 2005-05-31 | Siebel Systems, Inc. | Method, apparatus, and system for implementing a framework to support a web-based application |
US7146617B2 (en) | 2001-09-29 | 2006-12-05 | Siebel Systems, Inc. | Method, apparatus, and system for implementing view caching in a framework to support web-based applications |
US20030084401A1 (en) | 2001-10-16 | 2003-05-01 | Abel Todd J. | Efficient web page localization |
US7064766B2 (en) | 2001-10-18 | 2006-06-20 | Microsoft Corporation | Intelligent caching data structure for immediate mode graphics |
US6954737B2 (en) | 2001-11-05 | 2005-10-11 | Johnsondiversey, Inc. | Method and apparatus for work management for facility maintenance |
US20040054610A1 (en) | 2001-11-28 | 2004-03-18 | Monetaire | Monetaire wealth management platform |
US7289793B2 (en) | 2001-12-03 | 2007-10-30 | Scott Gilbert | 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 |
AU2002366924A1 (en) | 2001-12-12 | 2003-07-09 | Nec Corporation | Electronic document reading system and method |
US20070203756A1 (en) | 2001-12-17 | 2007-08-30 | Siebel Systems, Inc. | Configuration of employee benefit plans |
US6804330B1 (en) | 2002-01-04 | 2004-10-12 | Siebel Systems, Inc. | Method and system for accessing CRM data via voice |
US7536294B1 (en) | 2002-01-08 | 2009-05-19 | Oracle International Corporation | Method and apparatus for translating computer programs |
US7334039B1 (en) | 2002-02-01 | 2008-02-19 | Oracle International Corporation | Techniques for generating rules for a dynamic rule-based system that responds to requests for a resource on a network |
US6892309B2 (en) * | 2002-02-08 | 2005-05-10 | Enterasys Networks, Inc. | Controlling usage of network resources by a user at the user's entry point to a communications network based on an identity of the user |
US7058890B2 (en) | 2002-02-13 | 2006-06-06 | Siebel Systems, Inc. | Method and system for enabling connectivity to a data system |
US7263492B1 (en) | 2002-02-15 | 2007-08-28 | Fair Isaac Corporation | Sequencing models of healthcare related states |
US7813937B1 (en) | 2002-02-15 | 2010-10-12 | Fair Isaac Corporation | Consistency modeling of healthcare claims to detect fraud and abuse |
US7076558B1 (en) | 2002-02-27 | 2006-07-11 | Microsoft Corporation | User-centric consent management system and method |
US6928436B2 (en) | 2002-02-28 | 2005-08-09 | Ilog Sa | Interactive generation of graphical visualizations of large data structures |
US6856942B2 (en) * | 2002-03-09 | 2005-02-15 | Katrina Garnett | System, method and model for autonomic management of enterprise applications |
WO2003079225A1 (en) | 2002-03-11 | 2003-09-25 | University Of Southern California | Named entity translation |
US7162715B1 (en) * | 2002-03-16 | 2007-01-09 | I-Squared, Inc. | Method and apparatus for preemptive monitoring of software binaries by instruction interception and dynamic recompilation |
US7672853B2 (en) | 2002-03-29 | 2010-03-02 | Siebel Systems, Inc. | User interface for processing requests for approval |
US7131071B2 (en) | 2002-03-29 | 2006-10-31 | Siebel Systems, Inc. | Defining an approval process for requests for approval |
US6898645B2 (en) | 2002-04-17 | 2005-05-24 | Canon Kabushiki Kaisha | Dynamic generation of a user interface based on automatic device detection |
US6724329B2 (en) | 2002-04-24 | 2004-04-20 | Intel Corporation | Decision feedback equalization employing a lookup table |
TW574660B (en) * | 2002-05-16 | 2004-02-01 | Ind Tech Res Inst | Method targeting at range search and for information search complying with specified rule |
US6791372B2 (en) | 2002-06-04 | 2004-09-14 | Intel Corporation | Active cascode differential latch |
US7941348B2 (en) | 2002-06-10 | 2011-05-10 | Ebay Inc. | Method and system for scheduling transaction listings at a network-based transaction facility |
US7110937B1 (en) | 2002-06-20 | 2006-09-19 | Siebel Systems, Inc. | Translation leveraging |
US20070208553A1 (en) | 2002-06-20 | 2007-09-06 | Mark Hastings | Visual context for translation |
US7640548B1 (en) | 2002-06-21 | 2009-12-29 | Siebel Systems, Inc. | Task based user interface |
JP4528116B2 (en) * | 2002-06-25 | 2010-08-18 | インターナショナル・ビジネス・マシーンズ・コーポレーション | Method and system for monitoring application performance in a distributed environment |
US7594181B2 (en) | 2002-06-27 | 2009-09-22 | Siebel Systems, Inc. | Prototyping graphical user interfaces |
US8639542B2 (en) | 2002-06-27 | 2014-01-28 | Siebel Systems, Inc. | Method and apparatus to facilitate development of a customer-specific business process model |
US7437720B2 (en) | 2002-06-27 | 2008-10-14 | Siebel Systems, Inc. | Efficient high-interactivity user interface for client-server applications |
US6754475B1 (en) | 2002-06-28 | 2004-06-22 | Motorola, Inc. | Transmission performance measurement and use thereof |
US20040133416A1 (en) | 2002-07-18 | 2004-07-08 | Norio Fukuoka | Information terminal device, method of acquiring information corresponding to language identification information from server and program thereof, network system, additional function purchasing progam, and program function adding method |
WO2004010319A2 (en) * | 2002-07-22 | 2004-01-29 | Thought, Inc. | Dynamic object- driven database manipulation and mapping system |
US7194413B2 (en) | 2002-07-31 | 2007-03-20 | Deere & Company | Method of providing localized information from a single global transformation source |
US6940917B2 (en) | 2002-08-27 | 2005-09-06 | Qualcomm, Incorporated | Beam-steering and beam-forming for wideband MIMO/MISO systems |
US6847970B2 (en) * | 2002-09-11 | 2005-01-25 | International Business Machines Corporation | Methods and apparatus for managing dependencies in distributed systems |
JP4032232B2 (en) | 2002-09-18 | 2008-01-16 | 株式会社ケーヒン | Fuel distribution pipes in fuel injectors |
GB2394548B (en) * | 2002-10-21 | 2005-12-14 | Abb Offshore Systems Ltd | Monitoring a microseismic event |
US20040088199A1 (en) * | 2002-10-31 | 2004-05-06 | Childress Allen B. | Method of forming a business rule |
EP1561178A4 (en) | 2002-11-15 | 2009-08-12 | Fair Isaac Corp | Fraud and abuse detection and entity profiling in hierarchical coded payment systems |
US8332828B2 (en) | 2002-11-20 | 2012-12-11 | Purenative Software Corporation | System for translating diverse programming languages |
US20040103014A1 (en) | 2002-11-25 | 2004-05-27 | Teegan Hugh A. | System and method for composing and constraining automated workflow |
US7024141B2 (en) | 2002-12-13 | 2006-04-04 | Ricoh Company, Ltd. | Developing device and process cartridge for an image forming apparatus |
US7509251B2 (en) | 2002-12-23 | 2009-03-24 | International Business Machines Corporation | Mock translating software applications at runtime |
JP2006512670A (en) | 2002-12-31 | 2006-04-13 | シーベル・システムズ・インコーポレーテッド | Method and apparatus for an integrated process modeler |
US7610575B2 (en) | 2003-01-08 | 2009-10-27 | Consona Crm Inc. | System and method for the composition, generation, integration and execution of business processes over a network |
JP4787460B2 (en) * | 2003-01-17 | 2011-10-05 | 日本電気株式会社 | System performance prediction method and method based on performance measurement of software components |
US7519541B2 (en) | 2003-01-29 | 2009-04-14 | Cerner Innovation, Inc. | System and method in a computer system for managing a number of attachments associated with a patient |
US7058367B1 (en) | 2003-01-31 | 2006-06-06 | At&T Corp. | Rate-adaptive methods for communicating over multiple input/multiple output wireless systems |
US20040162822A1 (en) * | 2003-02-13 | 2004-08-19 | Khachatur Papanyan | Method and apparatus for converting in-line database queries to stored procedures |
US6927728B2 (en) | 2003-03-13 | 2005-08-09 | Motorola, Inc. | Method and apparatus for multi-antenna transmission |
WO2004086197A2 (en) | 2003-03-24 | 2004-10-07 | Siebel Systems, Inc. | Custom common object |
US7904340B2 (en) | 2003-03-24 | 2011-03-08 | Siebel Systems, Inc. | Methods and computer-readable medium for defining a product model |
US7711680B2 (en) | 2003-03-24 | 2010-05-04 | Siebel Systems, Inc. | Common common object |
US8762415B2 (en) | 2003-03-25 | 2014-06-24 | Siebel Systems, Inc. | Modeling of order data |
US7124145B2 (en) | 2003-03-27 | 2006-10-17 | Millennium It (Usa) Inc. | System and method for dynamic business logic rule integration |
US20040220792A1 (en) * | 2003-04-30 | 2004-11-04 | Gallanis Peter Thomas | Performance modeling for information systems |
US6976144B1 (en) * | 2003-05-06 | 2005-12-13 | Pegasystems, Inc. | Methods and apparatus for digital data processing with mutable inheritance |
US7269544B2 (en) | 2003-05-20 | 2007-09-11 | Hewlett-Packard Development Company, L.P. | System and method for identifying special word usage in a document |
WO2005001627A2 (en) | 2003-06-04 | 2005-01-06 | Rulespower, Inc. | Relational logic management system |
US7409336B2 (en) | 2003-06-19 | 2008-08-05 | Siebel Systems, Inc. | Method and system for searching data based on identified subset of categories and relevance-scored text representation-category combinations |
US20040260659A1 (en) | 2003-06-23 | 2004-12-23 | Len Chan | Function space reservation system |
EP1492232A1 (en) | 2003-06-27 | 2004-12-29 | Dialog Semiconductor GmbH | Comparator with high-voltage inputs in an extended CMOS process for higher voltage levels |
US7237227B2 (en) | 2003-06-30 | 2007-06-26 | Siebel Systems, Inc. | Application user interface template with free-form layout |
EP1690210A2 (en) | 2003-07-07 | 2006-08-16 | Metatomix, Inc. | Surveillance, monitoring and real-time events platform |
JP4400126B2 (en) * | 2003-08-08 | 2010-01-20 | 株式会社日立製作所 | Centralized disk usage control method in virtual centralized network storage system |
US7178109B2 (en) * | 2003-08-12 | 2007-02-13 | Chordiant Software, Inc. | Process/viewer interface |
US7596504B2 (en) | 2003-08-20 | 2009-09-29 | International Business Machines Corporation | Management of support center calls |
US20050049924A1 (en) | 2003-08-27 | 2005-03-03 | Debettencourt Jason | Techniques for use with application monitoring to obtain transaction data |
US8635218B2 (en) | 2003-09-02 | 2014-01-21 | International Business Machines Corporation | Generation of XSLT style sheets for different portable devices |
US6918222B2 (en) | 2003-09-09 | 2005-07-19 | Illinois Tool Works Inc. | Fastener for spacing object from substrate |
US7318020B1 (en) | 2003-10-08 | 2008-01-08 | Microsoft Corporation | Methods and systems for external localization |
JP2005149126A (en) | 2003-11-14 | 2005-06-09 | Sony Corp | Information acquiring system and method, and information processing program |
JP3971368B2 (en) | 2003-11-18 | 2007-09-05 | 株式会社東芝 | A signal intensity detection circuit and an amplification factor control system using the same. |
US7412388B2 (en) | 2003-12-12 | 2008-08-12 | International Business Machines Corporation | Language-enhanced programming tools |
US7321897B2 (en) * | 2004-01-22 | 2008-01-22 | Microsoft Corporation | Binary dependency database |
US7779395B1 (en) | 2004-03-05 | 2010-08-17 | Adobe Systems Incorporated | System and method for routing data |
US7010465B2 (en) | 2004-03-29 | 2006-03-07 | Microsoft Corporation | Scalability test and analysis |
US20050228875A1 (en) * | 2004-04-13 | 2005-10-13 | Arnold Monitzer | System for estimating processing requirements |
US20050234882A1 (en) * | 2004-04-20 | 2005-10-20 | Calpont Corporation | Data structure for a hardware database management system |
US7665063B1 (en) | 2004-05-26 | 2010-02-16 | Pegasystems, Inc. | Integration of declarative rule-based processing with procedural programming |
US7076493B2 (en) * | 2004-05-28 | 2006-07-11 | Metadata, Llc | Defining a data dependency path through a body of related data |
US7424485B2 (en) | 2004-06-03 | 2008-09-09 | Microsoft Corporation | Method and apparatus for generating user interfaces based upon automation with full flexibility |
US20060080082A1 (en) | 2004-08-23 | 2006-04-13 | Geneva Software Technologies Limited | System and method for product migration in multiple languages |
US20060063138A1 (en) | 2004-09-16 | 2006-03-23 | Sap Aktiengesellschaft | Methods and systems for adapting data from a user interface |
WO2006036887A2 (en) | 2004-09-28 | 2006-04-06 | Yost David A | Improved system of gui text cursor, caret, and selection |
US7983895B2 (en) | 2004-11-09 | 2011-07-19 | Sony Online Entertainment Llc | System and method for generating grammatically correct text strings |
US7577561B2 (en) | 2004-11-09 | 2009-08-18 | Sony Online Entertainment Llc | System and method for generating a target language markup language text template |
US7554522B2 (en) | 2004-12-23 | 2009-06-30 | Microsoft Corporation | Personalization of user accessibility options |
US20060149751A1 (en) | 2004-12-30 | 2006-07-06 | Sripad Jade | Custom templates |
US7555645B2 (en) | 2005-01-06 | 2009-06-30 | Oracle International Corporation | Reactive audit protection in the database (RAPID) |
US8335704B2 (en) | 2005-01-28 | 2012-12-18 | Pegasystems Inc. | Methods and apparatus for work management and routing |
US7653528B2 (en) | 2005-03-08 | 2010-01-26 | Microsoft Corporation | Resource authoring incorporating ontology |
JP2006252049A (en) | 2005-03-09 | 2006-09-21 | Fuji Xerox Co Ltd | Translation system, translation method and program |
US7302417B2 (en) | 2005-05-02 | 2007-11-27 | Synopsys, Inc. | Method and apparatus for improving efficiency of constraint solving |
US20060271920A1 (en) | 2005-05-24 | 2006-11-30 | Wael Abouelsaadat | Multilingual compiler system and method |
US7460884B2 (en) | 2005-06-29 | 2008-12-02 | Microsoft Corporation | Data buddy |
US8140362B2 (en) | 2005-08-30 | 2012-03-20 | International Business Machines Corporation | Automatically processing dynamic business rules in a content management system |
US20070055938A1 (en) | 2005-09-07 | 2007-03-08 | Avaya Technology Corp. | Server-based method for providing internet content to users with disabilities |
CN1936849A (en) * | 2005-09-19 | 2007-03-28 | 国际商业机器公司 | Resource dynamic regulation method and apparatus |
JP2007141123A (en) | 2005-11-22 | 2007-06-07 | Internatl Business Mach Corp <Ibm> | Link of same character strings in different files |
US8069153B2 (en) | 2005-12-02 | 2011-11-29 | Salesforce.Com, Inc. | Systems and methods for securing customer data in a multi-tenant environment |
US20070136068A1 (en) | 2005-12-09 | 2007-06-14 | Microsoft Corporation | Multimodal multilingual devices and applications for enhanced goal-interpretation and translation for service providers |
US20070143851A1 (en) * | 2005-12-21 | 2007-06-21 | Fiberlink | Method and systems for controlling access to computing resources based on known security vulnerabilities |
US7640222B2 (en) | 2006-03-03 | 2009-12-29 | Pegasystems Inc. | Rules base systems and methods with circumstance translation |
US20070233902A1 (en) | 2006-03-30 | 2007-10-04 | Alan Trefler | User interface methods and apparatus for rules processing |
US8924335B1 (en) | 2006-03-30 | 2014-12-30 | Pegasystems Inc. | Rule-based user interface conformance methods |
US20090132232A1 (en) | 2006-03-30 | 2009-05-21 | Pegasystems Inc. | Methods and apparatus for implementing multilingual software applications |
US20080208785A1 (en) | 2006-03-30 | 2008-08-28 | Pegasystems, Inc. | User interface methods and apparatus for rules processing |
US7827155B2 (en) | 2006-04-21 | 2010-11-02 | Microsoft Corporation | System for processing formatted data |
US7937690B2 (en) * | 2006-05-23 | 2011-05-03 | Hewlett-Packard Development Company, L.P. | Evaluating performance of software application |
EP1870804A1 (en) | 2006-06-22 | 2007-12-26 | Microsoft Corporation | Dynamic software localization |
US20080077384A1 (en) | 2006-09-22 | 2008-03-27 | International Business Machines Corporation | Dynamically translating a software application to a user selected target language that is not natively provided by the software application |
US20080085502A1 (en) | 2006-10-04 | 2008-04-10 | Ecollege.Com | Web service api for student information and course management systems |
US8037329B2 (en) * | 2007-01-31 | 2011-10-11 | Hewlett-Packard Development Company, L.P. | Systems and methods for determining power consumption profiles for resource users and using the profiles for resource allocation |
JP4396994B2 (en) | 2007-02-09 | 2010-01-13 | インターナショナル・ビジネス・マシーンズ・コーポレーション | Resource file translation verification method, apparatus, and program |
US8250525B2 (en) | 2007-03-02 | 2012-08-21 | Pegasystems Inc. | Proactive performance management for multi-user enterprise software systems |
US20090158407A1 (en) | 2007-12-13 | 2009-06-18 | Fiberlink Communications Corporation | Api translation for network access control (nac) agent |
US7975217B2 (en) | 2007-12-21 | 2011-07-05 | Google Inc. | Embedding metadata with displayable content and applications thereof |
US7984035B2 (en) | 2007-12-28 | 2011-07-19 | Microsoft Corporation | Context-based document search |
US20100217737A1 (en) | 2009-02-20 | 2010-08-26 | Ajay Shama | Method and system for business rules management |
US20120041921A1 (en) | 2010-08-16 | 2012-02-16 | Salesforce.Com, Inc. | Mechanism for facilitating efficient business rules management and data processing |
US8880487B1 (en) | 2011-02-18 | 2014-11-04 | Pegasystems Inc. | Systems and methods for distributed rules processing |
-
2007
- 2007-03-02 US US11/681,269 patent/US8250525B2/en active Active
-
2008
- 2008-02-29 EP EP08731127.0A patent/EP2115581B1/en active Active
- 2008-02-29 WO PCT/US2008/055503 patent/WO2008109441A1/en active Application Filing
-
2012
- 2012-06-28 US US13/536,079 patent/US9189361B2/en active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20010052108A1 (en) * | 1999-08-31 | 2001-12-13 | Michel K. Bowman-Amuah | System, method and article of manufacturing for a development architecture framework |
US20040117759A1 (en) * | 2001-02-22 | 2004-06-17 | Rippert Donald J | Distributed development environment for building internet applications by developers at remote locations |
US20060064486A1 (en) * | 2004-09-17 | 2006-03-23 | Microsoft Corporation | Methods for service monitoring and control |
US20060173871A1 (en) * | 2005-02-01 | 2006-08-03 | Seiko Epson Corporation | Resource managing system, resource managing program and resource managing method |
Cited By (20)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8479157B2 (en) | 2004-05-26 | 2013-07-02 | Pegasystems Inc. | Methods and apparatus for integration of declarative rule-based processing with procedural programming in a digital data-processing evironment |
US8959480B2 (en) | 2004-05-26 | 2015-02-17 | Pegasystems Inc. | Methods and apparatus for integration of declarative rule-based processing with procedural programming in a digital data-processing environment |
US8335704B2 (en) | 2005-01-28 | 2012-12-18 | Pegasystems Inc. | Methods and apparatus for work management and routing |
US9658735B2 (en) | 2006-03-30 | 2017-05-23 | Pegasystems Inc. | Methods and apparatus for user interface optimization |
US10838569B2 (en) | 2006-03-30 | 2020-11-17 | Pegasystems Inc. | Method and apparatus for user interface non-conformance detection and correction |
US8924335B1 (en) | 2006-03-30 | 2014-12-30 | Pegasystems Inc. | Rule-based user interface conformance methods |
US9189361B2 (en) | 2007-03-02 | 2015-11-17 | Pegasystems Inc. | Proactive performance management for multi-user enterprise software systems |
US8250525B2 (en) | 2007-03-02 | 2012-08-21 | Pegasystems Inc. | Proactive performance management for multi-user enterprise software systems |
US10467200B1 (en) | 2009-03-12 | 2019-11-05 | Pegasystems, Inc. | Techniques for dynamic data processing |
US9678719B1 (en) | 2009-03-30 | 2017-06-13 | Pegasystems Inc. | System and software for creation and modification of software |
US9270743B2 (en) | 2011-02-18 | 2016-02-23 | Pegasystems Inc. | Systems and methods for distributed rules processing |
US8880487B1 (en) | 2011-02-18 | 2014-11-04 | Pegasystems Inc. | Systems and methods for distributed rules processing |
US9195936B1 (en) | 2011-12-30 | 2015-11-24 | Pegasystems Inc. | System and method for updating or modifying an application without manual coding |
US10572236B2 (en) | 2011-12-30 | 2020-02-25 | Pegasystems, Inc. | System and method for updating or modifying an application without manual coding |
US10469396B2 (en) | 2014-10-10 | 2019-11-05 | Pegasystems, Inc. | Event processing with enhanced throughput |
US11057313B2 (en) | 2014-10-10 | 2021-07-06 | Pegasystems Inc. | Event processing with enhanced throughput |
US10698599B2 (en) | 2016-06-03 | 2020-06-30 | Pegasystems, Inc. | Connecting graphical shapes using gestures |
US10698647B2 (en) | 2016-07-11 | 2020-06-30 | Pegasystems Inc. | Selective sharing for collaborative application usage |
US11048488B2 (en) | 2018-08-14 | 2021-06-29 | Pegasystems, Inc. | Software code optimizer and method |
US11567945B1 (en) | 2020-08-27 | 2023-01-31 | Pegasystems Inc. | Customized digital content generation systems and methods |
Also Published As
Publication number | Publication date |
---|---|
US20130007267A1 (en) | 2013-01-03 |
US9189361B2 (en) | 2015-11-17 |
EP2115581A1 (en) | 2009-11-11 |
US8250525B2 (en) | 2012-08-21 |
EP2115581A4 (en) | 2012-11-28 |
EP2115581B1 (en) | 2019-06-26 |
US20080216055A1 (en) | 2008-09-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP2115581B1 (en) | Proactive performance management for multi-user enterprise software systems | |
Ibidunmoye et al. | Performance anomaly detection and bottleneck identification | |
EP3340057B1 (en) | Container monitoring method and apparatus | |
Bruneo et al. | Workload-based software rejuvenation in cloud systems | |
US8365182B2 (en) | Method and system for provisioning of resources | |
US8255355B2 (en) | Adaptive method and system with automatic scanner installation | |
RU2526711C2 (en) | Service performance manager with obligation-bound service level agreements and patterns for mitigation and autoprotection | |
US7996842B2 (en) | Computer resource management for workloads or applications based on service level objectives | |
US6959265B1 (en) | User-centric measurement of quality of service in a computer network | |
US8826286B2 (en) | Monitoring performance of workload scheduling systems based on plurality of test jobs | |
US7954014B2 (en) | Health check framework for enterprise systems | |
US6675128B1 (en) | Methods and apparatus for performance management using self-adjusting model-based policies | |
US20050262505A1 (en) | Method and apparatus for dynamic memory resource management | |
KR20170032360A (en) | System and method for resource isolation and consumption in a multitenant application server environment | |
US20100319004A1 (en) | Policy Management for the Cloud | |
US20060025985A1 (en) | Model-Based system management | |
US20070143767A1 (en) | Method, system and computer program for dynamic resources allocation | |
CN101297536A (en) | Method and system for preparing to perform system management tasks on an endpoint | |
US8312466B2 (en) | Restricting resources consumed by ghost agents | |
US8555286B2 (en) | Method, system, and apparatus for establishing a software configurable computing environment | |
Procaccianti et al. | A catalogue of green architectural tactics for the cloud | |
JP2005108220A (en) | Real-time sla impact analysis | |
CA2480955A1 (en) | System and method for monitoring a computer application | |
Fareghzadeh et al. | Toward holistic performance management in clouds: taxonomy, challenges and opportunities | |
US20080221820A1 (en) | System for First Pass Filtering of Anomalies and Providing a Base Confidence Level for Resource Usage Prediction in a Utility Computing Environment |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 08731127 Country of ref document: EP Kind code of ref document: A1 |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2008731127 Country of ref document: EP |
|
NENP | Non-entry into the national phase |
Ref country code: DE |