Revision as of 21:22, 7 September 2013 editAnomieBOT (talk | contribs)Bots6,568,569 editsm Dating maintenance tags: {{Fact}}← Previous edit | Revision as of 16:52, 9 December 2013 edit undoMadScientistX11 (talk | contribs)Extended confirmed users4,453 edits Rewrote the majority of the articleNext edit → | ||
Line 1: | Line 1: | ||
A '''frame language''' is a technology used for ] in ]. ] are stored as ] of ] and subsets of the frame concepts. They are similar to class hierarchies in ] although their fundamental design goals are different. Frames are focused on explicit and intuitive representation of knowledge where as objects focus on ] and ]. Frames originated in AI research and objects primarily in ]. However, in practice the techniques and capabilities of frame and object-oriented languages overlap significantly. | |||
A '''frame language''' is a ]. It applies the ] concept to the structuring of language properties. Frame languages are usually ]. | |||
==Description== | ==Description== | ||
Early work on Frames was inspired by psychological research going back to the 1930's that indicated people use stored stereotypical knowledge to interpret and act in new cognitive situations.<ref>{{cite book|last=Bartlett|first=F.C.|title=Remembering: A Study in Experimental and Social Psychology|year=1932|publisher=Cambridge University Press|location=Cambridge, England}}</ref> The term Frame was first used by Marvin Minsky as a paradigm to understand visual reasoning and natural language processing.<ref>{{cite book|last=Minsky|first=Marvin|title=The Psychology of Computer Vision|year=1975|publisher=McGraw Hill|location=New York|pages=211-277|editor=Pat Winston|chapter=A Framework for Representing Knowledge}}</ref> In these and many other types of problems the potential solution space for even the smallest problem is huge. For example, extracting the phonemes from a raw audio stream or detecting the edges of an object. Things which seem trivial to humans are actually quite complex. In fact how difficult they really were was probably not fully understood until AI researchers began to investigate the complexity of getting computers to solve them. | |||
Frame languages primarily focus on ''the recognition and description of ] and classes'', with relations and interactions considered as "secondary". | |||
The initial notion of Frames or Scripts as they were also called is that they would establish the context for a problem and in so doing automatically reduce the possible search space significantly. The idea was also adopted by Schank and Abelson who used it to illustrate how an AI system could process common human interactions such as ordering a meal at a restaurant.<ref>{{cite book|last=Schank|first=Roger|title=Scripts, Plans, Goals, and Understanding|year=1977|publisher=Lawrence Erlbaum|location=Hillsdale, New Jersey|coauthors=R. P. Abelson}}</ref> These interactions were standardized as Frames with slots that stored relevant information about each Frame. Slots are analogous to object properties in object-oriented modeling and to relations in entity-relation models. Slots often had default values but also required further refinement as part of the execution of each instance of the scenario. I.e., the execution of a task such as ordering at a restaurant was controlled by starting with a basic instance of the Frame and then instantiating and refining various values as appropriate. Essentially the abstract Frame represented an object class and the frame instances an object instance. In this early work the emphasis was primarily on the static data descriptions of the Frame. Various mechanisms were developed to define the range of a slot, default values, etc. However, even in these early systems there were procedural capabilities. One common technique was to use "triggers" (similar to the database concept of triggers) attached to slots. A trigger was simply procedural code that was attached to a slot. The trigger could fire either before and/or after a slot value was accessed or modified. | |||
In general, "]" in this context means "something that can be/(has to be) fulfilled"{{fact|date=September 2013}}. In such sense, for example: ]s are frame languages, but also every ] is a frame language{{fact|date=September 2013}}. In specific contexts, the authors of computer languages use the term "frame" arbitrarily and frequently intuitively, and in a ] sense. | |||
As with object classes Frames were organized in ] hierarchies. For example, a basic frame might be ordering at a restaurant. An instance of that would be Joe goes to McDonalds. A specialization (essentially a ]) of the restaurant frame would be a frame for ordering at a fancy restaurant. The fancy restaurant frame would inherit all the default values from the restaurant frame but also would either add more slots or change one or more of the default values (e.g., expected price range) for the specialized frame.<ref>{{cite book|last=Feigenbaum|first=Edward|title=The Handbook of Artificial Intelligence, Volume III|publisher=Addison-Wesley|isbn=0201118114|pages=216-222|url=https://archive.org/stream/handbookofartific01barr#page/156/mode/2up|coauthors=Avron Barr|date=September 1, 1986}}</ref><ref>{{cite journal|last=Bobrow|first=D.G.|coauthors=Terry Winograd|title=An Overview of KRL: A Knowledge Representation Language|journal=Cognitive Science|year=1977|volume=1|pages=3-46}}</ref> | |||
In the field of ], a frame is a ] introduced by ] in the 1970s that can be used for ]. Minsky frames are intended to help an ] system recognize specific instances of patterns. Frames usually contain properties called ''attributes'' or ''slots''. Slots may contain ''default values'' (subject to override by detecting a different value for an attribute), refer to other frames (''component relationships'') or contain ''methods'' for recognizing pattern instances. Frames are thus a machine-usable formalization of ]s or ]. In contrast, the ] paradigm partitions an information domain into abstraction hierarchies (] and subclasses) rather than partitioning into component hierarchies, and is used to implement any kind of information processing. ] is loosely based on Minsky Frames, its purpose being software ''synthesis'' rather than pattern ''analysis''. | |||
After these early Frame languages the most significant advancement in the technology was the introduction of formal semantics and automatic classification pioneered by the ] language.<ref>{{cite journal|last=Brachman|first=Ron|title=A Structural Paradigm for Representing Knowledge|journal=Bolt, Beranek, and Neumann Technical Report|date=1978|issue=3605}}</ref> Much of the early Frame language research (e.g. Schank and Abelson) had been driven by findings from experimental psychology and attempts to design knowledge representation tools that corresponded to the patterns humans were thought to use to function in daily tasks. These researchers were less interested in mathematical formality since they believed such formalism were not necessarily good models for the way the average human conceptualizes the world. Researchers such as ] on the other hand wanted to give AI researchers the mathematical formalism and computational power that were associated with Logic. Their aim was to map the Frame classes, slots, constraints, and rules in a Frame language to set theory and logic. One of the benefits of this approach is that the validation and even creation of the models could be automated using theorem provers and other automated reasoning capabilities. The drawback was that it could be more difficult to initially specify the model in a language with a formal semantics. The way humans use language for example is often far from truly logical. | |||
Like many other knowledge representation systems and languages, frames are an attempt to resemble the way human beings are storing knowledge. It seems like we are storing our knowledge in rather large chunks, and that different chunks are highly interconnected. In frame-based knowledge representations knowledge describing a particular concept is organized as a frame. The frame usually contains a name and a set of slots. | |||
The slots describe the frame with ]s <slotname value> or alternatively a triple containing framename, slotname and value in some order. In many frame systems the slots are complex structures that have facets describing the properties of the slot. The value of a slot may be a primitive such as a text string or an integer, or it may be another frame. Most systems allow multiple values for slots and some systems support procedural attachments. These attachments can be used to compute the slot value, or they can be triggers used to make consistency checking or updates of other slots. The triggers can be trigged by updates on slots. | |||
==Inference and reasoning== | |||
{{Expand section|date=October 2011}} | |||
In most frame-based ]s, ] is the central ] mechanism. The frames are organized as a ] with some general ] as the root frame. Many systems support ]. In these systems the tree structure can look more like a ] with possible cycles. | |||
] in frame-systems is based on frame ], inheritance and ]. | |||
This evolution also illustrates a classic divide in AI research known as the ]. The "neats" were researchers who placed the most value on mathematical precision and formalism which could be achieved via ] and ]. The "scruffies" were more interested in modeling knowledge in representations that were intuitive and psychologically meaningful to humans.<ref>{{cite book|last=Crevier|first=Daniel|title=AI: The Tumultuous Search for Artificial Intelligence|year=1993|publisher=Basic Books|location=New York|isbn=ISBN 0-465-02997-3|page=168}}</ref> | |||
KL-ONE spawned several subsequent Frame languages. One of the most widely used successors to KL-ONE was the Loom language developed by Robert MacGregor at the ]. The formal semantics of languages such as KL-ONE and Loom gave these frame languages a new type of automated reasoning capability known as the classifier. The classifier is an engine that analyzes the various declarations in the frame language: the definition of sets, subsets, relations, etc. The classifier can then automatically deduce various additional relations and can detect when some parts of a model are inconsistent with each other. In this way many of the tasks that would normally be executed by forward or backward chaining in an inference engine can instead be performed by the classifier.<ref>{{cite journal|last=MacGregor|first=Robert|title=Using a description classifier to enhance knowledge representation|journal=IEEE Expert|year=1991|month=June|volume=6|issue=3|url=http://ieeexplore.ieee.org/xpl/login.jsp?tp=&arnumber=87683&url=http%3A%2F%2Fieeexplore.ieee.org%2Fxpls%2Fabs_all.jsp%3Farnumber%3D87683|accessdate=10 November 2013}}</ref>This technology is especially valuable in dealing with the Internet. It is an interesting result that the formalism of languages such as KL-ONE can be most useful dealing with the highly informal and unstructured data found on the Internet. On the Internet it is simply not feasible to require all systems to standardize on one data model. It is inevitable that terminology will be used in multiple inconcistent forms. The automatic classification capability of the classifier engine provieds AI developers with a powerful toolbox to help bring order and consistency to a very inconsistent collection of data (i.e., the Internet). <ref>{{cite journal|last=Berners-Lee|first=Tim|coauthors=James Hendler and Ora Lassila|title=The Semantic Web A new form of Web content that is meaningful to computers will unleash a revolution of new possibilities|journal=Scientific American|date=May 17, 2001|url=http://www.cs.umd.edu/~golbeck/LBSC690/SemanticWeb.html}}</ref> | |||
==Implementations== | ==Implementations== | ||
Line 27: | Line 20: | ||
==References== | ==References== | ||
{{reflist}} | |||
==Additional References== | |||
* Marvin Minsky, , MIT-AI Laboratory Memo 306, June, 1974. | * Marvin Minsky, , MIT-AI Laboratory Memo 306, June, 1974. | ||
* Marvin Minsky, ''A Framework for Representing Knowledge'', in: Patrick Henry Winston (ed.), The Psychology of ]. McGraw-Hill, New York (U.S.A.), 1975. | * Marvin Minsky, ''A Framework for Representing Knowledge'', in: Patrick Henry Winston (ed.), The Psychology of ]. McGraw-Hill, New York (U.S.A.), 1975. |
Revision as of 16:52, 9 December 2013
A frame language is a technology used for knowledge representation in artificial intelligence. Frames are stored as ontologies of sets and subsets of the frame concepts. They are similar to class hierarchies in object-oriented languages although their fundamental design goals are different. Frames are focused on explicit and intuitive representation of knowledge where as objects focus on encapsulation and information hiding. Frames originated in AI research and objects primarily in software engineering. However, in practice the techniques and capabilities of frame and object-oriented languages overlap significantly.
Description
Early work on Frames was inspired by psychological research going back to the 1930's that indicated people use stored stereotypical knowledge to interpret and act in new cognitive situations. The term Frame was first used by Marvin Minsky as a paradigm to understand visual reasoning and natural language processing. In these and many other types of problems the potential solution space for even the smallest problem is huge. For example, extracting the phonemes from a raw audio stream or detecting the edges of an object. Things which seem trivial to humans are actually quite complex. In fact how difficult they really were was probably not fully understood until AI researchers began to investigate the complexity of getting computers to solve them.
The initial notion of Frames or Scripts as they were also called is that they would establish the context for a problem and in so doing automatically reduce the possible search space significantly. The idea was also adopted by Schank and Abelson who used it to illustrate how an AI system could process common human interactions such as ordering a meal at a restaurant. These interactions were standardized as Frames with slots that stored relevant information about each Frame. Slots are analogous to object properties in object-oriented modeling and to relations in entity-relation models. Slots often had default values but also required further refinement as part of the execution of each instance of the scenario. I.e., the execution of a task such as ordering at a restaurant was controlled by starting with a basic instance of the Frame and then instantiating and refining various values as appropriate. Essentially the abstract Frame represented an object class and the frame instances an object instance. In this early work the emphasis was primarily on the static data descriptions of the Frame. Various mechanisms were developed to define the range of a slot, default values, etc. However, even in these early systems there were procedural capabilities. One common technique was to use "triggers" (similar to the database concept of triggers) attached to slots. A trigger was simply procedural code that was attached to a slot. The trigger could fire either before and/or after a slot value was accessed or modified.
As with object classes Frames were organized in subsumption hierarchies. For example, a basic frame might be ordering at a restaurant. An instance of that would be Joe goes to McDonalds. A specialization (essentially a subclass) of the restaurant frame would be a frame for ordering at a fancy restaurant. The fancy restaurant frame would inherit all the default values from the restaurant frame but also would either add more slots or change one or more of the default values (e.g., expected price range) for the specialized frame.
After these early Frame languages the most significant advancement in the technology was the introduction of formal semantics and automatic classification pioneered by the KL-ONE language. Much of the early Frame language research (e.g. Schank and Abelson) had been driven by findings from experimental psychology and attempts to design knowledge representation tools that corresponded to the patterns humans were thought to use to function in daily tasks. These researchers were less interested in mathematical formality since they believed such formalism were not necessarily good models for the way the average human conceptualizes the world. Researchers such as Ron Brachman on the other hand wanted to give AI researchers the mathematical formalism and computational power that were associated with Logic. Their aim was to map the Frame classes, slots, constraints, and rules in a Frame language to set theory and logic. One of the benefits of this approach is that the validation and even creation of the models could be automated using theorem provers and other automated reasoning capabilities. The drawback was that it could be more difficult to initially specify the model in a language with a formal semantics. The way humans use language for example is often far from truly logical.
This evolution also illustrates a classic divide in AI research known as the "neats vs. scruffies". The "neats" were researchers who placed the most value on mathematical precision and formalism which could be achieved via First Order Logic and Set Theory. The "scruffies" were more interested in modeling knowledge in representations that were intuitive and psychologically meaningful to humans. KL-ONE spawned several subsequent Frame languages. One of the most widely used successors to KL-ONE was the Loom language developed by Robert MacGregor at the Information Sciences Institute. The formal semantics of languages such as KL-ONE and Loom gave these frame languages a new type of automated reasoning capability known as the classifier. The classifier is an engine that analyzes the various declarations in the frame language: the definition of sets, subsets, relations, etc. The classifier can then automatically deduce various additional relations and can detect when some parts of a model are inconsistent with each other. In this way many of the tasks that would normally be executed by forward or backward chaining in an inference engine can instead be performed by the classifier.This technology is especially valuable in dealing with the Internet. It is an interesting result that the formalism of languages such as KL-ONE can be most useful dealing with the highly informal and unstructured data found on the Internet. On the Internet it is simply not feasible to require all systems to standardize on one data model. It is inevitable that terminology will be used in multiple inconcistent forms. The automatic classification capability of the classifier engine provieds AI developers with a powerful toolbox to help bring order and consistency to a very inconsistent collection of data (i.e., the Internet).
Implementations
- Frame Representation Language (FRL), 1977, Roberts/Goldstein.
- Two examples of frame- or frame based- languages are OIL and F-logic.
- An editor for frame-based ontologies is Protégé.
- The Knowledge Machine (KM) is a knowledge representation language and reasoning engine. The knowledge is represented as frames, but KM is also influenced by logic. This combination makes KM very expressive and provides it with a clear, formal semantics.
- KL-ONE is a well known knowledge representation system in the tradition of semantic networks and frames. The system is an attempt to overcome semantic indistinctness in semantic network representations and builds upon the idea of Structured inheritance networks.
References
- Bartlett, F.C. (1932). Remembering: A Study in Experimental and Social Psychology. Cambridge, England: Cambridge University Press.
- Minsky, Marvin (1975). "A Framework for Representing Knowledge". In Pat Winston (ed.). The Psychology of Computer Vision. New York: McGraw Hill. pp. 211–277.
- Schank, Roger (1977). Scripts, Plans, Goals, and Understanding. Hillsdale, New Jersey: Lawrence Erlbaum.
{{cite book}}
: Unknown parameter|coauthors=
ignored (|author=
suggested) (help) - Feigenbaum, Edward (September 1, 1986). The Handbook of Artificial Intelligence, Volume III. Addison-Wesley. pp. 216–222. ISBN 0201118114.
{{cite book}}
: Unknown parameter|coauthors=
ignored (|author=
suggested) (help) - Bobrow, D.G. (1977). "An Overview of KRL: A Knowledge Representation Language". Cognitive Science. 1: 3–46.
{{cite journal}}
: Unknown parameter|coauthors=
ignored (|author=
suggested) (help) - Brachman, Ron (1978). "A Structural Paradigm for Representing Knowledge". Bolt, Beranek, and Neumann Technical Report (3605).
- Crevier, Daniel (1993). AI: The Tumultuous Search for Artificial Intelligence. New York: Basic Books. p. 168. ISBN ISBN 0-465-02997-3.
{{cite book}}
: Check|isbn=
value: invalid character (help) - MacGregor, Robert (1991). "Using a description classifier to enhance knowledge representation". IEEE Expert. 6 (3). Retrieved 10 November 2013.
{{cite journal}}
: Unknown parameter|month=
ignored (help) - Berners-Lee, Tim (May 17, 2001). "The Semantic Web A new form of Web content that is meaningful to computers will unleash a revolution of new possibilities". Scientific American.
{{cite journal}}
: Unknown parameter|coauthors=
ignored (|author=
suggested) (help)
Additional References
- Marvin Minsky, A Framework for Representing Knowledge, MIT-AI Laboratory Memo 306, June, 1974.
- Marvin Minsky, A Framework for Representing Knowledge, in: Patrick Henry Winston (ed.), The Psychology of Computer Vision. McGraw-Hill, New York (U.S.A.), 1975.
- Daniel G. Bobrow, Terry Winograd, An Overview of KRL, A Knowledge Representation Language, Stanford Artificial Intelligence Laboratory Memo AIM 293, 1976.
- R. Bruce Roberts and Ira P. Goldstein, The FRL Primer, 1977
- R. Bruce Roberts and Ira P. Goldstein, The FRL Manual, 1977
- R. Brachman, J. Schmolze. An overview of the KL-ONE Knowledge Representation System. Cognitive science 9, 171-216, 1985
- Fikes, R. E., and T. Kehler. (1985). The role of frame-based representation in knowledge representation and reasoning. Communications of the ACM 28(9):904-920.
- Peter Clark & Bruce Porter: KM - The Knowledge Machine 2.0: Users Manual, http://www.cs.utexas.edu/users/mfkb/RKF/km.html.
- Peter D. Karp, The Design Space of Frame Knowledge Representation Systems, Technical Note 520. Artificial Intelligence Center, SRI International, 1992
See also
External links
- http://hopl.murdoch.edu.au/showlanguage.prx?exp=6540&language=Frames
- Frame-Based Systems
- The Generic Frame Protocol
- The Protégé Ontology Editor