Jump to content

Examine individual changes

This page allows you to examine the variables generated by the Edit Filter for an individual change.

Variables generated for this change

VariableValue
Name of the user account (user_name)
'208.114.185.103'
Page ID (page_id)
10136
Page namespace (page_namespace)
0
Page title without namespace (page_title)
'Expert system'
Full page title (page_prefixedtitle)
'Expert system'
Action (action)
'edit'
Edit summary/reason (summary)
'/* Shells or Inference Engine */ '
Whether or not the edit is marked as minor (no longer in use) (minor_edit)
false
Old page wikitext, before the edit (old_wikitext)
'{{article issues | refimprove=November 2008 | cleanup=November 2008 }} {{about|a software type|the Italian software company|Expert System S.p.A.}} An '''expert system''' is [[software]] that attempts to provide an answer to a problem, or clarify uncertainties where normally one or more human [[expert]]s would need to be consulted. Expert systems are most common in a specific [[problem domain]], and is a traditional application and/or subfield of [[artificial intelligence]]. A wide variety of methods can be used to simulate the performance of the expert however common to most or all are 1) the creation of a [[knowledge base]] which uses some [[knowledge representation]] formalism to capture the [[Subject Matter Expert]]'s (SME) knowledge and 2) a process of gathering that knowledge from the SME and codifying it according to the formalism, which is called [[knowledge engineering]]. Expert systems may or may not have learning components but a third common element is that once the system is developed it is proven by being placed in the same real world problem solving situation as the human SME, typically as an aid to human workers or a supplement to some information system. Expert systems were introduced by researchers in the Stanford Heuristic Programming Project, [[Edward Feigenbaum]], PI, with the [[Dendral]] and [[Mycin]] systems. Principal contributors to the technology were Bruce Buchanan, Edward Shortliffe, Randall Davis, William vanMelle, Carli Scott, and others at Stanford. Expert systems were among the first truly successful forms of AI software. <ref>{{Harvnb|ACM|1998|loc=I.2.1|ref=ACM1998}}</ref> <ref>{{Harvnb|Russell|Norvig|2003|pp=22−24}}</ref> <ref>{{Harvnb|Luger|Stubblefield|2004|pp=227-331}}</ref> <ref>{{Harvnb|Nilsson|1998|loc=chpt. 17.4}}</ref> <ref>{{Harvnb|McCorduck|2004|pp=327-335, 434-435}}</ref> <ref>{{Harvnb|Crevier|1993|pp=145-62, 197−203}}</ref> The topic of expert systems has many points of contact with general [[systems theory]], [[operations research]], [[business process reengineering]] and various topics in [[applied mathematics]] and [[management science]]. == Aspects == === Certainty factors ===<!--- Linked to from [[Certainty factor]] ---> The [[MYCIN]] rule-based expert system introduced a quasi-probabilistic approach called certainty factors, whose rationale is explained below. A human, when reasoning, does not always conclude things with 100% confidence: he might venture, "If Fritz is green, then he is probably a frog" (after all, he might be a [[chameleon]]). This type of reasoning can be imitated by using numeric values called ''confidences''. For example, if it is known that Fritz is green, it might be concluded with 0.85 confidence that he is a frog; or, if it is known that he is a frog, it might be concluded with 0.95 confidence that he hops. These certainty factor (CF) numbers quantify uncertainty in the degree to which the available evidence supports a hypothesis. They represent a degree of confirmation and are not probabilities in a [[Bayesian probability|Bayesian]] sense. The CF calculus, developed by Shortliffe & Buchanan, increases or decreases the CF associated with a hypothesis as each new piece of evidence becomes available. It can be mapped to a probability update, although degrees of confirmation are not expected to obey the laws of probability. It is important to note, for example, that evidence for hypothesis H may have nothing to contribute to the degree to which Not_h is confirmed or disconfirmed (e.g., although a fever lends some support to a diagnosis of infection, fever does not disconfirm alternative hypotheses) and that the sum of CFs of many competing hypotheses may be greater than one (i.e., many hypotheses may be well confirmed on the available evidence). The CF approach to rule-based expert system design does not have a widespread following, in part because of the difficulty of meaningfully assigning CFs a priori. (The above example of green creatures being likely to be frogs is excessively naive.) Alternative approaches to quasi-probabilistic reasoning in expert systems involve [[Fuzzy Logic]], which has a firmer mathematical foundation. Also, rule-engine shells such as [[Drools]] and [[Jess programming language|Jess]] do not support probability manipulation: they use an alternative mechanism called salience, which is used to prioritize the order of evaluation of activated rules. In certain areas, as in the tax-advice scenarios discussed later, probabilistic approaches are not acceptable.(Being likely to be 95% correct means a 5% probability of being wrong.) The rules that are defined in such systems have no exceptions: they are only a means of achieving software flexibility when external circumstances change frequently. Because rules are stored as data, the core software does not need to be rebuilt each time changes to federal and state tax codes are announced. <!-- Section needs to be revised --> === Chaining === Two methods of reasoning when using [[Rule of inference|inference rules]] are backward chaining and forward chaining. [[Forward chaining]] starts with the data available and uses the inference rules to conclude more data until a desired [[goal]] is reached. An [[inference engine]] using forward chaining searches the inference rules until it finds one in which the [[Antecedent (logic)|''if'' clause]] is known to be [[logical value|true]]. It then concludes the ''then'' clause and adds this information to its [[data]]. It would continue to do this until a goal is reached. Because the data available determines which inference rules are used, this method is also called ''data driven''. [[Backward chaining]] starts with a list of goals and works backwards to see if there is data which will allow it to conclude any of these goals. An inference engine using backward chaining would search the inference rules until it finds one which has a ''then'' clause that matches a desired goal. If the ''if'' clause of that inference rule is not known to be true, then it is added to the list of goals. For example, suppose a [[Rule-based system|rule base]] contains #(1) IF X is green THEN X is a [[frog]]. (Confidence Factor: +1%) #(2) IF X is NOT green THEN X is NOT a frog. (Confidence Factor: +99%) #(3) IF X is a frog THEN X hops. (Confidence Factor: +50%) #(4) IF X is NOT a frog THEN X does NOT hop. (Confidence Factor +50%) Suppose a goal is to conclude that Fritz hops. Let X = "Fritz". The rule base would be searched and rule (3) would be selected because its conclusion (the ''then'' clause) matches the goal. It is not known that Fritz is a frog, so this "if" statement is added to the goal list. The rule base is again searched and this time rule (1) is selected because its then clause matches the new goal just added to the list. This time, the ''if'' clause (Fritz is green) is known to be true and the goal that Fritz hops is concluded. Because the list of goals determines which rules are selected and used, this method is called ''goal driven''. However, that if we use confidence factors in even a simplistic fashion, (for example, by multiplying them together as if they were like soft probabilities), we get a result that is known with a confidence factor of only one-half of 1%. (by multiplying 0.5 x 0.01 = 0.005). This is very useful, since without confidence factors, we might erroneously conclude with certainty that a sea turtle named Fritz hops just by virtue of being green. In [[Classical logic]] or Aristotelian [[term logic]]systems, there are no probabilities or confidence factors; all facts are regarded as certain. (An ancient example from Aristotle: "Socrates is a man. All men are mortal. Thus Socrates is mortal"). In real world applications, few facts are known with absolute certainty and the opposite of a given statement may be more likely to be true ("Green things in the pet store are not frogs, with probability or confidence factor 99% in my pet store survey)". Thus it is often useful when building such systems to try and prove both the goal and the opposite of a given goal to see which is more likely. === Software architecture === The following general points about expert systems and their architecture have been illustrated. :1. The sequence of steps taken to reach a conclusion is dynamically synthesized with each new case. It is not explicitly programmed when the system is built. :2. Expert systems can process multiple values for any problem parameter. This permits more than one line of reasoning to be pursued and the results of incomplete (not fully determined) reasoning to be presented. :3. [[Problem solving]] is accomplished by applying specific knowledge rather than specific technique. This is a key idea in expert systems technology. It reflects the belief that human experts do not process their knowledge differently from others, but they do possess different knowledge. With this [[philosophy]], when one finds that their expert system does not produce the desired results, work begins to expand the knowledge base, not to re-program the [[Algorithm|procedure]]s. There are various expert systems in which a rulebase and an inference engine cooperate to simulate the reasoning process that a human expert pursues in analyzing a problem and arriving at a conclusion. In these systems, in order to simulate the human reasoning process, a vast amount of knowledge needed to be stored in the knowledge base. Generally, the knowledge base of such an expert system consisted of a relatively large number of "if then" type of statements that were interrelated in a manner that, in theory at least, resembled the sequence of mental steps that were involved in the human reasoning process. Because of the need for large storage capacities and related programs to store the rulebase, most expert systems have, in the past, been run only on large information handling systems. Recently, the storage capacity of personal computers has increased to a point where it is becoming possible to consider running some types of simple expert systems on [[personal computer]]s. In some [[application software|applications]] of expert systems, the nature of the application and the amount of stored information necessary to simulate the [[human reasoning process]] for that application is just too vast to store in the active [[computer storage|memory]] of a [[computer]]. In other applications of expert systems, the nature of the application is such that not all of the information is always needed in the reasoning process. An example of this latter type application would be the use of an expert system to diagnose a data processing system comprising many separate components, some of which are optional. When that type of expert system employs a single integrated rulebase to diagnose the minimum system configuration of the data processing system, much of the rulebase is not required since many of the components which are optional units of the system will not be present in the system. Nevertheless, earlier expert systems require the entire rulebase to be stored since all the rules were, in effect, chained or linked together by the structure of the rulebase. When the rulebase is segmented, preferably into contextual segments or units, it is then possible to eliminate portions of the Rulebase containing data or knowledge that is not needed in a particular application. The segmenting of the rulebase also allows the expert system to be run with systems or on systems having much smaller memory capacities than was possible with earlier arrangements since each segment of the rulebase can be paged into and out of the system as needed. The segmenting of the rulebase into contextual segments requires that the expert system manage various intersegment relationships as segments are paged into and out of memory during execution of the program. Since the system permits a rulebase segment to be called and executed at any time during the processing of the first rulebase, provision must be made to store the data that has been accumulated up to that point so that at some time later in the process, when the system returns to the first segment, it can proceed from the last point or rule node that was processed. Also, provision must be made so that data that has been collected by the system up to that point can be passed to the second segment of the rulebase after it has been paged into the system and data collected during the processing of the second segment can be passed to the first segment when the system returns to complete processing that segment. The [[user interface]] and the [[procedure interface]] are two important functions in the [[information collection process]]. === End user === There are two styles of user-interface design followed by expert systems. In the original style of user interaction, (as in the example below, where a backward-chaining system seeks to determine a set of restaurants to recommend), the software takes the end-user through an interactive dialog: :Q. Do you know which restaurant you want to go to? :A. No :Q. Is there any kind of food you would particularly like? :A. No :Q. Do you like spicy food? :A. No :Q. Do you usually drink wine with meals? :A. Yes :Q. When you drink wine, is it French wine? :A. Yes The system must function in the presence of partial information, since the user may choose not to respond to every question. There is no fixed [[control structure]]: Dialogs are dynamically synthesized from the "goal" of the system, the contents of the knowledge base, and the user's responses. This approach wastes much of the user's time, because it does not allow a priori volunteering of information that the user considers important (e.g., Northern Italian, French or Turkish cuisine, moderately priced, with large wine selection, not more than 20 minutes driving distance), and is unlikely to be acceptable to busy users - e.g., a mobile-device user who needs to obtain information as efficiently as possible. Consequently, it has fallen into disfavor. Commercially viable systems will try to optimize the user experience by presenting options for commonly requested information (based on a history of previous queries of the system) using old-fashioned technology such as forms, augmented by keyword-based search. The gathered information may be verified by a confirmation step (e.g., to recover from spelling mistakes), and now act as input to a forward-chaining engine. If confirmatory questions are asked in a subsequent phase (based on which rules are activated by the obtained information) they are more likely to be specific and relevant. Implementing the ability, within an expert system, to learn from a stored history of its previous use, involves employing technologies considerably different from rule engines, and is considerably more challenging from a software-engineering perspective. It can, however, make the difference between commercial success and failure. A large part of the revulsion that users felt towards Microsoft's [[Office Assistant]] was due to the extreme naivete of its rules ("It looks like you are typing a letter: would you like help?") and a failure to adapt to the user's level of expertise over time - e.g., a user who regularly uses features such as Styles, Outline view, Table of Contents or cross-references is unlikely to be a beginner who needs help writing a letter. === Explanation system === Another major distinction between expert systems and traditional systems is illustrated by the following answer given by the system when the user answers a question with another question, "Why", as occurred in the above example. The answer is: :A. I am trying to determine the type of restaurant to suggest. So far Indian is not a likely choice. It is possible that French is a likely choice. I know that if the diner is a wine drinker, and the preferred wine is French, then there is strong evidence that the restaurant choice should include French. It is very difficult to implement a general [[explanation system]] (answering questions like "Why" and "How") in a traditional computer program. An expert system can generate an explanation by retracing the steps of its reasoning. The response of the expert system to the question WHY is an exposure of the underlying [[knowledge structure]]. It is a rule; a set of [[antecedent condition]]s which, if true, allow the [[logical assertion|assertion]] of a [[consequent]]. The rule references values, and tests them against various [[Constraint satisfaction|constraint]]s or asserts constraints onto them. This, in fact, is a significant part of the knowledge structure. There are values, which may be associated with some organizing [[entity]]. For example, the individual diner is an entity with various attributes (values) including whether they drink wine and the kind of wine. There are also rules, which associate the currently known [[Value (computer science)|value]]s of some attributes with assertions that can be made about other attributes. It is the orderly processing of these rules that dictates the dialog itself. === Comparison to problem-solving systems === The principal distinction between expert systems and traditional [[problem solving]] programs is the way in which the problem related expertise is coded. In traditional applications, problem expertise is encoded in both program and data structures. In the expert system approach all of the problem related expertise is encoded <i>mostly<i> in [[data structures]]. An example, related to tax advice, contrasts the traditional problem solving program with the expert system approach. In the traditional approach data structures describe the taxpayer and tax tables, while a program contains rules (encoding expert knowledge) that relate information about the taxpayer to tax table choices. In the expert system approach, the latter information is also encoded in data structures. (The collective data structures are called the [[knowledge base]].)The program ([[inference engine]]) of an expert system is relatively independent of the [[problem domain]] (taxes) and processes the rules without regard to the problem area they describe. processing sequence and focus. This organization has several benefits. * New Rules can be added to the knowledge base (or altered) without needing to rebuild the program. This allows changes to be made rapidly to a system (e.g., after it has been shipped to its customers, to accommodate very recent changes in state/federal tax codes.) * Rules are arguably easier for (non-programmer) domain experts to create and modify than writing code. (Commercial rule engines typically come with editors that allow rule creation/modification through a graphical user interface, which also performs actions such as consistency and redundancy checks.) Modern rule engines allow a hybrid approach: some allow rules to be "compiled" into a form that is more efficiently machine-executable. Also for efficiency concerns, rule engines allow rules to be defined more expressively and concisely by allowing software developers to create functions in a traditional programming language such as Java, which can then be invoked from either the condition or the action of a rule. Such functions may incorporate domain-specific (but reusable) logic. === Individuals interacted with === There are generally three individuals having an interaction with expert systems. Primary among these is the [[end-user]]; the individual who uses the system for its problem solving assistance. In the building and maintenance of the system there are two other roles: the [[problem domain expert]] who builds and supplies the knowledge base providing the domain expertise, and a [[knowledge engineers|knowledge engineer]] who assists the experts in determining the [[knowledge representation|representation]] of their knowledge, enters this knowledge into an [[explanation module]] and who defines<small></small> the [[inference technique]] required to obtain useful problem solving activity. Usually, the [[knowledge engineer]] will represent the problem solving activity in the form of rules which is referred to as a [[rule-based programming|rule-based]] expert system. When these rules are created from the domain expertise, the knowledge base stores the rules of the expert system. === Inference rule === An understanding of the "[[inference rule]]" concept is important to understand expert systems. An inference rule is a [[statement]] that has two parts, an [[Conditional (programming)|''if'' clause]] and a ''then'' clause. This rule is what gives expert systems the ability to find solutions to diagnostic and [[prescriptive]] problems. An example of an inference rule is: :If the restaurant choice includes French, and the occasion is romantic, :Then the restaurant choice is definitely [[Paul Bocuse]]. An expert system's rulebase is made up of many such inference rules. They are entered as separate rules and it is the inference engine that uses them together to draw conclusions. Because each rule is a unit, rules may be deleted or added without affecting other rules (though it should affect which conclusions are reached). One advantage of inference rules over traditional programming is that inference rules use [[reasoning]] which more closely resemble human reasoning. Thus, when a conclusion is drawn, it is possible to understand how this conclusion was reached. Furthermore, because the expert system uses knowledge in a form similar to the [[expert]], it may be easier to retrieve this information from the expert. === Procedure node interface === The function of the procedure node interface is to receive information from the procedures coordinator and create the appropriate [[procedure call]]. The ability to call a [[Subroutine|procedure]] and receive information from that procedure can be viewed as simply a generalization of input from the external world. While in some earlier expert systems external information has been obtained, that information was obtained only in a predetermined manner so only certain information could actually be acquired. This expert system, disclosed in the cross-referenced application, through the knowledge base, is permitted to invoke any procedure allowed on its host system. This makes the expert system useful in a much wider class of knowledge domains than if it had no external access or only limited external access. In the area of [[machine diagnostics]] using expert systems, particularly self-diagnostic applications, it is not possible to conclude the current state of "health" of a machine without some information. The best source of information is the machine itself, for it contains much detailed information that could not reasonably be provided by the operator. The knowledge that is represented in the system appears in the rulebase. In the rulebase described in the cross-referenced applications, there are basically four different types of objects, with associated information present. # Classes—these are questions asked to the user. # Parameters—a parameter is a place holder for a character string which may be a variable that can be inserted into a class question at the point in the question where the parameter is positioned. # Procedures—these are definitions of calls to external procedures. # Rule Nodes—The inferencing in the system is done by a tree structure which indicates the rules or logic which mimics human reasoning. The nodes of these trees are called rule nodes. There are several different types of rule nodes. The rulebase comprises a forest of many trees. The top node of the tree is called the goal node, in that it contains the conclusion. Each tree in the forest has a different goal node. The leaves of the tree are also referred to as rule nodes, or one of the types of rule nodes. A leaf may be an evidence node, an external node, or a reference node. An evidence node functions to obtain information from the operator by asking a specific question. In responding to a question presented by an evidence node, the operator is generally instructed to answer "yes" or "no" represented by numeric values 1 and 0 or provide a value of between 0 and 1, represented by a "maybe." Questions which require a response from the operator other than yes or no or a value between 0 and 1 are handled in a different manner. A leaf that is an external node indicates that data will be used which was obtained from a procedure call. A reference node functions to refer to another tree or subtree. A tree may also contain intermediate or minor nodes between the goal node and the leaf node. An intermediate node can represent [[logical operation]]s like And or Or. The [[inference logic]] has two functions. It selects a [[tree]] to trace and then it traces that tree. Once a tree has been selected, that tree is traced, depth-first, left to right. The word "tracing" refers to the action the system takes as it traverses the tree, asking classes (questions), calling procedures, and calculating confidences as it proceeds. As explained in the cross-referenced applications, the selection of a tree depends on the ordering of the trees. The original ordering of the trees is the order in which they appear in the rulebase. This order can be changed, however, by assigning an evidence node an attribute "initial" which is described in detail in these applications. The first action taken is to obtain values for all evidence nodes which have been assigned an "initial" attribute. Using only the answers to these initial evidences, the rules are ordered so that the most likely to succeed is evaluated first. The trees can be further re-ordered since they are constantly being updated as a selected tree is being traced. It has been found that the type of information that is solicited by the system from the user by means of questions or classes should be tailored to the level of knowledge of the user. In many applications, the group of prospective uses is nicely defined and the knowledge level can be estimated so that the questions can be presented at a level which corresponds generally to the average user. However, in other applications, knowledge of the specific [[Application domain|domain]] of the expert system might vary considerably among the group of prospective users. One application where this is particularly true involves the use of an expert system, operating in a self-diagnostic mode on a [[personal computer]] to assist the operator of the personal computer to diagnose the cause of a fault or error in either the hardware or software. In general, asking the [[operator]] for information is the most straightforward way for the expert system to gather information assuming, of course, that the information is or should be within the operator's understanding. For example, in diagnosing a personal computer, the expert system must know the major functional [[Electronic component|components]] of the system. It could ask the operator, for instance, if the [[Display device|display]] is a [[monochrome]] or color display. The operator should, in all probability, be able to provide the correct answer 100% of the time. The expert system could, on the other hand, cause a [[test unit]] to be run to determine the type of display. The accuracy of the data collected by either approach in this instance probably would not be that different so the [[Knowledge engineering|knowledge engineer]] could employ either approach without affecting the accuracy of the diagnosis. However, in many instances, because of the nature of the information being solicited, it is better to obtain the information from the system rather than asking the operator, because the [[accuracy]] of the data supplied by the operator is so low that the system could not effectively process it to a meaningful conclusion. In many situations the information is already in the system, in a form of which permits the correct [[answer]] to a question to be obtained through a process of inductive or deductive reasoning. The data previously collected by the system could be answers provided by the user to less complex questions that were asked for a different reason or results returned from test units that were previously run. == Application == Expert systems are designed and created to facilitate tasks in the fields of [[accounting]], medicine, [[process control]], [[financial service]], [[manufacturing|production]], [[human resources]] etc. Typically, the problem area are complex enough such that a more simple traditional algorithm is insufficient to provide the proper solution. Indeed, the foundation of a successful expert system depends on a series of technical procedures and development that may be designed by certain technicians and related experts. As such, expert systems do not typically provide a definitive answer, but provide a probabilistic recommendations. A good example of application of expert systems in financial area is [[expert systems for mortgages]]. Loan departments are interested in expert systems for [[mortgages]] because of the growing cost of labour which makes the handling and acceptance of relatively small loans less profitable. They also see in the application of expert systems a possibility for standardised, efficient handling of [[mortgage loans|mortgage loan]], and appreciate that for the acceptance of [[mortgages]] there are hard and fast rules which do not always exist with other types of loans. Another common application in the financial area for expert systems are in providing trading recommendations in various [[marketplaces]]. These markets involve numerous variables and human emotions which may be impossible to deterministically characterize, thus expert systems based on the rules of thumbs from experts and simulation data are employed. Expert system of this type can ranges from ones providing regional retail recommendations like [[Wishabi]], to ones used to assist monetary decision referenced by financial institution and governments. While expert systems have distinguished themselves in [[Artificial intelligence|AI]] research in finding practical application, their application has been limited. Expert systems are notoriously narrow in their domain of [[knowledge]]&mdash;as an amusing example, a researcher used the "skin disease" expert system to diagnose his rustbucket car as likely to have developed measles&mdash;and the systems were thus prone to making [[error]]s that [[human]]s would easily spot. Additionally, once some of the mystique had worn off, most [[programmer]]s realized that simple expert systems were essentially just slightly more elaborate versions of the [[decision logic]] they had already been using. Therefore, some of the techniques of expert systems can now be found in most complex programs without any fuss about them. An example, and a good demonstration of the limitations of, an expert system used by many people is the [[Microsoft Windows]] [[operating system]] [[troubleshooting]] software located in the "help" section in the [[taskbar]] menu. Obtaining expert/technical operating system support is often difficult for individuals not closely involved with the development of the operating system. Microsoft has designed their expert system to provide solutions, advice, and suggestions to common errors encountered throughout using the operating systems. Another 1970s and 1980s application of expert systems &mdash; which we today would simply call [[AI]] &mdash; was in [[computer games]]. For example, the computer [[baseball]] games [[Earl Weaver Baseball]] and [[Tony La Russa Baseball]] each had highly detailed simulations of the game strategies of those two baseball managers. When a human played the game against the computer, the computer queried the [[Earl Weaver]] or [[Tony La Russa]] Expert System for a decision on what strategy to follow. Even those choices where some randomness was part of the natural system (such as when to throw a surprise pitch-out to try to trick a runner trying to steal a base) were decided based on probabilities supplied by Weaver or La Russa. Today we would simply say that "the game's AI provided the opposing manager's strategy." === Advantages and disadvantages === * Compared to traditional programming techniques, expert-system approaches provide the added flexibility (and hence easier modifiability) that arises from the ability to model rules as data rather than as code. In situations where an organization's IT department is overwhelmed by a software-development backlog, rule-engines, by facilitating turnaround, provide a means that can allow organizations to adapt more readily to changing needs. * In practice, modern expert-system technology is employed as an adjunct to traditional programming techniques, and this hybrid approach allows the combination of the strengths of both approaches. Thus, rule engines allow control through programs (and user interfaces) written in a traditional language, and also incorporate necessary functionality such as inter-operating with existing database technology. ====Disadvantages==== * The [[GIGO]] phenomenon: The fact that a system uses expert-system technology provides no guarantee about the quality of the rules themselves. All self-designated experts are not necessarily so, and one notable challenge in expert-system design is in getting a system to recognize the limits to its knowledge. (Some human experts exhibit this problem too, but the really good ones know what they don't know and are not ashamed to admit it.) * An expert-system/rule-based approach is not optimal for all problems, and it requires considerable knowledge not to misapply a technology. * Ease of rule creation and rule modification can be double-edged. A system can be sabotaged by a non-knowledgable user who is enabled all too easily to add worthless rules, or rules that conflict with existing ones. Reasons for the failure of many systems include the absence of (or neglecting to employ diligently) facilities for system audit, detection of possible conflict, and rule lifecycle management (e.g., version control, thorough testing before deployment, etc.) The problems to be addressed here are as much technological as organizational. === Types of problems solved === Expert systems are most valuable to organizations that have a high-level of [[know-how]] experience and expertise that cannot be easily transferred to other members. They are designed to carry the intelligence and information found in the intellect of experts and provide this knowledge to other members of the organization for [[problem-solving]] purposes. Typically, the problems to be solved are of the sort that would normally be tackled by a medical or other [[professional]]. Real experts in the problem domain (which will typically be very narrow, for instance "diagnosing skin conditions in teenagers") are asked to provide "[[rule of thumb|rules of thumb]]" on how they evaluate the problems, either explicitly with the aid of experienced [[systems development|systems developer]]s, or sometimes implicitly, by getting such experts to evaluate [[test case]]s and using computer programs to examine the test data and (in a strictly limited manner) derive [[Operator|rule]]s from that. Generally, expert systems are used for problems for which there is no single "correct" solution which can be encoded in a conventional algorithm &mdash; one would not write an expert system to find shortest paths through graphs, or sort data, as there are simpler ways to do these tasks. Simple systems use simple true/false [[logic]] to evaluate data. More sophisticated systems are capable of performing at least some [[evaluation]], taking into account real-world uncertainties, using such methods as [[fuzzy logic]]. Such sophistication is difficult to develop and still highly imperfect. == Shells or Inference Engine == A shell is a complete development environment for building and maintaining knowledge-based applications. It provides a step-by-step methodology, and ideally a user-friendly interface such as a graphical interface, for a knowledge engineer that allows the domain experts themselves to be directly involved in structuring and encoding the knowledge. Examples of shells include [[Drools]], [[CLIPS]], [[Jess programming language|JESS]], [[d3web]], and [[eGanges]]. == See also == {{multicol}} * [[AI production]]s * [[Artificial intelligence]] * [[Artificial neural network]] * [[Action selection mechanism]] * [[Business Intelligence]] * [[Case-based reasoning]] * [[Connectionist expert system]] {{multicol-break}} * [[Decision support system]] * [[Data Mining]] * [[Fuzzy logic]] * [[Fuzzy cognitive map]] * [[Heuristic (computer science)]] * [[Inference engine]] * [[Knowledge Acquisition and Documentation Structuring]] * [[Knowledge base]] * [[Knowledge engineering]] {{multicol-break}} * [[Machine learning]] * [[OPS5]] * [[Production system]] * [[Rete algorithm]] * [[Self service software]] * [[Expert systems for mortgages]] * [[Type-2 fuzzy sets and systems]] {{multicol-end}} ==References== <references/> == Bibliography == * {{cite book | author = Ignizio, James | title = Introduction to Expert Systems | year = 1991 | isbn = 0-07-909785-5}} * {{cite book | author = Giarratano, Joseph C. and Riley, Gary | title = Expert Systems, Principles and Programming | year = 2005 | isbn = 0-534-38447-1}} * {{cite book | author = Jackson, Peter | title = Introduction to Expert Systems | year = 1998 | isbn = 0-201-87686-8}} * {{cite book | author = Walker, Adrian et al. | title = Knowledge Systems and Prolog | publisher = [[Addison-Wesley]] | year = 1990 | isbn = 0-201-52424-4}} * {{cite book | author = Darlington, Keith | title = The Essence of Expert Systems | publisher = [[Pearson Education]] | year = 2000 | isbn = 0-13-022774-9}} ==External links== * {{dmoz|Computers/Artificial_Intelligence/|Artificial Intelligence}} {{DEFAULTSORT:Expert System}} [[Category:Artificial intelligence]] [[Category:Decision theory]] [[Category:Expert systems|*]] [[Category:Information systems]] [[ar:نظم خبيرة]] [[az:Ekspert sistemlər]] [[ca:Sistema expert]] [[cs:Expertní systém]] [[de:Expertensystem]] [[et:Ekspertsüsteem]] [[es:Sistema experto]] [[fa:سامانه‌های خبره]] [[fr:Système expert]] [[ko:전문가 시스템]] [[hr:Ekspertni sustavi]] [[id:Sistem pakar]] [[it:Sistema esperto]] [[he:מערכת מומחה]] [[lv:Ekspertsistēma]] [[lt:Ekspertinė sistema]] [[hu:Szakértő rendszer]] [[nl:Expertsysteem]] [[ja:エキスパートシステム]] [[pl:System ekspertowy]] [[pt:Sistema especialista]] [[ru:Экспертная система]] [[simple:Expert system]] [[sk:Expertný systém]] [[sr:Ekspertski sistemi]] [[sv:Expertsystem]] [[th:ระบบผู้เชี่ยวชาญ]] [[tr:Uzman sistemler]] [[uk:Експертні системи]] [[vi:Hệ chuyên gia]] [[zh:专家系统]]'
New page wikitext, after the edit (new_wikitext)
'{{article issues | refimprove=November 2008 | cleanup=November 2008 }} {{about|a software type|the Italian software company|Expert System S.p.A.}} An '''expert system''' is [[software]] that attempts to provide an answer to a problem, or clarify uncertainties where normally one or more human [[expert]]s would need to be consulted. Expert systems are most common in a specific [[problem domain]], and is a traditional application and/or subfield of [[artificial intelligence]]. A wide variety of methods can be used to simulate the performance of the expert however common to most or all are 1) the creation of a [[knowledge base]] which uses some [[knowledge representation]] formalism to capture the [[Subject Matter Expert]]'s (SME) knowledge and 2) a process of gathering that knowledge from the SME and codifying it according to the formalism, which is called [[knowledge engineering]]. Expert systems may or may not have learning components but a third common element is that once the system is developed it is proven by being placed in the same real world problem solving situation as the human SME, typically as an aid to human workers or a supplement to some information system. Expert systems were introduced by researchers in the Stanford Heuristic Programming Project, [[Edward Feigenbaum]], PI, with the [[Dendral]] and [[Mycin]] systems. Principal contributors to the technology were Bruce Buchanan, Edward Shortliffe, Randall Davis, William vanMelle, Carli Scott, and others at Stanford. Expert systems were among the first truly successful forms of AI software. <ref>{{Harvnb|ACM|1998|loc=I.2.1|ref=ACM1998}}</ref> <ref>{{Harvnb|Russell|Norvig|2003|pp=22−24}}</ref> <ref>{{Harvnb|Luger|Stubblefield|2004|pp=227-331}}</ref> <ref>{{Harvnb|Nilsson|1998|loc=chpt. 17.4}}</ref> <ref>{{Harvnb|McCorduck|2004|pp=327-335, 434-435}}</ref> <ref>{{Harvnb|Crevier|1993|pp=145-62, 197−203}}</ref> The topic of expert systems has many points of contact with general [[systems theory]], [[operations research]], [[business process reengineering]] and various topics in [[applied mathematics]] and [[management science]]. == Aspects == === Certainty factors ===<!--- Linked to from [[Certainty factor]] ---> The [[MYCIN]] rule-based expert system introduced a quasi-probabilistic approach called certainty factors, whose rationale is explained below. A human, when reasoning, does not always conclude things with 100% confidence: he might venture, "If Fritz is green, then he is probably a frog" (after all, he might be a [[chameleon]]). This type of reasoning can be imitated by using numeric values called ''confidences''. For example, if it is known that Fritz is green, it might be concluded with 0.85 confidence that he is a frog; or, if it is known that he is a frog, it might be concluded with 0.95 confidence that he hops. These certainty factor (CF) numbers quantify uncertainty in the degree to which the available evidence supports a hypothesis. They represent a degree of confirmation and are not probabilities in a [[Bayesian probability|Bayesian]] sense. The CF calculus, developed by Shortliffe & Buchanan, increases or decreases the CF associated with a hypothesis as each new piece of evidence becomes available. It can be mapped to a probability update, although degrees of confirmation are not expected to obey the laws of probability. It is important to note, for example, that evidence for hypothesis H may have nothing to contribute to the degree to which Not_h is confirmed or disconfirmed (e.g., although a fever lends some support to a diagnosis of infection, fever does not disconfirm alternative hypotheses) and that the sum of CFs of many competing hypotheses may be greater than one (i.e., many hypotheses may be well confirmed on the available evidence). The CF approach to rule-based expert system design does not have a widespread following, in part because of the difficulty of meaningfully assigning CFs a priori. (The above example of green creatures being likely to be frogs is excessively naive.) Alternative approaches to quasi-probabilistic reasoning in expert systems involve [[Fuzzy Logic]], which has a firmer mathematical foundation. Also, rule-engine shells such as [[Drools]] and [[Jess programming language|Jess]] do not support probability manipulation: they use an alternative mechanism called salience, which is used to prioritize the order of evaluation of activated rules. In certain areas, as in the tax-advice scenarios discussed later, probabilistic approaches are not acceptable.(Being likely to be 95% correct means a 5% probability of being wrong.) The rules that are defined in such systems have no exceptions: they are only a means of achieving software flexibility when external circumstances change frequently. Because rules are stored as data, the core software does not need to be rebuilt each time changes to federal and state tax codes are announced. <!-- Section needs to be revised --> === Chaining === Two methods of reasoning when using [[Rule of inference|inference rules]] are backward chaining and forward chaining. [[Forward chaining]] starts with the data available and uses the inference rules to conclude more data until a desired [[goal]] is reached. An [[inference engine]] using forward chaining searches the inference rules until it finds one in which the [[Antecedent (logic)|''if'' clause]] is known to be [[logical value|true]]. It then concludes the ''then'' clause and adds this information to its [[data]]. It would continue to do this until a goal is reached. Because the data available determines which inference rules are used, this method is also called ''data driven''. [[Backward chaining]] starts with a list of goals and works backwards to see if there is data which will allow it to conclude any of these goals. An inference engine using backward chaining would search the inference rules until it finds one which has a ''then'' clause that matches a desired goal. If the ''if'' clause of that inference rule is not known to be true, then it is added to the list of goals. For example, suppose a [[Rule-based system|rule base]] contains #(1) IF X is green THEN X is a [[frog]]. (Confidence Factor: +1%) #(2) IF X is NOT green THEN X is NOT a frog. (Confidence Factor: +99%) #(3) IF X is a frog THEN X hops. (Confidence Factor: +50%) #(4) IF X is NOT a frog THEN X does NOT hop. (Confidence Factor +50%) Suppose a goal is to conclude that Fritz hops. Let X = "Fritz". The rule base would be searched and rule (3) would be selected because its conclusion (the ''then'' clause) matches the goal. It is not known that Fritz is a frog, so this "if" statement is added to the goal list. The rule base is again searched and this time rule (1) is selected because its then clause matches the new goal just added to the list. This time, the ''if'' clause (Fritz is green) is known to be true and the goal that Fritz hops is concluded. Because the list of goals determines which rules are selected and used, this method is called ''goal driven''. However, that if we use confidence factors in even a simplistic fashion, (for example, by multiplying them together as if they were like soft probabilities), we get a result that is known with a confidence factor of only one-half of 1%. (by multiplying 0.5 x 0.01 = 0.005). This is very useful, since without confidence factors, we might erroneously conclude with certainty that a sea turtle named Fritz hops just by virtue of being green. In [[Classical logic]] or Aristotelian [[term logic]]systems, there are no probabilities or confidence factors; all facts are regarded as certain. (An ancient example from Aristotle: "Socrates is a man. All men are mortal. Thus Socrates is mortal"). In real world applications, few facts are known with absolute certainty and the opposite of a given statement may be more likely to be true ("Green things in the pet store are not frogs, with probability or confidence factor 99% in my pet store survey)". Thus it is often useful when building such systems to try and prove both the goal and the opposite of a given goal to see which is more likely. === Software architecture === The following general points about expert systems and their architecture have been illustrated. :1. The sequence of steps taken to reach a conclusion is dynamically synthesized with each new case. It is not explicitly programmed when the system is built. :2. Expert systems can process multiple values for any problem parameter. This permits more than one line of reasoning to be pursued and the results of incomplete (not fully determined) reasoning to be presented. :3. [[Problem solving]] is accomplished by applying specific knowledge rather than specific technique. This is a key idea in expert systems technology. It reflects the belief that human experts do not process their knowledge differently from others, but they do possess different knowledge. With this [[philosophy]], when one finds that their expert system does not produce the desired results, work begins to expand the knowledge base, not to re-program the [[Algorithm|procedure]]s. There are various expert systems in which a rulebase and an inference engine cooperate to simulate the reasoning process that a human expert pursues in analyzing a problem and arriving at a conclusion. In these systems, in order to simulate the human reasoning process, a vast amount of knowledge needed to be stored in the knowledge base. Generally, the knowledge base of such an expert system consisted of a relatively large number of "if then" type of statements that were interrelated in a manner that, in theory at least, resembled the sequence of mental steps that were involved in the human reasoning process. Because of the need for large storage capacities and related programs to store the rulebase, most expert systems have, in the past, been run only on large information handling systems. Recently, the storage capacity of personal computers has increased to a point where it is becoming possible to consider running some types of simple expert systems on [[personal computer]]s. In some [[application software|applications]] of expert systems, the nature of the application and the amount of stored information necessary to simulate the [[human reasoning process]] for that application is just too vast to store in the active [[computer storage|memory]] of a [[computer]]. In other applications of expert systems, the nature of the application is such that not all of the information is always needed in the reasoning process. An example of this latter type application would be the use of an expert system to diagnose a data processing system comprising many separate components, some of which are optional. When that type of expert system employs a single integrated rulebase to diagnose the minimum system configuration of the data processing system, much of the rulebase is not required since many of the components which are optional units of the system will not be present in the system. Nevertheless, earlier expert systems require the entire rulebase to be stored since all the rules were, in effect, chained or linked together by the structure of the rulebase. When the rulebase is segmented, preferably into contextual segments or units, it is then possible to eliminate portions of the Rulebase containing data or knowledge that is not needed in a particular application. The segmenting of the rulebase also allows the expert system to be run with systems or on systems having much smaller memory capacities than was possible with earlier arrangements since each segment of the rulebase can be paged into and out of the system as needed. The segmenting of the rulebase into contextual segments requires that the expert system manage various intersegment relationships as segments are paged into and out of memory during execution of the program. Since the system permits a rulebase segment to be called and executed at any time during the processing of the first rulebase, provision must be made to store the data that has been accumulated up to that point so that at some time later in the process, when the system returns to the first segment, it can proceed from the last point or rule node that was processed. Also, provision must be made so that data that has been collected by the system up to that point can be passed to the second segment of the rulebase after it has been paged into the system and data collected during the processing of the second segment can be passed to the first segment when the system returns to complete processing that segment. The [[user interface]] and the [[procedure interface]] are two important functions in the [[information collection process]]. === End user === There are two styles of user-interface design followed by expert systems. In the original style of user interaction, (as in the example below, where a backward-chaining system seeks to determine a set of restaurants to recommend), the software takes the end-user through an interactive dialog: :Q. Do you know which restaurant you want to go to? :A. No :Q. Is there any kind of food you would particularly like? :A. No :Q. Do you like spicy food? :A. No :Q. Do you usually drink wine with meals? :A. Yes :Q. When you drink wine, is it French wine? :A. Yes The system must function in the presence of partial information, since the user may choose not to respond to every question. There is no fixed [[control structure]]: Dialogs are dynamically synthesized from the "goal" of the system, the contents of the knowledge base, and the user's responses. This approach wastes much of the user's time, because it does not allow a priori volunteering of information that the user considers important (e.g., Northern Italian, French or Turkish cuisine, moderately priced, with large wine selection, not more than 20 minutes driving distance), and is unlikely to be acceptable to busy users - e.g., a mobile-device user who needs to obtain information as efficiently as possible. Consequently, it has fallen into disfavor. Commercially viable systems will try to optimize the user experience by presenting options for commonly requested information (based on a history of previous queries of the system) using old-fashioned technology such as forms, augmented by keyword-based search. The gathered information may be verified by a confirmation step (e.g., to recover from spelling mistakes), and now act as input to a forward-chaining engine. If confirmatory questions are asked in a subsequent phase (based on which rules are activated by the obtained information) they are more likely to be specific and relevant. Implementing the ability, within an expert system, to learn from a stored history of its previous use, involves employing technologies considerably different from rule engines, and is considerably more challenging from a software-engineering perspective. It can, however, make the difference between commercial success and failure. A large part of the revulsion that users felt towards Microsoft's [[Office Assistant]] was due to the extreme naivete of its rules ("It looks like you are typing a letter: would you like help?") and a failure to adapt to the user's level of expertise over time - e.g., a user who regularly uses features such as Styles, Outline view, Table of Contents or cross-references is unlikely to be a beginner who needs help writing a letter. === Explanation system === Another major distinction between expert systems and traditional systems is illustrated by the following answer given by the system when the user answers a question with another question, "Why", as occurred in the above example. The answer is: :A. I am trying to determine the type of restaurant to suggest. So far Indian is not a likely choice. It is possible that French is a likely choice. I know that if the diner is a wine drinker, and the preferred wine is French, then there is strong evidence that the restaurant choice should include French. It is very difficult to implement a general [[explanation system]] (answering questions like "Why" and "How") in a traditional computer program. An expert system can generate an explanation by retracing the steps of its reasoning. The response of the expert system to the question WHY is an exposure of the underlying [[knowledge structure]]. It is a rule; a set of [[antecedent condition]]s which, if true, allow the [[logical assertion|assertion]] of a [[consequent]]. The rule references values, and tests them against various [[Constraint satisfaction|constraint]]s or asserts constraints onto them. This, in fact, is a significant part of the knowledge structure. There are values, which may be associated with some organizing [[entity]]. For example, the individual diner is an entity with various attributes (values) including whether they drink wine and the kind of wine. There are also rules, which associate the currently known [[Value (computer science)|value]]s of some attributes with assertions that can be made about other attributes. It is the orderly processing of these rules that dictates the dialog itself. === Comparison to problem-solving systems === The principal distinction between expert systems and traditional [[problem solving]] programs is the way in which the problem related expertise is coded. In traditional applications, problem expertise is encoded in both program and data structures. In the expert system approach all of the problem related expertise is encoded <i>mostly<i> in [[data structures]]. An example, related to tax advice, contrasts the traditional problem solving program with the expert system approach. In the traditional approach data structures describe the taxpayer and tax tables, while a program contains rules (encoding expert knowledge) that relate information about the taxpayer to tax table choices. In the expert system approach, the latter information is also encoded in data structures. (The collective data structures are called the [[knowledge base]].)The program ([[inference engine]]) of an expert system is relatively independent of the [[problem domain]] (taxes) and processes the rules without regard to the problem area they describe. processing sequence and focus. This organization has several benefits. * New Rules can be added to the knowledge base (or altered) without needing to rebuild the program. This allows changes to be made rapidly to a system (e.g., after it has been shipped to its customers, to accommodate very recent changes in state/federal tax codes.) * Rules are arguably easier for (non-programmer) domain experts to create and modify than writing code. (Commercial rule engines typically come with editors that allow rule creation/modification through a graphical user interface, which also performs actions such as consistency and redundancy checks.) Modern rule engines allow a hybrid approach: some allow rules to be "compiled" into a form that is more efficiently machine-executable. Also for efficiency concerns, rule engines allow rules to be defined more expressively and concisely by allowing software developers to create functions in a traditional programming language such as Java, which can then be invoked from either the condition or the action of a rule. Such functions may incorporate domain-specific (but reusable) logic. === Individuals interacted with === There are generally three individuals having an interaction with expert systems. Primary among these is the [[end-user]]; the individual who uses the system for its problem solving assistance. In the building and maintenance of the system there are two other roles: the [[problem domain expert]] who builds and supplies the knowledge base providing the domain expertise, and a [[knowledge engineers|knowledge engineer]] who assists the experts in determining the [[knowledge representation|representation]] of their knowledge, enters this knowledge into an [[explanation module]] and who defines<small></small> the [[inference technique]] required to obtain useful problem solving activity. Usually, the [[knowledge engineer]] will represent the problem solving activity in the form of rules which is referred to as a [[rule-based programming|rule-based]] expert system. When these rules are created from the domain expertise, the knowledge base stores the rules of the expert system. === Inference rule === An understanding of the "[[inference rule]]" concept is important to understand expert systems. An inference rule is a [[statement]] that has two parts, an [[Conditional (programming)|''if'' clause]] and a ''then'' clause. This rule is what gives expert systems the ability to find solutions to diagnostic and [[prescriptive]] problems. An example of an inference rule is: :If the restaurant choice includes French, and the occasion is romantic, :Then the restaurant choice is definitely [[Paul Bocuse]]. An expert system's rulebase is made up of many such inference rules. They are entered as separate rules and it is the inference engine that uses them together to draw conclusions. Because each rule is a unit, rules may be deleted or added without affecting other rules (though it should affect which conclusions are reached). One advantage of inference rules over traditional programming is that inference rules use [[reasoning]] which more closely resemble human reasoning. Thus, when a conclusion is drawn, it is possible to understand how this conclusion was reached. Furthermore, because the expert system uses knowledge in a form similar to the [[expert]], it may be easier to retrieve this information from the expert. === Procedure node interface === The function of the procedure node interface is to receive information from the procedures coordinator and create the appropriate [[procedure call]]. The ability to call a [[Subroutine|procedure]] and receive information from that procedure can be viewed as simply a generalization of input from the external world. While in some earlier expert systems external information has been obtained, that information was obtained only in a predetermined manner so only certain information could actually be acquired. This expert system, disclosed in the cross-referenced application, through the knowledge base, is permitted to invoke any procedure allowed on its host system. This makes the expert system useful in a much wider class of knowledge domains than if it had no external access or only limited external access. In the area of [[machine diagnostics]] using expert systems, particularly self-diagnostic applications, it is not possible to conclude the current state of "health" of a machine without some information. The best source of information is the machine itself, for it contains much detailed information that could not reasonably be provided by the operator. The knowledge that is represented in the system appears in the rulebase. In the rulebase described in the cross-referenced applications, there are basically four different types of objects, with associated information present. # Classes—these are questions asked to the user. # Parameters—a parameter is a place holder for a character string which may be a variable that can be inserted into a class question at the point in the question where the parameter is positioned. # Procedures—these are definitions of calls to external procedures. # Rule Nodes—The inferencing in the system is done by a tree structure which indicates the rules or logic which mimics human reasoning. The nodes of these trees are called rule nodes. There are several different types of rule nodes. The rulebase comprises a forest of many trees. The top node of the tree is called the goal node, in that it contains the conclusion. Each tree in the forest has a different goal node. The leaves of the tree are also referred to as rule nodes, or one of the types of rule nodes. A leaf may be an evidence node, an external node, or a reference node. An evidence node functions to obtain information from the operator by asking a specific question. In responding to a question presented by an evidence node, the operator is generally instructed to answer "yes" or "no" represented by numeric values 1 and 0 or provide a value of between 0 and 1, represented by a "maybe." Questions which require a response from the operator other than yes or no or a value between 0 and 1 are handled in a different manner. A leaf that is an external node indicates that data will be used which was obtained from a procedure call. A reference node functions to refer to another tree or subtree. A tree may also contain intermediate or minor nodes between the goal node and the leaf node. An intermediate node can represent [[logical operation]]s like And or Or. The [[inference logic]] has two functions. It selects a [[tree]] to trace and then it traces that tree. Once a tree has been selected, that tree is traced, depth-first, left to right. The word "tracing" refers to the action the system takes as it traverses the tree, asking classes (questions), calling procedures, and calculating confidences as it proceeds. As explained in the cross-referenced applications, the selection of a tree depends on the ordering of the trees. The original ordering of the trees is the order in which they appear in the rulebase. This order can be changed, however, by assigning an evidence node an attribute "initial" which is described in detail in these applications. The first action taken is to obtain values for all evidence nodes which have been assigned an "initial" attribute. Using only the answers to these initial evidences, the rules are ordered so that the most likely to succeed is evaluated first. The trees can be further re-ordered since they are constantly being updated as a selected tree is being traced. It has been found that the type of information that is solicited by the system from the user by means of questions or classes should be tailored to the level of knowledge of the user. In many applications, the group of prospective uses is nicely defined and the knowledge level can be estimated so that the questions can be presented at a level which corresponds generally to the average user. However, in other applications, knowledge of the specific [[Application domain|domain]] of the expert system might vary considerably among the group of prospective users. One application where this is particularly true involves the use of an expert system, operating in a self-diagnostic mode on a [[personal computer]] to assist the operator of the personal computer to diagnose the cause of a fault or error in either the hardware or software. In general, asking the [[operator]] for information is the most straightforward way for the expert system to gather information assuming, of course, that the information is or should be within the operator's understanding. For example, in diagnosing a personal computer, the expert system must know the major functional [[Electronic component|components]] of the system. It could ask the operator, for instance, if the [[Display device|display]] is a [[monochrome]] or color display. The operator should, in all probability, be able to provide the correct answer 100% of the time. The expert system could, on the other hand, cause a [[test unit]] to be run to determine the type of display. The accuracy of the data collected by either approach in this instance probably would not be that different so the [[Knowledge engineering|knowledge engineer]] could employ either approach without affecting the accuracy of the diagnosis. However, in many instances, because of the nature of the information being solicited, it is better to obtain the information from the system rather than asking the operator, because the [[accuracy]] of the data supplied by the operator is so low that the system could not effectively process it to a meaningful conclusion. In many situations the information is already in the system, in a form of which permits the correct [[answer]] to a question to be obtained through a process of inductive or deductive reasoning. The data previously collected by the system could be answers provided by the user to less complex questions that were asked for a different reason or results returned from test units that were previously run. == Application == Expert systems are designed and created to facilitate tasks in the fields of [[accounting]], medicine, [[process control]], [[financial service]], [[manufacturing|production]], [[human resources]] etc. Typically, the problem area are complex enough such that a more simple traditional algorithm is insufficient to provide the proper solution. Indeed, the foundation of a successful expert system depends on a series of technical procedures and development that may be designed by certain technicians and related experts. As such, expert systems do not typically provide a definitive answer, but provide a probabilistic recommendations. A good example of application of expert systems in financial area is [[expert systems for mortgages]]. Loan departments are interested in expert systems for [[mortgages]] because of the growing cost of labour which makes the handling and acceptance of relatively small loans less profitable. They also see in the application of expert systems a possibility for standardised, efficient handling of [[mortgage loans|mortgage loan]], and appreciate that for the acceptance of [[mortgages]] there are hard and fast rules which do not always exist with other types of loans. Another common application in the financial area for expert systems are in providing trading recommendations in various [[marketplaces]]. These markets involve numerous variables and human emotions which may be impossible to deterministically characterize, thus expert systems based on the rules of thumbs from experts and simulation data are employed. Expert system of this type can ranges from ones providing regional retail recommendations like [[Wishabi]], to ones used to assist monetary decision referenced by financial institution and governments. While expert systems have distinguished themselves in [[Artificial intelligence|AI]] research in finding practical application, their application has been limited. Expert systems are notoriously narrow in their domain of [[knowledge]]&mdash;as an amusing example, a researcher used the "skin disease" expert system to diagnose his rustbucket car as likely to have developed measles&mdash;and the systems were thus prone to making [[error]]s that [[human]]s would easily spot. Additionally, once some of the mystique had worn off, most [[programmer]]s realized that simple expert systems were essentially just slightly more elaborate versions of the [[decision logic]] they had already been using. Therefore, some of the techniques of expert systems can now be found in most complex programs without any fuss about them. An example, and a good demonstration of the limitations of, an expert system used by many people is the [[Microsoft Windows]] [[operating system]] [[troubleshooting]] software located in the "help" section in the [[taskbar]] menu. Obtaining expert/technical operating system support is often difficult for individuals not closely involved with the development of the operating system. Microsoft has designed their expert system to provide solutions, advice, and suggestions to common errors encountered throughout using the operating systems. Another 1970s and 1980s application of expert systems &mdash; which we today would simply call [[AI]] &mdash; was in [[computer games]]. For example, the computer [[baseball]] games [[Earl Weaver Baseball]] and [[Tony La Russa Baseball]] each had highly detailed simulations of the game strategies of those two baseball managers. When a human played the game against the computer, the computer queried the [[Earl Weaver]] or [[Tony La Russa]] Expert System for a decision on what strategy to follow. Even those choices where some randomness was part of the natural system (such as when to throw a surprise pitch-out to try to trick a runner trying to steal a base) were decided based on probabilities supplied by Weaver or La Russa. Today we would simply say that "the game's AI provided the opposing manager's strategy." === Advantages and disadvantages === * Compared to traditional programming techniques, expert-system approaches provide the added flexibility (and hence easier modifiability) that arises from the ability to model rules as data rather than as code. In situations where an organization's IT department is overwhelmed by a software-development backlog, rule-engines, by facilitating turnaround, provide a means that can allow organizations to adapt more readily to changing needs. * In practice, modern expert-system technology is employed as an adjunct to traditional programming techniques, and this hybrid approach allows the combination of the strengths of both approaches. Thus, rule engines allow control through programs (and user interfaces) written in a traditional language, and also incorporate necessary functionality such as inter-operating with existing database technology. ====Disadvantages==== * The [[GIGO]] phenomenon: The fact that a system uses expert-system technology provides no guarantee about the quality of the rules themselves. All self-designated experts are not necessarily so, and one notable challenge in expert-system design is in getting a system to recognize the limits to its knowledge. (Some human experts exhibit this problem too, but the really good ones know what they don't know and are not ashamed to admit it.) * An expert-system/rule-based approach is not optimal for all problems, and it requires considerable knowledge not to misapply a technology. * Ease of rule creation and rule modification can be double-edged. A system can be sabotaged by a non-knowledgable user who is enabled all too easily to add worthless rules, or rules that conflict with existing ones. Reasons for the failure of many systems include the absence of (or neglecting to employ diligently) facilities for system audit, detection of possible conflict, and rule lifecycle management (e.g., version control, thorough testing before deployment, etc.) The problems to be addressed here are as much technological as organizational. === Types of problems solved === Expert systems are most valuable to organizations that have a high-level of [[know-how]] experience and expertise that cannot be easily transferred to other members. They are designed to carry the intelligence and information found in the intellect of experts and provide this knowledge to other members of the organization for [[problem-solving]] purposes. Typically, the problems to be solved are of the sort that would normally be tackled by a medical or other [[professional]]. Real experts in the problem domain (which will typically be very narrow, for instance "diagnosing skin conditions in teenagers") are asked to provide "[[rule of thumb|rules of thumb]]" on how they evaluate the problems, either explicitly with the aid of experienced [[systems development|systems developer]]s, or sometimes implicitly, by getting such experts to evaluate [[test case]]s and using computer programs to examine the test data and (in a strictly limited manner) derive [[Operator|rule]]s from that. Generally, expert systems are used for problems for which there is no single "correct" solution which can be encoded in a conventional algorithm &mdash; one would not write an expert system to find shortest paths through graphs, or sort data, as there are simpler ways to do these tasks. Simple systems use simple true/false [[logic]] to evaluate data. More sophisticated systems are capable of performing at least some [[evaluation]], taking into account real-world uncertainties, using such methods as [[fuzzy logic]]. Such sophistication is difficult to develop and still highly imperfect. == Shells or Inference Engine == A shell is a complete development environment for building and maintaining knowledge-based applications. It provides a step-by-step methodology, and ideally a user-friendly interface such as a graphical interface, for a knowledge engineer that allows the domain experts themselves to be directly involved in structuring and encoding the knowledge. Examples of shells include [[Drools]], [[CLIPS]], [[Jess programming language|JESS]], [[d3web]], and [[eGanges]]. DON't KNOW WHAT THEY AR ETALKING ABOUT THIS IS RUBBISH< BUNCH OF BIG WORDS AND NO ANSWERS>>>>>>>>>>>>WHAT A JOKE> WASTE OF TIME> GOOD JOB GUYS == See also == {{multicol}} * [[AI production]]s * [[Artificial intelligence]] * [[Artificial neural network]] * [[Action selection mechanism]] * [[Business Intelligence]] * [[Case-based reasoning]] * [[Connectionist expert system]] {{multicol-break}} * [[Decision support system]] * [[Data Mining]] * [[Fuzzy logic]] * [[Fuzzy cognitive map]] * [[Heuristic (computer science)]] * [[Inference engine]] * [[Knowledge Acquisition and Documentation Structuring]] * [[Knowledge base]] * [[Knowledge engineering]] {{multicol-break}} * [[Machine learning]] * [[OPS5]] * [[Production system]] * [[Rete algorithm]] * [[Self service software]] * [[Expert systems for mortgages]] * [[Type-2 fuzzy sets and systems]] {{multicol-end}} ==References== <references/> == Bibliography == * {{cite book | author = Ignizio, James | title = Introduction to Expert Systems | year = 1991 | isbn = 0-07-909785-5}} * {{cite book | author = Giarratano, Joseph C. and Riley, Gary | title = Expert Systems, Principles and Programming | year = 2005 | isbn = 0-534-38447-1}} * {{cite book | author = Jackson, Peter | title = Introduction to Expert Systems | year = 1998 | isbn = 0-201-87686-8}} * {{cite book | author = Walker, Adrian et al. | title = Knowledge Systems and Prolog | publisher = [[Addison-Wesley]] | year = 1990 | isbn = 0-201-52424-4}} * {{cite book | author = Darlington, Keith | title = The Essence of Expert Systems | publisher = [[Pearson Education]] | year = 2000 | isbn = 0-13-022774-9}} ==External links== * {{dmoz|Computers/Artificial_Intelligence/|Artificial Intelligence}} {{DEFAULTSORT:Expert System}} [[Category:Artificial intelligence]] [[Category:Decision theory]] [[Category:Expert systems|*]] [[Category:Information systems]] [[ar:نظم خبيرة]] [[az:Ekspert sistemlər]] [[ca:Sistema expert]] [[cs:Expertní systém]] [[de:Expertensystem]] [[et:Ekspertsüsteem]] [[es:Sistema experto]] [[fa:سامانه‌های خبره]] [[fr:Système expert]] [[ko:전문가 시스템]] [[hr:Ekspertni sustavi]] [[id:Sistem pakar]] [[it:Sistema esperto]] [[he:מערכת מומחה]] [[lv:Ekspertsistēma]] [[lt:Ekspertinė sistema]] [[hu:Szakértő rendszer]] [[nl:Expertsysteem]] [[ja:エキスパートシステム]] [[pl:System ekspertowy]] [[pt:Sistema especialista]] [[ru:Экспертная система]] [[simple:Expert system]] [[sk:Expertný systém]] [[sr:Ekspertski sistemi]] [[sv:Expertsystem]] [[th:ระบบผู้เชี่ยวชาญ]] [[tr:Uzman sistemler]] [[uk:Експертні системи]] [[vi:Hệ chuyên gia]] [[zh:专家系统]]'
Whether or not the change was made through a Tor exit node (tor_exit_node)
0
Unix timestamp of change (timestamp)
1284424165