Problem-Solving Methods in Protégé-2000 Monica Crubézy Stanford Medical Informatics MIS November 1999
2 What is a Problem-Solving Method ? A problem-solving method (PSM): realises the task of a KBS (planning, diagnosis) implements a reasoning process in a program (search in a tree) employs the concepts of the KB as knowledge roles (findings) PSMs cover: interpreters, rule engines, algorithms generic methods in AI (propose&revise) domain-specific methods (Protean - ribosome topology identification )
3 Problem-Solving in Protégé Protégé was domain-independent, but method-specific: expert-system shell for Episodic Skeletal Plan Refinement problem- or task-specific KBs (protocol-based advice) Since Protégé-II, the behaviour of a KBS is: an abstract model of problem-solving, i.e. a PSM identifies roles of domain knowledge & ordering of inferences composed from more primitive methods an independent component, reusable across tasks, with libraries of generic PSMs (Eriksson et al. 1995) across domains, with declarative mapping relations (Gennari et al & 1995, Park et al. 1998) Protégé-2000 is entirely application-independent: generic knowledge model and tools to build an ontology of classes, customize KA forms and enter specific instances no embedded problem-solving assumptions
4 What is a PSM in Protégé-2000 ? A separate component in a KBS architecture, that: provides a function, as a “black box” makes its interface requirements on inputs and outputs explicit is recursively decomposed into sub-tasks, solved by sub-methods is stored in a (conceptual) library of reusable PSMs A piece of code: written in any language (CLIPS, C++, Java) applied to a KB stored in any back-end format (CLIPS, DB, XML) run externally or within a Java tab plug-in Examples: Propose&Revise constraint satisfaction (elevator configuration) board-game method (room assignment) EON guideline interpreter (e.g. hypertension guidelines) Eligibility Screening Tab (breast-cancer protocols)
5 Designing a PSM: Important steps Gennari et al Method Selection Task Analysis Method Configuration
6 Task analysis Define real-world activity accomplished by the KBS Specification of a functional goal: inputs and expected outputs of problem-solving contextual requirements, e.g. time, user interaction, flexibility availability and form of domain knowledge Identification of dimensions for method selection: expressed in domain space of discourse formal vs. informal problem characteristics
7 Method selection Find a PSM to realize the task, that: matches task specification takes advantage of domain knowledge characteristics Indexing criteria: task requirements (solution quality, automation level) I/O specification (information at run-time / part of task definition) domain knowledge type and availability (expert reasoning) method properties (computational & space complexity) task and method spaces cognitive distance in representations of problem and knowledge method flexibility w.r.t. task specifics
8 Method configuration Adapt PSM to specific application problem Mapping PSM and domain spaces: identify domain knowledge that fulfils PSM I/O roles identify transformation relations acquire extra domain knowledge if needed Composing complex PSMs from sub-methods: identify sub-tasks of PSM select available sub-components that solve the sub-tasks linkto sub-components inputs and outputs Refining PSMs to fit task-specific needs: narrow scope of PSM with additional ontological commitments specialize behaviour of PSM with alternative sub-components
9 Example Task analysis: elevator configuration (Sisyphus II) set of building specifications and requirements (speed, capacity) find a configuration of elevator components so that no constraints are violated large body of knowledge (elevator components, safety constraints) Method selection: propose-and-revise constraint satisfaction set of parameters and run-time inputs set of constraints that must be satisfied set of fixes to correct violated constraints decomposed in select, propose, verify, revise sub-methods Method configuration: mapping range constraints for task parameters to method fixes using a revise method that fixes constraints locally or globally
10 Building a KBS in Protégé-2000 Domain ontology Protégé 2000 Domain-specific KA tool PSM KBS PSM library KB Adapted from Eriksson et al Mapping relations PSM selection PSM description PSM configuration PSM
11 A PSM description ontology A semi-formal language to describe PSMs uniformly: unifies experience in KA and SE: Unified Problem-Solving Method Description Language (UPML, IBROW 3 project, Fensel et al ) Initial method description language (Gennari et al. 1998) makes knowledge and know-how about PSM components explicit enables PSM indexing, retrieval and integration provides domain experts with access to libraries of reusable PSMs Concepts to describe PSM properties and interface: Nature: Complex or Primitive Pragmatics: author, references, success history Method Ontology: input/output interface and terms Competence: goal, input/output conditions, sub-tasks Operational specification: inference structure, knowledge roles Related concepts: Tasks, Domain Model, Bridges, Refiners
12
13 A PSM Tab for informed PSM selection A Protégé Tab: takes advantage of Protégé API and UI (forms, diagram widget) interfaces a domain KB with external PSM KBs provides improved navigation through PSM instances Browsing PSM libraries from a domain ontology: view PSM descriptions in a guided way (with +/- details) focus attention on function and requirements of PSMs Expressing queries centered on the application problem: allow to use task specification as a guide for selection suggest related PSMs, appropriate to domain requirements Annotating PSM descriptions with practical feedback: add pragmatic information (see also Gennari & Ackerman, 1999) indicate successful vs. ineffectual application cases
14 PSM Tab: Preliminary version PSM Tab in Protégé Available KBs of PSMs PSMs in selected KB Pragmatic properties of selected PSM Reference annotations Usage feedback
15 Competence (I/O roles, conditions, sub-tasks) Operational Description (control, knowledge roles) Capabilities of selected PSM
16 PSM configuration tools Mapping PSM requirements to domain concepts: use the method ontology, that explicits I/O interface identify mapping relations between PSM and domain ontologies (Gennari et al. 1994, Park&Musen 1998) ontology of mapping relations (from simple renaming to complex combination or addition of knowledge) mapping interpreter generates a “virtual knowledge base” use typical cases of applying PSMs to suggest mapping Adapting PSM for the application at hand: replace sub-components, via PSM-task bridges that map sub- methods together in complex PSMs define specific refinements of PSMs via PSM refiners (Fensel et al. 1998) to solve domain task by specialization (Eriksson et al. 1995) to match a class of tasks
17 Work in progress… Next steps ( Test the PSM ontology: create PSM instances search propose&revise, cover&differentiate, board-game method, chronological backtracking, etc. Protean and other methods used in molecular biology identify missing or redundant distinctions Improve the PSM Tab: enhance browsing relationships between different PSMs, or PSMs and tasks method input/output ontology, conditions on knowledge roles develop query possibilities focus editing for annotation Integrating mapping tool support
18 Conclusions KBS development is a continuous modeling activity: revises task analysis as more insight is gained on domain/methods leads to the refinement of generic PSMs defines the scope and use of domain knowledge PSMs are components which are complex to describe: integrate modeling of declarative and procedural knowledge must explicit an interface to map to domain knowledge clearly defined in a PSM ontology PSMs can be reused more easily if: cognitive distance from method to task space is minimal underlying conceptual model is understandable mapping relations are explicit and principled Protégé-2000 enables to handle PSMs in those respects
19 References: PSM libraries, reuse, mapping Eriksson, H., Shahar, Y., Tu, S.W., Puerta, A.R., and Musen, M.A. (1995). Task modeling with reusable problem-solving methods. Artificial Intelligence 79. SMI Gennari, J.H., Tu, S.W., Rothenfluh, T.E. and Musen, M.A. (1994). Mapping domains to methods in support of reuse. International Journal of Human-Computer Studies 41. SMI Gennari, J.H., Altman, R.B. and Musen, M.A. (1995). Reuse with Protege-II: From Elevators to Ribosomes. ACM-SigSoft 1995 Symposium on Software Reusability, Seattle. SMI Gennari, J.H., Stein, A.R., and Musen, M.A. (1996). Reuse for Knowledge-Based Systems and CORBA Components. In: 10th Knowledge Acquisition for Knowledge-Based Systems Workshop, Banff, Canada. SMI Park, J.Y., Gennari, J.H. and Musen, M.A. (1998). Mappings for Reuse in Knowledge- Based Systems. In: 11th Workshop on Knowledge Acquisition, Modeling, and Management, Banff, Canada. SMI Park, J.Y., and Musen, M.A (1998). VM-in-Protege: A Study of Software Reuse. In: Medinfo '98: Ninth World Congress on Medical Informatics, Seoul, South Korea, IOS Press. SMI
20 References: Method ontology, UPML Gennari, J.H., Grosso, W.E., and Musen, M.A. (1998). A Method-Description Language: An initial ontology with examples. In: 11th Workshop on Knowledge Acquisition, Modeling, and Management, Banff, Canada. SMI Fensel, D., and Motta, E. (1998). Structured Development of Problem Solving Methods. In: 11th Workshop on Knowledge Acquisition, Modeling, and Management, Banff, Canada. ksi.cpsc.ucalgary.ca/KAW/KAW.html Fensel, D., Benjamins, V.R., Motta, E., and Wielinga, B. (1999). UPML: A Framework for knowledge system reuse. In: Proceedings of the International Joint Conference on AI (IJCAI-99), Stockholm, Sweden. Fensel, D., Benjamins, V.R., Decker, S., Gaspari, M., Groenboom, R., Grosso, W., Motta, E., Musen, M.A., Plaza, E., Schreiber, G., Studer, R., and Wielinga, R. (1999). The Unified Problem-solving Method Development Language, UPML. Benjamins, V.R., Plaza, E., Motta, E., Fensel, D., Studer, R., Wielinga, B., Schreiber, G., Zdrahal, Z., and Decker, S. (1998). IBROW3: An intelligent brokering service for knowledge-component reuse on the World-Wide Web. In: 11th Workshop on Knowledge Acquisition, Modeling, and Management, Banff, Canada. Gennari, J.H., and Ackerman, M. (1999), Extra-Technical Information for Method Libraries. In: Proceedings of the 12th Workshop on Knowledge Acquisition, Modeling and Management, Banff, Canada. ksi.cpsc.ucalgary.ca/KAW/KAW.html