Revision as of 16:52, 9 December 2013 editMadScientistX11 (talk | contribs)Extended confirmed users4,453 edits Rewrote the majority of the article← Previous edit | Latest revision as of 18:54, 23 June 2024 edit undoConan (talk | contribs)Extended confirmed users2,323 editsm Bot: Removing category Category:Artificial intelligence because it's already under Category:Knowledge representation | ||
(76 intermediate revisions by 34 users not shown) | |||
Line 1: | Line 1: | ||
#REDIRECT ] | |||
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. | |||
==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. | |||
{{R from merge}} | |||
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. | |||
{{R to section}} | |||
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> | |||
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. | |||
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== | |||
*Frame Representation Language (FRL), 1977, Roberts/Goldstein. | |||
*Two examples of frame- or frame based- languages are ] and ]. | |||
*An ] for frame-based ] is ]. | |||
*The ] (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. | |||
*] 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== | |||
{{reflist}} | |||
==Additional References== | |||
* 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. | |||
* Daniel G. Bobrow, Terry Winograd, , Stanford Artificial Intelligence Laboratory Memo AIM 293, 1976. | |||
* R. Bruce Roberts and Ira P. Goldstein, , 1977 | |||
* R. Bruce Roberts and Ira P. Goldstein, , 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, , Technical Note 520. ], ], 1992 | |||
==See also== | |||
*] | |||
*] | |||
*] | |||
*] | |||
==External links== | |||
*http://hopl.murdoch.edu.au/showlanguage.prx?exp=6540&language=Frames | |||
* | |||
* | |||
* | |||
] | ] |
Latest revision as of 18:54, 23 June 2024
Redirect to:
- From a merge: This is a redirect from a page that was merged into another page. This redirect was kept in order to preserve the edit history of this page after its content was merged into the content of the target page. Please do not remove the tag that generates this text (unless the need to recreate content on this page has been demonstrated) or delete this page.
- For redirects with substantive page histories that did not result from page merges use {{R with history}} instead.
- To a section: This is a redirect from a topic that does not have its own page to a section of a page on the subject. For redirects to embedded anchors on a page, use {{R to anchor}} instead.