Jonathan Lee (Ed.) Software Engineering with Computational Intelligence Springer-Verlag Berlin Heidelberg GmbH Studies in Fuzziness and Soft Computing, Volume 121 http://www.springer.de/cgi-bin/search_book.pl?series=2941 Editor-in-chief Prof. Janusz Kacprzyk Systems Research Institute Polish Academy of Sciences ul. Newelska 6 01-447 Warsaw Poland E-mail: [email protected] Further volumes of this se ries can be Vol. Ill. P.S. Szcepaniak, J. Segovia, J. Kacprzyk and L.A. Zadeh (Eds.) found at our homepage Intelligent Exploration of the Web, 2003 ISBN 3-7908-1529-2 Vol. 102. B. Liu Vol. ll2. Y. Jin Theory and Practice ofUncertain Programming, Advanced Fuzzy Systems Design and 2002 Applications, 2003 ISBN 3-7908-1490-3 ISBN 3-7908-1537-3 Vol. 103. N. Barnes and Z.-Q. Liu Vol. 113. A. Abraham, L.C. Jain and J. Kacprzyk Knowledge-Based Vision-Guided Robots, 2002 (Eds.) ISBN 3-7908-1494-6 Recent Advances in Intelligent Paradigms and Applications", 2003 Vol. 104. F. Rothlauf ISBN 3·7908-1538-1 Representations for Genetic and Evolutionary Algorithms", 2002 Vol. ll4. M. Fitting and E. Orowska (Eds.) ISBN 3-7908-1496-2 Beyond Two: Theory and Applications of Multiple Valued Logic, 2003 Vol. lOS. J. Segovia, P.S. Szczepaniak and ISBN 3-7908-1541·1 M. Niedzwiedzinski (Eds.) E-Commerce and Intelligent Methods, 2002 Vol. ll5. J.J. Buckley ISBN 3-7908-1499-7 Fuzzy Probabilities, 2003 ISBN 3-7908-1542-X Vol. 106. P. Matsakis and L.M. Sztandera (Eds.) Applying Soft Computing in Defining Spatial Vol. ll6. C. Zhou, D. Maravall and D. Ruan (Eds.) Relations", 2002 Autonomous Robotic Systems, 2003 ISBN 3-7908-1504-7 ISBN 3-7908-1546-2 Vol. 107. V. Dimitrov and B. Hodge Volll7. O. Castillo, P. Melin Social Fuzziology, 2002 Soft Computing and Fractal Theory for Intelligent ISBN 3-7908-1506-3 Manufacturing, 2003 ISBN 3-7908-1547-0 Vol. 108. L.M. Sztandera and C. Pastore (Eds.) Soft Computing in Textile Sciences, 2003 Vol. ll8. M. Wygralak ISBN 3-7908-1512-8 Cardinalities of Fuzzy Sets, 2003 ISBN 3-540-00337-1 Vol. 109. R.J. Duro, J. Santos and M. Grafta (Eds.) Biologically Inspired Robot Behavior Engineering, Vol. ll9. Karmeshu (Ed.) 2003 Entropy Measures, Maximum Entropy Principle ISBN 3-7908-1513-6 and Emerging Applications, 2003 ISBN 3·540-00242-1 Vol. llO. E. Fink I. 112. Y. Jin Advanced Fuzzy Systems Design and Vol. 120. H.M. Cartwright, L.M. Sztandera (Eds.) Applications, 2003 Soft Computing Approaches in Chemistry, 2003 ISBN 3-7908-1523-3 ISBN 3·540-00245-6 Jonathan Lee (Ed.) Software Engineering with Computational Intellingence Springer Prof. Jonathan Lee National Central University Dept. of Computer Science 320 Chung-Li Taiwan R.O.C E-mail: [email protected] ISBN 978-3-642-05595-9 ISBN 978-3-540-36423-8 (eBook) DOI 10.1007/978-3-540-36423-8 Library of Congress Cataloging-in-Publication-Data applied for A catalog record for this book is available from the Library of Congress. Bibliographie information published by Die Deutsche Bibliothek Die Deutsche Bibliothek lists this publication in the Deutsche Nationalbibliographie; detailed bibliographie data is available in the internet at <http://dnb.ddb.de>. This work is subject to copyright. All rights are reserved, whether the whole or part of the material is concerned, specifically the rights of translation, reprinting, reuse of illustrations, recitations, broadcasting, reproduction on microfilm or in any other way, and storage in data banks. Duplication of this publication or parts thereof is permitted only under the provisions of the German copyright Law of September 9, 1965, in its current version, and permission for use must always be obtained from Springer-Verlag. Violations are liable for prosecution under the German Copyright Law. http://www.springer.de © Springer-Verlag Berlin Heidelberg 2003 Originally published by Springer-Verlag Berlin Heidelberg New York in 2001 Softcover reprint ofthe hardcover 1st edition 2003 The use of general descriptive names, registered names trademarks, etc. in this publication does not imply, even in the absence of a specific statement, that such names are exempt from the relevant protective laws and regulations and therefore free for general use. Cover design: E. Kirchner, Springer-Verlag, Heidelberg Printed on acid free paper 62/3020/M -5 4 3 2 1 0 Foreword It is not an exaggeration to view Professor Lee's book," Software Engineer ing with Computational Intelligence," or SECI for short, as a pioneering contribution to software engineering. Breaking with the tradition of treat ing uncertainty, imprecision, fuzziness and vagueness as issues of peripheral importance, SECI moves them much closer to the center of the stage. It is ob vious, though still not widely accepted, that this is where these issues should be, since the real world is much too complex and much too ill-defined to lend itself to categorical analysis in the Cartesian spirit. As its title suggests, SECI employs the machineries of computational intel ligence (CI) and, more or less equivalently, soft computing (SC), to deal with the foundations and principal issues in software engineering. Basically, CI and SC are consortia of methodologies which collectively provide a body of con cepts and techniques for conception, design, construction and utilization of intelligent systems. The principal constituents of CI and SC are fuzzy logic, neurocomputing, evolutionary computing, probabilistic computing, chaotic computing and machine learning. The leitmotif of CI and SC is that, in general, better performance can be achieved by employing the constituent methodologies of CI and SC in combination rat her than in a stand-alone mode. In what follows, I will take the liberty of focusing my attention on fuzzy logic and fuzzy set theory, and on their roles in software engineering. But first, a couple of points of semantics which are in need of clarification. What are the differences between uncertainty, imprecision, fuzziness and vagueness? A voiding a lengthy discussion, I will confine myself to clarifying the difference between fuzziness and vagueness-two distinct concepts which are frequently used in the same sense. Before the advent of fuzzy set theory and fuzzy logic, the term that was used in the literatures of philosophy and logic to describe fuzziness was vagueness. But, in fact, in English at least, fuzziness and vagueness have dis tinct meanings. More specifically, vagueness relates to insufficient specificity whereas fuzziness relates to unsharpness of class boundaries. For example, the proposition "I will be back in a few minutes," is fuzzy but not vague, while "I will be back sometime," is both fuzzy and vague. In general, vague ness is a property of propositions but not predicates, while fuzziness applies to both propositions and predicates, in the sense that a proposition is fuzzy if it contains a fuzzy predicate. Another point that is in need of clarification is the meaning of "fuzzy logic." Frequently, what is not recognized is that "fuzzy logic" has two distinct meanings. In a narrow sense, fuzzy logic is a logical system which deals with modes of reasoning which are approximate rat her than exact. In a broader VI Foreword sense, which is in prevalent use today, fuzzy logic (FL) is not just a logical system but a collection of concepts and techniques for dialing with imprecisely defined classes and relations. Thus, FL subsurnes fuzzy logic in its narrow sense, and has a much broader scope. What is used in SEC I is FL. What should be underscored is that in FL everything is-or is allowed to be-a matter of degree. It is this fundamental facet of FL that makes it possible to construct models-in every field, including software engineering-wh ich are much closer to reality than those based on bivalent logic and classical analysis. A case in point is the fuzzy-Iogic-based treatment in Chapter 3 of the important issue of requirement engineering. More specifically, in real world settings it is rarely the case that the goals and constraints are rigid, with no compromises allowed. Employment of FL makes it possible to define require ments and associated trade-offs though the use of concepts and techniques drawn from fuzzy logic and, especially, test-score semantics and fuzzy aggre gation operators. Underlying these concepts and techniques is the fact that even when the ultimate goal is crisp, as it is in the case of chess, the inter mediate goals are fuzzy because the relationship between the terminal goal and the intermediate goals is too complex to lend itself to precise analysis. One of the principal tools in the armamentarium of fuzzy logic is the cal culus of fuzzy if-then rules (CFR). This tool is employed with skill and insight in many chapters in SECI, especially in the context of fuzzy objects, fuzzy relations and fuzzy object-oriented languages and databases. It is of histori cal interest to note that my 1973 paper in which this ca1culus was outlined was greeted by many leading system theorists at the time with derision and contempt. A sampie is the comment made by KaIman after hearing my first exposition in 1972: "I would like to comment brieflyon Professor Zadeh's presentation. His proposals could be severely, ferociously, even brutally crit icized from a technical point of view. This would be out of place here. But a blunt quest ion remains: Is Professor Zadeh presenting important ideas or is he indulging in wishful thinking?" Today, thirty years later, history provides an answer. The ca1culus of fuzzy if-then rules and the underlying concept of the linguistic variable are employed in almost all applications of fuzzy logic in the realms of control, system analysis, knowledge representation, decision analysis and optimization. A new and important development in fuzzy logic which may well have a substantial bearing on software engineering is the methodology of Computing with Words and Perceptions (CWP). A concept which plays a key role in CWP is that of Precisiated Natural Language (PNL). The language of fuzzy if-then rules is a sublanguage of PNL. In CWP, the objects of computation are words and perceptions describes in a naturallanguage. So far as PNL is concerned, it consists of propositions drawn from a naturallanguage, NL, which are precisiable through translation into a precisiation language. In the case of PNL, the precisiation language Foreword VII is the language of generalized constraints (GCL). By construction, GCL is maximally expressive. To reason with perceptions, propositions in PNL are translated into what is referred to as Protoformal Language (PFL). A mod ular multiagent Deduction Module in PNL contains a large variety of proto formal rules of deduction which govern goal-directed generalized constraint propagation. At this juncture, CWP and PNL are in initial stages of development. Eventually, I believe, they will prove to be of high relevance to software engineering, opening the door to new applications and new ideas for further advances. In conclusion, Software Engineering with Computational Intelligence is a work whose importance cannot be overstated. SECI is a must reading for those who are involved, in one way or another, with the development or use of software engineering and its methodologies. Professor Lee, the contributors to SECI and the publisher, Springer, deserve our thanks and congratula tions for producing a work that presents, with high authority and impressive expository skill, a wealth of information and new ideas in one of the most important domains of information science and technology. Berkeley, CA, Lotfi A. Zadeh November 18, 2002 Contents 1 Introduction to Software Engineering with Computational Intelligence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Jonathan Lee 1.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.2 Managing Imprecise and Conflicting Requirements . . . . . . . . . . . . . 2 1.3 Coping with Fuzzy Objects and Imprecise Knowledge . . . . . . . . . . 2 1.4 Handling Uncertainty for Software Quality Prediction . . . . . . . . . . 4 1.5 Conclusion. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 References ...... . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 2 Fuzzy Concepts and Formal Methods ..................... 9 Chris Matthews, Paul A. Swatman 2.1 Introduction. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 2.2 Fuzzy Set Representation in Z .............................. 14 2.3 The Toolkit Summary ..................................... 16 2.4 Some Illustrative Examples ................................ 28 2.5 Toolkit Usage - Reflections and Guidelines .................. 39 2.6 Conclusion. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. 45 References ..................................................... 46 3 Trade-off Requirement Engineering. . . .. . . . . . . . .. . . . .. . . .. 51 Jonathan Lee, Jong-Yih Kuo, Nien-Lin Hsueh, Yong-Yi Fanjiang 3.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. 51 3.2 Requirements Elicitation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. 52 3.3 Modeling Soft Requirements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. 56 3.4 Analyzing Soft Requirements ............................... 57 3.5 Related Work . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. 66 3.6 Conclusion. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. 69 References ..................................................... 69 4 A Generalized Object-Oriented Data Model Based on Level- 2 Fuzzy Sets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. 73 Guy de Tri, Rita de Caluwe, Jörg Verstraete, Axel Hallez 4.1 Introduction ............................................ " 73 4.2 Types and Type System .................................. " 75 4.3 Generalized Types and Generalized Type System ............ " 86 4.4 Conclusions ............................................... 105 References ..................................................... 106 X Contents 5 Modelling Imperfect Spatial Information in a Fuzzy Object Oriented Database ............................................ 109 Gloria Bordogna, Sergio Chiesa 5.1 Introduction .............................................. 109 5.2 Imperfect information in fuzzy databases ..................... 110 5.3 Representing Imperfect Spatial Information within fuzzy set and possibility theory .......................................... 113 5.4 Representation of imperfect spatial information in a Fuzzy Ob- ject Oriented Database .................................... 118 5.5 Vague query constraints evaluation on imperfect spatial informa- tion ..................................................... 124 5.6 Conclusions ............................................... 127 References ....................................... . . . . . . . . . . . . .. 127 6 Using Classical Object-Oriented Features to build a FOODBS13J Fernando Berzal, Nicolas Marin, Glga Pons, Maria Amparo Vila 6.1 Introduction .............................................. 131 6.2 Building a fuzzy database system over a classical one .......... 133 6.3 Managing fuzzy capabilities using classical object oriented features135 6.4 Some implementations issues ................................ 150 6.5 Conclusions and Further Work .............................. 152 References ..................................................... 153 7 Domain Analysis for the Engineering of Spatiotemporal Software ...................................................... 157 Ali Dogru and Adnan Yazici 7.1 Introduction .............................................. 157 7.2 Domain Analysis .......................................... 158 7.3 Domain Model ............................................ 161 7.4 Conclusions ............................................... 169 References " ................................................... 169 8 Object-Oriented Framework of Fuzzy Knowledge Systems. 171 Mong-Fong Horng, Shiuh-Chu Lee and Yau-Hwang Kuo 8.1 Introduction .............................................. 171 8.2 Fuzzy Linguistic Objects (FLOs) ............................ 172 8.3 Partial Inheritance Model .................................. 174 8.4 Reasoning in FLO-based Framework ......................... 176 8.5 Conclusions and Discussions ................................ 177 References ................ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. 178 9 Fuzzy Evaluation of Domain Knowledge ................... 183 Bedir Tekinerdogan and Mehmet Aksit 9.1 Introduction .............................................. 183 9.2 Solution Domain Analysis .................................. 184 9.3 Problem Statement ........................................ 186