|Publication number||USRE38865 E1|
|Application number||US 10/141,383|
|Publication date||Nov 1, 2005|
|Filing date||May 8, 2002|
|Priority date||Apr 14, 1998|
|Also published as||US6059842|
|Publication number||10141383, 141383, US RE38865 E1, US RE38865E1, US-E1-RE38865, USRE38865 E1, USRE38865E1|
|Inventors||Daniel Peter Dumarot, David Alan Stevenson, Nicolas Richard Dono, James Randall Moulic, Clifford Alan Pickover, Bengt-Olaf Schneider, Adelbert Smith|
|Original Assignee||International Business Machines Corporation|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (18), Referenced by (14), Classifications (13), Legal Events (4)|
|External Links: USPTO, USPTO Assignment, Espacenet|
This invention relates to the optimization of computer software and hardware, and in particular to optimization according to user-specified preferences, databases, and dynamic monitoring of system behavior and performance.
Computer operating systems include a large number of parameters, many of which may be queried, controlled, and changed in order to alter the characteristics of the computer system. Similarly, software applications running on computer systems also often include a large number of parameters, many of which may be controlled and changed to alter the characteristics of the application running on the computer system. As an example, in Microsoft's Windows NT operating system, the resolution and color characteristics of the computer system's display may be changed by selecting the “Control Panel” icon from a “Settings” menu item. When the control panel is displayed, a user is presented with a set of new icons, one of which (“Display Properties”) may be selected to bring up another panel containing a set of tabs. The “Settings” tab on the “Display Properties” panel may be selected which allows a user to manually change the number of colors, resolution, video refresh rate, font size, and related graphical characteristics. The user specifies the refresh frequency by selecting from a pull-down menu list of available settings (e.g. 60 Hz, 70 Hz, etc.). The user can specify the screen resolution by selecting a slider icon and moving it right or left to increase or decrease the screen resolution (e.g., from 1024×1280 pixels to 600×800 pixels). Some of these settings may affect the performance of applications running on the system. For example, decreasing the color resolution and screen resolution may increase the speed of some graphics applications.
This example focuses on system settings. When one also considers the numerous application settings and various different hardware configurations available to users, and the interaction of all of these settings and configurations, the control accessing of the plurality of settings and configurations can be cumbersome and often requires detailed knowledge on the part of computer users. The need for a dynamic, semi-automatic, consolidated, and rule-based system that changes such settings and other aspects of the computer system, and makes recommendations, becomes apparent. Although many graphical user interfaces exist to control various aspects of the system (such as the graphical slider which controls screen resolution for Windows platforms) and in applications, the need for improved graphical user interfaces becomes apparent as computer systems become more complex.
With reference now to the figures and in particular to
Graphical user interfaces (GUIs) provide ways for users of computers and other devices to effectively communicate with the computer. In GUIs, available applications and data sets are often represented by icons 63 consisting of small graphical representations which can be selected by a user and moved on the screen. The data sets (including pages of information) and applications may reside on the local computer or on a remote computer accessed over a network. The selection of icons often takes the place of typing in a command using a keyboard in order to initiate a program or access a data set. In general, icons are tiny on-screen symbols that simplify access to a program, command, or data file. Icons are often activated or selected by moving a mouse-controlled cursor onto the icon and pressing one or more times on a mouse button.
GUIs include graphical images on computer monitors and often consist of both icons and windows. (GUIs may also reside on the screens of televisions, kiosks, personal digital assistants (PDAs), automatic teller machines (AIMs), and on other devices and appliances such as ovens, cameras, video recorders and instrument consoles.) A computer window is a portion of the graphical image that appears on the monitor and is dedicated to some specific purpose. Windows allow the user to treat the graphical images on the computer monitor like a desktop where various files can remain open simultaneously. The user can control the size, shape, and position of the windows.
Although the use of GUls with icons usually simplifies a user's interactions with a computer, GUIs are often tedious and frustrating to use. Icons must be maintained in a logical manner. It is difficult to organize windows and icons when many are similarly displayed at the same time on a single device.
In a drag-and-drop GUI, icons are selected 64 and moved 68 (i.e. “dragged”) to a target icon 69 to achieve a desired effect. For example, an icon representing a computer file stored on disk may be dragged over an icon containing an image of a printer in order to print the file, or dragged over an icon of a trash can to delete the file. An icon representing a page of information on the World Wide Web may be selected and dragged to a trash can to delete the link to the page of information. The page of information may be on the local machine or on a remote machine. A typical user's screen contains many icons, and only a subset of them will at anyone time be valid, useful targets for a selected icon. For example, it would not be useful to drag the icon representing a data file on top of an icon whose only purpose is to access an unrelated multimedia application.
Icons 63 could include static or animated graphics, text, multimedia presentations, and windows displaying TV broadcasts. Icons 63 could also include three dimensional images, for example, those used in virtual reality applications.
An object of this invention is a method and system for increasing the apparent speed of a computer by automatically optimizing software and hardware according to user-specified preferences.
Another object of this invention is to provide a method and system for increasing the apparent speed of a computer using a database.
Yet another object of this invention is to provide a method and system for effectively increasing the apparent speed of a computer based on results obtained by dynamically monitoring system behavior and performance.
This invention permits users to conveniently optimize software running on a computer. The term “optimize” refers to running of a computer system or software more efficiently, for example, by maximizing both the speed with which a software application runs and user satisfaction, and/or minimizing cost or resource use. “Optimization” includes the setting of various parameters in hardware, operating system software, or application software such that the system as a whole runs as efficiently as possible. These parameters might be set to optimize speed, system resource cost, or other variables corresponding to a user's satisfaction.
Accordingly, this invention provides for a method of enhancing, for example, program application performance on a computer system. With this invention configuration information and performance capabilities based on characteristics of the program/system are determined. Then, the configuration information and the performance capabilities are used to optimize configuration parameters of the program applications so as to enhance the performance of the workstation in running the program'system. Further, with this invention user preferences in the operation of the program are selected by, for example, dragging rule icons to a target optimizer icon to provide user selected rules of operation of the application program.
The invention will be further understood by reference to the following detailed description when read in conjunction with the accompanying drawings, wherein:
With reference now to
The core architecture includes a Central Processing Unit 165, memory controller 162, system memory 65, disk storage 70, disk storage controller 75, and graphics subsystem 166. The computer system 12 can be either a stand alone workstation or a server and a workstation connected to each other via a communications network such as the internet. A portion of the system memory is set aside for an optimizer-database cache 80. Additionally, file space 85 on the disk storage unit 70 may be set aside for the optimizer database 140. Generally speaking, a cache or buffer is a place where data (files, images, and other information) can be stored to avoid having to read the data from a slower device, such as a remote, network-attached computer disk. For instance, a disk cache can store information that can be read without accessing remote disk storage.
With reference now to
In step 320, the optimizer 136 monitors system 12 behavior. For example, the optimizer may query the current CPU use, memory use, or other activity 321 using operating system commands known to those skilled in the art. Also, a monitor program 137 may use such commands to monitor such activity. This monitor program 137 may contain a graphical user interface 139 that displays such activity in graphical form, such as with bar graphs, pie carts, numerical indicators, gauges, etc. This activity 321 may be stored in the form of dynamic values M1, M2, . . . , MN in settings 460 and read by the optimizer program 136. Alternatively, the values corresponding to system activity/use may be directly obtained using operating system commands. One benefit of storing the dynamic data is that the optimizer 136 may compare current to past system activity. In this step 320, the optimizer also may perform performance measurements to “benchmark” the system by running built-in test routines. For example, the optimizer may time the rotation of a 3-D graphical object to assess the speed of the graphics subsystem 166.
In step 325, the optimizer 136 reads user input. For example, the user may enter text or data at the keyboard 40 (or with various input devices 46, 48, 50, or by voice input using audio input device 51) that specifies a level of optimization 326. This level of optimization may control which of the application settings 420 are used to optimize the application in step 330 or optimize the system 12 in step 340. A user wishing to have maximum performance may, for example, sacrifice graphic quality controlled in applications settings 420, that are generally read upon invocation of application 138.
By way of example, the optimizer 136 can adjust the following parameter settings 420, in the Unigraphics control file to adjust performance. (Unigraphics is an graphically-intensive engineering application created by EDS.) The values for each of these settings may be determined in step 325 and stored in record 430.
Low Performance settings
High Performance settings
In this example, if a user sets suppressAutoRefresh to TRUE, the application performance can improve by reducing excess redrawing. “Low Performance” is generally correlated with higher graphical quality. The “level” of optimization 326 may correspond to the number of “high performance” settings selected. For example, highest performance (highest level of optimization) may correspond to the use of all the settings in their high performance states. Lower levels of optimization correspond to fewer of the high-performance settings being used. Those values that constitute high performance settings may be stored in application settings 420.
Similarly, the optimizer also optimizes system settings 440. These are settings independent of applications and generally associated with the computer or its hardware or software components. For example, the graphics card may have general settings that control the resolution, color depth, synchronization on vertical refresh, and other features. The disk may have a fragmentation state which may be altered. The size of “swap” spaces may be specified. These system settings are sometimes stored in the system registry or in initialization files which may be modified using methods known to those skilled in the art.
Returning to step 325 in
In step 350, the optimizer 136 may provide suggestions or recommendations 480, for example, in the form of specific text that is output to the user. This output may appear in the optimizer's graphical user interface 139, in a web browser 90, or as audible sound played through speakers 54 another audio output device. These recommendations may be used to warn the user of various conditions (e.g. “disk space is low”), or give suggestions on how to improve performance (e.g. “purchase more memory”). The optimizer contains rules 331, 341, 351 that it uses to make such optimizations 330, 340 and recommendations 350. For example, a rule may be: If A1=yes, and S1=200 MHz, or M1=90%, then make suggestion and change (in step 340) the graphic card settings (e.g. 450) that control “synchronization on vertical refresh”. In this example, S1 corresponds to the processor frequency, and M1 corresponds to the percentage of memory used. A rule may consist of a set of conditionals and Boolean operations (e.g. if A and B are true and C is false then make suggestions and take action).
Note that the suggestions 480, entire records 430, and rules 331, 341, 351 may be segregated into different files in database 400, stored at a local machine 12 or remote machine 130. Users may view (360) the rules 331, 341, 350, records 430, and suggestions 480 using graphical user interface 53, which may visually segregate these items based on origin of the suggestions (e.g. companies, individuals, etc.), severity, date, or other criteria. These rules and suggestions may be web accessible (using network 110) for dynamic optimization across the web using a propriety program product at the web server.
The optimizer in steps 330, 340 and 350 may learn 370 from a user's past activity. For example, if the user has always used an application with small files, and past CPU use has always been low (e.g. as stored in settings 470), the software optimizer can make suggestions (480), accordingly. Note that one benefit of having portions of the database 140 (e.g. the settings and suggestions) and rules 331, 341, and 351 on a remote machine 130 is that a company or system administrator can continually manage and update messages and rules as new information is provided by application vendors. When a user runs an application in 410, the user can make use of the latest information in the database. If the database 140 resides on a remote machine 130 the optimization 330, 340, and 350 can be performed either on the local machine or the remote machine. If performed on a remote machine, messages and other parameters are fed from the remote server 130 to the client 12 using the network 110.
In one embodiment, the optimizer icon 510 consists of different regions 520 to which iconic rules 540 are dragged. The optimizer software determines near what location 520 icon is positioned using techniques which are well known to those skilled in the art of GUI interfaces. In addition to performing general optimization, the optimizer icons 510 may be used to specify the ‘nature’ of the update; for example, one optimizer icon 510 may be specified for optimization concerning graphics, while another icon 511 may be specific for controlling all aspects of memory and disk space. The optimizer icon may change its graphical attribute such as color or brightness 570 in response to the information gained when the optimizer software applies the rules 541. For example, once a rule is successfully applied, then the optimizer region 520 may turn red 570. The iconic rules 541 may also change graphical attributes in a similar manner. (Changes in graphical characteristics of the iconic rules and optimizer icons are carried out in step 670 in FIG. 7).
The rule application can be carried out by the optimizer software by comparing the position 585 of icon 540 to values stored in a position file 596 which may be stored on disk.
The optimizer icon 510 may also contain graphical indications of regions 520, such as cutouts 530, to which iconic rules 540 may be dragged. In this manner, when the icons are placed in the optimizer icon 510 there can be a graphical indication 551 of the binding to the user. Additionally, the area around the cutout may change color or brightness 570 once an icon 540 is located in the cutout. The use of discrete cutouts 530 may be useful when only a limited number of rules may be used. The rules may be evident to the user by text 560 written on the optimizer icon or by colors 570.
The rule 541 represented by an icon 540 is applied 660. The icon 540 or optimizer icon 510 optionally may change color, brightness, texture, blink rate, shape, size, or other graphical attribute (see step 670). This graphical attribute may be a function of the nature of the rule. For example, an iconic rule that increases graphics quality may be red. An icon representing a rule that decreases graphics quality may be green. The optimizer icon may change colors when the rule is successfully applied or has a beneficial effect.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US5263164 *||Jan 9, 1991||Nov 16, 1993||Verifone, Inc.||Method and structure for determining transaction system hardware and software configurations|
|US5428791 *||Sep 29, 1994||Jun 27, 1995||International Computers Limited||Configuration mechanism for a computer system having generic user interface and component-specific builder modules|
|US5436748 *||Apr 28, 1993||Jul 25, 1995||Societe Anonyme Dite: Alcatel Cit||Automatically configurable optical system for connecting customer premises networks to a switching center of a telecommuncation network|
|US5497490 *||Jul 8, 1992||Mar 5, 1996||International Business Machines Corporation||Automatic reconfiguration of alterable systems|
|US5506952 *||Jan 3, 1994||Apr 9, 1996||International Business Machines Corporation||Method and system for guiding the formation of a correctly structured instruction for data processing systems|
|US5530887 *||Feb 28, 1994||Jun 25, 1996||International Business Machines Corporation||Methods and apparatus for providing automatic hardware device identification in computer systems that include multi-card adapters and/or multi-card planar complexes|
|US5613125 *||Aug 1, 1996||Mar 18, 1997||Motorola, Inc.||Method and system for selectively defining hardware parameters in an executable operating system program|
|US5668992 *||Aug 1, 1994||Sep 16, 1997||International Business Machines Corporation||Self-configuring computer system|
|US5668995 *||Apr 22, 1994||Sep 16, 1997||Ncr Corporation||Method and apparatus for capacity planning for multiprocessor computer systems in client/server environments|
|US5713009 *||Sep 8, 1995||Jan 27, 1998||Digital Equipment Corporation||Method and apparatus for configuring a computer system|
|US5745880 *||Oct 3, 1994||Apr 28, 1998||The Sabre Group, Inc.||System to predict optimum computer platform|
|US5784539 *||Nov 26, 1996||Jul 21, 1998||Client-Server-Networking Solutions, Inc.||Quality driven expert system|
|US5809282 *||Jun 7, 1995||Sep 15, 1998||Grc International, Inc.||Automated network simulation and optimization system|
|US5815152 *||Jun 19, 1997||Sep 29, 1998||Logical Software Solutions Corporation||Method and apparatus for defining and evaluating a graphic rule|
|US5822565 *||Aug 6, 1997||Oct 13, 1998||Digital Equipment Corporation||Method and apparatus for configuring a computer system|
|US5944819 *||Feb 18, 1993||Aug 31, 1999||Hewlett-Packard Company||Method and system to optimize software execution by a computer using hardware attributes of the computer|
|US5978594 *||Mar 6, 1997||Nov 2, 1999||Bmc Software, Inc.||System for managing computer resources across a distributed computing environment by first reading discovery information about how to determine system resources presence|
|US6177860 *||Jul 10, 1998||Jan 23, 2001||International Business Machines Corporation||Method and economical direct connected apparatus for deploying and tracking computers|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US7614007 *||Nov 3, 2009||International Business Machines Corporation||Executing multiple file management operations|
|US7757216 *||Jul 13, 2010||Orcle International Corporation||Application server performance tuning client interface|
|US7827535 *||Dec 10, 2003||Nov 2, 2010||Oracle International Corporation||Application performance tuning server-side component|
|US8321803 *||Nov 27, 2012||International Business Machines Corporation||Aggregating service components|
|US8572593 *||Sep 11, 2007||Oct 29, 2013||Oracle International Corporation||Simplifying determination of whether application specific parameters are setup for optimal performance of associated applications|
|US20030204714 *||Apr 24, 2002||Oct 30, 2003||Rothman Michael A.||Methods and apparatuses for uniform configuration for a computer system|
|US20050034117 *||Jul 9, 2004||Feb 10, 2005||Hitachi, Ltd.||Information processing apparatus and an information processing system|
|US20050132335 *||Dec 10, 2003||Jun 16, 2005||Jonathan Maron||Application performance tuning server-side component|
|US20050144267 *||Dec 10, 2003||Jun 30, 2005||Jonathan Maron||Application server performance tuning client interface|
|US20050160373 *||Jan 16, 2004||Jul 21, 2005||International Business Machines Corporation||Method and apparatus for executing multiple file management operations|
|US20060047794 *||Sep 2, 2004||Mar 2, 2006||Microsoft Corporation||Application of genetic algorithms to computer system tuning|
|US20070061429 *||Sep 12, 2005||Mar 15, 2007||Microsoft Corporation||Optimizing utilization of application resources|
|US20090037824 *||Sep 11, 2007||Feb 5, 2009||Oracle International Corporation||Simplifying determination of whether application specific parameters are setup for optimal performance of associated applications|
|US20090319951 *||Dec 24, 2009||International Business Machines Corporation||Aggregating Service Components|
|U.S. Classification||717/153, 715/961, 715/965, 715/967, 715/846|
|Cooperative Classification||Y10S715/967, Y10S706/922, Y10S715/965, G06F8/443, G06F11/3466, G06F9/44505|
|Sep 24, 2007||FPAY||Fee payment|
Year of fee payment: 8
|Jun 30, 2011||FPAY||Fee payment|
Year of fee payment: 12
|Feb 28, 2013||AS||Assignment|
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:INTERNATIONAL BUSINESS MACHINES CORPORATION;REEL/FRAME:029900/0285
Effective date: 20121231
Owner name: ACTIVISION PUBLISHING, INC., CALIFORNIA
|Feb 11, 2014||AS||Assignment|
Owner name: BANK OF AMERICA, N.A., TEXAS
Free format text: SECURITY AGREEMENT;ASSIGNOR:ACTIVISION PUBLISHING, INC.;REEL/FRAME:032240/0257
Effective date: 20140131